欢迎来到天天文库
浏览记录
ID:22284563
大小:198.67 KB
页数:6页
时间:2018-10-28
《实验三二维图形的区域填充》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库。
1、西北农林科技大学实验报告学院名称:理学院专业年级:计算131姓名:学号:课程:计算机图形学报告日期:2015.12.11实验三二维图形的区域填充一.实验目的1)加深对填充算法的理解,分析比较种子填充和边缘填充的差异。2)掌握二维图形区域种子填充的原理和算法。二.实验内容用种子填充算法编写程序实现区域填充,并能在计算机上编译运行,正确地实现任意多边形边界的单色填充。三.实验内容1)对任意多边形的几何形状进行分析,选定比较合适的算法模型选用种子填充算法:种子填充算法又称为边界填充算法。其基本思想是:从多边形区域的一个内点开始,由内向
2、外用给定的颜色画点直到边界为止。如果边界是以一种颜色指定的,则种子填充算法可逐个像素地处理直到遇到边界颜色为止。步骤:①在画图板中画出要填充的图形。②在matlab中读入该图片。③对读入的图片二值化,使之变为01矩阵。①以行为单位进行扫描,若遇到0,就把该位置的列坐标记到数组a中。②以行为单位进行扫描,给每行的a(i,l)列到max(a(i,:))列进行着色。2)画出程序流程确定种子点元素(X,y)判断种子点(x,y)是否满足非边界、非填充色的条件,若满足条件,以y作为当前扫描线沿当前扫描线向左、右两个方向填充,直到边界。确定新
3、的种子点:检查与当前扫描线y上、下相邻的两条扫描线上的像素。若存在非边界、未填充的像素,则返回上一步进行扫描填充。直至区域所有元素均为填充色,程序结朿。3)编写程序的源程序;functiontianchong(x,y)x=[40704024]y=[10308034]n=length(x);P=1;A=[0,0];x=[x,x(1)];y=[y,y⑴】;fori=1:n[a,k]=Bresenhamline(x(i),y(i),x(i+1),y(i+1));p=p+k;A=[A;a];endA=A(2:p,:);m=p-1;yO=
4、min(A(:,2));y1=max(A(:,2));yy=yo;whileyy5、);x=xO;y=yO;plot(x,y’’b*.);a=[xy】;k=1;if(abs(dx)>=abs(dy))p=-abs(dx);whileabs(x)〜=abs(x1)if(dx〉=0)x=x+1:endif(dx<0)x=x-1:endP=P+d2;ifp〉0if(dy〉=O)y=y+1:endif(dy<0)y=y-1:endP=p-d1;endholdon;a=[a;xy];k=k+1;%pause(0.01);plot(x,y’’b*.);endendif(abs(dx)6、whileabs(y)〜=abs(y1)if(dy〉=O)y=y+1:endif(dy<0)y=y-1:endp=p+d1;ifp〉0if(dx〉=O)x=x+1:endif(dx<0)x=x-1:endP=p-d2;endholdon;a=[a;xy];k=k+1;%pause(0.01);plot(x,y,V);endendholdon;4)编辑源程序并进行调试。程序运行图像如下:80一.实验总结本次实验主要是对填充算法的学习,让我对填充算法有了更多理解,对MATLAB也有了更丰富的认识。
5、);x=xO;y=yO;plot(x,y’’b*.);a=[xy】;k=1;if(abs(dx)>=abs(dy))p=-abs(dx);whileabs(x)〜=abs(x1)if(dx〉=0)x=x+1:endif(dx<0)x=x-1:endP=P+d2;ifp〉0if(dy〉=O)y=y+1:endif(dy<0)y=y-1:endP=p-d1;endholdon;a=[a;xy];k=k+1;%pause(0.01);plot(x,y’’b*.);endendif(abs(dx)6、whileabs(y)〜=abs(y1)if(dy〉=O)y=y+1:endif(dy<0)y=y-1:endp=p+d1;ifp〉0if(dx〉=O)x=x+1:endif(dx<0)x=x-1:endP=p-d2;endholdon;a=[a;xy];k=k+1;%pause(0.01);plot(x,y,V);endendholdon;4)编辑源程序并进行调试。程序运行图像如下:80一.实验总结本次实验主要是对填充算法的学习,让我对填充算法有了更多理解,对MATLAB也有了更丰富的认识。
6、whileabs(y)〜=abs(y1)if(dy〉=O)y=y+1:endif(dy<0)y=y-1:endp=p+d1;ifp〉0if(dx〉=O)x=x+1:endif(dx<0)x=x-1:endP=p-d2;endholdon;a=[a;xy];k=k+1;%pause(0.01);plot(x,y,V);endendholdon;4)编辑源程序并进行调试。程序运行图像如下:80一.实验总结本次实验主要是对填充算法的学习,让我对填充算法有了更多理解,对MATLAB也有了更丰富的认识。
此文档下载收益归作者所有