♥,.*,.♥,.*,.♥,.*,.♥,.*♥,.*,.♥,.*,.♥,.*,.♥,.*,.♥,.*,.♥,.*,.♥,.*,.♥♥,.*,.♥,.*,.♥,.*,.♥,.*♥,.*,.♥,.*,.♥,.*,.♥,.*,.♥,.*,.♥,.*,.♥,.*,.♥
目录
1.光栅化
2.区域填充(种子填充算法)
3.多边形的扫描转换(扫描线算法)
4.多边形的扫描转换与区域填充比较
♥,.*,.♥,.*,.♥,.*,.♥,.*♥,.*,.♥,.*,.♥,.*,.♥,.*,.♥,.*,.♥,.*,.♥,.*,.♥♥,.*,.♥,.*,.♥,.*,.♥,.*♥,.*,.♥,.*,.♥,.*,.♥,.*,.♥,.*,.♥,.*,.♥,.*,.♥
1.光栅化
光栅化是在设备变换的时候进行的操作。即从图像坐标系得到规格化设备坐标系。
光栅图形的本质是点阵表示。
多边形有两种表示方式:
- 顶点表示:利用有序顶点来表示多边形
- 点阵表示:用多边形内部的像素集合来表示多边形
多边形的扫描转换就是将多边形的顶点表示转换为多边形的点阵表示。

2.区域填充
将已经表示成点阵的像素集合,进行区域内部的填充。
区域有两种表示:
(1)内部表示
区域内的所有像素着同一种颜色,边界像素不能着上述颜色。
(2)边界表示
边界上的所有像素着同一种颜色,区域内部像素不能着上述颜色。
区域填充的类型有四连通邻域和八连通邻域。


区域填充可以使用区域种子填充算法。
内部表示的区域种子填充算法为(四连通区域):
Flood_Fill_4(x, y, G0, G1)
{
if(GetPixel(x,y) ==G0 ) // GetPixel(x,y) 返回(x,y)的颜色
{
SetPixel(x, y, G1); //将(x,y)的添上颜色G1
Flood_Fill_4(x-1, y, G0, G1);
Flood_Fill_4(x, y+1, G0, G1);
Flood_Fill_4(x+1, y, G0, G1);
Flood_Fill_4(x, y-1, G0, G1);
}
}
边界表示的区域种子填充算法为:

本文介绍了光栅化的基本概念,包括顶点表示和点阵表示,并详细阐述了区域填充算法,如种子填充,以及多边形的扫描转换算法,如逐点判断和扫描线算法。扫描线算法利用区域、扫描线和边的连贯性提高效率,但数据结构和程序结构较为复杂。最后,对比了多边形扫描转换与区域填充在基本思想、边界要求和出发点上的差异。
最低0.47元/天 解锁文章
2133





