亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? 0303.c

?? 計算機圖形學
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* WIN-TC BGI 圖形編程模板 */

#include "Conio.h"
#include "graphics.h"
#include "math.h"
#include <malloc.h>
#define closegr closegraph
#define pi 3.1415926
#define X 0
#define Y 1
#define LEN sizeof (struct node)

void initgr(void) /* BGI初始化 */
{
  int gd = DETECT, gm = 0; /* 和gd = VGA,gm = VGAHI是同樣效果 */
  registerbgidriver(EGAVGA_driver);/* 注冊BGI驅動后可以不需要.BGI文件的支持運行 */
  initgraph(&gd, &gm, "");
}
/*--------------------------Pro.1   Line---------------------------*/
void line2(int x0,int y0,int x1,int y1,int color)
{
   int dx,dy,incrE,incrNE,d,x,y;
    dx=x1-x0;
    dy=y1-y0;
    d=dx-2*dy;
    incrE=-2*dy;
    incrNE=2*(dx-dy);
    x=x0,y=y0;
    putpixel(x,y,color);
    while(x<x1)
    {  if(d>0)
        d+=incrE;
        else
        {  d+=incrNE;
            y++;
        }
      x++;
      putpixel(x,y,color);
    }

}
void Line1(int x1,int y1,int x2,int y2,int color)
{
 int x;
float increy,increx,i,steps;
increx=x2-x1;
increy=y2-y1;
steps=increy/increx;
i=y1;
for(x=x1;x<=x2;x++)
{
putpixel(x,(int)(i+0.5),color);
i+=steps;}
}
 zheng()
 {
   initgr(); /* BGI初始化*/
   Line1(50,50,300,200,2);
   Line1(50,150,300,300,2);
   Line1(50,250,300,400,2);
   outtextxy(350,300,"The Green ones: DDALine.");
   getch();
   line2(50,50,300,300,WHITE);
   line2(50,150,300,400,WHITE);
   outtextxy(350,320,"The White ones: MIDPOINTLine.");
   getch();

 }

/*------------------------Pro.2 The Bezier curve ang B yangtiao curve-------------------------*/
typedef struct {
     int x,y;
  }Vector;
void DisplayCubicBezierCurve(Vector P[4],int count)
{ float C[2][4],t ,deltat;
  Vector V,newV;
  int i,j;

    C[0][0]=   P[0].x  ;
    C[0][1]=-3*P[0].x+3*P[1].x;
    C[0][2]= 3*P[0].x-6*P[1].x+3*P[2].x;
    C[0][3]=  -P[0].x+3*P[1].x-3*P[2].x+P[3].x;

    C[1][0]=   P[0].y  ;
    C[1][1]=-3*P[0].y+3*P[1].y;
    C[1][2]= 3*P[0].y-6*P[1].y+3*P[2].y;
    C[1][3]=  -P[0].y+3*P[1].y-3*P[2].y+P[3].y;






  V.x=P[0].x;V.y=P[0].y;
  deltat=1.0/count;
  t=0.0;
  for (i=1;i<=count;i++)
  { t+=deltat;
    newV.x=C[X][0]+t*(C[X][1]+t*(C[X][2]+t*C[X][3]));
    newV.y=C[Y][0]+t*(C[Y][1]+t*(C[Y][2]+t*C[Y][3]));
    setcolor(RED);
    line(V.x,V.y,newV.x,newV.y);
    V.x=newV.x,V.y=newV.y;

  }


}
 liu(void)
{  int i,j;
   int count;
   Vector P[4];
  initgr(); /* BGI初始化 */

  /*****此部分添加你自己的代碼,例如
  line(25, 25, 220, 220);
  circle(100, 100, 50);
  等等*****/
  count=1000;
  printf("Please input the Vector\n");
  for (i=0;i<4;i++)
    scanf("%d%d",&P[i].x,&P[i].y);
   cleardevice();
   DisplayCubicBezierCurve(P, count);
   setcolor(BLUE);
   for (i=0;i<3;i++)
     line(P[i].x,P[i].y,P[i+1].x,P[i+1].y);




  getch(); /* 暫停一下,看看前面繪圖代碼的運行結果 */
  closegr(); /* 恢復TEXT屏幕模式 */
  return 0;
}

/*-------------------------------------Pro.3 The Midcircle,DDAcircle and DDAEllipse--------------------------------*/
void circlepoints(int x0,int y0,int x,int y,int color)
{
 putpixel(x0+x,y0+y,color);
 putpixel(x0+y,y0+x,color);
 putpixel(x0-y,y0+x,color);
 putpixel(x0-x,y0+y,color);
 putpixel(x0+y,y0-x,color);
 putpixel(x0+x,y0-y,color);
 putpixel(x0-x,y0-y,color);
 putpixel(x0-y,y0-x,color);
}
/*-------------圓的中點算法-----------------*/
void MidPointCircle(int x0,int y0,int r,int color)
{
  int x,y,d;

  x=0;
  y=r;
  d=5-4*r;
  circlepoints(x0,y0,x,y,color);
  while (y>x)
  {
    if (d<=0)
     d+=8*x+12;
    else
     {
       d+=8*(x-y)+20;
       y--;
     }
    x++;
    circlepoints(x0,y0,x,y,color);

  }

}
/*----------------圓的DDA算法--------------------*/
void DDAcircle(int x0,int y0,double r,double ts,double te)
{
  double rad,tsl,tel,deg,dte,ta,ct,st;
  int x,y,n,i;
  /*準備工作*/
  rad=0.0174533;
  tsl=ts*rad;
  tel=te*rad;
  if (r<5.08)
    deg=0.015;
  else
    if (r<7.62)
     deg=0.06;
    else
     if (r<25.4)
      deg=0.075;
     else
      deg=0.15;
  dte=deg*25.4/r;
  /*一些小約定*/
  if(tel<tsl)
   tel+=2*pi;
     n=(int)((tel-tsl)/dte+0.5);
  if (n==0)
     n=(int)(2*pi/dte+0.5);
   /*開始畫*/
  /*初始化*/
  ta=tsl;
  x=x0+r*cos(tsl);
  y=y0+r*sin(tsl);
  moveto(x,y);

  setcolor(WHITE);
  for(i=1;i<=n;i++)
  {
    ta+=dte;
    ct=cos(ta);
    st=sin(ta);
    x=x0+r*ct;
    y=y0+r*st;
    lineto(x,y);

    setcolor(WHITE);
  }
  /*收尾工作*/
  x=x0+r*cos(tel);
  y=y0+r*sin(tel);
  lineto(x,y);
  setcolor(WHITE);

}
/*---------------橢圓的中點算法---------------------*/
void ellipsepoint(int x0,int y0,int x,int y, int color)
{ putpixel(x+x0,y+y0,color);
  putpixel(-x+x0,y+y0,color);
  putpixel(-x+x0,-y+y0,color);
  putpixel(x+x0,-y+y0,color);
 }
void epse(int x0,int y0,int a,int b,int color)
{ float d,squarea,squareb;
   int xp,yp,x,y;
   squarea=a*a;
   squareb=b*b;
   xp=(int)(0.5+(float)squarea/sqrt((float)(squarea+squareb)));
   yp=(int)(0.5+(float)squareb/sqrt((float)(squarea+squareb)));
   /*生成第一象限內的上半部分橢圓*/
   x=0;
   y=b;
   d=4*(squareb-squarea*b)+squarea; /*初始化*/
   ellipsepoint(x0,y0,x,y,color);
   while(x<=xp)
   {
   if(d<=0)
            d+=4*squareb*(2*x+3);
     else
     {      d+=4*squareb*(2*x+3)-8*squarea*(y-1);
                  y--;
     }
     x++;
     ellipsepoint(x0,y0,x,y,color);
   }
   /*畫下半部分*/
   x=a;
   y=0;
   d=4*(squarea-squareb*a)+squareb;      /*初始化*/
   ellipsepoint(x0,y0,x,y,color);
   while(y<yp)
   {
   if(d<=0)
            d+=4*squarea*(2*y+3);
     else  {      d+=4*squarea*(2*y+3)-8*squareb*(x-1);
                  x--;
     }
     y++;
     ellipsepoint(x0,y0,x,y,color);
   }
}
Midpointellipse()
{
 /* initgr();  BGI初始化 */
  epse(200,200,98,50,YELLOW);

  /* getch(); 暫停一下,看看前面繪圖代碼的運行結果 */

}
/*--------------橢圓的角度DDA算法-------------------*/
void DDAellipse(int xc,int yc,double a,double b,double alp,double ts,double te)
{
 double rad,tsl,tel,alpl,deg,dte,r,ta,a1,a2,b1,b2;
 int x,y,n,i;

 rad=0.0174533;
 tsl=ts*rad;
 tel=te*rad;     /*將角度轉化為弧度*/
 alpl=alp*rad;   /*橢圓的長軸與x軸的夾角*/
 a1=a*cos(tsl);
 b1=cos(alpl);
 a2=b*sin(tsl);
 b2=sin(alpl);
 r=(a>b)?a:b;

 if(r<5.08)
  deg=0.015;
  else
   if(r<7.62)
    deg=0.06;
   else
    if(r<25.4)
     deg=0.075;
    else
    deg=0.15;
  dte=deg*25.4/r;

 if(tel<tsl)
  tel+=2*pi;
  n=(int)((tel-tsl)/dte+0.5);
  if(n==0)
   n=(int)(2*pi/dte+0.5);
  ta=tsl;
  x=xc+a1*b1-a2*b2;
  y=yc+a1*b2+a2*b1;
  setcolor(RED);
  moveto(x,y);
  for(i=1;i<=n;i++)
  {
    ta+=dte;
    a1=a*cos(ta);
    a2=b*sin(ta);
    x=xc+a1*b1-a2*b2;
    y=yc+a1*b2+a2*b1;
    lineto(x,y);
    setcolor(RED);
  }
  a1=a*cos(tel);
  a2=b*sin(tel);
  x=xc+a1*b1-a2*b2;
  y=yc+a1*b2+a2*b1;
  lineto(x,y);

}
  tang(void)
{ int k;
  loop1:initgr(); /* BGI初始化 */

    rectangle(50,30,400,200);
    outtextxy(120,180, "Welcome You!!") ;
    getch();
    outtextxy(100,50,"No.1   The midpointcircle.") ;
    getch();
    outtextxy(120,70,"No.2   The DDAcircle") ;
    getch();
    outtextxy(140,90, "No.3   The DDAellipse") ;
    getch();
    outtextxy(80,140, "Please input a number...") ;
    scanf("%d",&k);
   loop2:switch(k)
    {
     case 1:{cleardevice();
             MidPointCircle(200,200,200,GREEN);
             getch();
             MidPointCircle(150,200,50,GREEN);
             getch();
             MidPointCircle(250,200,50,GREEN);
             getch();
             DDAcircle(200,200,100,60,120);
             getch();
             outtextxy(100,420,"The Midpointcircle.");
             getch();
             goto loop1;break;}
     case 2:{cleardevice();
             DDAcircle(200,200,100,0,360);
             getch();
             MidPointCircle(300,300,100,GREEN);
             getch();
             line(290,250,400,200);
             outtextxy(402,200,"The DDAcircle.");
             getch();
             line(401,300,490,300);
             outtextxy(492,300,"The MidpointCircle.");
             /*outtextxy(100,420,"The DDAcircle.");*/
             getch();
             goto loop1;break;}
     case 3:{cleardevice();
             DDAellipse(201,201,200,100,0,0,360);
             outtextxy(420,180,"Rotate 0.");
             getch();
             DDAellipse(201,201,200,100,45,0,360);
             outtextxy(420,200,"Rotate 45.");
             getch();
             DDAellipse(201,201,200,100,90,0,360);
             outtextxy(420,220,"Rotate 90.");
             getch();
             DDAellipse(201,201,200,100,135,0,360);
             outtextxy(420,240,"Rotate 135.");
             getch();
             outtextxy(100,420,"The RED ones: DDAellipse.");
             getch();
             Midpointellipse();
             outtextxy(100,440,"The YELLOW ones: MIDPOINTellipse.");
             getch();
             outtextxy(200,200,"That's all! Thank you!!");break;}
     default:{outtextxy(80,160,"INPUT ERROR!  Please input again!");
              scanf("%d",&k);goto loop2;}

    }
  getch(); /* 暫停一下,看看前面繪圖代碼的運行結果 */
 closegr();  /* 恢復TEXT屏幕模式 */
  return 0;
}
/*--------------------------------------Pro.4 The AreaFilled------------------------*/
struct node
 { int dx,dy;
   struct node *next;
   };
struct node *creat()
{ struct node *h,*p,*r;
  int x,y;
  scanf("%d,%d",&x,&y);
  h=NULL;
  while (x!=0)
  { p=(struct node *)malloc(LEN);
    p->dx=x;
    p->dy=y;
    if (h==NULL) h=p;
     else r->next=p;
    r=p;
    scanf("%d,%d",&x,&y);
   }
  r->next=NULL;
  return(h);
 }
struct node *create()
{ struct node *h,*p,*r;
  int x,y;
  int i;
  int n[10][2];
  h=NULL;
  n[1][0]=100;
  n[1][1]=100;
  n[2][0]=180;
  n[2][1]=80;
  n[3][0]=220;/*220*/
  n[3][1]=150;
  n[4][0]=120;
  n[4][1]=250;
  n[5][0]=70;
  n[5][1]=150;
  for (i=1;i<=4;i++)
  { p=(struct node *)malloc(LEN);
    p->dx=n[i][0];
    p->dy=n[i][1];
    if (h==NULL) h=p;
     else r->next=p;
    r=p;
   }
  r->next=NULL;
  return(h);
 }
draw_polo(h)
struct node *h;
{ int sx,sy;
  struct node *q;
  setcolor(14);
  q=h;
  sx=q->dx;
  sy=q->dy;
  q=q->next;
  while (q!=NULL)
   {
    line(sx,sy,q->dx,q->dy);
    sx=q->dx;
    sy=q->dy;
    q=q->next;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产一区二区三区免费看| 成人中文字幕电影| 国产日产欧美一区| 在线精品观看国产| 国产xxx精品视频大全| 午夜av一区二区| 综合亚洲深深色噜噜狠狠网站| 欧美日本在线一区| av成人免费在线| 美女爽到高潮91| 丝袜a∨在线一区二区三区不卡| 久久久国产午夜精品| 91精品蜜臀在线一区尤物| 色94色欧美sute亚洲线路一ni | 亚洲免费观看高清完整版在线 | 亚洲午夜免费电影| 亚洲婷婷在线视频| 国产日韩欧美精品电影三级在线| 欧美日本韩国一区二区三区视频 | 91精品国产高清一区二区三区蜜臀 | 一区二区三区电影在线播| 国产欧美一区二区精品仙草咪| 欧美一区二区三区啪啪| 欧美视频一区二区在线观看| 成人国产精品免费观看视频| 国产不卡高清在线观看视频| 国模大尺度一区二区三区| 蜜臀久久久99精品久久久久久| 日韩有码一区二区三区| 午夜在线成人av| 亚洲尤物在线视频观看| 亚洲精品国产品国语在线app| 国产精品美女一区二区在线观看| 欧美高清一级片在线观看| 久久九九99视频| 久久精品一区二区三区不卡| 欧美不卡一区二区三区| 精品伦理精品一区| 欧美videofree性高清杂交| 日韩视频一区在线观看| 日韩精品一区二区三区四区视频| 欧美一区三区四区| 日韩一级片在线播放| 日韩欧美一级精品久久| 精品三级在线看| 久久久综合精品| 国产欧美久久久精品影院| 久久久午夜电影| 国产亚洲综合av| 国产精品久久久久久久久快鸭 | 亚洲精品精品亚洲| 亚洲一本大道在线| 日韩av一二三| 久久国产精品第一页| 国产伦精一区二区三区| 不卡欧美aaaaa| 91热门视频在线观看| 欧美调教femdomvk| 欧美一区二区三区人| 久久综合色综合88| 中文字幕一区二区三区视频| 一区二区三区在线视频免费| 午夜精品影院在线观看| 激情欧美日韩一区二区| www.亚洲精品| 欧美日韩视频不卡| 久久久精品国产免费观看同学| 国产精品人妖ts系列视频| 樱花草国产18久久久久| 日本成人在线不卡视频| 国产成人欧美日韩在线电影| 在线观看免费一区| 日韩精品在线一区| 日韩理论电影院| 日本欧美一区二区在线观看| 大白屁股一区二区视频| 欧美年轻男男videosbes| 久久综合九色综合97婷婷| 日韩一区欧美一区| 久久精品噜噜噜成人88aⅴ| 99精品欧美一区二区蜜桃免费| 欧美日韩国产高清一区二区| 久久无码av三级| 亚洲黄色免费电影| 国产精品自拍三区| 欧美军同video69gay| 亚洲国产精品精华液ab| 视频一区视频二区中文| 99久久精品国产毛片| 日韩女优电影在线观看| 一区二区高清视频在线观看| 国产在线一区观看| 欧美日韩国产欧美日美国产精品| 国产三区在线成人av| 亚洲成人动漫av| 99精品1区2区| 久久精品欧美一区二区三区麻豆| 综合欧美一区二区三区| 国产精品123| 欧美精品一卡两卡| 亚洲乱码精品一二三四区日韩在线| 精品一区二区三区在线播放 | 白白色 亚洲乱淫| 日韩欧美精品在线视频| 亚洲小说春色综合另类电影| 高清在线观看日韩| 精品国产乱码91久久久久久网站| 亚洲综合图片区| 波多野洁衣一区| 亚洲综合丝袜美腿| 成人精品小蝌蚪| 久久综合久久99| 老司机精品视频线观看86| 欧美日韩一区二区三区在线| 亚洲日本丝袜连裤袜办公室| 国产a区久久久| 日韩亚洲欧美在线观看| 香蕉久久夜色精品国产使用方法 | 欧美va日韩va| 日本视频在线一区| 欧美日本一区二区三区四区| 亚洲午夜国产一区99re久久| 色综合欧美在线视频区| 综合久久久久久| www.亚洲精品| 亚洲免费在线播放| av电影在线观看一区| 一区在线观看免费| 99久久777色| 亚洲免费观看高清| 91色porny| 亚洲一区在线观看免费| 欧美综合久久久| 香蕉久久夜色精品国产使用方法| 欧美日韩国产综合一区二区三区| 亚洲一二三四在线观看| 欧美日本韩国一区二区三区视频 | 久久亚洲精华国产精华液| 韩国欧美国产一区| 久久精品夜色噜噜亚洲aⅴ| 韩国女主播一区| 国产人久久人人人人爽| 蜜臀久久99精品久久久久久9| 最新欧美精品一区二区三区| 国产91在线观看| 国产精品每日更新在线播放网址 | 激情综合网av| 久久久精品tv| 成人av网站在线观看免费| 亚洲欧洲制服丝袜| 在线免费观看日本一区| 国产真实乱对白精彩久久| 久久综合九色综合欧美亚洲| 成人免费看片app下载| 亚洲欧美激情视频在线观看一区二区三区 | 欧美本精品男人aⅴ天堂| 国内成+人亚洲+欧美+综合在线 | 亚洲精品va在线观看| 91福利在线导航| 日本在线不卡视频| 久久综合九色综合97婷婷女人 | 国产真实乱子伦精品视频| 国产欧美一区二区精品仙草咪 | 欧美一区二区三区在线| 精品午夜久久福利影院| 中文字幕一区二区三中文字幕| 欧美伊人久久久久久午夜久久久久| 五月天国产精品| 久久久av毛片精品| 色综合久久综合中文综合网| 日本一不卡视频| 中文字幕不卡在线播放| 欧美区在线观看| 成人一级片网址| 日日夜夜免费精品| 国产精品久久久久影视| 欧美日韩成人在线一区| 国产成人综合在线播放| 亚洲一区中文在线| 国产欧美日韩麻豆91| 欧洲一区二区三区在线| 国产精品一区久久久久| 亚洲小少妇裸体bbw| 久久久99久久精品欧美| 欧美日韩免费观看一区三区| 国产成人精品免费一区二区| 日精品一区二区三区| 欧美国产97人人爽人人喊| 91麻豆精品国产91久久久久久久久| 国产美女一区二区| 午夜影视日本亚洲欧洲精品| 国产女主播在线一区二区| 欧美日韩国产区一| 岛国精品一区二区| 青青草97国产精品免费观看| 亚洲免费在线视频一区 二区| 日韩欧美中文字幕制服| 国产在线精品一区二区不卡了 | 日韩综合一区二区| 国产精品第一页第二页第三页|