4上机实验报告3:图形裁剪算法的具体实现.docVIP

4上机实验报告3:图形裁剪算法的具体实现.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
4上机实验报告3:图形裁剪算法的具体实现

计算机图形学课程实验报告 信息与计算科学 (三) 上机实验3:裁剪算法 班级: 姓名: 学号: 上机实验(3)的题目和要求 一、实验目的 掌握图形裁剪算法的基本思想,并能上机编程实现相应的算法。 二、实验要求(Direction) 每个学生单独完成。 开发语言规定为C语言。 请在自己的实验报告上写明姓名、学号、班级。 每次交的实验报告内容包括:试验目的和意义、题目、程序制作步骤、主程序(包括源代码注释)。 三、实验题目 实验题1: 上机编一程序实现直线的中点裁剪算法。具体要求如下说明: 1 该程序能实现窗口屏幕上任意一条直线的裁剪; 2 直线段要求可以随机输入; 运行结果图: 裁剪之前 裁剪之后 #define LE 2 #define RI 4 #define BO 6 #define TO 10 #define XLEFT 150 #define XRIGHT 350 #define YBOTTOM 150 #define YTOP 300 #include math.h #include stdio.h #include graphics.h void main() { int x1,y1,x2,y2,xx,yy,xxx,yyy; int graphdriver=DETECT,graphmode; initgraph(graphdriver,graphmode, ); setcolor(6); line(XLEFT,YTOP,XRIGHT,YTOP); line(XLEFT,YBOTTOM,XRIGHT,YBOTTOM); line(XLEFT,YTOP,XLEFT,YBOTTOM); line(XRIGHT,YTOP,XRIGHT,YBOTTOM); x1=50;y1=200;x2=400;y2=300; setcolor(1); line(x1,y1,x2,y2); xx=0;yy=0;xxx=0;yyy=0; draw_ett(x1,y1,x2,y2,xx,yy); draw_ett(x2,y2,xx,yy,xxx,yyy); setcolor(4); line(xx,yy,xxx,yyy); getch(); closegraph(); } int encode (int x, int y, int *code) { int c=0; if (xXLEFT) c=c|LE; else if (xXRIGHT) c=c|RI; if (yYBOTTOM) c=c|BO; else if (yYTOP) c=c|TO; *code=c; return code; } draw_ett(int x1, int y1, int x2, int y2, int *x, int *y) { int code1,code2,code; int xx,yy; float d,d1,d2; encode(x1,y1,code1); encode(x2,y2,code2); if (code2==0) { xx=x2; yy=y2; *x=xx; * y=yy; return;} if ((code1code2)!=0) return; L1: xx=(x1+x2)/2; yy=(y1+y2)/2; encode(xx, yy, code); d1=(yy-y1)*(yy-y1); d2=(xx-x1)*(xx-x1); d=sqrt(d1+d2); if (d=1) { *x=xx;*y=yy; return;} if ((codecode1)!=0) { x1=xx; y1=yy; } else { x2=xx; y2=yy;} goto L1; } 实验题2: 实现Sutherland-Hodgeman多边形裁剪算法。对矩形窗口中一多边形进行裁剪。 运行结果图: /* Sutherland-Hodgman 算法 */ #define LEN sizeof(struct node) #include math.h #include

文档评论(0)

153****9595 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档