中点画圆(计算机图形学)

程序源码

#include <graphics.h>
#include <conio.h>
#include<stdio.h>

//中点画圆法
void MidpointCircle(int x0,int y0,int r,int color)
{
   int x,y,d;
   x=0; y=r; d=1-r;
   while(x<y){

	   // 利用圆的八分对称性画点
		putpixel(x0 + x, y0 + y, color);
		putpixel(x0 + x, y0 - y, color);
		putpixel(x0 - x, y0 + y, color);
		putpixel(x0 - x, y0 - y, color);
		putpixel(x0 + y, y0 + x, color);
		putpixel(x0 + y, y0 - x, color);
		putpixel(x0 - y, y0 + x, color);
		putpixel(x0 - y, y0 - x, color);

		  if(d<0)
		  {
			 d+=2*x+3;
			 x++;
		  }
		  else
		  {
			d+=2*(x-y)+5;
			x++;
			y--;
		  }
   }/*while*/
}/*MidpointCircle*/

// 主函数
void main()
{

	//请输入圆心坐标和半径
	int x,y,r;
	printf("请输入圆心坐标和半径:\n");
	scanf("%d%d%d",&x,&y,&r);
	
	initgraph(640, 480);
	
	// 测试画圆
         MidpointCircle(<span style="font-family:Arial, Helvetica, sans-serif;">x,y</span>,r,RED);
		
	
	// 按任意键退出
	getch();
	closegraph();
}


效果截图



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值