ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

Excel-VBA-质量问题可视化管理-02-小圆圈颜色修改

2020-11-28 09:00:48  阅读:261  来源: 互联网

标签:02 newShape VBA sht Cells Excel Value 颜色 小圆圈


系统:Windows 7
软件:Excel 2016

  • 本系列是假设一种应用场景,键盘质量检查中,发现问题,如何在键盘图片上进行标记和后续的跟踪管理
  • 其实也同样适用在其它应用场景,尤其与位置相关的质量特性管理上
  • 核心知识点:在背景图片特定位置插入一个圆圈(表示问题点),并对圆圈进行进行颜色等特性的改变

Part 1: 项目基本介绍

  1. 假设键盘的检查质量特性有:尺寸,颜色2种质量特性
  2. 每次对生产的键盘进行质量特性检查时,将具体问题在键盘图片上进行位置标记
    • 尺寸质量问题,使用圆形标记
    • 颜色质量问题,使用矩形进行标记
    • 红色表示不达标;绿色表示已达标
  3. 效果类似下图,随着文章的撰写,可能也会添加一些新的需求,欢迎读者提供有意思的想法

键盘图片(仅做示意,并不表示真有质量问题;如有侵权请联系我)
在这里插入图片描述

Part 2: 万里长征第2步:修改小圆圈颜色

  1. 对于上一篇的文章生成的小圆圈,可以理解为质量问题的区域
  2. 那么实际质量问题可以简单分为三个状态
    • 红色,问题发现,无措施
    • 黄色,有措施,执行中
    • 绿色,问题已解决
  3. 本文的目的就是修改小圆圈的颜色

颜色修改
在这里插入图片描述

Part 3:代码


Sub changeColor()
    Set sht = ThisWorkbook.Worksheets("测试")
    shapeColor = sht.Range("D2")
    
    If shapeColor = "红色" Then
        fillColorR = 255
        fillColorG = 0
        fillColorB = 0
        
        lineColorR = 255
        lineColorG = 0
        lineColorB = 0
    ElseIf shapeColor = "黄色" Then
        fillColorR = 255
        fillColorG = 192
        fillColorB = 0
        
        lineColorR = 255
        lineColorG = 192
        lineColorB = 0
    ElseIf shapeColor = "绿色" Then
        fillColorR = 0
        fillColorG = 176
        fillColorB = 80
        
        lineColorR = 0
        lineColorG = 176
        lineColorB = 80
    Else
        MsgBox "该颜色未识别"
    End If
    
    sht.Cells(2, "K").Value = fillColorR
    sht.Cells(2, "L").Value = fillColorG
    sht.Cells(2, "M").Value = fillColorB
    sht.Cells(2, "N").Value = lineColorR
    sht.Cells(2, "O").Value = lineColorG
    sht.Cells(2, "P").Value = lineColorB
    
    shapeName = sht.Cells(2, "F").Value
    Set newShape = sht.Shapes.Range(Array(shapeName))
    
    With newShape.Fill
        .Visible = msoTrue
        .ForeColor.RGB = RGB(fillColorR, fillColorG, fillColorB)
        .Transparency = 0
        .Solid
    End With
    
    With newShape.Line
        .Visible = msoTrue
        .ForeColor.RGB = RGB(lineColorR, lineColorG, lineColorB)
        .Transparency = 0
    End With
    
End Sub

代码截图
在这里插入图片描述

结果
在这里插入图片描述

Part 4: 部分代码说明

  1. 颜色RGB值获取
    • 可以通过录制宏实现,将颜色与RGB值一一对应
  2. 小圆圈对象获取
    • Set newShape = sht.Shapes.Range(Array(shapeName)),获取小圆圈对象,这里的写法是可以同时获取多个对象的。
    • 对于只获取一个对象,也可以这么写Set newShape = sht.Shapes(shapeName)
  3. 修改小圆圈颜色
    • 通过newShape.Fill修改填充颜色
    • 通过newShape.Line修改轮廓颜色

  • 更多学习交流,可加小编微信号learningBin

更多精彩,请关注微信公众号
扫描二维码,关注本公众号

公众号底部二维码.jpg

标签:02,newShape,VBA,sht,Cells,Excel,Value,颜色,小圆圈
来源: https://blog.csdn.net/zishendianxia/article/details/110258359

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有