//*************************
//获取点中y坐标最大值
//*************************
int CPolygonFillView::GetMaxY()
{
int result = points[0].y;
for(int i = 1; i < count; i++)
if(result < points[i].y)
result = points[i].y;
return result;
}
//*************************
//获取点中y坐标最小值
//*************************
int CPolygonFillView::GetMinY()
{
int result = points[0].y;
for(int i = 0; i < count; i++)
if(result > points[i].y)
result = points[i].y;
return result;
}
//*******************************************************
//判断是否为极值点,参数为一条边的y较小点和其在pionts数组中的下标
//********************************************************
bool CPolygonFillView::IsSuperPoint(CPoint &point,int i){
if(i == 0)
return ((points[0].y > points[1].y&&points[0].y > points[count-1].y)
||(points[0].y < points[1].y&& points[0].y < points[count-1].y));
else if(i == count-1)
return ((points[i].y > points[0].y&&points[i].y > points[i-1].y)
||(points[i].y < points[0].y&&points[i].y < points[i-1].y));
else
return ((points[i].y > points[i-1].y&&points[i].y > points[i+1].y)
||(points[i].y < points[i-1].y&&points[i].y < points[i+1].y));
}
//*************************
//用改进的冒泡法对链表排序
//*************************
void CPolygonFillView::SortEdges()
{
if(head == NULL || head->next == NULL) return;
Edge *p,*q = head;
float tymax;
float txmin;
float tm;
bool flag = true;
while(flag){
flag = false;
for(p=q;p->next!=NULL;p=p->next){
if(p->xmin > p->next->xmin){
tymax = p->ymax;
p->ymax = p->next->ymax;
p->next->ymax = tymax;
txmin = p->xmin;
p->xmin = p->next->xmin;
p->next->xmin = txmin;
tm = p->m;
p->m = p->next->m;
p->next->m = tm;
flag = true;
}
q = q->next;
}
}
}
//**************************************
// 从活动边表中清除不满足条件的边
//**************************************
void CPolygonFillView::ClearEdges(int ymax)
{
if(head == NULL) return;
if(head->next==NULL)
{
if(head->ymax = ymax)
head = NULL;
}
else
{
Edge *p = head,*q = head->next,*r = head;
while(head!=NULL && head->ymax == ymax )
{
head = head->next;
r->next = NULL;
r = head;
}
while(q!=NULL)
{
if(q->ymax == ymax){
p->next = q->next;
q->next = NULL;//删除边
q = p->next;//恢复q为恰当的值
}
else{
if(p==NULL) break;
p = p->next;
if(q==NULL) break;
q = q->next;
}
}
}
}
//**************************************
// 向活动边表中添加的边
//**************************************
void CPolygonFillView::AddEdges(int index)
{
if(edgeTable[index].head == NULL) return;
if(head == NULL)
{
head = edgeTable[index].head;
}
else
{
for(Edge *p=head;p->next!=NULL;p=p->next){}
p->next = edgeTable[index].head;
}
}
//*****************************
//初始化边表
//*****************************
void CPolygonFillView::InitEdgeTable()
{
int ymin,t;
Edge *p = NULL;
CPoint cp;
for(int i=0;i<count;i++)
{
cp = points[i].y > points[(i+1)%count].y
? points[(i+1)%count] : points[i];
t = points[i].y > points[(i+1)%count].y
? (i+1)%count : i;
edge[i].m =(float) (points[i].x - points[(i+1)%count].x)/
(points[i].y - points[(i+1)%count].y);
if(IsSuperPoint(cp,t))
{
edge[i].xmin = cp.x;
edge[i].ymax = points[i].y > points[(i+1)%count].y
? points[i].y : points[(i+1)%count].y;
ymin = cp.y;
}
else
{
edge[i].xmin = cp.x + edge[i].m;
edge[i].ymax = points[i].y > points[(i+1)%count].y
? points[i].y : points[(i+1)%count].y;
ymin = cp.y + 1;
}
if((p=edgeTable[ymin].head)==NULL)
{
edgeTable[ymin].head = &edge[i];
}
else
{
if(edge[i].xmin<=p->xmin){
edge[i].next = p;
edgeTable[ymin].head = &edge[i];
}
else{
while(p->next!=NULL&&p->next->xmin<edge[i].xmin){
p = p->next;
}
edge[i].next = p->next;
p->next = &edge[i];
}
}
}
}
//******************
//对多边形进行填充
//******************
void CPolygonFillView::Polygonfill(CClientDC &dc,COLORREF color)
{
int begin = GetMinY(),end = GetMaxY();
Edge *q = NULL;
for(int i=begin;i<=end;i++)
{
AddEdges(i);
SortEdges();
q=head;
if(q==NULL) break;
while(q->next!=NULL)
{
for(int j=q->xmin;j<q->next->xmin;j++)
{
SetPixel(dc,j,i,color);
}
q=q->next->next;
if(q==NULL) break;
}
ClearEdges(i);
q=head;
while(q!=NULL)
{
q->xmin += q->m;
q = q->next;
}
}
}
分享到:
相关推荐
使用VS 2017实现多边形填充中的种子填充算法,此资源包括完整的项目文件,可以直接使用。此代码仅供学习交流使用。
(系统会自己调高积分,我重新改成5分啦!)大学计算机图形学课程作业代码,完美实现多边形有效边表填充算法,自用,具体代码完整。打包下载,可直接运行。c/c++语言MFC实现。支持vs。
本程序是在上次的画直线、画圆的程序上修改的,添加了扫描线填充算法,使用OpenGL+MFC实现。 填充算法的使用说明: 1、选择菜单中的“种子填充”--〉“鼠标画边界”,然后在绘图区域左键点击若干个点作为多边形的...
实现了图形学中,多边形区域的扫描线填充、扫描线种子填充算法实现,用MFC
资源内容:透过鼠标获取多边形顶点绘制多边形,通过预先设定好的个顶点颜色,实现过度填充 语言:C++ 运行环境:Visual Studio 2013/更高版本
编写应用程序,采用鼠标输入顶点的方法确定待填充多边形(多 边形最后一点双击);实现边标志算法完成对该多边形的填充,要求 完成使用自己学号的后四位数字对多边形内部进行填充。
边缘填充算法,注意此算法中的多边形的顶点坐标是可以自己手动输入的,所以多边形的形状是有自己控制的
包含多种计算机图像学的基本算法:DDA画线,Bresenhen算法,画圆,画多边形,Cohen-Sutherland裁剪算法,Liang-Barsky裁剪算法,扫描线填充算法,三次样条曲线,Bezier曲线,三次B样条曲线,二维图形变换(平移,...
图形学作业,扫描转换多边形,种子区域填充
二、多边形扫描转换算法和区域填充算法实现(扫描线算法为必做,基于求余运算的边缘填充和边标志算法为任选;基于种子的区域填充采用4连通区域的递归种子填充算法,或扫描线种子填充算法,要求种子点(x,y)可交互输入...
实现了计算机图形学中,多边形区域的扫描线填充、种子填充算法,MFC VC++
用鼠标在屏幕上绘制任意顶点数的封闭多边形并填充,填充效果如下图所示。编程要求:⑴多边形的顶点数不受限制; ⑵按下鼠标左键,拖动鼠标绘制多边形,同时按下Shift键可以绘制水平边...⑷使用边缘填充算法填充多边形。
包括DDA,Bresenham,扫描填充的有序边表算法,三视图以及消隐的算法,因为是自己要交的课程实验,所以是一定可以运行的
第一步:点击button选择想要的算法。第二步:点击确认开始绘图。第三步:鼠标单击输入任意多边形的点,双击鼠标左键结束输入绘图完成
计算机图形学作业-基于C++实现MFC程序源码+项目说明.zip 【资源介绍】 MFC程序实现: 1.基本图形绘制: Bresenham、DDA、改进的Bresenham、系统库函数四种方法画直线, Bresenham画圆,Bresenham画椭圆,绘制矩形,...
利用1/8圆中点算法和Bresenham算法生成圆,多边形扫描线算法实现对多边形内部的填充。 注意:可能由于配置原因导致无法直接运行,可以直接运行文件中的Debug文件夹里的exe程序查看效果,再查看代码,自己进行进一步...
1、运行附件中参考例子,理解Visual C++和OpenGL的使用。 2、参照附件例子,修改程序,实现可以在视图客户区中进行绘图,并可以实现重画...用多边形扫描线算法实现对多边形内部的填充,要求内部颜色和边界颜色不一致。
本资源为计算机图形学基本算法的实现,包括直线DDA,中点画线,八分法画圆,四分法画椭圆,直线的裁剪,区域填充的扫描线算法,裁剪多边形算法等。基于vs2010MFC,有需要自取
计算机图形学 有效边表填充算法(6)代码发布在我的博客http://blog.csdn.net/qingdujun/article/details/40154077, 同时这里也传上来了一个Demo,参考别人的改写的。
计算机图形学边标志算法MFC,C++实现,无error,VS下直接运行,鼠标单击设定多边形顶点,最后一点双击开始运行,向多边形内部填充数字