数据库

首页 » 常识 » 问答 » Access数据库编程案例颜色码数制转
TUhjnbcbe - 2025/1/9 21:43:00

Access数据库编程案例-颜色码数制转换(人教版《信息技术》必修第一册P17例题,基于VBA)

图1本案例的效果案例来源介绍本案例来自于人民教育出版社《信息技术》第17页的1道例题,题干部分如下:

实践活动:颜色码的数制转换

在计算机中,RGB(red,green,blue)颜色值可以表示为十六进制颜色码。例如,颜色值RGB(64,,)可记为#40E0D0,其中表示红色的64,表示绿色的和标识蓝色的分别对应十六进制数40H、E0H、D0H。

1.将#D3、#D2B48C表示成相对应的RGB颜色值

2.使用计算器程序,验证上述结果。

本文对该题目进行了一下修改,利用VBA代码,通过改变RGB数字来更改颜色,并且在窗体进行自动化展示。

我把操作代码直接做成了一个软件案例(基于Access数据库)。

今天我把本案例的设计过程、代码的逻辑写成一篇技术文案,供大家参考。

本次分享分为以下3个部分:1.需求分解;2.代码层次;3.代码讲解。

1.需求分解

本案例要完成的任务是:自动化的、直观地演示在不同RGB值下的颜色,以及将10进制RGB数字转化为16进制数字。主要需求分解如下:

(1)窗体和控件

本案例要做一个Access窗体,在窗体上设置3个文本框,分别控制RGB的3种颜色,每当更改数字的值就更改指定控件的颜色。图2窗体界面

(2)页眉、图片和正方形

本案例页眉、图片背景和正方形的颜色要随着文本框中数字的改变而改变。

(3)自动化

用最简洁的方法,尽量少的控件,用最直观的方式演示颜色变化效果。

2.代码层次

本案例的所有代码分为核心代码和调用代码。这样做的好处是比较节省空间,层次比较分明,看得比较清晰。

本案例的核心代码不采用模块封装的方法,直接采用子过程PrivateSub编程。主要是因为比较简单,不用封装。

(1)核心代码

核心代码功能包括两项:

更改文本框里的RGB值,然后页眉、图片背景的颜色也随之自动更改。

更改文本框里的RGB值,然后10进制数字自动转化为16进制数字。

这两段代码分别放在一个子过程里,需要的时候进行调用。图3核心代码

(2)调用代码

调用代码的含义就是在需要的时候运行核心代码。

本案例只要更改文本框的数字就直接“召唤”(Call)核心代码。

如果不采用核心代码和调用代码分开的编程模式,代码会比较长还比较乱,尤其不利于操作比较复杂的调用过程。

图4调用代码

3.代码讲解

本章节讲解一下核心代码的逻辑和调用代码。

(1)核心代码

颜色变换代码是本案例的核心,是第1段核心代码。本段代码全文如下:

PrivateSubUpdateRectangleColor()

DimRedValueAsInteger先定义三个整型变量,分别代表红绿蓝

DimGreenValueAsInteger

DimBlueValueAsInteger

从文本框获取RGB值

RedValue=Nz(Val(Text1),0)

GreenValue=Nz(Val(Text2),0)

BlueValue=Nz(Val(Text3),0)

确保RGB值在0到之间

IfRedValue0ThenRedValue=0

IfRedValueThenRedValue=

IfGreenValue0ThenGreenValue=0

IfGreenValueThenGreenValue=

IfBlueValue0ThenBlueValue=0

IfBlueValueThenBlueValue=

更新矩形框、图片和页眉的颜色

Me.Box1.BackColor=RGB(RedValue,GreenValue,BlueValue)

Me.Image1.BackColor=RGB(RedValue,GreenValue,BlueValue)

Me.Section(acHeader).BackColor=RGB(RedValue,GreenValue,BlueValue)

EndSub

这段代码的含义如下:

先设定3个变量RedValue、GreenValue和BlueValue,分别代表红色、绿色和蓝色。

3个变量取值分别来自于三个文本框Text1、Text2和Text3。

需要确保文本框里输入的数字要在0和之间,如果超出这个范围的数字,数值要么是0要么是。

3个控件的颜色要随着数字更改而变化,这3个变颜色的控件分别是:1个正方形Box1、宇哥本人的照片背景颜色Image1、以及窗体的页眉Section(acHeader)。这3个控件的背景色调用代码都是BackColor。

以下是第2段核心代码,10进制转化为16进制的代码:

PrivateSubConvertToHex()

DimRedValueAsInteger

DimGreenValueAsInteger

DimBlueValueAsInteger

DimHexColorAsString

从文本框中获取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=HexColor

EndSub

这段代码的含义如下:除了定义红绿蓝3个颜色的变量,再定义第4个变量HexColor

用1个函数Hex,这个函数就是专门做10进制16进制转换的,把红绿蓝3个变量转换为16进制之后合并就OK了。不复杂。

这两段代码没有涉及到调用的过程,调用这两段代码要通过控件的操作。

(2)调用代码

调用代码是案例自动化的一部分,不可或缺,完整的调用代码如下:

PrivateSubForm_Load()设定默认的颜色值,浅绿色

Text1=

Text2=

Text3=

CallUpdateRectangleColor

CallConvertToHex

Me.Refresh

EndSub

PrivateSubText1_AfterUpdate()文本框更新后触发操作

CallUpdateRectangleColor

CallConvertToHex

Me.Refresh

EndSub

PrivateSubText1_Change()文本框更改后触发操作

CallUpdateRectangleColor

CallConvertToHex

Me.Refresh

EndSub

这段代码只举了1个文本框的案例,另外两个文本框操作完全相同,故省略。

我个人比较喜欢文本框“更新后”+“更改”的自动化操作方式,好处是不需要单独设一个按钮控件,只有有更改就自动计算,缺点是代码比较长一些,需要为3个文本框分别设定代码。

你如果愿意可以不用这种思路,加一个按钮控件操作也可以,代码就2行。

第1段代码是设定本案例的默认颜色值,浅绿色。打开这个窗体就直接带入3个文本框的数值。

第2段第3段代码意思是只要文本框有更新有更改,就自动“召唤”(Call)上一章的核心代码,根据3个文本框的数值进行颜色的判定和显示。

代码逻辑讲解完毕。

很简单很清楚有木有。

总结

本案例重点知识点有3个:

1.掌握Access框架的控件颜色更改的技术。

2.10进制转16进制的Hex函数使用。

3.窗体自动化技术。

用数字控制控件颜色,这件事情VBA编程的技术本身不难,知识点不多。

但是需要重视细节的把控,另外也要理解模块化编程、以及把核心代码和调用代码分开的好处。

想学习Access数据库请私聊。

--TheEnd--
1
查看完整版本: Access数据库编程案例颜色码数制转