【计算机图形学】作业:Bresenham 法绘制圆

题目:

请采用 Bresenham 法绘制圆(共 30 分)。要求: (1) 给出算法的文字描述(共 15 分)。 (2) 编写函数,在给定圆心坐标和半径的情况下,计算出圆 上所有的点,并将这些点存储在数组中(共 15 分)。

解答:

1、给出算法的文字描述(共 15 分)。

  1. 输入圆的圆心(xc,yc),半径r。数组circlepoints为输出,保存圆上所有点。
  2. 初始化,x=0,y=r,d=2*(1-r),i=d1=d2=direction=0。
  3. 若y>=0,将(xc+x,yc+y),(xc-x,yc+y),(xc+x,yc-y),(xc-x, yc-y)这四个点存入数组circlepoints[i...i+3],i=i+4,并画出这四个点;否则算法结束。
  4. 如果d<0,则d1=2*(d+y)-1,若d1<0,direction=1;否则,direction=2。如果d>0,则d2=2*(d-x)-1,若d2<=0,direction=2;否则,direction=3。如果d==0,direction=2。
  5. 若direction==1,d+=2*x+3,x++;若direction==2,d+=2*(x+1)-2*(y-1)+2,x++,y--;若direction==3,d+=-2*(y-1)+1,y--。转入步骤(3)。

(2) 编写函数,在给定圆心坐标和半径的情况下,计算出圆上所有的点,并将这些点存储在数组中(共 15 分)。

复制代码
void Bresenham_Circle(int xc, int yc, int r)
{
	int x, y, d, d1,d2,direction,i=0; CPoint circlepoints[N];
	x = 0, y = r, d = 2 * (1 - r);//初始化
	while (y >= 0)
	{
		circlepoints[i]=CPoint(x + xc, y + yc);
		circlepoints[i+1]=CPoint(x + xc, -y + yc);
		circlepoints[i+2]=CPoint(-x + xc, y + yc);
		circlepoints[i+3]=CPoint(-x + xc, -y + yc);i=i+4;
		if (d < 0)
		{
			d1 = 2 * (d + y) - 1;
			if (d1 < 0) direction = 1;
			else direction = 2;
		}

		else if (d > 0)
		{
			d2 = 2 * (d - x) - 1;
			if (d2 <= 0) direction = 2;
			else direction = 3;
		}
		else direction = 2;
		switch (direction)
		{
		case 1:d += 2 * x + 3; x++;  break;
		case 2: d += 2 * (x + 1) - 2 * (y - 1) + 2; x++, y--; break;
		case 3:d += -2 * (y - 1) + 1; y--; break;
		}
	}
}
相关推荐
崇山峻岭之间3 分钟前
C++ Prime Plus 学习笔记026
c++·笔记·学习
永远都不秃头的程序员(互关)11 分钟前
C语言 基本语法
c语言·开发语言
甄心爱学习26 分钟前
CSP认证 备考(python)
数据结构·python·算法·动态规划
木鹅.28 分钟前
LangChain4j
java
永远都不秃头的程序员(互关)42 分钟前
Java核心技术精要:高效实践指南
java·开发语言·性能优化
是Dream呀1 小时前
Python圣诞特辑:打造一棵会唱歌、会下雪的魔法圣诞树
开发语言·python·pygame
未来之窗软件服务1 小时前
幽冥大陆(四十一)美萍V10酒店门锁SDK C#语言仙盟插件——东方仙盟筑基期
开发语言·c#·仙盟创梦ide·东方仙盟·东方仙盟sdk·酒店智能门锁·东方仙盟 vos 智能浏览器
kyle~1 小时前
排序---常用排序算法汇总
数据结构·算法·排序算法
赖small强1 小时前
【Linux C/C++开发】Linux 平台 Stack Protector 机制深度解析
linux·c语言·c++·stack protector·stack-protector·金丝雀机制