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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? guicirc.c

?? 一個(gè)在44b0上移植成功的ucgui
?? 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 "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();
}














?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
97久久超碰国产精品| 亚洲国产日韩精品| 国产成人欧美日韩在线电影| 久久久久久久久久看片| 国产乱码精品一区二区三区五月婷| 欧美r级电影在线观看| 国产一区日韩二区欧美三区| 欧美精彩视频一区二区三区| 国产成人午夜精品5599 | 69堂亚洲精品首页| 日韩成人av影视| 国产亚洲一区字幕| 97aⅴ精品视频一二三区| 亚洲超丰满肉感bbw| 日韩欧美一区中文| 粉嫩蜜臀av国产精品网站| 亚洲免费在线视频一区 二区| 欧美性xxxxxxxx| 极品美女销魂一区二区三区免费| 国产精品污污网站在线观看 | 欧美日韩中文一区| 美女脱光内衣内裤视频久久影院| 国产午夜精品久久久久久久 | 日本最新不卡在线| 久久精品亚洲精品国产欧美kt∨| 99久久精品免费看| 麻豆精品一区二区| 亚洲日本va在线观看| 日韩一区二区三区四区 | 国产**成人网毛片九色 | 高清成人在线观看| 亚洲444eee在线观看| 国产欧美va欧美不卡在线| 欧美三级在线视频| 丁香一区二区三区| 免费在线看一区| 亚洲免费观看在线观看| 欧美成人一区二区三区 | 91精品国产乱码久久蜜臀| 波多野结衣中文字幕一区 | 亚洲三级在线免费| 日韩精品一区在线| 欧美日韩色综合| 91蜜桃在线观看| 国产精品91xxx| 麻豆精品蜜桃视频网站| 夜夜精品视频一区二区| 中文字幕二三区不卡| 精品久久久三级丝袜| 欧美日韩一区二区三区四区 | 久久99国产精品久久| 亚洲在线免费播放| 亚洲欧美日韩人成在线播放| 久久久久久久久久久黄色| 欧美一级夜夜爽| 欧美日韩在线观看一区二区| 99re6这里只有精品视频在线观看 99re8在线精品视频免费播放 | 国产清纯白嫩初高生在线观看91| 欧美高清视频在线高清观看mv色露露十八| 成人黄色一级视频| 成人免费看视频| 国产成人av一区| 国产精品18久久久久久久久久久久 | 制服.丝袜.亚洲.另类.中文 | 久久99在线观看| 日韩影院免费视频| 天堂成人国产精品一区| 亚洲大片免费看| 亚洲国产wwwccc36天堂| 亚洲国产日韩一区二区| 一区二区三区高清| 亚洲国产成人精品视频| 亚洲午夜久久久久久久久电影网 | www.欧美亚洲| 92国产精品观看| 色综合激情五月| 色综合咪咪久久| 色呦呦网站一区| 在线观看国产日韩| 国产亚洲欧美日韩在线一区| 欧美一区二区三区在线观看| 91精品国产全国免费观看| 4438亚洲最大| 精品久久久久一区| 久久免费国产精品| 国产精品美女久久福利网站| 亚洲欧美怡红院| 一区二区在线看| 亚洲国产日日夜夜| 蜜臀av国产精品久久久久 | 久久精品国产999大香线蕉| 麻豆成人久久精品二区三区红 | 激情综合色丁香一区二区| 久久精品国产精品亚洲综合| 国内成人免费视频| 成人精品小蝌蚪| 欧美羞羞免费网站| 精品日韩一区二区三区免费视频| 久久久美女毛片| 亚洲美女免费在线| 三级不卡在线观看| 国产成人综合在线播放| www.爱久久.com| 欧美系列日韩一区| 日韩视频免费直播| 久久精品欧美一区二区三区麻豆| √…a在线天堂一区| 天天综合色天天综合| 国产酒店精品激情| 欧美在线观看一区二区| 精品久久久久久久一区二区蜜臀| 国产欧美一区二区精品婷婷| 亚洲精品亚洲人成人网| 免费人成在线不卡| 成人网页在线观看| 制服丝袜一区二区三区| 国产精品视频第一区| 午夜伦理一区二区| 国产盗摄一区二区三区| 欧美日韩亚洲高清一区二区| 久久精品欧美一区二区三区麻豆| 自拍偷拍国产亚洲| 精品一区二区精品| 欧美性大战久久久久久久蜜臀| 亚洲精品一区在线观看| 樱花影视一区二区| 国产不卡视频在线播放| 91麻豆精品国产无毒不卡在线观看| 久久久久国产免费免费| 午夜亚洲国产au精品一区二区| 国产成人av一区| 日韩一本二本av| 亚洲午夜av在线| 成人18视频在线播放| 精品粉嫩超白一线天av| 亚洲午夜久久久久久久久久久| 国产91精品一区二区麻豆网站| 91精品国产综合久久久蜜臀图片| 国产精品高潮呻吟久久| 激情久久五月天| 欧美高清dvd| 亚洲激情av在线| eeuss影院一区二区三区| 日韩精品一区二区三区在线观看| 亚洲一区二区三区不卡国产欧美| 成人精品高清在线| 国产性做久久久久久| 久久er99热精品一区二区| 欧美美女一区二区三区| 亚洲精品日韩专区silk| 成人黄色一级视频| 欧美激情一区三区| 国产一区二区导航在线播放| 欧美一区二区不卡视频| 丝袜美腿高跟呻吟高潮一区| 91久久国产最好的精华液| 日韩精品欧美成人高清一区二区| 成人精品小蝌蚪| 国产校园另类小说区| 国产精品白丝av| 久久精品欧美一区二区三区麻豆| 久久精品国产免费看久久精品| 欧美一区永久视频免费观看| 性久久久久久久久| 69堂国产成人免费视频| 天堂资源在线中文精品| 欧美日韩国产成人在线免费| 三级亚洲高清视频| 欧美一区二区视频在线观看2022 | 国内精品在线播放| 国产亚洲一区字幕| 成人丝袜高跟foot| 日韩毛片一二三区| 91视频免费观看| 亚洲免费av在线| 欧美日韩一区二区三区在线 | 欧美日韩精品三区| 青青草一区二区三区| 91精品国产综合久久久久久漫画 | 日日夜夜一区二区| 欧美一区二区免费观在线| 久久精品国产网站| 国产情人综合久久777777| av影院午夜一区| 一区二区三区四区在线播放| 欧美在线你懂得| 另类欧美日韩国产在线| 久久久久久一二三区| 成人夜色视频网站在线观看| 亚洲天堂免费看| 欧美日韩久久久久久| 久久99国产精品麻豆| 国产精品嫩草影院com| 欧美亚洲禁片免费| 久久成人羞羞网站| 综合激情成人伊人| 欧美日韩亚洲另类| 国产一区二区精品久久| 亚洲日本va在线观看| 欧美一卡在线观看|