




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、计算机图形学Visual C+版考试作业报告题目:计算机图形学图形画板专业:推荐IT学长淘宝日用品店 530213班级:推荐IT学长淘宝日用品店 530213学号:推荐IT学长淘宝日用品店530213姓名:推荐IT学长淘宝日用品店 530213指导教师: 推荐IT学长淘宝日用品店 530213完成日期: 2015年12月2日一、课程设计目的本课程设计的目标就是要达到理论与实际应用相结合,提高学生设计图形及编写大 型程序的能力,并培养基本的、良好的计算机图形学的技能。设计中要求综合运用所学知识,上机解决一些与实际应用结合紧密的、规模较大的 问题,通过分析、设计、编码、调试等各环节的训练,使学生深
2、刻理解、牢固掌握计算 机图形学基本知识和算法设计的基本技能术,掌握分析、解决实际问题的能力。通过这次设计,要求在加深对课程基本内容的理解。同时,在程序设计方法以及上 机操作等基本技能和科学作风方面受到比较系统和严格的训练。二、设计内容推荐IT学长淘宝日用品店530213设计一个图形画板,在这个图形画板中要实现:1,画线功能,而且画的线要具备反走样功能。利用上面的画线功能实现画矩形,椭圆,多边形,并且可以对这些图形进行填充。可以对选中区域的图形放大,缩小,平移,旋转等功能。三、设计过程程序预处理:包括头文件的加载,常量的定义以及全局变量的定义#in elude stdafx.h #in clud
3、e GraDesig n.h #i nclude GraDesig nDoc.h#include GraDesignView.h#include math.h#ifdef _DEBUG#define new DEBUG_NEW#undef THIS_FILEstatic char THIS_FILE = _FILE_;#endif/* 自定义全局变量int type = -1;CPoint point1;CPoint point2;CPoint temp2;CPoint remember;int i = 0;/ 推荐 IT 学长淘宝日用品 店 530213/ CGraDesignViewIMP
4、LEMENT_DYNCREATE(CGraDesignView, CView)BEGIN_MESSAGE_MAP(CGraDesignView, CView) /AFX_MSG_MAP(CGraDesignView)ON_WM_LBUTTONDOWN()ON_WM_LBUTTONUP()CGraDesignView:CGraDesignView()CGraDesignView:CGraDesignView()ON_COMMAND(line, Online)ON_COMMAND(rectangle, Onrectangle)ON_COMMAND(ellipse, Onellipse)ON_COM
5、MAND(polygon, Onpolygon)ON_COMMAND(fill, Onfill)ON_WM_RBUTTONDOWN()ON_COMMAND(tobig, Ontobig) /AFX_MSG_MAP/ Standard printing commandsON_COMMAND(ID_FILE_PRINT, CView:OnFilePrint) ON_COMMAND(ID_FILE_PRINT_DIRECT, CView:OnFilePrint)ON_COMMAND(ID_FILE_PRINT_PREVIEW, CView:OnFilePrintPreview) END_MESSAG
6、E_MAP()/ 推 荐 IT 学 长 淘 宝 日 用 品 店 530213/ CGraDesignView construction/destruction CGraDesignView:CGraDesignView()/ TODO: add construction code hereBOOL CGraDesignView:OnPreparePrinting(CPrintInfo* pInfo)BOOL CGraDesignView:OnPreparePrinting(CPrintInfo* pInfo)BOOL CGraDesignView:PreCreateWindow(CREATES
7、TRUCT& cs) / TODO: Modify the Window class or styles here by modifying/ the CREATESTRUCT csreturn CView:PreCreateWindow(cs); / CGraDesignView drawingvoid CGraDesignView:OnDraw(CDC* pDC)CGraDesignDoc* pDoc = GetDocument();ASSERT_VALID(pDoc);/ TODO: add draw code for native data here / CGraDesignView
8、printing/ default preparationvoid CGraDesignView:Dump(CDumpContext& dc) constvoid CGraDesignView:Dump(CDumpContext& dc) constreturn DoPreparePrinting(pInfo);void CGraDesignView:OnBeginPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)/ TODO: add extra initialization before printingvoid CGraDesignView:OnE
9、ndPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)/ TODO: add cleanup after printing/ CGraDesignView diagnostics#ifdef _DEBUGvoid CGraDesignView:AssertValid() constCView:AssertValid();CView:Dump(dc);/*画线函数*is通过CGraDesignDoc* CGraDesignView:GetDocument() / non-debug version inlineASSERT(m_pDocument-IsKi
10、ndOf(RUNTIME_CLASS(CGraDesignDoc);return (CGraDesignDoc*)m_pDocument;#endif /_DEBUG推荐 IT 学长淘宝日用品店 530213画 直 线 : RunLine 函 数 绘 制 任 意 斜 率 的 直 线 , 并 且 添 加 反 走 样 算 法 , OnLButtonDown,OnLButtonUp 函数记录鼠标的点击位置void CGraDesignView:RunLine(CPoint CP0, CPoint CP1) CDC *pDC=GetDC();CPoint p,t;int x,y;double e,k,
11、e1; x=CP1.x-CP0.x;/ 斜率无穷if(x=0)if(CP0.yCP1.y) t=CP0;CP0=CP1;CP1=t;p=CP0;while(p.ySetPixelV(p,RGB(0,0,0);p.y+;elsey=CP1.y-CP0.y;k=double(y)/double(x);/ 斜率 0 至 1if(k=0 & kCP1.x)t=CP0;CP0=CP1;CP1=t;p=CP0;x=CP1.x-CP0.x;y=CP1.y-CP0.y;/ 画反走样k=double(CP0.y-CP1.y)/(CP0.x-CP1.x);e=k;while(p.xSetPixelV(p.x,p.
12、y,RGB(e*255,e*255,e*255);pDC-SetPixelV(p.x,p.y+1,RGB(e1*255,e1*255,e1*255);p.x+;e=e+k;if(e=1)e-;p.y+;/ 斜率大于 1 if(k=1)if(CP0.y=CP1.y)t=CP0;CP0=CP1;CP1=t;p=CP0;x=CP1.x-CP0.x;y=CP1.y-CP0.y;k=double(CP0.y-CP1.y)/(CP0.x-CP1.x);e=1/k;while(p.xSetPixelV(p.x,p.y,RGB(e*255,e*255,e*255); pDC-SetPixelV(p.x+1,p
13、.y,RGB(e1*255,e1*255,e1*255);p.y+;e=e+1/k;if(e=1)e-;p.x+;/ 斜率-1 至 0if(k-1)if(CP0.xCP1.x)t=CP0;CP0=CP1;CP1=t;p=CP0;x=CP1.x-CP0.x;y=CP1.y-CP0.y; k=double(CP0.y-CP1.y)/(CP0.x-CP1.x);e=k; while(p.xSetPixelV(p.x,p.y,RGB(e*255,e*255,e*255);pDC-SetPixelV(p.x,p.y-1,RGB(e1*255,e1*255,e1*255);p.x+;e=e-k;if(e=
14、1)e-;p.y-;/ 斜率小于等于 -1if(k=-1)if(CP0.yCP1.y-1)e1=1-e;pDC-SetPixelV(p.x,p.y,RGB(e*255,e*255,e*255);pDC-SetPixelV(p.x+1,p.y,RGB(e1*255,e1*255,e1*255);p.y-;e=e-1/k;if(e=1)e-;p.x+;推荐 IT 学长淘宝日用品店 530213void CGraDesignView:Onrectangle()type = 2;画矩形:利用画线功能通过实现 RunRectangle 函数画出矩形*void CGraDesignView:RunRect
15、angle(CPoint CP0, CPoint CP1)CDC *pDC=GetDC();CPoint CP2,CP3;/0 1 在同一对角线, 2 和 1 在垂直方向, 0 3 在竖直方向CP2.x=CP1.x;CP2.y=CP0.y;CP3.x=CP0.x;CP3.y=CP1.y;/*利用前面的功能画4 条边*RunLine(CP0,CP2);RunLine(CP0,CP3);RunLine(CP1,CP2);RunLine(CP1,CP3);void CGraDesignView:Onellipse()type = 3;画椭圆:利用画线功能通过实现 RunEllipse 函数画出椭圆*
16、void CGraDesignView:RunEllipse(CPoint CP0, CPoint CP1)CDC *pDC=GetDC();CRect rect;GetClientRect(&rect);pDC-SetMapMode(8);pDC-SetWindowExt(rect.Width(),rect.Height();pDC-SetViewportExt(rect.Width(),-rect.Height();pDC-SetViewportOrg(CP0.x+CP1.x)/2,(CP0.y+CP1.y)/2);/ 建立坐标轴 /double a,b,d,d2,a2,b2;CPoint
17、 p,p0;int endx,endy;a=abs(CP0.x-CP1.x)/2;b=abs(CP0.y-CP1.y)/2;a2=a*a;b2=b*b;endx=(int)(a2/sqrt(a2+b2);d=b2-b*a2+0.25*a2;p.x=0;p.y=(long)b;if(CP0.y = CP1.y)RunRectangle(CP0,CP1);elsewhile(p.xSetPixelV(p,RGB(0,0,0); pDC-SetPixelV(p.x,-p.y,RGB(0,0,0); pDC-SetPixelV(-p.x,p.y,RGB(0,0,0);pDC-SetPixelV(-p.
18、x,-p.y,RGB(0,0,0);if(d=0)d=d+2*b2*p.x-2*a2*p.y+3*b2+2*a2;p.y-;else d=d+2*b2*p.x+3*b2;p.x+;d2=b2*(p.x+0.5)*(p.x+0.5)+a2*(p.y-1)*(p.y-1)-a2*b2;while(p.y=0)pDC-SetPixelV(p,RGB(0,0,0); pDC-SetPixelV(p.x,-p.y,RGB(0,0,0);pDC-SetPixelV(-p.x,p.y,RGB(0,0,0);pDC-SetPixelV(-p.x,-p.y,RGB(0,0,0);p.y-;if(d20)d2=d
19、2+2*b2*p.x-2*a2*p.y+2*b2+3*a2;p.x+;elsed2=d2-2*a2*p.y+3*a2;void CGraDesignView:Onpolygon()type = 4;void CGraDesignView:Onfill()type = 5;画多边形:利用画线功能通过鼠标左键函数 OnLButtonDown 取点,用鼠标右键函数On RButt on Dow n实现回到原点CPoint temp2;CPoint remember;int i = 0;/ 多边形 1if(4 = type)i+;tempi%2 = point;if(1=i) remember = t
20、empi; return; RunLine(tempi%2,temp(i+1)%2);/ 画多边形,按鼠标右键结束,并自动连接起始点,数据清零 RunLine(tempi%2,remember);i=0;temp0.x=0;temp0.y=0;temp1.x=0;temp1.y=0;CView:OnRButtonDown(nFlags, point);填充:通过实现 RunFill 函数实现填充CPoint stack1000000;void CGraDesignView:RunFill(CPoint point)CPoint p;int top;COLORREF r;CClientDC dc
21、(this);top=0;stacktop=point;top+;while(top!=0)top-;p=stacktop;r=dc.GetPixel(p);if(r != RGB(255,255,255) continue;dc.SetPixelV(p,RGB(0,255,0);r=dc.GetPixel(p.x+1,p.y);if(r = RGB(255,255,255) & r!=RGB(0,255,0)stacktop.x=p.x+1;stacktop.y=p.y;top+;r=dc.GetPixel(p.x-1,p.y);if(r = RGB(255,255,255) & r!=RG
22、B(0,255,0)stacktop.x=p.x-1;stacktop.y=p.y;top+;r=dc.GetPixel(p.x,p.y+1);if(r = RGB(255,255,255)& r!=RGB(0,255,0) stacktop.x=p.x;stacktop.y=p.y+1;top+;r=dc.GetPixel(p.x,p.y-1);if(r = RGB(255,255,255) & r!=RGB(0,255,0) stacktop.x=p.x;stacktop.y=p.y-1;top+;void CGraDesignView:Ontobig()type = 6;推荐 IT 学长淘宝日用品店 5302131需求分析本程序将实现多功能画板的功能: 1,画线功能,而且画的线要具备反走样功能。2, 利用上面的画线功能实现画矩形,椭圆,多边形,并且可以对这些图形进行填充。 3,可以对选中区域的图形放大,缩小,平移,旋转等功能。2概要设计RunLine(CPoint CP0, CPoint CP1) /
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 检测公司委托协议书范本
- 互联网企业典当质押贷款协议
- 民用建筑租赁合同范本及详细条款
- 转租合同协议书样板范本
- 免除房款协议书范本
- 车辆牌照租赁与绿色出行激励政策合同
- 甜品店品牌区域代理合作协议
- 绿色制造厂房租赁安全与节能减排协议
- 财务结算财务担保合同范本
- 住宅小区新能源汽车充电桩车位租赁合同
- JBT 11699-2013 高处作业吊篮安装、拆卸、使用技术规程
- 家长会课件:初中七年级家长会课件
- 厦门大学2023年826物理化学考研真题(含答案)
- 市政工程施工安全台帐范本12本(含内容)
- 《食管胃底静脉曲张》课件
- 周围性面瘫的分期治疗技术课件
- AutoCAD 2020中文版从入门到精通(标准版)
- 初中英语2023年中考专题训练任务型阅读-判断正误篇
- 2022年江西南昌高新技术产业开发区人民检察院聘用制检察辅助人员招聘考试真题
- 小学安全隐患排查表
- 学校财务人员述职报告范文
评论
0/150
提交评论