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