下载此文档

实验五 计算机图形学 北信科.docx


文档分类:IT计算机 | 页数:约9页 举报非法文档有奖
1/9
下载提示
  • 1.该资料是网友上传的,本站提供全文预览,预览什么样,下载就什么样。
  • 2.下载该文档所得收入归上传者、原创者。
  • 3.下载的文档,不会出现我们的网址水印。
1/9 下载此文档
文档列表 文档介绍
实验报告
课程名称 计算机图形学
实验项目 实验五线段裁剪
系 别 计算机学院
班级/学号 计科1104班/2011011???
姓 名
日 期 2013年10月18日
指导教师 谷葆春
成 绩
一、 实验目的
理c|RIGHT;
if(yl<YB) c=c|BOTTOM;
else if(yl>YT) c=c|TOP;
codel=c;
c=0;
if(x2<XL) c=c|LEFT;
else if(x2>XR) c=c|RIGHT;
if(y2<YB) c=c|BOTTOM;
else if(y2>YT) c=c|TOP;
code2=c;
while(codel !=0||code2!=0)
(
if((codel & code2) !=0)( xl=x2=y l=y2=0;break;) code二code1;
if(codel ==0) code=code2;
if( ((LEFT & code))!=0)
{
x=XL;
y=yl+(y2-yl)*(XL-xl)/(x2-xl);
1
else if (( RIGHT & code)!=0)
{
x=XR;
y=yl+(y2-yl)*(XR-xl)/(x2-xl);
}
else if( (BOTTOM & code )!=0)
{
y=YB;
x=x 1+(x2-x 1)*(YB -y l)/(y2-yl);
else if((TOP & code)!=0)
y=YT;
x=x 1+(x2-x 1 )* (YT-y l)/(y2-y 1);
}
if(code==codel)
{
xl=x;yl=y;
c=0;
if(x<XL) c=c|LEFT;
else if(x>XR) c=c|RIGHT;
if(y<YB) c=c|BOTTOM;
else if(y>YT) c=c|TOP;
codel=c;
}
else
{
x2=x;y2=y;
c=0;
if(x<XL) c=c|LEFT;
else if(x>XR) c=c|RIGHT;
if(y<YB) c=c|BOTTOM;
else if(y>YT) c=c|TOP;
code2=c;
)
}
float k;
k=(float)(y2-yl)/(x2-xl);
for(x=x l;x<x2;x++)
(
y=k*(x-xl)+yl;
PenA myPen=gcnew Pen(Color::Red, 1 .Of);
Rectangle rl=Rectangle(x,int(y+), 1,1);
e->Graphics->DrawRectangle(myPen,rl);
}
for(x=XL;xv=XR;x++)
(
PenA myPen二gcnew Pen(Color::Blue, 1 .Of);
Rectangle rl =Rectangle(x,200,1,1);
e->Graphics->DrawRectangle(myPen,rl);
}
for(x=XL;xv=XR;x++)
{
PenA myPen=gcnew Pen(Color::Blue, 1

实验五 计算机图形学 北信科 来自淘豆网m.daumloan.com转载请标明出处.

相关文档 更多>>
非法内容举报中心
文档信息
  • 页数9
  • 收藏数0 收藏
  • 顶次数0
  • 上传人小博士
  • 文件大小107 KB
  • 时间2022-06-17