本文主要是介绍华科_图形学笔记_0402_图形思维的起点_朴素的软光栅(二)_01,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
计算机图形学_华中科技大学_中国大学MOOC(慕课)
4.2.1_如果是圆?(上):八分法画圆
圆的扫描转换算法
圆心位于原点的扫描转换

圆心在任意一点
圆具有非常良好的对称性

如果我们得到了其中一段圆弧的上面的像素点,就可以通过对称的方法,得到另外的7个点
于是要得到整个圆的扫描转换的像素集,只需要扫描转换1/8段圆弧即可,这就是 八分法画圆

用简单的方程生成圆弧,利用函数方程,直接离散计算

X是最大位移方向

在绘制这1/8圆弧的时候,X每次走一步,而Y方向上怎么走步,需要靠公式来计算

利用极坐标方程,直接离散计算

这里的δθ为一个固定角度的步长,可以灵活的进行设定
使用这个方法,以固定角度为步长的时候,就可以沿着圆周等距把这个圆弧的上面的点绘制出来,这个时候θ的步长的选择就可以根据应用和显示的需要来灵活的选择

当然步长选的很小的时候,它这个圆弧看起就圆滑一些

两种计算方法

4.2.2_如果是圆?(上):中点画圆法
中点画圆法画法思想分析
问题描述:绘制x ^2+y ^2 = R ^2

对直线中点Bresenham画法的联想

圆的隐式方程F(X,y) = x^2 + y^2 - R^2

问题的简化:只考虑这1/8段圆弧

中点Bresenham画圆法
X每次增加1,y减少1或者不变

仍然把中点拿出来


在这里约定取 Pu

构造出判别式
这个判别式其实就是把中点的坐标带入这个圆的隐式方程F中

进行误差项的递推
第一种情况d<=0,取 Pu

第二种情况d>0,取 Pd

d的初值 判别式的初值是1.25-R

由于使用的只是d的符号,这里可以有一个巧妙的替代,用d-0.25来代替d,这样来摆脱小数


直接改为d和0的比较,也就是判断d的符号

得到中点Bresenham算法画圆的步骤



中点Bresenham算法画圆的程序

4.3_椭圆又如何?:椭圆的重点Bresenham算法
提纲

椭圆中点画法思想分析
通常定义椭圆是到两个定点距离之和等于常数点的集合
为了简化起见,中心落在坐标原点的标准椭圆

得到一个椭圆的函数


椭圆的对称性
椭圆不具备圆形这么好的对称性,但是也是关于x,y轴对称的



由微分的知识,我们可以得到椭圆上一个点X,Y处法向量的表示



对上下两个部分进行公式推导




有了递推还是要回到d1的初值



椭圆中点Breseham算法


在椭圆弧的绘制中,还有两个问题需要注意

从上半部分转入下半部分

刚转入下半部分的时候,需要对下半部分的中点的初值来进行计算

算法步骤



步骤6进行了下半部分


仍然要根据d的符号来判断该怎么取点,以及d本身该怎样进行增量计算


最后实例

这篇关于华科_图形学笔记_0402_图形思维的起点_朴素的软光栅(二)_01的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!