《计算机图形学-课程设计作品》由会员分享,可在线阅读,更多相关《计算机图形学-课程设计作品(15页珍藏版)》请在金锄头文库上搜索。
1、计算机图形学Visual c+版考试作业报告题目: 计算机图形学图形画板 专业: 推荐IT学长淘宝日用品店 班级: 推荐IT学长淘宝日用品店 学号: 推荐IT学长淘宝日用品店 姓名: 推荐IT学长淘宝日用品店 指导教师: 推荐IT学长淘宝日用品店 完成日期: 2015年12月2日一、课程设计目的本课程设计的目标就是要达到理论与实际应用相结合,提高学生设计图形及编写大型程序的能力,并培养基本的、良好的计算机图形学的技能。设计中要求综合运用所学知识,上机解决一些与实际应用结合紧密的、规模较大的问题,通过分析、设计、编码、调试等各环节的训练,使学生深刻理解、牢固掌握计算机图形学基本知识和算法设计的基
2、本技能术,掌握分析、解决实际问题的能力。通过这次设计,要求在加深对课程基本内容的理解。同时,在程序设计方法以及上机操作等基本技能和科学作风方面受到比较系统和严格的训练。二、设计内容推荐IT学长淘宝日用品店设计一个图形画板,在这个图形画板中要实现:1, 画线功能,而且画的线要具备反走样功能。2, 利用上面的画线功能实现画矩形,椭圆,多边形,并且可以对这些图形进行填充。3,可以对选中区域的图形放大,缩小,平移,旋转等功能。3、 设计过程程序预处理:包括头文件的加载,常量的定义以及全局变量的定义#include stdafx.h#include GraDesign.h#include GraDesi
3、gnDoc.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学长淘宝日用品店/ CGraDesignViewIMPLEMENT_DYNCREATE(CGraDesignView, CView)BEGIN_
4、MESSAGE_MAP(CGraDesignView, CView)/AFX_MSG_MAP(CGraDesignView)ON_WM_LBUTTONDOWN()ON_WM_LBUTTONUP()ON_COMMAND(line, Online)ON_COMMAND(rectangle, Onrectangle)ON_COMMAND(ellipse, Onellipse)ON_COMMAND(polygon, Onpolygon)ON_COMMAND(fill, Onfill)ON_WM_RBUTTONDOWN()ON_COMMAND(tobig, Ontobig)/AFX_MSG_MAP/ S
5、tandard 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_MESSAGE_MAP()/推荐IT学长淘宝日用品店/ CGraDesignView construction/destructionCGraDesignView:CGraDesignView()/ TODO: add constru
6、ction code hereCGraDesignView:CGraDesignView()BOOL CGraDesignView:PreCreateWindow(CREATESTRUCT& 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 = GetDoc
7、ument();ASSERT_VALID(pDoc);/ TODO: add draw code for native data here/ CGraDesignView printingBOOL CGraDesignView:OnPreparePrinting(CPrintInfo* pInfo)/ default preparationreturn DoPreparePrinting(pInfo);void CGraDesignView:OnBeginPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)/ TODO: add extra initial
8、ization before printingvoid CGraDesignView:OnEndPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)/ TODO: add cleanup after printing/ CGraDesignView diagnostics#ifdef _DEBUGvoid CGraDesignView:AssertValid() constCView:AssertValid();void CGraDesignView:Dump(CDumpContext& dc) constCView:Dump(dc);CGraDesign
9、Doc* CGraDesignView:GetDocument() / non-debug version is inlineASSERT(m_pDocument-IsKindOf(RUNTIME_CLASS(CGraDesignDoc);return (CGraDesignDoc*)m_pDocument;#endif /_DEBUG推荐IT学长淘宝日用品店画直线:RunLine函数绘制任意斜率的直线,并且添加反走样算法,通过OnLButtonDown,OnLButtonUp函数记录鼠标的点击位置/*画线函数*void CGraDesignView:RunLine(CPoint CP0, C
10、Point CP1)CDC *pDC=GetDC();CPoint p,t;int x,y;double e,k,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-C
11、P1.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=1)e-;p.y+;/斜率大于1if(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.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-