Bresenham画椭圆算法

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

算法步骤:

(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 ellipsedrawEllipse (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;
}

 

转载于:https://www.cnblogs.com/tangshiguang/p/6748361.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/429379.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

iOS MD5 (消息摘要算法5)

一、MD5定义 MD5即Message-Digest Algorithm 5&#xff08;消息-摘要算法5&#xff09;&#xff0c;为计算机安全领域广泛使用的一种散列函数&#xff0c;用以提供消息的完整性保护&#xff08;又译摘要算法、哈希算法&#xff09;&#xff0c;主流编程语言普遍已有MD5实现。…

“每日一道面试题”.Net中所有类的基类是以及包含的方法

闲来无事&#xff0c;每日一贴。水平有限&#xff0c;大牛勿喷。 .Net中所有内建类型的基类是System.Object毋庸置疑 Puclic Class A{}和 Public Class A&#xff1a;System.Object{}是等效的 System.Object包含了Finalize在内的8个方法。 公共实例方法&#xff1a; Virtual b…

JAVA怎么将整数反转_【leetcode刷题】[简单]7.反转整数(reverse integer)-java

反转整数 reverse integer题目给定一个 32 位有符号整数&#xff0c;将整数中的数字进行反转。示例 1:输入: 123输出: 321示例 2:输入: -123输出: -321示例 3:输入: 120输出: 21注意:假设我们的环境只能存储 32 位有符号整数&#xff0c;其数值范围是 [− 2^31, 2^31 − 1]。根…

Linux实战案例(2)实例讲解使用软连接的场景和过程

使用场景&#xff1a;使用软连接简化版本切换动作 进入操作目录&#xff0c; cd /opt/modules/ 1、创建软连接ln -s jdk1.8.0_131 jdk1.8ln -s spark-2.1.0-bin-hadoop2.7 sparkln -s hadoop-2.7.3 hadoop 2、删除软连接rm -rf hadooprm -rf sparkrm -rf jdk1.8 3、验证结果 …

java单车吧_暑假一个月,撸个共享单车后台

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼加解密差不多了&#xff0c;下一步开始写登录了。//先对称加密 key 和数据String key "j783420jfjyqalgr";String data "周"; // FBI通缉人 周String encrypt AESUtil.encrypt(data, key); // 向服务器传输…

KVM虚拟化技术之使用Qemu-kvm创建和管理虚拟机

一 .KVM 简介 KVM &#xff08;名称来自英语&#xff1a; Kernel-basedVirtual Machine 的缩写&#xff0c;即基于内核的虚拟机&#xff09; &#xff0c; 是一种用于Linux内核中的虚拟化基础设施&#xff0c;可以将Linux内核转化为一个hypervisor。KVM在2007年2月被导入Li…

java序列化写法_java-spark的各种常用算子的写法

通常写spark的程序用scala比较方便&#xff0c;毕竟spark的源码就是用scala写的。然而&#xff0c;目前java开发者特别多&#xff0c;尤其进行数据对接、上线服务的时候&#xff0c;这时候&#xff0c;就需要掌握一些spark在java中的使用方法了一、mapmap在进行数据处理、转换的…

python 如何在一个for循环中遍历两个列表

是我在看《笨方法学python》过程中发现有一行代码看不懂——“ for sentence in snippet, phrase:”&#xff0c;所以研究了半天&#xff0c;感觉挺有收获的。所以就放在博客上分享给大家了。 直入主题&#xff1a; 为了不耽误大家时间&#xff0c;如果知道以下为两段代码为什么…

画王八java代码参数_java画乌龟源代码-郭遥航.doc

java画乌龟源代码-郭遥航.doc /*JAVA基本功小练习用java语言描述小王八用鼠标可以拖动小乌龟进行移动选中乌龟时可以显示小乌龟的腹面*/importjava.awt.*;importjavax.swing.*;importjava.awt.event.MouseMotionListener;importjava.awt.event.MouseListener;importjava.awt.ev…

Longest Substring With At Most K Distinct Characters

Given a string, find the length of the longest substring T that contains at most k distinct characters. For example, Given s “eceba” and k 2, T is "ece" which its length is 3. Analyses: Map each character in the string into a index in an arra…

java不同环境_Spring Boot系列 – 5. 不同的环境使用不同的配置

SpringBoot系列-5.不同的环境使用不同的配置数据库spring boot中&#xff0c;可以通过在application.yml配置文件中&#xff0c;配置多个不同的profile&#xff0c;实现在不同的环境(比如开发、测试和生产环境)使用不同的配置变量。具体配置如下(application.yml中的内容)&…

SQL Server的WAITFOR DELAY注入

SQL Server的WAITFOR DELAY注入WAITFOR是SQL Server中Transact-SQL提供的一个流程控制语句。它的作用就是等待特定时间&#xff0c;然后继续执行后续的语句。它包含一个参数DELAY&#xff0c;用来指定等待的时间。如果将该语句成功注入后&#xff0c;会造成数据库返回记录和Web…

java服务注册中心有哪些_Spring Cloud服务注册中心简述

概念当一个大型系统拥有很多服务时&#xff0c;往往需要一个服务注册中心来管理这些服务&#xff0c;它可以提供如下功能&#xff1a;登记每个服务提供的功能检测每个服务是否可用&#xff0c;不可用的服务剔除服务间互相调用时&#xff0c;通过服务注册中心很容易找到目标服务…

如何监听RecyclerView划到最后一条数据

实现代码&#xff1a;//RecyclerView的滑动监听mRecyclerView.addOnScrollListener(new RecyclerView.OnScrollListener() { //当RecyclerView滑动时触发 Override public void onScrolled(RecyclerView recyclerView, int dx, int dy) { super.onScrolled(rec…

java小白会有那些工作_Java小白找工作与学习的第四天

昨天没有更新&#xff0c;其实很大一部分原因是我写了这么多字的简书&#xff0c;竟然没有一个人看&#xff0c;确实感觉不太对劲&#xff0c;但是我今天又想开了&#xff0c;我是要为自己学习的&#xff0c;不一定要他人的鼓励下才能继续学习&#xff0c;要享受一个人的孤独&a…

JavaScript原生对象及扩展

来源于 https://segmentfault.com/a/1190000002634958 内置对象与原生对象 内置&#xff08;Build-in&#xff09;对象与原生&#xff08;Naitve&#xff09;对象的区别在于&#xff1a;前者总是在引擎初始化阶段就被创建好的对象&#xff0c;是后者的一个子集&#xff1b;而后…

实例化Java对象_Java面向对象基础之对象实例化

1、实例化对象的过程可以分为两部分,例如下面代码:Person per new Person();该代码分为两部分:第一,声明对象:Personper&#xff0c;这部分是在栈内存中声明的&#xff0c;与数组一样&#xff0c;数组名称及时保存在占内存之中&#xff0c;只是开闭了真内存&#xff0c;对象是…

HTTP 错误 404.2 - Not Found 由于 Web 服务器上的“ISAPI 和 CGI 限制”列表设置,无法提供您请求的页面 详细错误:HTTP 错误...

错误摘要 HTTP 错误 404.2 - Not Found 由于 Web 服务器上的“ISAPI 和 CGI 限制”列表设置&#xff0c;无法提供您请求的页面。 详细错误信息 模块IsapiModule通知ExecuteRequestHandler处理程序ExtensionlessUrlHandler-ISAPI-4.0_32bit错误代码0x800704ec请求的 URLhttp://:…

java knn分类_返回2个或更多最近邻居的KNN算法

这正是构建这些度量树的原因 .你问的问题就像你要求的东西一样简单&#xff0c;就像使用sklearn的KDTree一样(根据游戏中的指标考虑BallTree)&#xff1a;import numpy as npfrom sklearn.neighbors import KDTreeX np.array([[1,1],[2,2], [3,3]]) # 3 points in 2 dimension…

php替换不区分大小写_PHP大小写问题:函数名和类名不区分,变量名区分

这篇文章主要介绍了PHP大小写问题&#xff0c;php中变量名是区分大小写的&#xff0c;而函数名与类名是不区分的PHP对大小写敏感问题的处理比较乱&#xff0c;写代码时可能偶尔出问题&#xff0c;所以这里总结一下。但我不是鼓励大家去用这些规则。推荐大家始终坚持“大小写敏感…