- 1、本文档共6页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
计算机图形学实验de-Casteljau算法
精品文档
精品文档
收集于网络,如有侵权请联系管理员删除
收集于网络,如有侵权请联系管理员删除
精品文档
收集于网络,如有侵权请联系管理员删除
实验7-2
一、实验题目
在屏幕上使用鼠标绘制任意控制点的控制多边形,基于de Casteljau算法绘制如图7-48所示的Bezier曲线。
二、实验思想
Bezier曲线上的点,可以使用Bezier曲线方程直接计算,但使用de Casteljau递推算法则要简单的多。
1.递推公式
给定空间n+1个控制点Pi(i=0,1, 2?n)及参数t,de Casteljau递推算法表述为:
当n=3时,有
三次Bezier曲线递推如下
第一级递推:
第二级递推:
第三级递推:
其中:规定:
定义Bezier曲线的控制点编号为 其中,r为递推次数。de Casteljau已经证明,当r=n时, 表示曲线上的点。根据式(7-16)可以绘制n次Bezier曲线。
三、实验代码
void CTestView::OnMENUBezierCurve()
{
// TODO: Add your command handler code here
RedrawWindow();
MessageBox("单击左键绘制特征多边形,单击右键绘制曲线","提示",MB_OK);
pt=new CPoint [N_MAX_POINT];
Flag=true;CtrlPoint=0;
}
void CTestView::DrawBezier()//绘制Bezier曲线
{
CClientDC dc(this);
int rate=500,n;
n=CtrlPoint-1;
double x,y;
double px[N_MAX_POINT],py[N_MAX_POINT];
for(int k=0;k<=n;k++)
{
px[k]=pt[k].x;
py[k]=pt[k].y;
}
for(double t=0;t<=1;t+=0.01/rate)
{
x=DeCasteliau(t,px);
y=DeCasteliau(t,py);
dc.SetPixel(ROUND(x),ROUND(y),RGB(0,0,255));
}
}
double CTestView::DeCasteliau(double t,double p[])//德卡斯特里奥函数
{
double pp[N_MAX_POINT][N_MAX_POINT];
int n=CtrlPoint-1;
for(int k=0;k<=n;k++)
{
pp[k][0]=p[k];
}
for(int r=1;r<=n;r++)
{
for(int i=0;i<=n-r;i++)
{
pp[i][r]=(1-t)*pp[i][r-1]+t*pp[i+1][r-1];
}
}
return(pp[0][n]);
}
void CTestView::DrawCharPolygon()//绘制控制多边形
{
CClientDC dc(this);
CPen NewPen,*OldPen;
NewPen.CreatePen(PS_SOLID,3,RGB(0,0,0));
OldPen=dc.SelectObject(&NewPen);
for(int i=0;i<CtrlPoint;i++)
{
if(i==0)
{
dc.MoveTo(pt[i]);
dc.Ellipse(pt[i].x-2,pt[i].y-2,pt[i].x+2,pt[i].y+2);
}
else
{
dc.LineTo(pt[i]);
dc.Ellipse(pt[i].x-2,pt[i].y-2,pt[i].x+2,pt[i].y+2);
}
}
dc.SelectObject(OldPen);
NewPen.DeleteObject();
}
void CTestView::OnLButtonDown(UINT nFlags, CPoint point)//获得屏幕控制点坐标
{
// TODO: Add your message handler code here and/or call default
CView::OnLButtonDown(nFlags, point);
if(Flag)
{
pt[CtrlPoint].x=point.x;
pt[CtrlPoint].y=point.y;
您可能关注的文档
- 詹森不等式讲解学习.doc
- 誓师大会流程电子教案.doc
- 警务室工作制度资料讲解.doc
- 警务战术原则复习课程.ppt
- 警告信模板教学提纲.doc
- 警卫转正试题二(答案)教学提纲.doc
- 警容风纪复习进程.doc
- 警察与赞美诗教案资料.doc
- 警察形象建设存在的问题和解决的对策说课讲解.doc
- 警察心理行为课后感2知识分享.doc
- 一病一品护理汇报(手工精品图文).ppt
- 国家义务教育质量监测四年级心理健康测试卷3+问卷(通用版附答案).docx
- 国家义务教育质量监测四年级心理健康测试卷2+问卷(通用版附答案).docx
- 国家义务教育质量监测四年级心理健康测试卷5+问卷(通用版附答案).docx
- 国家义务教育质量监测四年级心理健康测试卷1+问卷(通用版附答案).docx
- 国家义务教育质量监测四年级心理健康测试卷4+问卷(通用版附答案).docx
- 13(猫)第3课时 课件+公开课一等奖创新教学设计.docx
- 孙权劝学 (同步公开课一等奖创新教学设计).docx
- 第17课 要是你在野外迷了路 公开课一等奖创新教学设计.docx
- 统编版(五四制)11古诗二首 池上 公开课一等奖创新教学设计.docx
文档评论(0)