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

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

?? guicirc.c

?? 在ucos上實現了圖形用戶接口GUI;值得一看
?? C
字號:
/*
*********************************************************************************************************
*                                                uC/GUI
*                        Universal graphic software for embedded applications
*
*                       (c) Copyright 2002, Micrium Inc., Weston, FL
*                       (c) Copyright 2002, SEGGER Microcontroller Systeme GmbH
*
*              礐/GUI is protected by international copyright laws. Knowledge of the
*              source code may not be used to write a similar product. This file may
*              only be used in accordance with a license and should not be redistributed
*              in any way. We appreciate your understanding and fairness.
*
----------------------------------------------------------------------
File        : GUICirc.C
Purpose     : Circle and ellipse drawing functions
----------------------------------------------------------------------
Version-Date---Author-Explanation
----------------------------------------------------------------------
1.00.02 011115 JE     a) GL_FillEllipse, GL_FillCircle, GL_DrawCircle changed
1.00.01 011113 JE     a) GL_DrawEllipse changed
1.00.00 991206 RS     First release
----------------------------------------------------------------------
Known problems or limitations with current version
----------------------------------------------------------------------
None.
----------------------------------------------------------------------
Open issues
----------------------------------------------------------------------
None
---------------------------END-OF-HEADER------------------------------
*/


#include <stddef.h>           /* needed for definition of NULL */
#include "GPrivate.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一区二区三区免费野_久草精品视频
国产精品青草综合久久久久99| 日本精品免费观看高清观看| 一区二区三区四区国产精品| 日本一区二区不卡视频| 国产亚洲欧美激情| 国产亚洲短视频| 国产欧美精品一区aⅴ影院| 欧美一级高清片| 精品区一区二区| 久久久蜜桃精品| 2023国产一二三区日本精品2022| 精品电影一区二区| 久久蜜桃一区二区| 久久久不卡影院| 中文字幕一区二| 亚洲精品亚洲人成人网| 亚洲乱码国产乱码精品精的特点 | 欧美天堂一区二区三区| 在线看不卡av| 67194成人在线观看| 日韩精品中文字幕在线不卡尤物| 欧美tk丨vk视频| 国产精品久久久一区麻豆最新章节| 国产精品乱码久久久久久| 1000部国产精品成人观看| 亚洲自拍偷拍九九九| 日韩高清欧美激情| 国产高清视频一区| 色婷婷亚洲综合| 日韩你懂的在线播放| 亚洲国产精华液网站w| 亚洲一区二区三区免费视频| 欧美a级一区二区| 成人免费看视频| 欧美在线一区二区三区| 欧美va亚洲va| 一区二区三区影院| 韩国三级中文字幕hd久久精品| av亚洲精华国产精华精华 | 视频一区二区中文字幕| 激情图片小说一区| 91欧美激情一区二区三区成人| 欧美日本不卡视频| 欧美国产日产图区| 日本91福利区| 色一区在线观看| 国产日韩欧美麻豆| 日日噜噜夜夜狠狠视频欧美人 | 国产91精品一区二区麻豆网站| 在线看国产一区| 国产日韩欧美麻豆| 美女网站一区二区| 欧美色爱综合网| 国产精品视频第一区| 精品一区二区三区免费观看| 欧美在线一二三四区| 国产精品全国免费观看高清| 狠狠v欧美v日韩v亚洲ⅴ| 制服丝袜亚洲色图| 亚洲高清免费在线| 日本久久一区二区三区| 国产精品久久久久永久免费观看| 麻豆视频观看网址久久| 欧美美女网站色| 一区二区三区四区亚洲| 91在线高清观看| 中文字幕一区二区三区在线不卡| 国内精品第一页| 亚洲精品一线二线三线| 免费人成在线不卡| 日韩写真欧美这视频| 亚洲国产日产av| 欧美丝袜丝nylons| 一区二区三区日韩精品| 色哟哟国产精品| 亚洲一区二区视频在线| 91色在线porny| 一区二区三区精品视频在线| 在线亚洲高清视频| 亚洲激情图片一区| 欧美性受极品xxxx喷水| 亚洲成av人片一区二区三区| 欧美日韩一级片在线观看| 亚洲超碰97人人做人人爱| 欧美亚洲国产一区二区三区| 亚洲1区2区3区4区| 7777精品久久久大香线蕉| 七七婷婷婷婷精品国产| 久久久亚洲精品一区二区三区| 国产精品自拍三区| 国产精品欧美经典| 在线观看亚洲a| 亚洲一区在线观看视频| 91精品国产手机| 国产剧情一区二区| 国产精品久久久久四虎| 在线观看成人小视频| 日本强好片久久久久久aaa| 日韩视频中午一区| 国产成人精品三级麻豆| 17c精品麻豆一区二区免费| 欧美日本一区二区| 国产乱码字幕精品高清av | 欧美日韩在线播放| 日本欧美在线观看| 中文字幕不卡的av| 欧美三级韩国三级日本三斤| 狠狠色丁香婷婷综合| 亚洲视频 欧洲视频| 69久久99精品久久久久婷婷| 经典一区二区三区| 欧美韩日一区二区三区四区| 欧美性色黄大片手机版| 精品一区二区三区久久| 亚洲综合男人的天堂| 欧美精品一区二区三区蜜桃视频| 粉嫩嫩av羞羞动漫久久久| 午夜不卡av在线| 2019国产精品| 欧美日韩国产高清一区| 福利一区在线观看| 男女男精品视频网| 亚洲欧美色一区| 久久久久久麻豆| 在线电影一区二区三区| 91亚洲国产成人精品一区二区三| 免费欧美高清视频| 亚洲综合无码一区二区| 2019国产精品| 欧美tk丨vk视频| 7777精品伊人久久久大香线蕉超级流畅 | 成人看片黄a免费看在线| 图片区小说区国产精品视频| 中文字幕av资源一区| 日韩免费视频一区| 欧美高清视频在线高清观看mv色露露十八 | 顶级嫩模精品视频在线看| 日韩影院免费视频| 一区二区理论电影在线观看| 欧美国产精品一区二区| 久久一夜天堂av一区二区三区| 欧美日免费三级在线| 色婷婷一区二区| 大尺度一区二区| 国产乱一区二区| 九九视频精品免费| 日韩和的一区二区| 日日夜夜一区二区| 午夜激情一区二区三区| 亚洲国产成人tv| 亚洲国产精品一区二区www| 依依成人精品视频| 亚洲欧美区自拍先锋| 中文字幕亚洲不卡| 亚洲欧美一区二区视频| 亚洲欧美另类久久久精品2019| 中文字幕在线一区二区三区| 国产精品午夜免费| 亚洲视频精选在线| 亚洲综合男人的天堂| 亚洲午夜久久久久| 午夜成人在线视频| 久久精品久久久精品美女| 久久99久久99| 国产成人精品午夜视频免费| 白白色亚洲国产精品| 日韩视频免费观看高清完整版 | 国产拍欧美日韩视频二区| 久久久久久久久久久久久女国产乱| 久久先锋影音av| 国产精品三级电影| 亚洲另类色综合网站| 日韩精品免费专区| 久草在线在线精品观看| 粉嫩aⅴ一区二区三区四区| 99视频热这里只有精品免费| 91福利在线播放| 91精品国产一区二区三区蜜臀| 精品国产伦一区二区三区观看体验 | 手机精品视频在线观看| 久久99精品一区二区三区| 福利一区二区在线| 欧美视频一区二区三区| 精品剧情v国产在线观看在线| 久久综合色播五月| 亚洲欧美日韩中文播放| 青青国产91久久久久久| 夫妻av一区二区| 欧美另类高清zo欧美| 久久久91精品国产一区二区三区| 亚洲乱码精品一二三四区日韩在线| 日本欧美大码aⅴ在线播放| 丰满少妇久久久久久久| 欧美日韩在线亚洲一区蜜芽| 欧美mv和日韩mv国产网站| 亚洲日本va在线观看| 激情久久久久久久久久久久久久久久| 99久久久无码国产精品| 日韩欧美成人午夜| 一区二区三区高清在线|