这里不仔细讲原理,只是把我写的算法发出来,跟大家分享下,如果有错误的话,还请大家告诉我,如果写的不好,也请指出来,一起讨论进步。

算法步骤:

(1) 输入椭圆的长半轴a和短半轴b。

(2) 计算初始值d = b*b + a * a * (-b + 0.25),  x = 0, y = b。

(3) 绘制点 (x, y)及其在四分象限上的另外3个对称点。

(4) 判断d的符号。若d <= 0,则先将d更新为d + b * b * (2 * x + 3),再将 (x, y)更新为(x+1, y);否则先将d更新为d + b * b * (2 * x + 3) + a * a (-2 * y + 2),再将(x, y)更新为(x+1, y-1)。

(5) 当b*b * (x+1) < a * a * (y - 0.5)时,重复步骤(3)和(4),否则转到步骤(6)。

(6) 用上半部分计算的最后点(x, y)来计算下半部分中d的初值: d = b * b * (x + 0.5) * (x + 0.5) + a * a * (y - 1) * (y - 1) - a * a * b * b。

(7) 绘制点(x, y)及其在四分象限上的另外3个对称点。

(8) 判断d的符号。若d <= 0,则先将d更新为d + b * b * (2 * xi + 2) + a * a * (-2 * yi + 3), 再将(x, y)更新为(x+1, y-1);否则先将d更新为d + a * a * (-2 * yi + 3),再将(x, y)更新为(x, y-1)。

(9) 当y >= 0, 重复步骤(7)和(8),否则结束。

下面是算法:

#include <GL/freeglut.h>
void init (void)
{
glClearColor (0.0f, 0.0f, 0.0f, 1.0f);
} void drawEllipse (int a, int b, int xLoc, int yLoc)
{
glPushMatrix ();
int x, y;
float d1, d2, aa, bb;
aa = a * a;
bb = b * b;
d1 = bb + aa * (-b + 0.25);
glTranslatef ((GLfloat) xLoc, (GLfloat) yLoc, 0.0f);
x = 0;
y = b;
glBegin (GL_POINTS);
glVertex2i ( x, y);
glVertex2i (-x, y);
glVertex2i (-x, -y);
glVertex2i ( x, -y);
while (bb * (x + 1) < aa * (y - 0.5))
{
if (d1 <= -0.000001)
{
d1 += bb * ((x << 1) + 3); }
else
{
d1 += bb * ((x << 1) + 3) + aa * (2 - (y << 1));
-- y;
}
++ x;
glVertex2i ( x, y);
glVertex2i (-x, y);
glVertex2i (-x, -y);
glVertex2i ( x, -y);
}
d2 = bb * (0.25 * x) + aa * (1 - (y << 1));
while (y > 0)
{
if (d2 <= -0.000001)
{
++ x;
d2 += bb * ((x + 1) << 1) + aa * (3 - (y << 1));
}
else
{
d2 += aa * (3 - (y << 1));
}
-- y;
glVertex2i ( x, y);
glVertex2i (-x, -y);
glVertex2i (-x, y);
glVertex2i ( x, -y);
}
glEnd ();
glPopMatrix ();
} void display (void)
{
glClear (GL_COLOR_BUFFER_BIT);
glLoadIdentity ();
glColor3f (1.0f, 0.0f, 0.0f);
// draw a ellipse
drawEllipse (200, 300, 50, 50);
glutSwapBuffers ();
} void reshape (int w, int h)
{
glViewport (0, 0, (GLsizei) w, (GLsizei) h);
glMatrixMode (GL_PROJECTION);
glLoadIdentity ();
if (w <= h)
{
gluOrtho2D (-600.0, 600.0, -600.0 * (GLfloat) h / (GLfloat) w, 600.0 * (GLfloat) h / (GLfloat) w);
}
else
{
gluOrtho2D (-600.0 * (GLfloat) w / (GLfloat) h,600.0 * (GLfloat) w / (GLfloat) h, -600.0, 600.0);
}
glMatrixMode (GL_MODELVIEW);
glLoadIdentity ();
}
void keyboard (unsigned char key, int x, int y)
{
switch (key)
{
case 27: // 'VK_ESCAPE'
exit (0);
break;
default:
break;
}
}
int main (int argc, char ** argv)
{
glutInit (&argc, argv);
glutInitDisplayMode (GLUT_DOUBLE | GLUT_RGB);
glutInitWindowSize (600, 600);
glutCreateWindow ("Bresenham ellipse");
init ();
glutReshapeFunc (reshape);
glutDisplayFunc (display);
glutKeyboardFunc (keyboard);
glutMainLoop ();
return 0;
}

最新文章

  1. Python3.5 day3作业一:实现简单的shell sed替换功能
  2. 浅谈Java中的equals和==
  3. 离屏渲染学习笔记 /iOS圆角性能问题
  4. 【CImg】三角形绘制算法实现
  5. 学习 AngularJS 第一天
  6. How to use BMW Multi Tool 7.3 to replace lost key for BMW X1
  7. oracle安装,配置,启动
  8. Csharp多态的实现(抽象类)
  9. box-sizing:content-box
  10. SQL sever 创建定时执行任务
  11. Android Studio 连接真机调试
  12. 史上最简单的MySQL安装教程之Linux(CentOS6.8)下安装MySQL5.6
  13. MongoDB学习笔记(一)
  14. Linux常用的网络命令
  15. 【CSS学习】--- 字体样式
  16. 2018-2019-2 20165315 《网络对抗技术》Exp3 免杀原理与实践
  17. redis调优的实战经验
  18. EF 数据类型 0xA7 的数据长度或元数据长度无效
  19. 2018.09.18 atcoder Many Formulas(搜索)
  20. js操作符类型转换

热门文章

  1. vijos1034题解
  2. Mac之OS系统下搭建JavaEE环境 &lt;三&gt; 之Eclipse 与 IntelliJ IDEA 的安装配置
  3. JavaWeb 后端 &lt;八&gt; 之 JDBC基礎(全)
  4. MySQL oracle 分页
  5. Abp(.NetCore)开发与发布过程
  6. ABAP,学习不一样的EXCEL导出----XLSX Workbench
  7. ibatis 架构
  8. iOS 使用 socket 即时通信(非第三方库)
  9. 一次浴火重生的MySQL优化(EXPLAIN命令详解)
  10. MySQL系列(四)---引擎