【计算机图形学】作业: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;
		}
	}
}
相关推荐
_OP_CHEN1 分钟前
【算法提高篇】(二)线段树之区间修改:懒标记的核心奥义与实战实现
算法·蓝桥杯·线段树·c/c++·区间查询·acm/icpc·懒标记
啊阿狸不会拉杆2 分钟前
《机器学习导论》第 18 章-增强学习
人工智能·python·学习·算法·机器学习·智能体·增强学习
源力祁老师2 分钟前
Odoo ORM 将 Python 查询意图编译为 SQL 的逐函数讲解(Odoo 19)
java·服务器·数据库
那我掉的头发算什么3 分钟前
【图书管理系统】基于Spring全家桶的图书管理系统(上)
java·服务器·数据库·spring boot·后端·spring·mybatis
廋到被风吹走3 分钟前
SOLID原则深度解析:面向对象设计的五大基石
java·log4j
田里的水稻6 分钟前
FA_规划和控制(PC)-D*规划
人工智能·算法·数学建模·机器人·自动驾驶
Web打印7 分钟前
Phpask(php集成环境)之09 统一管理网站和监听端口
开发语言·php
cjl_8520087 分钟前
MS SQL Server 实战 排查多列之间的值是否重复
java
海兰8 分钟前
ES 9.3.0 日志模式分析
java·大数据·elasticsearch
程序员敲代码吗10 分钟前
微服务熔断降级配置详解与实践:使用Sentinel和Nacos
java·微服务·sentinel