第7章绘图方法.ppt

上传人:本田雅阁 文档编号:3132101 上传时间:2019-07-15 格式:PPT 页数:38 大小:314.52KB
返回 下载 相关 举报
第7章绘图方法.ppt_第1页
第1页 / 共38页
第7章绘图方法.ppt_第2页
第2页 / 共38页
第7章绘图方法.ppt_第3页
第3页 / 共38页
第7章绘图方法.ppt_第4页
第4页 / 共38页
第7章绘图方法.ppt_第5页
第5页 / 共38页
点击查看更多>>
资源描述

《第7章绘图方法.ppt》由会员分享,可在线阅读,更多相关《第7章绘图方法.ppt(38页珍藏版)》请在三一文库上搜索。

1、台州学院计算机系,1,第7章 绘图方法,台州学院计算机系,2,本章内容,7.1 坐标系统 7.1.1 坐标刻度 7.1.2 自定义坐标系 7.2 绘图属性 7.2.1当前坐标 7.2.2使用颜色 7.3绘图方法 7.3.1画点方法Pset 7.3.2画线、矩形方法Line6.4 滚动条 7.3.3画圆、圆弧和椭圆方法Circle 7.4绘图应用实例,台州学院计算机系,3,7.1 坐标系统,在Visual Basic中,容器都有一个自己默认的坐标系,坐标系中的坐标原点在容器里的左上角,X轴向右为正、Y轴向下为正,如图7-1所示窗体容器的默认坐标系。,台州学院计算机系,4,7.1.1坐标刻度,在V

2、isual Basic中,容器的默认坐标系其缺省的坐标刻度是Twip(缇)。我们在程序设计中,也可以使用其它的刻度单位如:磅和毫米等等。这些可通过设置容器的ScaleMode属性进行选择改变坐标系统的刻度单位。其ScaleMode的属性值如表7-1所示。,台州学院计算机系,5,7.1.2自定义坐标系,1自定义坐标系的Scale方法 格式:容器名.Scale (x1,y1)-(x2,y2) 功能:定义容器(缺省容器名指窗体)左上角的坐标为(x1,y1),右下角的坐标值为(x2,y2)。 例如:用下列语句是在图片框控件中设置自己的坐标系,且图片框左上角的坐标为(-2,1),右下角的坐标是(2,-1

3、),则原点在图片框中心。 Picture1.Scale (-2 * 3.14, 1)-(2 * 3.14, -1) 使用无参数的Scale方法(如“容器名.Scale”),则可以使该容器的坐标还原为系统默认的坐标系。,台州学院计算机系,6,2使用属性自定义坐标系 除了用Scale方法自定义坐标系外,也可以使用如下四个容器类对象的属性来定义坐标系,效果一样。 ScaleLeft:容器左上角的横坐标,缺省值为0。 ScaleTop:容器左上角的纵坐标,缺省值为0。 ScaleWidth:容器自身的宽度值。 ScaleHeight:容器自身的高度值。 若容器左上角的坐标为(x1,y1),右下角的坐标

4、值为(x2,y2),则: 容器名.ScaleLeft=x1 容器名.ScaleTop=y1 容器名.ScaleWidth=x2-x1 容器名.ScaleHeight=y2-y1 故上述例子也可这样来自定义坐标系: Picture1.ScaleLeft = -2 * 3.14 Picture1.ScaleTop = 1 Picture1.ScaleWidth = 4 * 3.14 Picture1.ScaleHeight = -2,台州学院计算机系,7,7.2.1当前坐标,当前坐标是指在坐标系中的当前位置。在容器的某一特定位置要输出一结果时,就要用到当前坐标。与当前坐标有关的两个属性: Curr

5、entX属性:当前点在容器内的横坐标(数值类型)。 CurrentY属性:当前点在容器内的纵坐标(数值类型)。 在设置CurrentX、CurrentY属性后,所设值就是下一个输出方法的当前位置。 如执行下列程序,则在图片框的中心输出“0”。 Private Sub Picture1_Click() Picture1.Scale (-2 * 3.14, 1)-(2 * 3.14, -1) Picture1.CurrentX = 0 Picture1.CurrentY = 0 Picture1.Print “0“ End Sub 在使用Cls方法后,CurrentX、CurrentY属性值为0。

6、,台州学院计算机系,8,7.2.2使用颜色,在使用图形方法绘图时要使用不同的颜色,Visual Basic中使用的颜色用一个长整型数(通常用16进制)表示,如&HFFFF00&。其数值由3部分组成:右边的两位(16进制数,下同)代表红色的值,中间的两位代表绿色的值,左边的两位代表蓝色的值。 每个值都可以取0到255之间的数值,因此共有256的立方种不同的颜色取值。 一是在设计阶段,可以通过在对象的属性窗口中选择需要设置的颜色属性,用打开的“调色板”对话框进行颜色设置。 二是程序运行运行阶段,可以使用颜色函数、使用系统预定义好的颜色常量、直接赋值或使用通用对话框中的“颜色”对话框来选取颜色。,台

7、州学院计算机系,9,7.2.2使用颜色,1颜色函数 Visual Basic提供了两个专门处理颜色的函数:RGB和QBColor。 (1)RGB函数 格式:RGB(Red,Green,Blue) 其中:Red、Green、Blue分别代表红色的值,绿色的值和蓝色的值。取值范围都是0到255。 例如:语句Form1.BackColor = RGB(255,255,0),用来将窗体Form1的背景色设置为黄色。 RGB函数采用红、绿、蓝三色原理,返回一个Long整数,用来表示一个颜色值。表7-2列出了一些常见的颜色以及这些颜色的三色值。,台州学院计算机系,10,7.2.2使用颜色,台州学院计算机系

8、,11,7.2.2使用颜色,2颜色常量 颜色常量是在Visual Basic系统内部预定义好的常量,程序设计时可以不需要声明就可以直接使用。如:Form1.BackColor = vbYellow Visual Basic定义的常用颜色常量如表7-4所示。,台州学院计算机系,12,7.2.2使用颜色,3直接赋值 如果知道具体的颜色值,也可以直接给颜色属性赋值。 例如:语句Form1.BackColor=&HFFFF00&,也是将窗体的背景色设置为黄色。 7.2.3线宽和线型 1线宽 DrawWidth属性:用以设置点的大小或线的宽度。以像素为单位,最小值为1。 2线型 DrawStyle属性:

9、设置所画线的形状。 7.2.4填充 在绘图中,如果图形是封闭的,就可以进行填充,与填充有关的两个属性。 1填充图案 FillStyle属性:设置填充的图案样式,可取值07之间。 2填充颜色 FillColor属性:设置填充的颜色。,台州学院计算机系,13,7.3.1画点方法Pset,Pset方法用于在对象的指定位置用某一颜色画点。 格式:容器名.Pset step(x,y),颜色 其中:(x,y)为画点的坐标。step表示用当前画点位置的相对值。颜色为画点的颜色值,缺省为用容器对象的前景色(ForeColor)画点。该方法所画点的大小,取决于容器对象的DrawWidth属性值。,台州学院计算机

10、系,14,7.3.1画点方法Pset,【例7-1】单击窗体,用Pset方法画出-2,2上的正弦曲线和余弦曲线。,台州学院计算机系,15,7.3.1画点方法Pset,【例7-1】单击窗体,用Pset方法画出-2,2上的正弦曲线和余弦曲线。 分析: (1)由于正弦曲线和余弦曲线的取值都在-1和1之间,且要求画出-2,2区间上的,因此可以先用Scale方法定义坐标系,使窗体对象的左上角坐标为-2,1,而右下角的坐标为2,-1,然后再用Pset方法画出该坐标系。 (2)单击窗体时,根据x从-2,2的不断取值,用y=sin(x)和y=cos(x)求出y,然后在(x,y)点用Pset画出即可(用循环实现)

11、。,台州学院计算机系,16,依据以上分析,可得程序代码如下: Const pi = 3.1416 Private Sub Form_click() Dim x As Single For x = -2 * pi To 2 * pi Step 0.01 Form1.PSet (x, Sin(x), vbBlue Form1.PSet (x, Cos(x), vbRed Next x End Sub Private Sub Form_Load() Dim x As Single, y As Single Form1.Scale (-2 * pi, 1)-(2 * pi, -1) For x = -

12、2 * pi To 2 * pi Step 0.01 Form1.PSet (x, 0) Next x For y = -1 To 1 Step 0.001 Form1.PSet (0, y) Next y Form1.CurrentX = 0.1 Form1.CurrentY = -0.01 Print “0“ End Sub,台州学院计算机系,17,【例7-2】将图片框Picture1中图像复制到图片框Picture2,要求保持色彩、纵横比例不变。,台州学院计算机系,18,分析: (1)当程序运行时,图片框Picture1中已加载图像,且“复制”按钮能用,“结束”按钮不能用。其运行界面如图

13、7-3所示。 图7-3图像复制运行界面 (2)当单击“复制”按钮后,Picture1中的图像按要求保持色彩、纵横比例不变后复制到Picture2,同时“复制”按钮不能用,“结束”按钮可用;单击“结束”退出程序。 依据以上分析,可得程序代码如下:,台州学院计算机系,19,依据以上分析,可得程序代码如下: Private Sub Command1_Click() Dim i As Integer, j As Integer, x As Integer, y As Integer Dim c As Long For i = 1 To Picture1.ScaleWidth For j = 1 To

14、Picture1.ScaleHeight c = Picture1.Point(i, j) x = Picture2.ScaleWidth * i / Picture1.ScaleWidth y = Picture2.ScaleHeight * j / Picture1.ScaleHeight Picture2.PSet (x, y), c Next j Next i Command1.Enabled = False Command2.Enabled = True End Sub Private Sub Command2_Click() End End Sub,台州学院计算机系,20,7.3.

15、2画线、矩形方法Line,Line方法用于在指定对象上画直线和矩形。 格式:容器名.Line step(x1,y1)-step(x2,y2),颜色,BF 其中:容器可以是窗体、图片框等,缺省为窗体。(x1,y1)为直线的起点坐标或矩形的左上角坐标,(x2,y2)为直线的终点坐标或矩形的右下角坐标。B为画矩形。F为填充的矩形,F必须和B一起使用。,台州学院计算机系,21,如例7-1中的画坐标系是用画点来完成的,现已经有了Line来画线,则可改为简单的如下代码: Private Sub Form_Load() Form1.Scale (-2 * pi, 1)-(2 * pi, -1) Form1.

16、Line (-2 * pi, 0)-(2 * pi, 0) Form1.Line (0, 1)-(0, -1) Form1.CurrentX = 0.1 Form1.CurrentY = -0.01 Print “0“ End Sub,台州学院计算机系,22,例如,执行下列程序,在窗体上输出结果如图7-4所示。 Private Sub Form_Click() Form1.FillStyle = 2 Form1.FillColor = vbBlue Form1.ForeColor = vbGreen Line (100, 100)-(1500, 1000), vbRed, B 红色外框,蓝色水

17、平填充线 Line (1600, 100)-(2500, 1000), ,B 绿色外框,蓝色水平填充线 Line (2800, 100)-(3800, 1000), vbRed, BF 红色实心矩形 End Sub,台州学院计算机系,23,7.3.3画圆、圆弧和椭圆方法Circle,Circle方法用于在指定对象上画圆、椭圆、圆弧和扇形。 格式:容器名. Circle Step (x,y),半径,颜色,起始角,终止角,长短轴比率 其中:(x,y)为圆心坐标。关键字Step表示采用当前作图位置的相对值。圆弧和扇形通过参数起始角,终止角控制。当起始角、终止角取值在02时为圆弧,当在起始角、终止角取

18、值前加一负号时,画出扇形,负号表示画圆心到圆弧的径向线。椭圆通过长短轴比率控制,默认值为1,画圆。,台州学院计算机系,24,【例7-3】单击窗体后,画一系列圆心在窗体中心,半径随机,且窗体所能容纳的同心圆。运行后如图7-5所示。,台州学院计算机系,25,分析: (1)根据题意每一个圆的圆心固定在窗体中心,即(x,y)确定;画的圆要在窗体内,则要求判断窗体的高度和宽度的大小,然后,半径是最小者的一半;同时画出的圆颜色是各不相同的,是随机的,则可用到Rnd。画这样一个圆可用一个过程来完成。 (2)单击窗体后,要画一系列这样的圆,则可在一个循环中调用过程就可以了。,台州学院计算机系,26,依据以上分

19、析,可得程序代码如下: Public Sub circledemo() Dim r As Integer,g As Integer,b As Integer Dim r1 As Single r = Int(Rnd * 255) g = Int(Rnd * 255) b = Int(Rnd * 255) If Form1.ScaleHeight Form1.ScaleWidth Then r1 = Rnd * Form1.ScaleHeight / 2 Else r1 = Rnd * Form1.ScaleWidth / 2 End If x = Form1.ScaleWidth / 2 y

20、= Form1.ScaleHeight / 2 Form1.Circle (x, y), r1, RGB(r, g, b) End Sub Private Sub Form_Click() Dim i As Integer Form1.Cls For i = 1 To 10000 Call circledemo Next i End Sub,台州学院计算机系,27,【例7-4】在窗体上画出1个红、绿、蓝各占1/3的圆饼图,如图7-6所示。,台州学院计算机系,28,分析: (1)根据题意,可以先建立一个坐标系,让写程序时更直观,如把窗体的横坐标方向向右,纵坐标方向向上,原点在窗体中心,且整个横坐

21、标为10个单位,纵坐标为8个单位。这样半径假设为2就行了。 (2)每次用Circle画1/3个圆弧,且在画之前要先设置填充样式和填充颜色,同时还要连接圆弧和圆心的线,即在起始角、终止角前加负号。,台州学院计算机系,29,依据以上分析,可得程序代码如下: Const pi = 3.14156 Private Sub Form_Click() Dim x As Integer,y As Integer Form1.Scale (-5, 3)-(5, -3) x = 0 y = 0 Form1.FillStyle = 0 Form1.FillColor = vbRed Form1.Circle (x

22、, y), 2, , -2 * pi, -2 * pi / 3 Form1.FillColor = vbGreen Form1.Circle (x, y), 2, , -2 * pi / 3, -4 * pi / 3 Form1.FillColor = vbBlue Form1.Circle (x, y), 2, , -4 * pi / 3, -2 * pi End Sub,台州学院计算机系,30,【例7-5】在图片框中画一个如图7-7所示的圆桶。,台州学院计算机系,31,分析: (1)根据题意,可以先建立一个坐标系,让写程序时更直观,如把图片框的横坐标方向向右,纵坐标方向向上,原点在窗体中心

23、,且整个横坐标为16个单位,纵坐标为20个单位。这样假设椭圆长轴为8,长短轴比率3/5就行了。 (2)然后从最底下的椭圆开始,用蓝色线条画到最上面的椭圆。最后在最上面画一个用白色填充了的椭圆。,台州学院计算机系,32,依据以上分析,可得程序代码如下: Private Sub Form_Click() Dim r As Single,y As Single,y1 As Single,y2 As Single Picture1.Scale (-8, 10)-(8, -10) r = 8 y1 = -r * 3 / 5 y2 = 10 - r * 3 / 5 For y = y1 To y2 Ste

24、p 0.01 Picture1.Circle (0, y), r, vbBlue, , , 3 / 5 Next y Picture1.FillColor = vbWhite Picture1.FillStyle = 0 Picture1.Circle (0, y), r, , , , 3 / 5 End Sub,台州学院计算机系,33,【例7-6】编程,如图7-8所示,输入不同的抛物线方程y=ax2+bx+c的三个系数a,b,c,在窗体上画出相应的抛物线。,台州学院计算机系,34,分析: (1)根据题意,可以先建立一个坐标系,如把图片框的横坐标方向向右,纵坐标方向向上,原点在窗体中心,且整个

25、横坐标为20个单位,纵坐标为20个单位,且用Line方法画出坐标轴。同时建立三个文本框用于输入a,b,c的值。 (2)单击“画抛物线”按钮,根据a,b,c输入的值,在图片框中用Pset方法画出该抛物线。,台州学院计算机系,35,Private Sub Form_Load() 定义坐标系 Picture1.Scale (-10, 10)-(10, -10) 画x坐标轴 Picture1.Line (-10, 0)-(10, 0) Picture1.Line (9, 0.3)-(10, 0) Picture1.Line (9, -0.3)-(10, 0) Picture1.CurrentX = 9

26、 Picture1.CurrentY = 0 Picture1.Print “x“ 画y坐标轴 Picture1.Line (0, -10)-(0, 10) Picture1.Line (-0.3, 9)-(0, 10) Picture1.Line (0.3, 9)-(0, 10) Picture1.CurrentX = 0.4 Picture1.CurrentY = 10 Picture1.Print “y“ 画原点 Picture1.CurrentX = 0.3 Picture1.CurrentY = 0 Picture1.Print “0“ End Sub Private Sub Com

27、mand1_Click() Dim a As Single, b As Single, c As Single Dim x As Single,y As Single Picture1.Cls Form_Load 输入三个系数 a = Val(Text1.Text) b = Val(Text2.Text) c = Val(Text3.Text) 画抛物线 For x = -5 To 5 Step 0.001 y = a * x * x + b * x + c Picture1.PSet (x, y), vbBlue Next x End Sub,台州学院计算机系,36,【例7-7】以1幅图为背

28、景,设计程序显示地球围绕太阳转动的画面,如图7-9所示。,台州学院计算机系,37,分析: (1)根据题意,加入背景图片,可以先建立一个坐标系,把窗体的横坐标方向向右,纵坐标方向向上,原点在窗体中心,且整个横坐标为4000个单位,纵坐标为2000个单位。 (2)当单击窗体时,画出一个太阳,同时画出地球的运行轨道,同时启动定时器。设置DrawMode为7是用于在相同的位置绘制相同的图形时,可以擦除原图。 (3)设置一个静态变量flag控制在两个时间段内在同一位置重复画地球,当flag为True时,改变地球在运行轨道上的圆心角,地球的运行轨道椭圆方程为: X=rx*cos(alfa) Y= ry*s

29、in(alfa) 其中rx为椭圆x轴上半径,ry为椭圆y轴上半径,alfa为圆心角。,台州学院计算机系,38,Private Sub Form_Click() Form1.Scale (-2000, 1000)-(2000, -1000) Form1.FillStyle = 0 Form1.FillColor = vbRed Form1.Circle (0, 0), 200, vbRed Form1.FillStyle = 1 Form1.Circle (0, 0), 1600, vbBlue, , , 0.5 Form1.DrawMode = 7 Form1.FillStyle = 0 Timer1.Enabled = True End Sub Private Sub Timer1_Timer() Static alfa As single, flag As Boolean Dim x As Single,y As single flag = Not flag If flag Then alfa = alfa + 0.314 End If If alfa 6.28 Then alfa = 0 End If x = 1600 * Cos(alfa) y = 800 * Sin(alfa) Form1.Circle (x, y), 80 End Sub,

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 其他


经营许可证编号:宁ICP备18001539号-1