【计算机图形学】作业: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)这四个点存入数组circlepointsi...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;
		}
	}
}
相关推荐
社交怪人几秒前
【判断大小】信息学奥赛一本通C语言解法(题号1043)
算法
许彰午3 分钟前
14_Java泛型完全指南
java·windows·python
Snasph14 分钟前
GNU Make 用户手册(中文版)
服务器·算法·gnu
智慧物业老杨16 分钟前
司法绿色通道下的物业纠纷数智化解决方案——基于“三优先“机制的全流程技术落地实践
java·django
2601_9611940221 分钟前
2026初级会计实务公式总结大全|计算题公式手册PDF
java·spring·eclipse·pdf·tomcat·hibernate
做个文艺程序员25 分钟前
第1篇:K8s 核心概念精讲:Pod、Deployment、Service 与 Namespace——Java 开发者快速上手指南
java·云原生·容器·kubernetes·容器编排
江澎涌40 分钟前
拆解与 AI 的一次对话
人工智能·算法·程序员
sheeta19981 小时前
LeetCode 每日一题笔记 日期:2026.06.02 题目:3635. 最早完成陆地和水上游乐设施的时间 II
笔记·算法·leetcode
Lsk_Smion1 小时前
力扣实训 _ [102].层序遍历--前序--后续_递归与非递归的实现
数据结构·算法·leetcode
小欣加油3 小时前
leetcode3751 范围内总波动值I
java·数据结构·c++·算法·leetcode