VB6.0程序设计,多边形颜色大小自定,多边形边数由用户输入,要求每1秒逆时针转动45度

VB6.0程序设计,多边形颜色大小自定,多边形边数由用户输入,要求每1秒逆时针转动45度,第1张

Dim PolygonEdgeCount, Vertices_X() As Single, Vertices_Y() As Single

Dim Radius As Single, BorderColor As Single

Private Sub Command1_Click()

  MePicture1Cls

  Dim InitialAngle As Single

  Text2 = 45 & "°/s"

  BorderColor = 255

  MePicture1Scale (-1000, 1000)-(1000, -1000)

  Radius = MePicture1ScaleWidth  04

  MePicture1PSet (0, 0), BorderColor

  PolygonEdgeCount = InputBox("请输入多边形的边数:", "", 8)

  If PolygonEdgeCount < 3 Or Not IsNumeric(PolygonEdgeCount) Then

    MsgBox "数据错误!", 16

    End

  End If

  Text1 = PolygonEdgeCount

  ReDim Vertices_X(PolygonEdgeCount - 1) As Single, Vertices_Y(PolygonEdgeCount - 1) As Single

  For i = 0 To PolygonEdgeCount - 1

    Vertices_X(i) = Radius  Cos(2  PI / PolygonEdgeCount  i)

    Vertices_Y(i) = Radius  Sin(2  PI / PolygonEdgeCount  i)

  Next i

  For i = 0 To PolygonEdgeCount - 2

    MePicture1Line (Vertices_X(i), Vertices_Y(i))-(Vertices_X(i + 1), Vertices_Y(i + 1)), BorderColor

  Next i

  MePicture1Line (Vertices_X(LBound(Vertices_X)), Vertices_Y(LBound(Vertices_Y)))-(Vertices_X(UBound(Vertices_X)), Vertices_Y(UBound(Vertices_Y))), BorderColor

  Timer1Interval = 10

End Sub

 

Private Sub Form_Load()

  MePicture1Width = 3600

  MePicture1Height = 3600

  MePicture1BackColor = &H0&

  MePicture1AutoRedraw = True

  MePicture1DrawWidth = 3

End Sub

 

Private Sub Timer1_Timer()

  MeCaption = Time

  Dim AngularVelocity As Single

  MePicture1Cls

  Static n As Integer

  AngularVelocity = 45  PI / 18000

  n = n + 1

  For i = 0 To PolygonEdgeCount - 1

    Vertices_X(i) = Radius  Cos(2  PI / PolygonEdgeCount  i + AngularVelocity  n)

    Vertices_Y(i) = Radius  Sin(2  PI / PolygonEdgeCount  i + AngularVelocity  n)

  Next i

  Text4 = Vertices_X(0): Text5 = Vertices_Y(0)

  MePicture1PSet (0, 0), BorderColor

  For i = 0 To PolygonEdgeCount - 2

    MePicture1Line (Vertices_X(i), Vertices_Y(i))-(Vertices_X(i + 1), Vertices_Y(i + 1)), BorderColor

  Next i

  MePicture1Line (Vertices_X(LBound(Vertices_X)), Vertices_Y(LBound(Vertices_Y)))-(Vertices_X(UBound(Vertices_X)), Vertices_Y(UBound(Vertices_Y))), BorderColor

  If n >= 800 Then n = 0

End Sub

1:当然是ADO好咯,ADODC比DATA时髦啊

2和3:引用的东西,都需要用代码来写的,这也是你第3个问题的答案,要用ADODC控件的话,在vb工具箱点右键单击,选择“部件……”,在选项卡中把microsoft ado date control 60(sp6)(oledb)勾上,确定,ok,工具箱里就有Adodc可用了

     Dim a(5) As Integer, st As String = ""

        For i = 10000 To 99999

            a(1) = i Mod 10

            a(2) = (i Mod 100) \ 10

            a(3) = (i Mod 1000) \ 100

            a(4) = (i Mod 10000) \ 1000

            a(5) = i \ 10000

            If a(1) ^ 5 + a(2) ^ 5 + a(3) ^ 5 + a(4) ^ 5 + a(5) ^ 5 = i Then

                st = st & i & " "

            End If

        Next

        TextBox6Text = st

Private Sub Command1_Click()

Dim a

a = Val(Text1Text)

Text1Text = Str(a \ 100) & "米" & Str((a Mod 100) \ 10) & "分米" & Str(a Mod 10) & "厘米"

End Sub

PrivateSubCommand1_Click()

Label1=""

IfOption1Value=TrueThenLabel1=Label1&""&Option1Caption

IfOption2Value=TrueThenLabel1=Label1&""&Option2Caption

IfOption3Value=TrueThenLabel1=Label1&""&Option3Caption

IfOption4Value=TrueThenLabel1=Label1&""&Option4Caption

IfOption5Value=TrueThenLabel1=Label1&""&Option5Caption

IfOption6Value=TrueThenLabel1=Label1&""&Option6Caption

IfOption7Value=TrueThenLabel1=Label1&""&Option7Caption

IfOption8Value=TrueThenLabel1=Label1&""&Option8Caption

IfCheck1Value=1ThenLabel1=Label1&""&Check1Caption

IfCheck2Value=1ThenLabel1=Label1&""&Check2Caption

IfCheck3Value=1ThenLabel1=Label1&""&Check3Caption

EndSub

PrivateSubCommand2_Click()

Label1=""

EndSub

PrivateSubCommand3_Click()

End

EndSub

以上是根据你的要求最简单的程序,请自己根据需要完善代码

VB60 全称为VisualBasic 60,是微软公司推出的可视化编程工具MSDN之一,是目前世界上使用最广泛的程序开发工具。如果你是一个对编程一无所知,而又迫切希望掌握一种快捷实用的编程语言的初学者,那选择VB 60没错的。即使考虑到VB程序本身编译和运行效率较低的不足(嘻嘻速度现在不是问题吧),单是它的快捷的开发速度,简单易学的语法,体贴便利的开发环境,它仍不失一款优秀的编程工具,是初学者的首选。 \x0d\也许你会问,我以前没学过任何一种语言,我能快速上手吗?别担心,没问题VB的语法的和QBASIB语言是基本相同的,也就是说它的语法是最容易被初学者所接受的。另外VB提供的是可视化的开发环境,我们可以象搭积木一样构建出程序的界面,而且VB提供了丰富的控件组,省去了我们自己写代码实现这些效果的麻烦,这样我们就能把更多的精力放在程序功能的实现上,所以VB学起来简单,用起来方便。 \x0d\接着看看VB语言的前景,在目前各种编程语言共存的时代,VB会不会落伍呢?当然不会了,在我写这篇文章的同时,微软已经透露了 VB70将完全面向对象的消息,可以肯定下一代VB的功能一定会强大很多,我们这些所谓的 VB 程序员总算可以放心了,VB不会落后于时代,毕竟它是使用人数最多的优秀的开发工具。 \x0d\好了,侃了这么多关于VB的台前幕后,总之是为想学编程的你树立信心,编程一点都不难,只要你决定了开始,就让我们一起踏上愉快的编程之旅吧。 \x0d\接下来谈谈怎样学习VB,先说说“看实例学VB60”系列教程,它是面向编程初学者的VB入门教程,这个教程的特点是抛开晦涩难懂的概念和语法,不做内容上的堆积和罗列,而是采用了每节一个生动有趣的小例子的形式,每个小例子中会涉及到一个或几个VB编程的知识点(可能是控件,也许会是某个函数或编程小技巧),使你快速入门。 \x0d\从对编程一窍不通或从未接触过编程的状态,通过学习能够对VB60的编程环境比较熟悉,掌握VB开发界面的使用方法;对VB语言的基本语法大致了解,知道常见的语句的意义;学习VB常用控件的使用方法,并能将它们灵活运用到应用程序中;能开发简单的VB程序。到那时你已经能够继续深入的学习VB编程,可以继续参与到程序设计栏目其他版块的学习中去,嘻嘻,目标就是这样啦。 \x0d\然后谈谈学习编程的方法,万事开头难,刚刚开始,遇到些困难没关系,慢慢来。编程是一个不断学习,不断积累的过程,编程的乐趣也正是存在于学习的过程中。我们每学一点,就赶快把它用到实际的程序中去,自己多学多用多实践,水平才能不断提高,这就是“学以致用”。 \x0d\另外,编程涉及到很多的知识,象 *** 作系统的、软件工程的、硬件系统的以及编程思想等各个方面,这就需要我们多看看这方面的资料,扩充自己的知识面。 \x0d\还有如果学习过程中遇到了什么问题,或者有什么好的心得,你可以到洪恩的“网上交流”的“编程技术”版去提问求助或是发表文章,那里有许多编程高手可以为你答疑,还有许多同样的初学者一起交流。 \x0d\“求知无限”是网上学习的特点,如果你觉得自己能够更深的学习VB或是其他编程的知识时,“程序设计”栏目的其他版块将是理想的去处,希望我们能在这样的学习环境中不断进步。 \x0d\教程分为三个大的部分,它们是由浅入深的一个系列,分别是: \x0d\一、熟悉一下VB60的编程环境 \x0d\二、学习VB常用控件的使用方法 \x0d\三、试着开发简单的VB应用程序

习题一

答案在教材上找。

习题二

1对象指现实世界中的实体。每个对象有自己的特征(属性)、行为(方法)和发生在该对象上的活动(事件)。

类是对同一种对象的集合与抽象。类包含所创建对象的属性数据,以及对这些数据进行 *** 作的方法。封装和隐藏是类的重要特性,将数据结构和对数据的 *** 作封装在一起,类的内部实现细节对用户来说是透明的。

VB工具箱中的可视图标是VB系统设计好的标准控件类。通过将控件类实例化,得到真正的控件对象。在窗体上画一个控件,就将类转换为对象,创建了一个控件对象。

VB中常用的对象是控件。此外,VB还提供了系统对象。窗体是个特例,它既是类也是对象。当向一个工程添加一个新窗体时,实质就由窗体类创建了一个窗体对象。

对象的三要素:属性、事件和方法。

属性:存放对象的数据(决定对象外观及功能)对象属性的设置方法:在设计阶段,利用属性窗口直接设置属性值;程序运行时,通过语句[对象名]属性名=属性值。若属性只能在设计阶段设置,在程序运行阶段不可改变,称为只读属性。

事件:发生在对象上的事情。同一事件,对不同的对象,会引发不同的反应。

事件过程:应用程序处理事件的步骤。应用程序设计的主要工作就是为对象编写事件过程的代码。

方法:面向对象的程序设计语言,为程序设计人员提供了一种特殊的过程和函数。方法是面向对象的,调用时一定要指明对象。

2窗体和控件具有的基本属性“

(1) Name属性:名称

所创建的对象名称,在程序中引用。

(2) Caption属性:标题

该属性决定了对象上显示的内容。

(3) Height、Width、Top和Left属性

决定对象的大小和位置。

(4) Enabled 属性:对象是否允许 *** 作

(5) Visible 属性:对象是否可见

(6) Font 属性组:文本的外观

FontName字体、FontSize大小

FontBold粗体、FontItalic斜体

FontStrikethru 删除线

FontUnderline 下划线

(7) ForeColor属性:前景颜色

(8) BackColor属性:背景颜色

(9) MousePointer属性:鼠标指针类型, 设置值范围0~15,由系统指定 。若为99,由用户提供的图形文件定义鼠标指针形状。

(10) MouseIcon属性:在MousePointer属性值为99时,存放自定义的鼠标图标文件(ico或cur)。图标库在Graphics目录下。

3窗体的事件:Load事件是在窗体被装入工作区时触发的事件。当应用程序启动,自动执行该事件,该事件通常用来在启动应用程序时对属性和变量进行初始化。

窗体的方法:(1)Print方法

用来显示文本内容,格式:[对象]print 表达式

(2)Cls方法

清除运行时在窗体或图形框中产生的文本或图形, Cls方法不能清除窗体在设计时的文本和图形。

格式:[对象]cls

(3)Move方法

可移动窗体或控件,并可改变其大小。

语法格式如下:

[对象]Move 左边距离[,上边距离[,宽度[,高度]]]

4标签作用:用于显示文本(输出)信息,不能作为输入信息的界面。其内容只能通过Caption属性设置或修改,不能直接编辑。

5文本框是一个文本编辑区域,可以在该区域输入、编辑、修改和显示正文内容。在VB中字符长度以字为单位,也就是一个西文字符与一个汉字都是一个字,长度为1。

重要属性(1) Text 显示或输入的正文内容。

(2) Maxlength 设置文本框可输入的文字最大长度。默认值为0,表示可以输入任意长字符串。

(3) MultiLine 多行属性

设置为True时,文本框可以输入或显示多行正文,同时具有文字处理器的自动换行功能,按Enter键可插入一空行。

(4) ScrollBars 滚动条属性

0-None 无滚动条

1-Horizontal 水平滚动条

2-Vertical 垂直滚动条

3-Both 同时加水平和垂直滚动条

注意:当MultiLine为True时,ScrollBars才有效

(5) PassWordChar 设置显示文本的替代符。例如,当设置为“”,则在文本框输入的内容均以“”显示,而存储的值是用户输入的原文。一般用于设置口令的输入。

当MultiLine为True时,该属性不起作用,密码不允许多行。

(6) Locked 指定文本控件是否可被编辑,默认值为False(可编辑),当设置为True时,文本控件相当于标签控件的作用。

注意:Locked与Enabled的区别。

(7)文本内容进行选择 *** 作的三个属性

SelStart 选定的正文开始位置

SelLength 选定的正文长度

SelText 选定的正文内容

这3个属性互相关联,例如设置SelStart、SelLength后,SelText 自动存放指定的文本。

注意:属性窗口中没有这三个属性,只能在程序代码中使用。

6文本框的事件:(1) Change事件:当Text属性值发生改变时引发该事件

(2) KeyPress事件:按下并且释放键盘上的一个键时,引发焦点所在控件的KeyPress事件,所按键的值存放在参数KeyAscii中。对回车的判断 KeyAscii=13

7文本框最有用的方法是SetFocus,把光标移到指定的文本框中。

8命令按钮 Picture属性:按钮可显示文件(bmp和Ico),当Style为1时有效。

10 启动窗体时将命令按钮定位在窗体中央的代码

Private Sub Form_Load()

Command1Left = Form1ScaleWidth / 2 - Command1Width / 2

Command1Top = Form1ScaleHeight / 2 - Command1Height / 2

End Sub

11.vb文件在 C:\Program Files\Microsoft Visual Studio\Common\Graphics 文件夹。

安装VB时可选择是否安装这些文件。

习题三

1 合法常量:

(1) Double

(2) 错误

(3) Double

(4) Double

(5) 错误

(6) Integer

(7) String

(8) String

(9) Date

(10) Double

(11) 错误(汉字字符)

(12)Integer(八进制)

(13) 错误(八进制无数码8)

(14) Integer

(15) Boolean

(16) 错误

(17) 错误(十六进制无数码g)

(18) Single

说明:浮点型变量默认为Double类型而非Single。

2 合法变量名:

(1) √

(2) √

(3) 误:数字开头

(4) 误:含空格

(5) 误:关键字

(6) √

(7) 误:关键字

(8) 误:有括号

(9) √

(10) √

(11) √

(12) √(汉字字符可作为变量名,但不常用,且此名称易误解)

变量命名规则见P41-42。

字母(汉字)开头,字母(汉字)、数字、下划线组成,长度为1-255个字符;关键字不可作为变量名,但可在变量名中嵌入关键字;不区分大小写。

常量、数组、类型、函数、过程、对象命名规则与此相同。常量名通常全用大写。

3 写VB表达式

(1) Abs(x + y) + z ^ 5

(2) (1 + x y) ^ 6

(3) (10 x + Sqr(3 y)) / (x y)

(4) (-b + Sqr(b ^ 2 - 4 a c)) / (2 a)

(5) 1 / (1 / r1 + 1 / r2 + 1 / r3)

(6) Sin(45 314159 / 180) + (Exp(10) + Log(10)) / Sqr(x + y + 1)

4 根据条件写表达式

(1) 随机产生大写字母 Chr(Int(Rnd (Asc("L") - Asc("C") + 1) + Asc("C")))

(2) [100,200]内的随机数 Int(Rnd 101) + 100

(3) 点(x,y)位于第一或第三象限 x > 0 And y > 0 Or x < 0 And y < 0 或 x y > 0

(4) x是5或7的整数倍 x Mod 5 = 0 Or Int(x / 7) = x / 7

(5) 将两位整数x的个位与十位对换 x \ 10 + (x Mod 10) 10

(6) 四舍五入取两位小数 Round(x, 2)

(7) 字符变量C是字母字符(不区分大小写)——准确地说是:字符变量C的第一个字符是字母

C >= "A" And C <= "Z" Or C >= "a" And C < "z"

或 UCase(C) >= "A" And UCase(C) <= "Z"

或 LCase(C) >= "a" And LCase(C) <= "z"

(8) 字符变量S第5个字符起取6个字符 Mid(S, 5, 6)

(9) 10≤x<20 10 <= x And x < 20

(10) x,y至少有一个小于z x < z Or y < z

(11)x,y都大于z x > z And y > z

5 写表达式的值

(1) 188 ——注意运算的优先级顺序,以及整除运算“\”的计算

(2) 200100 —— 计算100 + "100"时,由于两个 *** 作数类型不同,在可能的情况下自动采用精度较高的类型,即把字符型转换为数值型,100 +100 得到200;然后进行字符串连接运算200 & 100 ,再自动将两个数值转换为字符串,得200100。

(3) 6856 ——在四舍五入函数产生之前,这就是四舍五入的计算方法

(4) 876554 ——先进行字符串的“+”运算,再转换成数值。在变量名和函数名后可加上类型符,以强调其类型,但不是必须的。

(5) 2000-2-29

(6) 6

6.Shell函数调用

i = Shell("mspaintexe", 1) '启动画图

i = Shell("C:\Program Files\Microsoft Office\OFFICE11\winwordexe", 1) '启动Word

说明:“画图”是Windows本身提供的程序,可以省略路径。

8 答:单精度浮点型

第7,9题答案在教材中找。

习题四

第1,3,5,8题答案在教材中找。

2 赋值语句的错误

(1)10x 不能做变量名。

上机验证结果:VB将10识别为行号,x = Sin(x) + y是为变量x赋值。故无语法错误。

(2)Sqr函数的参数为负数。

上机验证结果:“无效的过程调用或参数”

(3)赋值号左边不是变量名。

上机验证结果:“缺少子程序、函数或属性”

(4)除数为0

上机验证结果:“溢出”。

4 [答案略]

说明:小数位可以使用四舍五入函数Round或输出格式函数Format。例如Round(x, 2)和Format(x, “000”)均可使结果只保留两位小数。但如果四舍五入后要进行数值运算,则使用Round函数,例如z=Round(x,2)+Round(y,2)。而Format函数通常只用于输出格式设置。

6.指出错误

(1)“≥”应改为“>=”,前者是中文字符,不具有运算功能。

(2)“10<x<20”应改为“10<x And x<20”,否则运行结果错误。

7.写条件语句

(1)

Dim c As String

c = InputBox("c=")

If Mid(c, 3, 1) = "C" Then

MsgBox "Yes"

Else

MsgBox "No"

End If

(2)

# 使用If语句

Dim x As Single, y As Single

x = Val(InputBox("x="))

If x > 20 Then

y = x ^ 2 + 3 x + 2

ElseIf x >= 10 Then

y = Sqr(3 x) - 2

ElseIf x > 0 Then

y = 1 / x + Abs(x)

End If

Print "y="; y

# 使用Select Case语句

Dim x As Single, y As Single

x = Val(InputBox("x="))

Select Case x

Case Is > 20

y = x ^ 2 + 3 x + 2

Case Is >= 10

y = Sqr(3 x) - 2

Case Is > 0

y = 1 / x + Abs(x)

End Select

Print "y="; y

(3)

# 使用If语句

Dim x As Single, y As Single, z As Single, Max As Single

x = Val(InputBox("x="))

y = Val(InputBox("y="))

z = Val(InputBox("z="))

Max = x

If y > Max Then Max = y

If z > Max Then Max = z

Print "Max="; Max

# 使用IIF函数

x = Val(InputBox("x="))

y = Val(InputBox("y="))

z = Val(InputBox("z="))

Max = IIf(x > y, x, y)

Max = IIf(z > Max, z, Max)

Print "Max="; Max

9 计算循环次数

(1) 6

(2)19

(3)0

(4)死循环直至溢出

10 40号语句执行 4次;第50 号语句执行12次;

执行第90号语句输出的结果是: 13,0,2

说明:该程序为嵌套循环,其中外循环由j值变化(1,4,7,10)控制执行4次,当j值为13时结束循环;内循环由k值变化(6,4,2)控制执行3次,当k值为0时结束循环。第40 行是外循环的循环体,故执行4次;第50 行是内循环的循环体,故执行43=12次。

11 可以定一个较大的循环次数,在循环体中根据条件用Exit For退出。

但这种情况通常用Do While循环控制。

12 编程(并非唯一正确答案)

(1)

Dim i As Integer, s As Integer

For i = 1 To 10

s = s + (i + 1) (2 i + 1)

Next i

Print "s="; s

(2)

Dim i As Integer, n3 As Integer, n7 As Integer

For i = 1 To 100

If i Mod 3 = 0 Then n3 = n3 + 1

If Int(i / 7) = i / 7 Then n7 = n7 + 1

Next i

Print "1-100中3的倍数有"; n3; "个"

Print "1-100中7的倍数有"; n7; "个"

(3)

Dim s1 As String, s2 As String, i As Integer

s1 = InputBox("Input String")

s2 = ""

For i = 1 To Len(s1)

s2 = Mid(s1, i, 1) + s2

Next i

Print "原序:"; s1

Print "反序:"; s2

For i = Len(s1) To 1 Step -1

s2 = s2 + Mid(s1, i, 1)

Next i

13 输出字符串“10100”。该程序功能是将十进制数转化为二进制。

说明:要理解该程序需要了解数制转换的计算方法(有兴趣者参看百度百科>

以上就是关于VB6.0程序设计,多边形颜色大小自定,多边形边数由用户输入,要求每1秒逆时针转动45度全部的内容,包括:VB6.0程序设计,多边形颜色大小自定,多边形边数由用户输入,要求每1秒逆时针转动45度、关于VB程序设计、vb程序设计教程曹利培版课后习题答案等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zz/9402230.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-28
下一篇 2023-04-28

发表评论

登录后才能评论

评论列表(0条)

保存