ImageVerifierCode 换一换
格式:DOCX , 页数:16 ,大小:64.20KB ,
资源ID:12914638      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bingdoc.com/d-12914638.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(反走样技术的研究.docx)为本站会员(b****6)主动上传,冰点文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰点文库(发送邮件至service@bingdoc.com或直接QQ联系客服),我们立即给予删除!

反走样技术的研究.docx

1、反走样技术的研究Revised on November 25, 2020反走样技术的研究反走样技术的研究摘要反走样技术是提高光栅图形显示质量的重要技术之一。研究如何消除或减缓走样现象,给人视觉上产生更舒适光滑的图形,在图形界面已成为人机交互主流方式的今天,具有一定的应用价值。在查阅了大量文献资料的基础上,本文从现有的反走样技术(如普通区域取样、普通过取样、加权过取样)入手,对反走样的理论基础和实现技术进行了分析研究。普通区域取样是将直线看成具有一定宽度的狭小矩形,当直线与像素相交时,求出两者相交区域的面积,然后根据相交区域的面积来确定像素的亮度值,从而达到反走样效果。而过取样是在提高分辨率下用

2、点取样方法计算,然后对几个像素的属性进行平均得到较低分辨率下的像素属性。由于需要对每个像素进行处理,因此速度比区域取样明显慢了很多。普通区域取样和过取样都是在整数坐标上进行的,而WU像素反走样算法采用了非整数坐标改进,视觉效果比前两者更好。本文的研究重点在直线段反走样、曲线反走样和图像处理速度方面进行了研究和改进。为了提高过取样的速度,充分利用直线段像素可能存在的多段相似性,算法对其中的一段进行反走样处理后,其余各段只要简单地复制即可,比普通过取样算法明显具有优势,速度提高了很多,也为并行处理提供了可能。在现有的反走样文献中,对曲线反走样提及较少,本文对圆的反走样算法及实现进行了分析探讨,充分

3、利用圆的八对称性,以加权过取样算法为基础在画圆的同时进行反走样。第三方面的工作是如何提高编程实现速度,常用的一种技术是利用Pixels方法,它通过对像素点逐个进行处理,分别对红色、绿色、蓝色分量进行处理来实现图形的反走样。这个方法虽然简单、直观,但处理速度缓慢。通过对Delphi图像处理机制的分析及实验,提出了利用Scnaline方法的改进方案,使处理速度提高到Pixels方法的50倍左右。关键词:反走样,区域取样,过取样本文由天空乐园网整理分享 一、研究背景光栅图形显示器是目前使用最广泛的图形显示器,因为它具有以下优点:光栅扫描显示器具有固定的刷新顺序,扫描从屏幕的左上角开始,从左到右,从上

4、到下的顺序进行刷新,从而刷新控制部件得以简化,节约了成本。在光栅显示系统中,构成图形的最小图形元素是像素,这样只要计算屏幕上位于给定区域以内的所有像素,并且赋予一定的颜色,就完成了图形的绘制。光栅显示器中的图形由像素构成,而每一个像素又可呈现出多级灰度或不同的颜色值,颜色丰富,显示出来的图形具有更好的视觉效果。光栅扫描显示器是一个画点设备,与图形的复杂度无关,刷新频率固定,因此不会象随机扫描显示器那样出现闪烁现象,人眼看上去更舒服。但光栅显示器也有它的缺陷,图形信号是连续的,而光栅显示系统中用来表示图形的却是一个个离散的像素。用离散的像素来表示连续的图形时会出现失真,也就称为走样,如图所示。图

5、锯齿状边界光栅显示系统为何会出现走样呢光栅图形显示器是一个画点设备,被显示的线段、字符、图形及背景色都按像素点一一存储在帧缓冲存储器中。当我们要画一条直线时,它通常不可能完全精确地从一个可编址的像素点画一条直线到另一个可编址的像素点,只可能用尽可能靠近这条直线路径的像素点集来近似地表示这条直线。显然只有画水平线、垂直线时,像素点集在直线路径上的位置才是准确的,其他情况下的直线均或多或少地存在阶梯状(锯齿状)的现象。光栅图形的走样现象除了上述锯齿状边界外,还有图形细节失真,狭小图形遗失等现象。图 图形细节失真在光栅显示器上显示如图(a)所示的细长矩形时,出现了图形细节失真,其结果如图(b)所示,

6、原细长的矩形被显示成了加宽的矩形。图 狭小图形的遗失由于光栅系统中表示图形的最小单位是一个像素,图形中那些比像素更窄的细节丢失了,这就出现了图形细节失真现象。在图中,一些狭小的图形分布在两条扫描线之间,由于它不覆盖任何一个像素中心,故不会被显示出来。当这些狭小的图形进行运动时,覆盖像素中心时被显示出来,不覆盖像素中心时不被显示出来。这样在运动的过程中时隐时现,产生闪烁。为了提高图形的显示质量,需要减少或消除上述走样现象。用于减少或消除这种走样现象的技术,称为反走样(Antialiasing)。研究如何消除或减缓这类走样现象,给人视觉上产生更舒适光滑的图形,在图形界面已成为人机交互主流方式的今天

7、,具有一定的应用价值。反走样技术能提高图形的显示质量,因此在很多画图软件中也采用了这种技术。优软电脑有限公司设计推出的新一代绘画程序-优软精灵画笔,在原有的各种绘画功能上,添加了一系列全新设计的绘画工具;可以打开外来JPG,TAG,TIFF,GIF,BMP文件;更新三维立体窗口系统;对压力感应笔高效率支持,速度和流畅度达到专业软件水准,让用户的体会更加细腻逼真。它的精妙之处在于具有细笔尖反走样功能,所以使细笔画更细致更漂亮。反走样技术不仅能提高图形显示质量,而且在反走样汉字方面也有很好的效果。由于汉字的笔画很多,而且大多数非水平非垂直,也会产生较严重的走样现象。图中第1 个字为追踪出的轮廓,第

8、2 个为显示的原始矢量字符。第3 个为反走样处理后的矢量字符。图矢量字体轮廓的反走样由此可见,反走样技术在实际应用中有十分重要的意义。另外, 在处理纹理图形, 以及在动画中闪烁的细小物体图形等问题中反走样技术都得到了广泛运用。二、反走样技术概述在光栅显示器上显示图形时,直线段或图形边界或多或少会呈锯齿状。原因是图形信号是连续的,而在光栅显示系统中,用来表示图形的却是一个个离散的象素。这种用离散量表示连续量引起的失真现象称之为走样(aliasing),走样是伴随着光栅显示系统而出现的,也是数字化的必然产物。用于减少或消除这种效果的技术称为反走样(antialiasing)。第一章中已经介绍了光栅

9、图形的走样现象除了阶梯状的边界外,还有图形细节失真(图形中的那些比象素更窄的细节变宽),狭小图形遗失等现象。常用的反走样方法主要有:提高分辨率、区域采样和加权区域采样等。下面将对他们进行介绍。 过取样技术 反走样的方法很多,一种简单的反走样方法是以较高的分辨率显示对象,如图。假设把显示器分辨率提高一倍,直线经过两倍的象素,锯齿也增加一倍,但同时每个阶梯的宽度也减小了一倍,所以显示出的直线段看起来就平直光滑了一些。这种反走样方法是以4倍的存储器代价和扫描转换时间获得的。因此,增加分辨率虽然简单,但是不经济的方法,而且它也只能减轻而不能消除锯齿问题。但是它的思想给我们以后的反走样方法一定的启示。图

10、 提高显示分辨率一种可行的反走样方法:在较高分辨率下用点取样方法计算,然后对几个像素的属性进行平均得到较低分辨率下的像素属性。这种技术称为过取样(Supersampling),或后滤波(Postfiltering)。该技术是把显示器看成是比实际更细的网格来增加取样率,然后根据这种更细的网格使用取样点来确定每个屏幕像素合适的亮度等级。 反走样的另一种方法是根据图形对象在每个像素点上的覆盖程度率来确定像素点的亮度,这种计算覆盖率的反走样技术称为区域取样(Area Sampling),或前滤波(Prefiltering)。 提高分辨率方法过取样方式的一个简单实现是用较高的分辨率进行计算,如图,在x方

11、向和y 方向上把分辨率提高一倍,使每个像素都对应4个子像素,然后扫描转换求得各子像素的颜色亮度,在对4个像素的颜色亮度进行平均,得到较低分辨率下的像素颜色亮度。由于像素中可供选择的子像素最大数目是4,因此,该例中提供的亮度等级数是5。如图中,编号为1和7的像素亮度级别是1,编号为2,3,4,5和6的像素亮度是2。通过这个方法为图中的每个像素设定不同的灰度值,可以使显示出来的直线看起来平滑一些,达到减少走样现象。6753412图 简单的过取样方式另一种过取样方式(重叠过取样),如图,假设显示器分辨率为m*n,其中m=4,n=3,首先把显示窗口划分为(2m+1)*(2n+1)个像素,然后通过扫描转

12、换求得各子像素的颜色值,在对为于子像素中心及四周的9个子像素的颜色值进行平均,最后得到显示像素的颜色亮度值。 由于接近像素区域中心的子像素在决定像素的颜色亮度值中发挥着重要的作用,因此过取样算法中采用了加权平均的方法来计算显示像素的颜色亮度值(基于加权模板的过取样)。图示出了3*3像素分割常采用的加权模板。中心子像素的权是角子像素的4倍,是其他子像素的2倍,中心子像素的加权系数是1/4,顶部和底部及两侧子像素的加权系数是1/8,而角子像素的加权系数是1/16。000000000000121242121 图 另一种过取样方式图 图 加权模板过取样的一种简单方法就是在较高的分辨率下进行计算,扫描转

13、换求得各子像素的颜色亮度,然后对子像素的颜色亮度进行平均,得到较低分辨率下的像素颜色亮度。由于接近像素区域中心的子像素在决定像素的颜色亮度值中发挥着重要的作用,因此过取样的另一种算法采用了加权平均的方法来计算显示像素的颜色亮度值。不管是哪一种方法都需要在内存中建立一个比现在大几倍的图,便于对像素取样,取得像素的亮度值。区域取样直线段扫描转换算法均假定像素是数学上的一个点,像素颜色是由对应于像素中心的图形中一点的颜色决定的;并且直线段是数学上抽象的直线段,它的宽度是0。但实际上像素不是一个点,而是一个有限区域。屏幕上所画的直线不是数学意义上的无宽度的理想线段,而是一个宽度至少为一个像素单位的线条

14、。算法中所假定的条件和实际情况之间的差距是造成走样的原因之一。为了减少走样,必须改变直线段的模型,从而得到了简单区域取样的方法,这个方法的具体步骤是:(1)将直线看成具有一定宽度的狭小矩形;(2)当直线与像素相交时,求出两者相交区域的面积;(3)根据相交区域的面积,确定像素的亮度值; 图 具有一定宽度的直线 图 灰度与面积成比例通过将每个像素亮度设置成与线条部分重叠的区域面积成正比,可以完成对直线的区域取样。若一个像素与线条部分重叠,根据重叠区域面积的大小来选择不同的灰度。重叠面积大的像素黑一点,重叠面积小的像素白一点。这种方法将产生模糊的边界,以次来减轻锯齿效应。图是待显示的直线段,图是采用

15、简单区域取样方法绘制的结果。这个方法中,起关键作用的是直线段与像素相交区域面积的计算。那么相交区域如何计算呢假设一条直线的斜率是m,若规定它的显示宽度是一个像素,那么直线和像素的相交有如下三种情况,如图所示。其中(c)的计算可转化为正方形面积减去两个三角形面积。接下来介绍(a)和(b)两种情况。 (a) (b) (c)图 直线段与像素相交的三种情况在图(a)中,假设三角形x方向上的边长为D,则y方向上的边长为mD,从而三角形的面积为.在图(b)中,假设梯形左底边长为D,则右底边长为D-m,从而梯形的面积为;所得到的面积介于0,1之间的实数,用它乘以像素的最大灰度值,即可得到像素实际显示的灰度值

16、。上面的计算十分的麻烦,为了简化计算,可以采用下面的离散方法:(图 (1)将屏幕像素分割成n个更小的子像素;(2)计算中心点落在直线内的子像素的个数,记为k;(3)k/n为线段与像素相交区域的近似值; 图 n=16,k=3,近似面积为3/16综上所述,非加权区域采样方法具有下面三条性质: (1)直线对一个像素亮度的贡献与两者相交区域的面积成正比,从而和直线与像素中心点的距离成反比。因为直线距像素中心越远,相交区域的面积越小。 (2)当直线和一个像素不相交时,它对该像素的亮度没有影响。 (3)相同面积的相交区域对像素的亮度贡献相同,而与这个相交区域落在像素内什么位置无关。 加权区域取样简单区域取

17、样由于相同面积重叠区域对像素的贡献相同,但是这样仍然会出现走样现象,接下来介绍的加权区域取样对此进行了改善,使得相交区域对像素亮度的贡献依赖于该区域与像素中心的距离。对于相同面积的相交区域,当它距离像素中心近时,它对像素亮度的贡献大,当它距离像素中心远时,对像素亮度贡献小。这种方法更符合人的视觉系统对图象信息的处理方式。 加权区域取样的特点:一是接近理想直线的像素将被分配更多的灰度值;二是相邻两个像素的滤波器相交,所以直线条经过该相交区域时,将对这两个像素都分配给适当的灰度值,这样就缩小了直线条上相邻像素的灰度差。加权区域取样方法的具体步骤如下:(1)求直线段与过滤器底面的重叠区域S。(2)计

18、算 的值,其中f(x,y)是过滤函数,S是过滤器的底面,且有 =1 。(3)上面得到的值介于0和1之间,用它乘以像素的最大灰度值,即得到该像素显示灰度值。求积分的运算量是很大的,为了方便计算,可以利用加权区域取样的离散计算方法:(1)将屏幕像素均匀分割成n个子像素,Siin=1,则每个子像素的面积为 ,计算每个子像素对原像素亮度的贡献, 将fi=1保存在加权表中。(2)求出所有中心落在直线段内的子像素的集合F。(3)计算所有这些子像素对原像素亮度的贡献之和。该值乘以像素的最大灰度值即为像素的显示灰度值。 根据上面的讨论,fi是一个经验值,因此我们可以根据经验直接设定fi的值。例如,我们将屏幕像

19、素划分为n=3*3=9个子像素,加权表可取作 有些反走样方法把像素当作是数学上的一个点,像素颜色是由对应于像素中心的图形中一点的颜色决定的;而区域取样认为像素不是一个点,而是一个有面积的区域,因此我们在区域取样时要计算直线段与像素相交区域的面积,然后根据相交区域面积来确定像素的亮度值。由于直线与像素相交的形式有三种,那么我们如何来判断直线与像素相交的形式呢图 区域取样示意图如图所示,设直线段与某像素纵列相交区域下顶点的y坐标为yl,m为该直线的斜率,y5是扫描线y+。如果yl+my5,则说明直线和像素的相交区域是由上中下三个相邻像素中的两个三角形和一个四边形组成,否则相交区域是由上下两个相邻像

20、素中的两个梯形组成。然后计算出相交区域的面积就可以得到每个像素的亮度,从而达到反走样直线,而且反走样的效果也十分的好。 WU像素反走样 WU反走样普通的Breshenham算法画线很快,但并不是很精细.通常的整数画线因为只能在整数坐标上绘图,所以产生难看的锯齿.介绍的WU像素反走样算法就采用了非整数坐标改进它,效果也十分的好。 一条经过wu反走样的直线要比一条普通的直线要好,产生光滑的边界,。如图所示。 图 普通直线和WU反走样直线的对比在WU反走样算法中,有一个重要的概念就是WU像素。WU像素具有两个属性:1、绘制的所有像素的亮度的总和等于原始的粒子的亮度。2、WU像素的中心亮度被定位在原始

21、粒子的非整数位置。根据WU像素的这两个属性我们就可以实现WU反走样直线。 WU反走样直线算法理想的反走样算法将计算每条线覆盖的精确区域,从区域可以得到像素的灰度值,从而达到反走样的效果。WU反走样直线不是这样做,而是跨骑着直线绘制一对像素。一个主循环将沿着直线的长度画一对像素,端点的像素对将被分别计算处理,如图所示。 图 跨骑着直线的像素对 图 亮度设置跨骑直线的像素对中,两个像素的亮度应该都是1,中心点的亮度就是理想直线的亮度。直线上的像素的亮度必须于(1-a)成比例,线下面的像素的亮度必须与(1-b)成比例。也就是说越靠近直线的像素应该越亮。沿着直线长度画这样的像素对,就可以得到一条WU反

22、走样直线。在画完了中间端点后,我们要画起始端点和终结端点,如图所示。可以看到直线的一个端点,用红色的点来表示,蓝色的点表示像素的中心点。你可以看到,顶点不在像素的中心点上,那么如何计算直线端点的两个像素的正确亮度呢方法就是把直线延长(向后或向前)到最近的整数x坐标(p),像计算直线上普通的像素对的亮度一样计算这些像素对。然后,因为直线只是覆盖这个像素的很小一部分xgap,直线将降低它的亮度,所以亮度应该乘上xgap。因此,当整条直线向右移动, xgap将变小,使得这个像素对平滑的变暗,按照这个方法可以画出两个端点。上面讲的是abs(xd)abs(yd)的情况,其实abs(xd)1,则仅需计算d

23、x/m个像素后就会出现dk=0;若计算达到dx的一半时仍未遇到精确落在直线上的像素,则由性质1可知m=1,从而利用性质2进行对称复制。这样的话比普通的反走样直线算法明显具有优势,速度提高了很多。圆反走样算法圆反走样算法只需考虑圆心位于坐标原点的圆弧反走样,对于圆心为任意点的圆弧,可以先将其平移到原点,然后反走样,再平移到原来的位置上。圆心位于原点的圆有四条对称轴x=0,y=0,x=y,x=-y,如图所示。因此只要知道圆弧上的一点(x,y)就可以得到它的七个对称点,也称为圆的八对称性。因此我们只要反走样八分之一圆弧其余的都可以对称得到反走样。圆的每一个八分之一圆弧都是由一段段的水平线段组成,因此

24、圆弧反走样的问题就是反走样一段段小的水平线段的问题。图圆的八对称性算法首先分析圆的特殊性,也就是圆具有八对称性,在画圆的同时进行反走样。总之,算法充分利用圆的八对称性,以加权过取样算法基础下图是圆反走样算法的部分效果实现图:图圆反走样效果 位图反走样对位图进行反走样,原理很简单,就是将原图放大三倍以后进行像素点间的平均操作,也就是目标像素点周围的8个像素点加上自己这个像素点共9个像素点的红色分量的总和,然后取平均值,在赋给目标像素中的红色分量。同理,绿色分量和蓝色分量也类似处理。在这里用了两种方法可以实现此操作,一个就是直接用像素点进行操作,另一个就是Scanline方法。虽然这两种方法的实现

25、原理是一样的,但是在速度上改进的Scanline方法明显要比直接用像素点进行操作的方法快。1)利用Pixels方法的实现技术这是直接通过像素点的操作,对像素点逐个进行处理,分别得到红色、绿色、蓝色分量来反走样图形。这个方法虽然实现十分简单,但是处理的速度十分的慢,需要相当长的一段时间。2)利用Scnaline方法的的实现技术 用Scnaline方法大大提高了速度,一般是直接像素点操作的50倍左右。Pixels方法是采用直接对每个像素点进行操作,在反走样的过程中逐个像素点反走样,它实现的时间是2003毫秒。而采用Scanline方法是逐行对像素进行操作,它实现的时间是30毫秒,速度明显提高了将近60倍。四、小 结本文通过阅读大量文献资料,对走样和反走样技术有了较深的认识。在分析讨论了反走样理论知识的基础上,本文实现了普通区域取样、普通过取样、加权过取样、WU反走样算法。普通区域取样是将直线看成具有一定宽度的狭小矩形,当直线与像素相交时,求出两者相交区域的面积,然后确定像素的亮度值,达到反走样效果。过取样是在较高分辨率下用点取样方法计算,然后对几个像素的属性进行平均得到较低分辨率下的像素属性。由于是对每个像素进行平均值计算,因此速度明显慢了很多。通常的反走样都是在整数坐标上进行的,而WU像素反走样算法就采用了非整数坐标改进,效果十分的好。上面的几

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2