前言:
此时兄弟们对“c语言数字翻译成英文是什么”都比较关注,我们都想要知道一些“c语言数字翻译成英文是什么”的相关内容。那么小编同时在网络上收集了一些关于“c语言数字翻译成英文是什么””的相关文章,希望看官们能喜欢,同学们快快来学习一下吧!Access数据库编程案例-颜色码数制转换(人教版《信息技术》必修第一册P17例题,基于VBA)
图1 本案例的效果
案例来源介绍
本案例来自于人民教育出版社《信息技术》第17页的1道例题,题干部分如下:
实践活动:颜色码的数制转换
在计算机中,RGB(red,green,blue)颜色值可以表示为十六进制颜色码。例如,颜色值RGB(64,224,208)可记为#40E0D0,其中表示红色的64,表示绿色的244和标识蓝色的208分别对应十六进制数40H、E0H、D0H。
1.将#9400D3、#D2B48C表示成相对应的RGB颜色值
2.使用计算器程序,验证上述结果。
本文对该题目进行了一下修改,利用VBA代码,通过改变RGB数字来更改颜色,并且在窗体进行自动化展示。
我把操作代码直接做成了一个软件案例(基于Access数据库)。
今天我把本案例的设计过程、代码的逻辑写成一篇技术文案,供大家参考。
本次分享分为以下3个部分:1.需求分解;2.代码层次;3.代码讲解。
1.需求分解
本案例要完成的任务是:自动化的、直观地演示在不同RGB值下的颜色,以及将10进制RGB数字转化为16进制数字。主要需求分解如下:
(1)窗体和控件
本案例要做一个Access窗体,在窗体上设置3个文本框,分别控制RGB的3种颜色,每当更改数字的值就更改指定控件的颜色。
图2 窗体界面
(2)页眉、图片和正方形
本案例页眉、图片背景和正方形的颜色要随着文本框中数字的改变而改变。
(3)自动化
用最简洁的方法,尽量少的控件,用最直观的方式演示颜色变化效果。
2.代码层次
本案例的所有代码分为核心代码和调用代码。这样做的好处是比较节省空间,层次比较分明,看得比较清晰。
本案例的核心代码不采用模块封装的方法,直接采用子过程Private Sub编程。主要是因为比较简单,不用封装。
(1)核心代码
核心代码功能包括两项:
更改文本框里的RGB值,然后页眉、图片背景的颜色也随之自动更改。
更改文本框里的RGB值,然后10进制数字自动转化为16进制数字。
这两段代码分别放在一个子过程里,需要的时候进行调用。
图3 核心代码
(2)调用代码
调用代码的含义就是在需要的时候运行核心代码。
本案例只要更改文本框的数字就直接“召唤”(Call)核心代码。
如果不采用核心代码和调用代码分开的编程模式,代码会比较长还比较乱,尤其不利于操作比较复杂的调用过程。
图4 调用代码
3.代码讲解
本章节讲解一下核心代码的逻辑和调用代码。
(1)核心代码
颜色变换代码是本案例的核心,是第1段核心代码。本段代码全文如下:
Private Sub UpdateRectangleColor() Dim RedValue As Integer '先定义三个整型变量,分别代表红绿蓝 Dim GreenValue As Integer Dim BlueValue As Integer ' 从文本框获取RGB值 RedValue = Nz(Val(Text1), 0) GreenValue = Nz(Val(Text2), 0) BlueValue = Nz(Val(Text3), 0) ' 确保RGB值在0到255之间 If RedValue < 0 Then RedValue = 0 If RedValue > 255 Then RedValue = 255 If GreenValue < 0 Then GreenValue = 0 If GreenValue > 255 Then GreenValue = 255 If BlueValue < 0 Then BlueValue = 0 If BlueValue > 255 Then BlueValue = 255 ' 更新矩形框、图片和页眉的颜色 Me.Box1.BackColor = RGB(RedValue, GreenValue, BlueValue) Me.Image1.BackColor = RGB(RedValue, GreenValue, BlueValue) Me.Section(acHeader).BackColor = RGB(RedValue, GreenValue, BlueValue)End Sub
这段代码的含义如下:
先设定3个变量RedValue、GreenValue和BlueValue,分别代表红色、绿色和蓝色。
3个变量取值分别来自于三个文本框Text1、Text2和Text3。
需要确保文本框里输入的数字要在0和255之间,如果超出这个范围的数字,数值要么是0要么是255。
3个控件的颜色要随着数字更改而变化,这3个变颜色的控件分别是:1个正方形Box1、宇哥本人的照片背景颜色Image1、以及窗体的页眉Section(acHeader)。
这3个控件的背景色调用代码都是BackColor。
以下是第2段核心代码,10进制转化为16进制的代码:
Private Sub ConvertToHex() Dim RedValue As Integer Dim GreenValue As Integer Dim BlueValue As Integer Dim HexColor As String ' 从文本框中获取10进制RGB值 RedValue = CInt(Text1.Value) GreenValue = CInt(Text2.Value) BlueValue = CInt(Text3.Value) ' 将RGB值转换为16进制 HexColor = Right("00" & Hex(RedValue), 2) & Right("00" & Hex(GreenValue), 2) & Right("00" & Hex(BlueValue), 2) ' 在text4中显示16进制颜色值 Text4.Value = HexColorEnd Sub
这段代码的含义如下:除了定义红绿蓝3个颜色的变量,再定义第4个变量HexColor
用1个函数Hex,这个函数就是专门做10进制16进制转换的,把红绿蓝3个变量转换为16进制之后合并就OK了。不复杂。
这两段代码没有涉及到调用的过程,调用这两段代码要通过控件的操作。
(2)调用代码
调用代码是案例自动化的一部分,不可或缺,完整的调用代码如下:
Private Sub Form_Load() '设定默认的颜色值,浅绿色Text1 = 200Text2 = 255Text3 = 200Call UpdateRectangleColorCall ConvertToHexMe.RefreshEnd SubPrivate Sub Text1_AfterUpdate() '文本框更新后触发操作Call UpdateRectangleColorCall ConvertToHexMe.RefreshEnd SubPrivate Sub Text1_Change() '文本框更改后触发操作Call UpdateRectangleColorCall ConvertToHexMe.RefreshEnd Sub
这段代码只举了1个文本框的案例,另外两个文本框操作完全相同,故省略。
我个人比较喜欢文本框“更新后”+“更改”的自动化操作方式,好处是不需要单独设一个按钮控件,只有有更改就自动计算,缺点是代码比较长一些,需要为3个文本框分别设定代码。
你如果愿意可以不用这种思路,加一个按钮控件操作也可以,代码就2行。
第1段代码是设定本案例的默认颜色值,浅绿色。打开这个窗体就直接带入3个文本框的数值。
第2段第3段代码意思是只要文本框有更新有更改,就自动“召唤”(Call)上一章的核心代码,根据3个文本框的数值进行颜色的判定和显示。
代码逻辑讲解完毕。
很简单很清楚有木有。
总结
本案例重点知识点有3个:
1.掌握Access框架的控件颜色更改的技术。
2.10进制转16进制的Hex函数使用。
3.窗体自动化技术。
用数字控制控件颜色,这件事情VBA编程的技术本身不难,知识点不多。
但是需要重视细节的把控,另外也要理解模块化编程、以及把核心代码和调用代码分开的好处。
想学习Access数据库请私聊。
--The End--
标签: #c语言数字翻译成英文是什么