⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 circle.c

📁 数字信号处理实验
💻 C
字号:
/* WIN-TC BGI 图形编程模板 */


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

int x0,y0;

void initgr(void) /* BGI初始化 */
{
  int gd = DETECT, gm; /* 和gd = VGA,gm = VGAHI是同样效果 */
  registerbgidriver(EGAVGA_driver);/* 注册BGI驱动后可以不需要.BGI文件的支持运行 */
  initgraph(&gd, &gm, "");
}


void setpixel(int x,int y,int color)
{
int rx=x+x0,ry=getmaxy()-(y+y0);
putpixel(rx,ry,color);
}
void circlepoints(int x,int y,int color)
{
setpixel(x,y,color);setpixel(y,x,color);
setpixel(-x,y,color);setpixel(y,-x,color);
setpixel(x,-y,color);setpixel(-y,x,color);
setpixel(-x,-y,color);setpixel(-y,-x,color);
}
void midpointcircle(int r,int color)
{
int x,y;
int e;
x=0;y=r;e=1-r;
circlepoints(x,y,color);
 while(x<=y)
 {
  if(e<0)
    e+=2*x+3;
    else
    {
       e+=2*(x-y)+5;
       y--;
    }
    x++;
    circlepoints(x,y,color);
 }
}

int main(void)
{ int r=-1,k=0,color;
  printf("x0=");scanf("%d",&x0);
  printf("\ny0=");scanf("%d",&y0);

  while(r<0)
  {
  if(k==1) printf("\nInput error!");
  k=1;
  printf("\nr=");scanf("%d",&r);
  }
  k=0;
  while(color<0||color>15)
  {
  if(k==1) printf("\nInput error!");
  k=1;
  printf("\ncolor=");scanf("%d",&color);
  }
  initgr(); /* BGI初始化 */
  midpointcircle(r,color);
  getch(); /* 暂停一下,看看前面绘图代码的运行结果 */
  closegraph(); /* 恢复TEXT屏幕模式 */
  return 0;
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -