【计算机图形学】作业: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;
		}
	}
}
相关推荐
草莓熊Lotso1 小时前
Linux 基础 IO 初步解析:从 C 库函数到系统调用,理解文件操作本质
linux·运维·服务器·c语言·数据库·c++·人工智能
梵刹古音1 小时前
【C语言】 字符数组相关库函数
c语言·开发语言·算法
闻缺陷则喜何志丹1 小时前
P8699 [蓝桥杯 2019 国 B] 排列数|普及+
c++·数学·蓝桥杯·数论·洛谷·数列
D_evil__7 小时前
【Effective Modern C++】第三章 转向现代C++:16. 让const成员函数线程安全
c++
微风中的麦穗7 小时前
【MATLAB】MATLAB R2025a 详细下载安装图文指南:下一代科学计算与工程仿真平台
开发语言·matlab·开发工具·工程仿真·matlab r2025a·matlab r2025·科学计算与工程仿真
2601_949146537 小时前
C语言语音通知API示例代码:基于标准C的语音接口开发与底层调用实践
c语言·开发语言
开源技术7 小时前
Python Pillow 优化,打开和保存速度最快提高14倍
开发语言·python·pillow
学嵌入式的小杨同学7 小时前
从零打造 Linux 终端 MP3 播放器!用 C 语言实现音乐自由
linux·c语言·开发语言·前端·vscode·ci/cd·vim
wfeqhfxz25887827 小时前
YOLO13-C3k2-GhostDynamicConv烟雾检测算法实现与优化
人工智能·算法·计算机视觉
毕设源码-朱学姐8 小时前
【开题答辩全过程】以 基于JavaWeb的网上家具商城设计与实现为例,包含答辩的问题和答案
java