三次Bezier曲线.docx
《三次Bezier曲线.docx》由会员分享,可在线阅读,更多相关《三次Bezier曲线.docx(9页珍藏版)》请在冰豆网上搜索。
![三次Bezier曲线.docx](https://file1.bdocx.com/fileroot1/2023-6/7/e6a7952a-3b25-482f-9e09-6692e0a62530/e6a7952a-3b25-482f-9e09-6692e0a625301.gif)
三次Bezier曲线
三次Bezier曲线
一、程序设计功能:
1.设计绘图窗口,能实现数据的多次输入;
2.具有多次绘图功能,能实现不同数据的绘图;
3.具有清屏功能,在画完该次图形后,清除图像并重建坐标系,
4.具有数据完整性检测功能,当数据输入不完整时,通过弹窗提示用户数据输入不完整。
二、程序设计思想:
先在草稿纸上求出三次Bezier曲线的各坐标参数前的系数表达式:
a1=-px(0)+3*px
(1)-3*px
(2)+px(3)
b1=3*px(0)-6*px
(1)+3*px
(2)
c1=-3*px(0)+3*px
(1)
d1=px(0)
a2=-py(0)+3*py
(1)-3*py
(2)+py(3)
b2=3*py(0)-6*py
(1)+3*py
(2)
c2=-3*py(0)+3*py
(1)
d2=py(0)
然后根据三次Bezier曲线的特点来定义为以u为变量的函数,然后根据取点速率的不同来绘制相应四个顶点的曲线。
三、程序代码:
PrivateSubCommand1_Click()
=2
=12'此处定义绘制坐标系时的字体大小,因为后面程序要用到字体设置,故此处字体设置要重新声明,不可用系统默认的字体,否则再次绘制图形时,坐标由于字体过大而很难看
(-300,300)-(300,-300)'定义PictureBox坐标系
(-300,0)-(300,0)
(0,300)-(0,-300)'VB编译系统中,其默认的是在Form(窗体)中画图,当需要在其他属性框中画图时,需要加上其对应的属性框名称
=270:
=40:
"X"
=15:
=285:
"Y"
=9'坐标上的数字字体小一些
Fori=-280To280Step40
(i,0)-(i,8)
=i-12:
=-5:
i
Nexti
Forj=-280To-40Step40
(0,j)-(8,j)
=-28:
=j+10:
j
Nextj
Forj=40To280Step40
(0,j)-(8,j)
=-28:
=j+10:
j
Nextj
Dimpx(4)AsDouble'定义控制点的x坐标的数组
Dimpy(4)AsDouble'定义控制点的y坐标的数组
Dima1,b1,c1,d1AsDouble'定义x系数
Dima2,b2,c2,d2AsDouble'定义y系数
Dimx,y,uAsDouble'定义曲线中的自变量u和变量x,y
If(NotIsNumeric(Text1)OrNotIsNumeric(Text2)OrNotIsNumeric(Text3)OrNotIsNumeric(Text4)_
OrNotIsNumeric(Text5)OrNotIsNumeric(Text6)OrNotIsNumeric(Text7)OrNotIsNumeric(Text8))Then
MsgBox"对不起!
系统检测到数据输入不完整,请您输入完整后绘图。
谢谢配合!
",,"友情提示"
Else
px(0)=:
py(0)=
px
(1)=:
py
(1)=
px
(2)=:
py
(2)=
px(3)=:
py(3)=
=18'设置字体,为显示输入的四个点设置字体大小
=px(0):
=py(0):
"P";0'P0单独打印
Fori=0To2
=
(px(i),py(i))-(px(i+1),py(i+1)),vbGreen:
"P";i+1'P1,P2,P3用for循环打印
Nexti
Fori=0To3'绘制四个圆点,此处代码可优化,亦可用circle语句画小圆后填充颜色
=7
(px(i),py(i))-(px(i)+1,py(i)-1)
Nexti
a1=-px(0)+3*px
(1)-3*px
(2)+px(3)'计算x和y的参数
b1=3*px(0)-6*px
(1)+3*px
(2)
c1=-3*px(0)+3*px
(1)
d1=px(0)
a2=-py(0)+3*py
(1)-3*py
(2)+py(3)
b2=3*py(0)-6*py
(1)+3*py
(2)
c2=-3*py(0)+3*py
(1)
d2=py(0)
Foru=0To1Step'每当u增加求一次x和y
x=a1*u^3+b1*u*u+c1*u+d1'求x的值
y=a2*u^3+b2*u*u+c2*u+d2'求y的值
Ifu=0Then
=x'设置画线起点
=y
Else
=3
-(x,y),RGB(255,0,0)'连点成线
EndIf
Nextu
EndIf
EndSub
PrivateSubCommand2_Click()'用于清空输入数据
=""
=""
=""
=""
=""
=""
=""
=""
EndSub
PrivateSubCommand3_Click()'清屏后再次绘制坐标系
=2
=12'此处定义绘制坐标系时的字体大小,因为后面程序要用到字体设置,故此处字体设置要重新声明,不可用系统默认的字体,否则再次绘制图形时,坐标由于字体过大而很难看
(-300,300)-(300,-300)'定义PictureBox坐标系
(-300,0)-(300,0)
(0,300)-(0,-300)'VB编译系统中,其默认的是在Form(窗体)中画图,当需要在其他属性框中画图时,需要加上其对应的属性框名称
=270:
=40:
"X"
=15:
=285:
"Y"
=9
Fori=-280To280Step40
(i,0)-(i,8)
=i-12:
=-5:
i
Nexti
Forj=-280To-40Step40
(0,j)-(8,j)
=-28:
=j+10:
j
Nextj
Forj=40To280Step40
(0,j)-(8,j)
=-28:
=j+10:
j
Nextj
EndSub
PrivateSubForm_Load()'预输入数据,避免调试时多次输入数据,其随窗体运行而显示
=-260:
=-230'冒号用于多条语句并行书写,以减小代码所占空间
=260:
=-230
=200:
=230
=-260:
=230
EndSub
VB程序运行结果图片展示:
第三次程序设计心得
在三次Bezier曲线的程序设计中,明白了计算机对于图行处理的能力是相当强的。
对于VB而言,其能根据取点速率的不同而精确确定相应图形的图像,能很好的满足人们在日常工作中的图像需求。
在本次程序设计中花费了大量时间在程序优化上,特别是在界面美化上。
因为我始终觉得一个良好的可执行程序不仅要具有精确计算的能力及绘图能力,还应该具有良好的用户体验界面,真正让用户在使用该程序时能有愉悦爽朗的心情。
这是我认为的CAD辅助设计的本质。
在具体界面美化过程中,我查找了大量的背景图片,最后选定了一张自然风景为背景。
因为一张好的背景图片不仅能给人良好的审美愉悦感,而且能让工作者在枯燥的工作中心生美意,同时能给予人心灵的绿意。
这是我在CAD课程中所学到的课外知识。
作为机械工作人员,不仅要具有严谨的工作思维,还要具有良好的审美观。
这样才能让我们在工作中不缺乏美感,不感到枯燥,更不会让同学及朋友觉得我们思维机械。
我所追求的是那种轻松学习,快乐工作的愉悦感。