(1)在考生文件夹下有一个工程文件sjt3.vbp。窗体上有个钟表图案,其中代表指针的直线的名称是Line1,还有一个名称为Lahel1的标签和其他一些控件(如图1所示)。在程序运行时,若用鼠标右键单击圆的边线,则指针恢复到起始位置(如图1所示);若用鼠标

admin2018-12-20  27

问题 (1)在考生文件夹下有一个工程文件sjt3.vbp。窗体上有个钟表图案,其中代表指针的直线的名称是Line1,还有一个名称为Lahel1的标签和其他一些控件(如图1所示)。在程序运行时,若用鼠标右键单击圆的边线,则指针恢复到起始位置(如图1所示);若用鼠标左键单击圆的边线,则指针指向鼠标单击的位置(如图2所示);若鼠标左键或右键单击其他位置,则在标签上输出“鼠标位置不对”。
    文件中已经给出了所有控件和程序,但程序不完整,请去掉程序中的注释符,把程序中的?改为正确的内容。程序中的oncircle函数的作用是判断鼠标单击的位置是否在圆的边线上(判断结果略有误差).是则返回True,否则返回False。符号常量x0、y0是圆心距窗体左上角的距离;符号常量radius是圆的半径。
    注意:不能修改程序中的其他部分和各控件的属性。最后将修改后的文件按原文件名存盘。

    (2)在考生文件夹下有一个工程文件sjt4.vbp,窗体如图所示。其功能是单击“输入数据”按钮,则可输入一个整数n(要求:8≤n≤12);单击“计算”按钮,则计算1!+2!+3!…+n!的值,并将计算结果显示在文本框中;单击“存盘”按钮,则把文本框中的结果保存到考生文件夹下的out4.dat文件中。
    文件中已经给出了所有控件和程序,但程序不完整,请去掉程序中的注释符,把程序中的?改为正确的内容,并编写“计算”按钮的Click事件过程。
    注意:不得修改已经存在的内容和控件属性,在结束程序运行之前,必须用“存盘”按钮存储计算结果,否则无成绩。最后将修改后的文件按原文件名存盘。

选项

答案(1) 【操作步骤】 步骤1:打开本题工程文件。 步骤2:打开代码编辑窗口,在指定位置编写如下代码。 Const y0& = 1110,x0& = 1100, radius&=750 Private Function oncircle(X As Single,Y As Single)As Boolean precision=55000 If Abs((X—x0)*(X—x0)+(y0一Y)*(y0一Y)一radius*radius)<precision Then’判断鼠标单击的位置是否在圆边上 oncircle=True Else oncircle=False End If End Function Private Sub Form_MouseDown(Button As Integer,Shift as Integer,X As Single,Y As Single) Const LEFT_BUTTON=1 If oncircle(X,Y)Then’调用oncircle函数判断鼠标单击的位置 Linel.X1=x0 Linel.Y1=y0 If Button=LEFT BUTTON Then Line1.X2=X Line1.Y2=Y ’直线另一端的y坐标为鼠标当前的y值 Else Line1.X2=Linel.X1 ’直线回到初始位置x不变 Linel.Y2=y0一radius& ’y2为原先坐标减去半径的值 End If Label1.Caption=”” Else’否则Label1显示位置不对 Label1=”鼠标位置不对” End If End Sub 程序结束 步骤3:调试并运行程序,关闭程序后按题目要求存盘。 (2) 【操作步骤】 步骤1:打开本题工程文件。 步骤2:打开代码编辑窗口,去掉程序中的注释符“’”,将问号改为正确的内容,并编写相应代码。 Dim n As Integer Private Sub Commandl_Click() n=Val(InputBox(”请输入整数(8—12)”,”输入”)) If n>12 Or n<8 Then’确定输入值最大为12,最小为8,否则提示错误 MsgBox(”数据错误,请重新输入”) Command2.Enabled=False Command3.Enabled=False’两按钮不可用 Else Command2.Enabled=True Command3.Enabled=True’两按钮可用 End If End Sub Private Sub Command2_Click() Dim S As Long,k As Integer ’考生应编写的程序 s=0 For k=1 To n s=s+f(k) Next k Text1=S ’编程结束 End Sub Function f(n As Integer)As Long s=1’初始化S为1 For k=2 To n’循环求n的阶乘 s=s* k Next f=s’返回阶乘结果 End Function Private Sub Command3_Click() Open App.Path&”\out4.dat”For Output As #1 Print #1,n,Text1 Close #1 End Sub 步骤3:调试并运行程序,关闭程序后按题目要求存盘,如图3.31所示。 [*]

解析
转载请注明原文地址:https://kaotiyun.com/show/pfFp777K
0

最新回复(0)