图形学学习笔记3——区域填充

区域填充

概念

连通方式:

  • 四连通:两个像素点上下相连或左右相连。
  • 八连通:两个像素点上下或左右或对角相连。

区域定义方式:

  • 内部定义(interior-defined): 区域内部所有像素点单一值,边界可以不是单一值。
  • 边界定义(boundary-defined): 边界是单一值,内部所有是区域。


    这里写图片描述

(a)和(b)是内部定义四连通,(c)是内部定义八连通,(d)既不是四连通也不是八连通,内部区域是四连通。

性质:

  • 四连通区域的边界必定是八连通
  • 八连通区域的边界必定是四连通
##注入填充算法## 递归的填充与自己相邻的像素点。比如填充内部八连通区域:
void flood-fill-8(x,y,old_value, new_value)
{
    if( get_pix_value(x,y) == old_value)
    {
        set_pix_value(x,y,new_value);
        flood-fill-8(x-1,y-1,old_value,new_value);
        flood-fill-8(x-1,y,old_value,new_value);
        flood-fill-8(x-1,y+1,old_value,new_value);
        flood-fill-8(x,y-1,old_value,new_value);
        flood-fill-8(x,y+1,old_value,new_value);
        flood-fill-8(x+1,y-1,old_value,new_value);
        flood-fill-8(x+1,y,old_value,new_value);
        flood-fill-8(x+1,y+1,old_value,new_value);
    }
}

注入填充算法多次重复访问像素点,效率并不高。

边界填充算法

填充被边界包围的区域。填充一个八连通边界包围的区域:

void boundary-fill-8(x,y,boundary_value, new_value)
{
    if( get_pix_value(x,y) != boundary_value)
    {
        set_pix_value(x,y,new_value);
        boundary-fill-8(x-1,y,boundary_value,new_value);
        boundary-fill-8(x,y-1,boundary_value,new_value);
        boundary-fill-8(x,y+1,boundary_value,new_value);
        boundary-fill-8(x+1,y,boundary_value,new_value);
    }
}

内部访问路径按照四连通设计。


  • 注入填充和边界填充都是深度递归,耗内存。

扫描线算法

该算法只适用于四连通区域。
思路:一行一行的填充,将填充行的端点记录,填充完该行,寻找上下行各自的待填充线段的端点,如此循环。

  1. 找区域内一行的右端点入栈。(一行可能有多个右端点)
  2. 取出栈内一点作为种子,按像素向左填充直到边界
  3. 在填充范围的上一行和下一行寻找尚未被填充的右端点入栈。(得在 xleft
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
计算机图形学——几何工具算法详解》PDF是一本关于计算机图形学的书籍,主要介绍了图形学中的几何工具算法。 该书详细解析了计算机图形学中的几何工具算法,涵盖了从基础知识到高级算法的内容。首先,书中介绍了计算机图形学的基本概念和原理,包括图形学的历史背景、矢量、二维坐标系和三维坐标系等基础知识。然后,书中详细介绍了几何变换算法,包括平移、旋转、缩放等操作对图形的影响及其在计算机图形学中的应用。此外,还介绍了曲线和曲面的绘制算法,如贝塞尔曲线、B样条曲线和NURBS曲面等,以及相关算法的实现方法。另外,书中还详细阐述了光照和着色算法,包括光照模型、阴影生成和着色技术等。 《计算机图形学——几何工具算法详解》PDF书籍内容丰富、详细,适合计算机图形学领域的学习者和研究者阅读。通过学习该书,读者可以系统地了解计算机图形学的几何工具算法,掌握图形学中的基本概念和实际应用技术。此外,书中还提供了大量的实例和案例,有助于读者将理论知识应用到实际问题解决中。 总之,通过阅读《计算机图形学——几何工具算法详解》PDF,读者可以深入了解计算机图形学的几何工具算法,掌握相关的基本概念和实际应用技术,对计算机图形学领域有更深入的认识和理解。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值