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

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

?? guicirc.c

?? uCGUI
?? C
字號:
/*************************************************************************************************************
                                                   uC/GUI
                                               嵌入式通用圖形軟件
File        : GUICirc.C
Purpose     : Circle and ellipse drawing functions
************************************************************************************************************/
#include <stddef.h>           /* needed for definition of NULL */
#include "GUI_Private.H"

/*************************************************************************************************************
* Draw Circle                        
*************************************************************************************************************/
static  void Draw8Point(int x0,int y0, int xoff, int yoff) 
{
  LCD_HL_DrawPixel(x0+xoff,y0+yoff);
  LCD_HL_DrawPixel(x0-xoff,y0+yoff);
  LCD_HL_DrawPixel(x0+yoff,y0+xoff);
  LCD_HL_DrawPixel(x0+yoff,y0-xoff);
  if (yoff) 
  {
    LCD_HL_DrawPixel(x0+xoff,y0-yoff);
    LCD_HL_DrawPixel(x0-xoff,y0-yoff);
    LCD_HL_DrawPixel(x0-yoff,y0+xoff);
    LCD_HL_DrawPixel(x0-yoff,y0-xoff);
  }
}


void GL_DrawCircle(int x0, int y0, int r) 
{
  I32 i;
  int imax = ((I32)((I32)r*707))/1000+1;
  I32 sqmax = (I32)r*(I32)r+(I32)r/2;
  I32 y=r;
  Draw8Point(x0,y0,r,0);
  for (i=1; i<= imax; i++) 
  {
    if ((i*i+y*y) >sqmax) 
    {
      Draw8Point(x0,y0,i,y);
      y--;
    }
    Draw8Point(x0,y0,i,y);
  }
}

void GUI_DrawCircle(int x0, int y0, int r) 
{
  #if (GUI_WINSUPPORT)
    GUI_RECT Rect;
  #endif
  GUI_LOCK();
  #if (GUI_WINSUPPORT)
    WM_ADDORG(x0,y0);
    Rect.x0 = x0-r;
    Rect.x1 = x0+r;
    Rect.y0 = y0-r;
    Rect.y1 = y0+r;
    WM_ITERATE_START(&Rect); 
    {
  #endif
    GL_DrawCircle( x0, y0, r);
  #if (GUI_WINSUPPORT)
    } WM_ITERATE_END();
  #endif
  GUI_UNLOCK();
}


/*************************************************************************************************************
* Fill Circle                       
*************************************************************************************************************/
void GL_FillCircle(int x0, int y0, int r) 
{
  I32 i;
  int imax = ((I32)((I32)r*707))/1000+1;
  I32 sqmax = (I32)r*(I32)r+(I32)r/2;
  I32 x=r;
  LCD_HL_DrawHLine(x0-r,y0,x0+r);
  for (i=1; i<= imax; i++) 
  {
    if ((i*i+x*x) >sqmax) 
    {
      /* draw lines from outside */
      if (x>imax) 
      {
        LCD_HL_DrawHLine (x0-i+1,y0+x, x0+i-1);
        LCD_HL_DrawHLine (x0-i+1,y0-x, x0+i-1);
      }
      x--;
    }
    /* draw lines from inside (center) */
    LCD_HL_DrawHLine(x0-x,y0+i, x0+x);
    LCD_HL_DrawHLine(x0-x,y0-i, x0+x);
  }
}

void GUI_FillCircle(int x0, int y0, int r) 
{
  GUI_LOCK();
  #if (GUI_WINSUPPORT)
    WM_ADDORG(x0,y0);
    WM_ITERATE_START(NULL); 
    {
  #endif
  GL_FillCircle(x0,y0,r);
  #if (GUI_WINSUPPORT)
    } WM_ITERATE_END();
  #endif
  GUI_UNLOCK();
}

/*************************************************************************************************************
* Ellipse drawing / filling               
The most efficient way to calculate the ellipse positions
is using the knowledge that the ellipse is just circle which has
compressed (or stretched) in one direction. For a circle, the
following equation holds true for all points located on the border of
it:
               x^2 + y(x)^2 = r^2 = const

Therefor, for an ellipse we can make use of the following equation:

               (ry*x)^2 + (rx*y(x))^2 = (ry*rx)^2 = const
*************************************************************************************************************/
void GL_FillEllipse(int x0, int y0, int rx, int ry) 
{
  I32 OutConst, Sum, SumY;
  int x,y;
  U32 _rx = rx;
  U32 _ry = ry;
  OutConst = _rx*_rx*_ry*_ry  /* Constant as explaint above */
            +(_rx*_rx*_ry>>1); /* To compensate for rounding */
  x = rx;
  for (y=0; y<=ry; y++) 
  {
    SumY =((I32)(rx*rx))*((I32)(y*y)); /* Does not change in loop */
    while (Sum = SumY + ((I32)(ry*ry))*((I32)(x*x)), (x>0) && (Sum>OutConst))
    {
      x--;
    }
    LCD_HL_DrawHLine(x0-x, y0+y, x0+x);
    if (y)
      LCD_HL_DrawHLine(x0-x, y0-y, x0+x);
  }
}

void GUI_FillEllipse(int x0, int y0, int rx, int ry) 
{
  #if (GUI_WINSUPPORT)
    GUI_RECT r;
  #endif
  GUI_LOCK();
  #if (GUI_WINSUPPORT)
    WM_ADDORG(x0,y0);
    /* Calc rectangle in order to avoid unnecessary drawing ops. */
    r.x0 = x0-rx; r.x1 = x0+rx; r.y0 = y0-ry; r.y1 = y0+ry;
    WM_ITERATE_START(&r); 
    {
  #endif
  GL_FillEllipse (x0,y0, rx, ry);
  #if (GUI_WINSUPPORT)
    } WM_ITERATE_END();
  #endif
  GUI_UNLOCK();
}

void GL_DrawEllipse(int x0, int y0, int rx, int ry) 
{
  I32 OutConst, Sum, SumY;
  int x,y;
  int xOld;
  U32 _rx = rx;
  U32 _ry = ry;
  OutConst = _rx*_rx*_ry*_ry  /* Constant as explaint above */
            +(_rx*_rx*_ry>>1); /* To compensate for rounding */
  xOld = x = rx;
  for (y=0; y<=ry; y++) 
  {
    if (y==ry) 
    {
      x=0;
    } 
    else 
    {
      SumY =((I32)(rx*rx))*((I32)(y*y)); /* Does not change in loop */
      while (Sum = SumY + ((I32)(ry*ry))*((I32)(x*x)), (x>0) && (Sum>OutConst)) 
      x--;
    }
/* Since we draw lines, we can not draw on the first
    iteration
*/
    if (y) 
    {
      GL_DrawLine1(x0-xOld,y0-y+1,x0-x,y0-y);
      GL_DrawLine1(x0-xOld,y0+y-1,x0-x,y0+y);
      GL_DrawLine1(x0+xOld,y0-y+1,x0+x,y0-y);
      GL_DrawLine1(x0+xOld,y0+y-1,x0+x,y0+y);
    }
    xOld = x;
  }
}

void GUI_DrawEllipse(int x0, int y0, int rx, int ry) 
{
  #if (GUI_WINSUPPORT)
    GUI_RECT r;
  #endif
  GUI_LOCK();
  #if (GUI_WINSUPPORT)
    WM_ADDORG(x0,y0);
  /* Calc rectangle in order to avoid unnecessary drawing ops. */
    r.x0 = x0-rx; r.x1 = x0+rx; r.y0 = y0-ry; r.y1 = y0+ry;
    WM_ITERATE_START(&r); 
    {
  #endif
  GL_DrawEllipse(x0, y0, rx, ry);
  #if (GUI_WINSUPPORT)
    } WM_ITERATE_END();
  #endif
  GUI_UNLOCK();
}














?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩三级免费观看| 欧美日韩一区二区不卡| 95精品视频在线| 欧美二区三区91| 色88888久久久久久影院野外| 久久精品国产秦先生| av在线播放成人| 一区二区三区不卡视频在线观看| 免费不卡在线视频| 欧美丝袜丝交足nylons| 久久精品亚洲麻豆av一区二区 | 欧美美女喷水视频| 欧美激情中文不卡| 国产一区二区导航在线播放| 欧美伦理电影网| 亚洲最大的成人av| 91丨porny丨户外露出| 日本一区二区三区国色天香| 美女视频免费一区| 91精品国产色综合久久不卡电影 | 国产一区二区调教| 欧美在线啊v一区| 国产精品久久久久影院老司| 黄色资源网久久资源365| 欧美日本一区二区三区| 亚洲精品视频在线观看免费| 成人app软件下载大全免费| 久久久久久久电影| 国产乱码精品一区二区三区av| 欧美一二区视频| 欧美bbbbb| 日韩三级电影网址| 国内精品嫩模私拍在线| 精品国产麻豆免费人成网站| 久久草av在线| 久久精品欧美日韩精品| 国产乱人伦偷精品视频免下载| 久久综合色综合88| 在线影视一区二区三区| 日韩一级高清毛片| 麻豆精品视频在线观看视频| 精品人在线二区三区| 在线视频一区二区三| 亚洲手机成人高清视频| 91蜜桃在线免费视频| 亚洲视频一二三| 欧美在线观看视频在线| 视频一区二区三区入口| 日韩视频中午一区| 国产精品18久久久久久久久| 中文字幕欧美激情一区| av在线播放不卡| 亚洲成人av中文| 欧美不卡一二三| 成人免费毛片a| 一区二区三区精品| 欧美大片在线观看一区二区| 国产黄色精品视频| 亚洲一区免费观看| 精品三级av在线| av在线播放成人| 国产成人精品亚洲午夜麻豆| 欧美一区二区三区人| 日日摸夜夜添夜夜添国产精品 | 在线观看视频91| 日韩精品亚洲一区二区三区免费| 精品精品国产高清a毛片牛牛| 成人免费三级在线| 成人av在线电影| 欧美中文字幕亚洲一区二区va在线| 国产欧美精品国产国产专区| 久久精品免视看| 亚洲老司机在线| 免费在线观看不卡| 99精品视频免费在线观看| 日本一二三四高清不卡| 国产精品国产三级国产aⅴ无密码| 天天综合天天综合色| 成人a免费在线看| 精品美女一区二区| 日韩激情中文字幕| 欧美美女一区二区在线观看| 午夜国产精品影院在线观看| 91免费版在线看| 美女视频一区二区三区| 成人午夜视频网站| 日精品一区二区三区| 久久婷婷成人综合色| 美女视频网站久久| 欧美伊人久久大香线蕉综合69 | 日韩一区二区中文字幕| 亚洲婷婷综合久久一本伊一区 | 国产精品美女久久久久久2018 | 亚洲精品成人天堂一二三| 在线不卡的av| 本田岬高潮一区二区三区| 麻豆成人91精品二区三区| 亚洲影院免费观看| 综合自拍亚洲综合图不卡区| 精品电影一区二区三区| 亚洲精品中文字幕在线观看| 成人午夜精品在线| 亚洲女与黑人做爰| 欧美人成免费网站| 成人少妇影院yyyy| 国产精品福利在线播放| 91社区在线播放| 久久国产精品99久久久久久老狼| 91精品国产综合久久精品| 国产综合色在线| 精品亚洲国产成人av制服丝袜| 色综合天天综合网天天看片| 久久久一区二区| 成人av一区二区三区| 高清视频一区二区| 不卡的av网站| 91麻豆国产福利在线观看| 91蜜桃视频在线| 日本精品裸体写真集在线观看| 色哟哟在线观看一区二区三区| 成人ar影院免费观看视频| 北岛玲一区二区三区四区| 99久久国产综合精品色伊| 成人激情开心网| 91美女在线视频| 欧美在线视频全部完| 欧美日韩国产bt| 日韩免费高清视频| 国产日韩视频一区二区三区| 中文字幕不卡在线| 亚洲三级在线免费观看| 一区二区三区日韩在线观看| 亚洲成人精品在线观看| 久久精品国产秦先生| 国产精品一区二区在线播放| 99re66热这里只有精品3直播| 欧美亚一区二区| 欧美一级生活片| 国产欧美日韩精品a在线观看| 国产精品美日韩| 亚洲国产视频在线| 成人免费在线视频| 亚洲日韩欧美一区二区在线| 日本不卡1234视频| 精品国产91洋老外米糕| 久久亚洲二区三区| 国产精品沙发午睡系列990531| 国产精品色呦呦| 日韩国产在线观看一区| 成人免费高清视频| 972aa.com艺术欧美| 日韩午夜激情av| 国产精品久久久久aaaa樱花| 调教+趴+乳夹+国产+精品| 久久精品国产一区二区三 | 国产精品66部| 在线日韩国产精品| 精品久久久久久久久久久久久久久| 欧美激情中文不卡| 奇米777欧美一区二区| 99re66热这里只有精品3直播| 极品美女销魂一区二区三区免费| 国产**成人网毛片九色| 色综合色狠狠综合色| 欧美一区二区精品在线| 一区二区三区在线免费观看| av一区二区三区四区| xnxx国产精品| 日本伊人色综合网| 色综合久久66| 中文字幕久久午夜不卡| 日韩vs国产vs欧美| 91精品黄色片免费大全| 亚洲免费观看高清完整版在线 | 中文字幕一区二区三区av| 一区二区三区精品视频在线| 成人精品视频一区| 久久久久久久久免费| 国产美女av一区二区三区| 国产精品免费aⅴ片在线观看| 韩国女主播一区| 亚洲精品国久久99热| 国产九九视频一区二区三区| 日韩欧美亚洲另类制服综合在线| 一区二区三区欧美日| 欧美亚洲尤物久久| 成人av动漫在线| 666欧美在线视频| 国产精品福利影院| 国产精品一品二品| 日韩精品一区二区三区视频| 亚洲h动漫在线| 欧美美女直播网站| 亚洲一区av在线| 欧美吻胸吃奶大尺度电影| 一区二区三区免费观看| 色婷婷综合中文久久一本| 一区二区在线观看免费| 欧美在线|欧美| 亚洲不卡在线观看|