《计算机图形学》实验指导书暨实验报告
然后出现下图:
为该类设计一个名字,如下所示:
点击确定后,出现下图:
《计算机图形学》实验指导书暨实验报告
然后再给对话框中的四个文本编辑框添加成员变量,如下所示:
成员变量设计完成后,出现下图:
《计算机图形学》实验指导书暨实验报告
到此为止,对话框设计完成,这时候打开文件视图,打开draw_lineView.h,将InputLineInfo.h包含进去。
(四)在绘图函数中添加代码
通过以上步骤,得到了与菜单对应的消息映射,就可以在函数中添加代码绘制图形了。 1、利用数值微分算法生成直线(算法的详细原理见教材)。 void CDraw_LineView::OnDda() { // TODO: Add your command handler code here InputLineInfo Dlg; Dlg.DoModal(); //打开直线参数设置对话框 CDC*pDC=GetDC();//得到绘图类指针 //RedrawWindow();//重绘窗口 int x,x0,y0,x1,y1;//(x0,y0)为直线的起点,(x1,y1)为直线的终点 float dx,dy,k,y; x0=Dlg.qidian_x,y0=Dlg.qidian_y; x1=Dlg.zhongdian_x,y1=Dlg.zhongdian_y; dx=x1-x0; dy=y1-y0; k=dy/dx; y=y0; for(x=x0;x<=x1;x++) { pDC->SetPixel(x,int(y+0.5),RGB(255,0,0)); y=y+k; } }
2、利用中点画线算法生成直线(算法的详细原理见教材)。 void CDraw_LineView::OnMid() {
《计算机图形学》实验指导书暨实验报告
// TODO: Add your command handler code here InputLineInfo Dlg; Dlg.DoModal(); //打开直线参数设置对话框 CDC*pDC=GetDC();//得到绘图类指针 //RedrawWindow();//重绘窗口 int x0,y0,x1,y1;//(x0,y0)为直线的起点,(x1,y1)为直线的终点 int a,b,delta1,delta2,d,x,y; x0=Dlg.qidian_x,y0=Dlg.qidian_y; x1=Dlg.zhongdian_x,y1=Dlg.zhongdian_y; a=y0-y1; b=x1-x0; d=2*a+b; delta1=2*a; delta2=2*(a+b); x=x0; y=y0; pDC->SetPixel(x,y,RGB(0,0,255));//SetPixel为CDC类里面的画点函数,具体参数 while(x
3、利用Bresenham画线算法生成直线(算法的详细原理见教材)
void CDraw_LineView::OnBre() { InputLineInfo Dlg; Dlg.DoModal(); //打开直线参数设置对话框 CDC*pDC=GetDC();//得到绘图类指针 //RedrawWindow();//重绘窗口 int x,y,x0,y0,x1,y1;//(x0,y0)为直线的起点,(x1,y1)为直线的终点 int dx,dy; float k,e; x0=Dlg.qidian_x,y0=Dlg.qidian_y; x1=Dlg.zhongdian_x,y1=Dlg.zhongdian_y; dx=x1-x0; dy=y1-y0;
《计算机图形学》实验指导书暨实验报告
k=float(dy)/dx; e=-0.5; x=x0; y=y0; for(int i=0;i<=dx;i++) { pDC->SetPixel(x,y,RGB(0,0,255)); x++; e=e+k; if(e>=0) { y++; e--; } } }
4、运行效果如图:
5、以上的内容为本次实验的基本部分,我们给出的示例代码只能解决直线斜率的绝对值不超过1的情形(|k|≤1)。当直线的斜率不满足这个条件的时候,如何处理,请同学们根据相关算法的思想,完成任意斜率直线的生成,上机调试通过,并撰写在实验报告书上。 五、思考
1、MFC开发绘图程序时,工作窗口坐标系是怎么样的,坐标原点在哪儿?
2、实现任意斜率直线生成问题时,能不能使用模块化的思想,即将各个画线算法程序进一步分解,通过不同的函数来完成不同斜率的生成?
3、三种不同的直线生成算法的分析和比较。 六、实验总结
百度搜索“77cn”或“免费范文网”即可找到本站免费阅读全部范文。收藏本站方便下次阅读,免费范文网,提供经典小说综合文库《计算机图形学》新版实验指导书(3)在线全文阅读。
相关推荐: