计算机图形学(二)输出图元_6_OpenGL曲线函数_3_椭圆生成算法

椭圆生成算法

非严格地说,椭圆是拉长了的圆。还可以说椭圆是经过修改的圆,它的半径从一个方向的最大值变到其正交方向的最小值。椭圆内部这两个正交方向的直线段称为椭圆的长轴和短轴。

椭圆的特征

通过椭圆上任一点到称为椭圆焦点的两个定点的距离可给出椭圆的精确定义:椭圆上任一点到这两点的距离之和都等于一个常数(参见图3.21 )。如果椭圆上的任一点P = (x,y)到两个焦点的距离为d1和d2,那么椭圆的通用方程可以表示为

用焦点坐标F1=(x1,y1)和F2 = (x2,y2)来表示距离d1和d2,可以得到

对方程求平方,去除剩余的根,再平方,可以按照下列形式重写通用椭圆方程:

其中,系数A, B, C, D,E, F依据焦点坐标和长轴及短轴的尺寸而求得。长轴是通过焦点从椭圆的一侧到另一侧的线段。短轴是横跨椭圆的较短尺寸,它在两个焦点之间的中点位置(椭圆中心)将长轴二等分。

在任意方向指定一个椭圆的交互方法是输入两个焦点和椭圆边界上一个点。利用这三个坐标位置,就可以求出方程(3.35)中的常数。然后就可以求出方程(3.36)中的系数,并利用其生成沿椭圆路径的像素。

如果短轴和长轴与坐标轴方向平行,那么椭圆方程就可以大大简化。图3.22给出了一个“标准位置”的椭圆。长轴和短轴平行于x和y轴。此例中参数rx标识长轴,参数ry标识短轴。对于图3.22中的椭圆方程,可以借助于椭圆中心坐标和参数rx和ry而改写为

利用极坐标:r和θ,也可以按照参数方程的形式来描述标准位置的椭圆:

称为椭圆离心角(eccentricangle)的θ沿其包围圆的圆周进行计量。如果rx> ry,包围圆的半径是r = rx(参见图3.23 ),否则,包围圆的半径是r = ry

和圆的算法一样,考虑椭圆的对称性可以进一步减少计算量。标准位置的椭圆在四分象限中是对称的但与圆不同,它在八分象限中不是对称的。因此,我们必须计算一个象限中椭圆曲线的像素位置,再由对称性得到其他三个象限中的像素位置(参见图3.24 )。

时间: 2024-10-06 22:31:05

计算机图形学(二)输出图元_6_OpenGL曲线函数_3_椭圆生成算法的相关文章

计算机图形学(二)输出图元_6_OpenGL曲线函数_1_圆生成算法

OpenGL曲线函数 生成圆和椭圆等基本曲线的函数并未作为图元功能包含在OpenGL核心库中.但该库包含了显示Bezier样条的功能,该曲线是由一组离散点定义的多项式.OpenGL实用库(GLU)中包含有球面和柱面等三维曲面函数以及生成B样条的函数,它是包含简化Bezier曲线的样条曲线的总集.我们可以使用有理B样条显示圆.椭圆和其他二维曲线.此外,OpenGL实用工具包(GLUT)中还有可以用来显示某些三维曲面(如球面.锥面和其他形体)的函数.然而,所有这些函数比本章中介绍的基本图元应用得更多

计算机图形学(二)输出图元_6_OpenGL曲线函数_5_其他曲线

其他曲线 许多曲线函数在对象建模.动画轨迹的描述.数据和函数的图形化以及其他图形应用中是十分有用的.常见的曲线包括圆锥曲线.三角和指数函数.概率分布.通用多项式和样条函数.这些曲线的显示可采用类似于前面讨论的圆和椭圆函数来生成.沿曲线轨迹的位置可直接从表达式y =f (x)或参数方程中得到.此外,还可以使用增量中点算法绘制用隐式函数f(x,y) = 0描述的曲线. 显示一指定的曲线函数的简单方法是使用直线段来逼近曲线.这时,对于要得到沿曲线轨迹的等距线段的端点位置,则可以使用参数表达式.也可以按

计算机图形学(二)输出图元_6_OpenGL曲线函数_2_中点画圆算法

中点画圆算法 如同光栅画线算法,我们在每个步中以单位间隔取样并确定离指定圆最近的像素位置.对于给定半径r和屏幕中心(xc,yc),可以先使用算法计算圆心在坐标原点(0, 0)的圆的像素位置,然后通过将xc加到x且yc加到y.从而把计算出的每个位置(x,y)移动到其适当的屏幕位置.在第一象限中,圆弧段从x = 0到x = y,曲线的斜率从0变化到-1.0.因此,可以在该八分圆上的正x方向取单位步长,并使用决策参数来确定每一步两个可能的y位置中,哪一个更接近于圆的位置.然后,其他七个八分圆中的位置可

计算机图形学(二)输出图元_6_OpenGL曲线函数_4_中点椭圆算法(上)

中点椭圆算法(上) 这里的方法类似于显示光栅圆.给定参数rx,ry和(xc,yc),首先确定以原点为中心的标准位置椭圆上的点(x,y),然后将这些点平移到以(xc,yc)为中心的椭圆上.如果希望显示不在标准位置的椭圆,那么就绕中心坐标旋转并对长轴和短轴重新定向.但目前仅考虑显示标准位置的椭圆,第4章将讨论变换对象方向和位置的通用方法. 中点椭圆算法将分成两部分应用于第一象限.图3.25给出了依据rx<ry的椭圆斜率对第一象限进行的划分.并通过在斜率绝对值小于1的区域内在x方向取单位步长,以及在斜

计算机图形学(二)输出图元_16_字符函数

OpenGL 字符函数 OpenGL基本库仅为显示单个字符和文字串提供了基本的支持.我们可以定义图3.61中的位图字符,并将一个位图集作为字库存储.一个文字串通过将从字库中选择的位图序列映射到帧缓存的 相邻位置来显示. 但是,OpenGL实用函数工具包(GLUT)中有一些预定义的字库.因此我们不用创建自己的位图字型库,除非需要显示GLUT中没有的字体.GLUT子程序可显示位图和轮廓字体.GLUT位图字体由OpenGL的glBitmap函数来绘制,而轮廓字体由折线边界(GL_LINE_STRIP)

计算机图形学(二)输出图元_18_显示列表_3_删除 OpenGL 显示表

删除 OpenGL 显示表 要删除连续的一组显示表,可调用函数: glDeleteLists (startID, nLists); 参数startID给出最前面的显示表标识,而参数nLists给出要删除的显示表总数.例如,语句: glDeleteLists (5, 4); 删除4个显示表,其标识为5, 6, 7和8.没有显示表对应的标识被忽略.

计算机图形学(二)输出图元_7_并行曲线算法

并行曲线算法 在曲线生成中使用的并行方法类似于显示线段中使用的方法.我们既可采用顺序算法按曲线分段分配处理器,也可以提出其他方法将处理器分配给屏幕的不同区域. 显示圆的并行中点方法是,将45°到90°的圆弧分成等长子圆弧,并给每段子圆弧配置一个处理器.然后类似于并行Bresenham画线算法,需要对每个处理器建立初始y值并确定参数pk的值.接着计算整个子圆弧的像素位置,并通过对称性得到其他八分圆中的位置.同样,并行椭圆中点算法将第一象限内的椭圆弧分割成等长弧,并将这些弧分配给各个处理器,在其他象

计算机图形学(二)输出图元_20_章节总结(上)

输出图元章节总结 发了好久第2章终于结束了,本章中讨论的输出图元为使用直线.曲线.填充区域.单元阵列样式和文本构造图形提供了基本的工具.我们通过在笛卡儿世界坐标系统中给出几何描述来指定图元. 用于沿线段路径绘制像素的三种方法是DDA算法.Bresenham算法和中点算法,Bresenham算法和中点算法是等同的并且是最有效的.沿线段路径的像素的颜色位存储按照递增地计算内存地址的方式而有效完成.任何线段生成算法都可以通过分割线段并将分割的线段分布到可用处理器上来获得并行的实现. 圆和椭圆采用中点算

计算机图形学(二)输出图元_10_多边形填充区_1_多边形分类和识别

多边形填充区 一个多边形(polygon)在数学上定义为由三个或者更多称为顶点的坐标位置描述的平面图形,这些顶点由称为多边性的边(edge或者side)顺序连接.进一步来看,几何上要求多边形的边除了端点之外没有其他公共点.因此,根据定义,一个多边形在其单一平面上必须有其所有的顶点且边之间无交叉.多边形的例子有三角形.矩形.八边形和十六边形等.有时,任一有封闭折线边界的平面图形暗指一个多边形,而若其没有交叉边则称为标准多边形(( standard polygon)或简单多边形( simple po