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

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

?? w1.c.c

?? 幾何變換程序
?? C
字號:
#include "math.h"
#include "graphics.h"
#define SIZE 10000
#define N 4
#define PI 3.14159265358979323846
typedef struct{ int x; int y;} point ;
typedef struct{ 
                point *base;
                point *top ;
                int    size;
               } stack ;
void initiate(stack *s);
void push(point seed,stack *s);
void pop(point *seed,stack *s);
void bresenham_line(int x0,int y0,int x1,int y1,int color);
void casteljau_bezier(int x[N],int y[N],int color);
void seed_fill(int boundcolor ,point seed, int color,stack s);
void coordinate_set() ;
void print();
void initgr(void)
{
  int gd = DETECT, gm = 0;
  registerbgidriver(EGAVGA_driver);
  initgraph(&gd, &gm, "");
}

main()
{
  int i,j;
  int x1[]={50,155,200,256},y1[]={52,125,18,54},
      x2[]={25,130,200,256},y2[]={20,110,-50,54} ,
      xx1[N], yy1[N], xx2[N], yy2[N];
  float sn,cs,sx;
  point seed={400,180};
  point a[6]={54,88,68,88,50,52,256,54,25,20,20,20}, aa[6];
  stack s;
  initgr();
  initiate(&s);
  coordinate_set();  /*畫坐標系*/
  for(j=0;j<N;j++)
    {
      xx1[j]=x1[j];yy1[j]=y1[j];
      xx2[j]=x2[j];yy2[j]=y2[j];
    }
  for(j=0;j<6;j++)
    {
      aa[j].x=a[j].x;
      aa[j].y=a[j].y;
    }

  for(i=0;i<60;i++)
    {  
       sn=sin(i*PI/30);    /*旋轉因子*/
       cs=cos(i*PI/30);
       sx=(float)(100-i)/100.0;  /*比例因子*/

       for(j=0;j<4;j++)        /*圖上坐標的比例變換加旋轉變換*/
         {
           x1[j]=(xx1[j]*cs-yy1[j]*sn)*sx;
           y1[j]=(xx1[j]*sn+yy1[j]*cs)*sx;
           x2[j]=(xx2[j]*cs-yy2[j]*sn)*sx;
           y2[j]=(xx2[j]*sn+yy2[j]*cs)*sx;
         }
       for(j=0;j<6;j++)
         {
           a[j].x=(aa[j].x*cs-aa[j].y*sn)*sx;
           a[j].y=(aa[j].x*sn+aa[j].y*cs)*sx;
         }

       for(j=0;j<N;j++)         /*坐標變換……由圖上坐標到屏幕坐標*/
         { 
           x1[j]+=320; y1[j]=240-y1[j];
           x2[j]+=320; y2[j]=240-y2[j];
         }
       for(j=0;j<6;j++)
         { 
           a[j].x+=320; a[j].y=240-a[j].y;
         }

       setcolor(YELLOW);
       bresenham_line(a[0].x,a[0].y,a[1].x,a[1].y,YELLOW);
       bresenham_line(a[1].x,a[1].y,a[2].x,a[2].y,YELLOW);
       bresenham_line(a[4].x,a[4].y,a[5].x,a[5].y,YELLOW);
       bresenham_line(a[0].x,a[0].y,a[5].x,a[5].y,YELLOW);
       casteljau_bezier(x1,y1,YELLOW);
       casteljau_bezier(x2,y2,YELLOW);
       print();

       if(i==0)
       seed_fill(YELLOW,seed,RED,s);

       for(j=0;j<N;j++)         /*坐標還原……由屏幕坐標到圖上坐標*/
         { 
           x1[j]-=320; y1[j]=240-y1[j];
           x2[j]-=320; y2[j]=240-y2[j];
         }
       for(j=0;j<6;j++)
         { 
           a[j].x-=320; a[j].y=240-a[j].y;
         }

    }

  getch();
  closegraph();
}

void initiate(stack *s)

{   
    s->base=(point*)malloc(SIZE*sizeof(point));
    s->top=s->base;
    s->size=SIZE;
}

void push(point seed,stack *s)

{   
  if(s->top-s->base>=s->size)
   {
     s->base=(point*)realloc(s->base,(s->size+100)*sizeof(point));
     s->top=s->base+s->size;
     s->size+=100;
   }
  (s->top)->x=seed.x;
  (s->top)->y=seed.y;
  s->top++;
}

void pop(point *seed,stack *s)

{   
   if(s->top!=s->base)
    {
      s->top--;
      seed->x=(s->top)->x;
      seed->y=(s->top)->y;
    }
}

void bresenham_line(int x0,int y0,int x1,int y1,int color)

{
  int i,x,y,dx,dy,n,flag,e=0;
  dx=x1-x0;  dy=y1-y0;
  flag=(dx*dy>=0)?1:-1;
  dx=abs(dx); dy=abs(dy);
  if(dy<=dx)
  {
     n=dx;
     if(x1>x0) { x=x0; y=y0;}
     else { x=x1; y=y1;}
     e=2*dy-dx;
     for(i=0;i<=n;i++)
       {
         putpixel(x,y,color);
         if(e>=0) {y=y+flag;e+=2*(dy-dx);}
         else e+=2*dy;
         x=x+1;
       }
  }
  else
    {
      n=dy;
      if(y1>y0) { x=x0; y=y0;}
      else { x=x1;y=y1;}
      e=2*dx-dy;
      for(i=0;i<=n;i++)
        {
          putpixel(x,y,color);
          if(e>=0) {x=x+flag; e+=2*(dx-dy);}
          else e+=2*dx;
          y=y+1;
        }
    }
}

void casteljau_bezier(int x[N],int y[N],int color)

{
  int i,j;
  float t,xx[N],yy[N];
  for(t=0;t<=1;t=t+0.0006)
    { 
      for(i=0;i<N;i++)
        {
          xx[i]=(float)x[i]; yy[i]=(float)y[i];
        }  
      for(i=1;i<N;i++)
         for(j=0;j<=N-i;j++)
           {   
             xx[j]=(1-t)*xx[j]+t*xx[j+1];
             yy[j]=(1-t)*yy[j]+t*yy[j+1];
           }
     putpixel(xx[0],yy[0],color);

    }
}


void seed_fill(int boundcolor ,point seed, int color,stack s)

{
  int x,y;
  push(seed,&s);
  while(s.top!=s.base)
     { 
       pop(&seed,&s);
       x=seed.x; y=seed.y;
       putpixel(seed.x,seed.y,color);
       if(getpixel(x-1,y)!=boundcolor&&getpixel(x-1,y)!=color)
         {
           seed.x=x-1; seed.y=y; push(seed,&s);
         }
       if(getpixel(x+1,y)!=boundcolor&&getpixel(x+1,y)!=color)
         {
           seed.x=x+1; seed.y=y; push(seed,&s);
         }
       if(getpixel(x,y-1)!=boundcolor&&getpixel(x,y-1)!=color)
         {
           seed.y=x; seed.y=y-1; push(seed,&s);
         }
       if(getpixel(x,y+1)!=boundcolor&&getpixel(x,y+1)!=color)
         {
           seed.x=x; seed.y=y+1; push(seed,&s);
         }

        if(seed.y>221) break;
    }
}

void coordinate_set()

{   
    setcolor(BLUE);
    line(100,240,540,240);
    line(520,235,540,240);
    line(520,245,540,240);
    line(320,20,320,460);
    line(315,40,320,20);
    line(325,40,320,20);
    outtextxy(530,250,"X");
    outtextxy(330,230,"0");
    outtextxy(340,30,"Y");
}
void print()
{    setcolor(YELLOW);

}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲狼人国产精品| 国产精品18久久久久久久久久久久| 亚洲图片一区二区| 麻豆成人免费电影| 91丨国产丨九色丨pron| 91精品国产91久久久久久一区二区| 国产欧美日韩三级| 日韩精品电影一区亚洲| 成人app下载| 久久久久久久久久久久电影| 亚洲成a人片综合在线| av不卡免费在线观看| 精品久久久久一区二区国产| 亚洲www啪成人一区二区麻豆| 成人少妇影院yyyy| 久久亚洲一区二区三区四区| 日韩黄色在线观看| 欧美日韩国产一级| 亚洲精品视频观看| 99在线精品一区二区三区| 久久婷婷久久一区二区三区| 久久99日本精品| 91精品国产免费久久综合| 亚洲成人一区二区在线观看| 欧美亚洲一区三区| 一区二区三区高清| 欧美性受xxxx| 亚洲成人av一区| 欧美情侣在线播放| 日韩中文字幕区一区有砖一区 | 从欧美一区二区三区| 日韩一区二区影院| 欧美aaa在线| 日韩欧美一区二区不卡| 久久国产精品免费| 2021中文字幕一区亚洲| 韩国一区二区视频| 欧美激情一区二区三区不卡 | 亚洲成人福利片| 欧美日韩国产bt| 日韩专区一卡二卡| 2020国产精品| av成人动漫在线观看| 亚洲国产成人av| 日韩视频中午一区| 国产成人午夜99999| 亚洲色图20p| 欧美精品九九99久久| 精品在线亚洲视频| 国产精品久久综合| 欧美日韩精品三区| proumb性欧美在线观看| 中文字幕一区二区三区四区| 日本高清不卡视频| 日本不卡视频在线| 国产午夜精品在线观看| 91亚洲国产成人精品一区二三| 午夜欧美视频在线观看| 欧美精品一区二区三区蜜桃| 北岛玲一区二区三区四区| 亚洲第一在线综合网站| 久久伊人蜜桃av一区二区| 成人99免费视频| 日韩高清在线不卡| 国产精品三级视频| 欧美放荡的少妇| 丁香六月综合激情| 日韩精品亚洲专区| 国产精品麻豆一区二区| 7777精品伊人久久久大香线蕉经典版下载 | 精品一区二区三区免费视频| 国产精品视频在线看| 在线播放日韩导航| 成人国产精品免费观看视频| 亚洲成年人影院| 欧美国产一区在线| 欧美一级在线视频| 91无套直看片红桃| 国产乱码一区二区三区| 首页综合国产亚洲丝袜| 成人免费在线观看入口| 精品久久免费看| 欧美午夜影院一区| 成人app下载| 激情五月婷婷综合| 午夜成人免费电影| 亚洲视频一区二区在线| 久久精品欧美日韩精品| 欧美一级午夜免费电影| 欧美日韩在线电影| 在线中文字幕不卡| 成人精品国产一区二区4080| 久久精品国产网站| 午夜久久久久久久久久一区二区| 自拍偷拍亚洲欧美日韩| 国产日韩精品一区二区浪潮av| 制服丝袜激情欧洲亚洲| 欧美性生活影院| 色噜噜狠狠色综合中国| 99re在线视频这里只有精品| 丁香激情综合国产| 国产乱子伦视频一区二区三区 | 亚洲国产精品久久久男人的天堂 | 欧美日韩一区在线| 色综合久久久久综合99| 成人精品gif动图一区| 国产一区二区三区美女| 久久精品国产精品青草| 日韩精品亚洲一区二区三区免费| 亚洲国产aⅴ成人精品无吗| 亚洲影视在线观看| 亚洲图片欧美视频| 亚洲一区二区在线视频| 亚洲最大色网站| 亚洲一区二区欧美日韩| 亚洲一区电影777| 亚洲电影第三页| 日本不卡视频在线观看| 久久99九九99精品| 国产一区二区成人久久免费影院 | 欧美激情一区二区三区不卡| 国产欧美久久久精品影院| 久久久久久免费网| 久久精品夜夜夜夜久久| 欧美激情一区不卡| 亚洲美女视频在线观看| 亚洲精品视频免费观看| 日本欧美肥老太交大片| 国产伦精一区二区三区| 不卡在线观看av| 在线精品视频一区二区三四| 欧美日韩一级二级三级| 日韩一区二区电影在线| 精品国产一区二区三区不卡 | 久久女同性恋中文字幕| 久久奇米777| 亚洲女子a中天字幕| 亚洲成人在线网站| 久久精工是国产品牌吗| 不卡一二三区首页| 欧美日韩一区在线观看| 26uuu精品一区二区三区四区在线| 国产女同性恋一区二区| 亚洲一二三四在线| 久久99精品网久久| 色综合天天综合狠狠| 日韩西西人体444www| 国产精品伦理在线| 三级欧美韩日大片在线看| 国产麻豆午夜三级精品| 欧美伊人精品成人久久综合97 | 亚洲国产日日夜夜| 国产麻豆视频一区| 欧美日韩国产片| 国产精品免费av| 蜜桃视频在线观看一区| 91色porny在线视频| 日韩欧美123| 亚洲综合清纯丝袜自拍| 国产高清亚洲一区| 欧美日韩成人在线| 国产精品国产三级国产aⅴ无密码| 日韩精品1区2区3区| 99视频有精品| 亚洲色图丝袜美腿| 国产精品77777| 91精品国产免费| 玉米视频成人免费看| 国产成人免费在线观看不卡| 欧美人伦禁忌dvd放荡欲情| 国产精品麻豆99久久久久久| 蓝色福利精品导航| 3751色影院一区二区三区| 国产精品国产三级国产aⅴ无密码| 狠狠久久亚洲欧美| 欧美电影免费观看高清完整版在线 | 日韩—二三区免费观看av| 91原创在线视频| 国产精品大尺度| 国产成人免费视频网站| 精品久久五月天| 精品一区二区久久| 7777精品伊人久久久大香线蕉经典版下载| 国产精品美女久久久久久久久| 国产综合色精品一区二区三区| 777久久久精品| 蜜臀久久久久久久| 欧美一区二区三区婷婷月色| 视频一区中文字幕| 4438x亚洲最大成人网| 天天色综合成人网| 9191国产精品| 日韩成人精品在线观看| 91精品国产欧美日韩| 日韩成人dvd| 精品动漫一区二区三区在线观看| 久久99国内精品| 久久久.com| jiyouzz国产精品久久| 亚洲欧美另类小说|