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

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

?? gui.c

?? LCD.rar
?? C
?? 第 1 頁 / 共 5 頁
字號:
/****************************************************************************************
* 文件名:GUI.C
* 功能:GUI基本繪圖函數。進行基本繪圖運算,并調用相應的刷新程序更新LCD顯示。
* 作者:黃紹斌
* 修改:馮建輝
* 日期:2006.09.13
* 備注:圖形操作層,進行各種圖形運算操作。
****************************************************************************************/
#include "gui.h"
#include <math.h>

/****************************************************************************
* 名稱:GUI_HLine()
* 功能:畫水平線。
* 入口參數:x0		水平線起點所在列的位置
*           y0		水平線起點所在行的位置
*           x1          水平線終點所在列的位置
*           color	顯示顏色(對于黑白色LCM,為0時滅,為1時顯示)
* 出口參數:無
* 說明:操作失敗原因是指定地址超出緩沖區范圍。
****************************************************************************/
void  GUI_HLine(unsigned int x0, unsigned char y0, unsigned int x1, TCOLOR color)
{
    unsigned char  bak;
    if(x0>x1) 				// 對x0、x1大小進行排列,以便畫圖
    {
        bak = x1;
        x1 = x0;
        x0 = bak;
    }   
    do
    {
        GUI_Point(x0, y0, color);	// 逐點顯示,描出垂直線
        x0++;
    }
    while(x1>=x0);
}

/***********************************************************************
* 名稱:GUI_RLine()
* 功能:畫豎直線。根據硬件特點,實現加速。
* 入口參數:x0		垂直線起點所在列的位置
*           y0		垂直線起點所在行的位置
*           y1          垂直線終點所在行的位置
*           color	顯示顏色(對于黑白色LCM,為0時滅,為1時顯示)
* 出口參數:	無
* 說明:操作失敗原因是指定地址超出緩沖區范圍。
***********************************************************************/
void  GUI_RLine(unsigned int x0, unsigned char y0, unsigned char y1, TCOLOR color)
{
    unsigned char  bak;
    if(y0>y1)                           // 對y0、y1大小進行排列,以便畫圖
    {
        bak = y1;
        y1 = y0;
        y0 = bak;
    }
    do
    {
        GUI_Point(x0, y0, color);	// 逐點顯示,描出垂直線
        y0++;
    }
    while(y1>=y0);
}

/****************************************************************************
* 名稱:GUI_Rectangle()
* 功能:畫矩形。
* 入口參數:x0		矩形左上角的x坐標值
*           y0		矩形左上角的y坐標值
*           x1          矩形右下角的x坐標值
*           y1          矩形右下角的y坐標值
*           color	顯示顏色
* 出口參數:無
* 說明:操作失敗原因是指定地址超出有效范圍。
****************************************************************************/
void  GUI_Rectangle(uint16 x0, uint8 y0, uint16 x1, uint8 y1, TCOLOR color)
{
   GUI_HLine(x0, y0, x1, color);
   GUI_HLine(x0, y1, x1, color);
   GUI_RLine(x0, y0, y1, color);
   GUI_RLine(x1, y0, y1, color);
}

/****************************************************************************
* 名稱:GUI_RectangleFill()
* 功能:填充矩形。畫一個填充的矩形,填充色與邊框色一樣。
* 入口參數:x0		矩形左上角的x坐標值
*           y0		矩形左上角的y坐標值
*           x1          矩形右下角的x坐標值
*           y1          矩形右下角的y坐標值
*           color	填充顏色
* 出口參數:無
* 說明:操作失敗原因是指定地址超出有效范圍。
****************************************************************************/
void  GUI_RectangleFill(uint16 x0, uint8 y0, uint16 x1, uint8 y1, TCOLOR color)
{
   uint32  i;

   /* 先找出矩形左上角與右下角的兩個點,保存在(x0,y0),(x1,y1) */
   if(x0>x1) 						// 若x0>x1,則x0與x1交換
   {
      i = x0;
      x0 = x1;
      x1 = i;
   }
   if(y0>y1)						// 若y0>y1,則y0與y1交換
   {
      i = y0;
      y0 = y1;
      y1 = i;
   }
   
   /* 判斷是否只是直線 */
   if(y0==y1) 
   {
      GUI_HLine(x0, y0, x1, color);
      return;
   }
   if(x0==x1) 
   {
      GUI_RLine(x0, y0, y1, color);
      return;
   }

   while(y0<=y1)						
   {
      GUI_HLine(x0, y0, x1, color);	                        // 當前畫水平線
      y0++;							// 下一行
   }
}

/****************************************************************************
* 名稱:GUI_Square()
* 功能:畫正方形。
* 入口參數:x0		正方形左上角的x坐標值
*           y0		正方形左上角的y坐標值
*           with        正方形的邊長
*           color	顯示顏色
* 出口參數:無
* 說明:操作失敗原因是指定地址超出有效范圍。
****************************************************************************/
void  GUI_Square(uint32 x0, uint32 y0, uint32  with, TCOLOR  color)
{
   if(with==0)
      return;
   if( (x0+with) > GUI_LCM_XMAX )
      return;
   if( (y0+with) > GUI_LCM_YMAX )
      return;
   GUI_Rectangle(x0, y0, x0+with, y0+with, color);
}



/****************************************************************************
* 名稱:GUI_Line()
* 功能:畫任意兩點之間的直線。
* 入口參數:x0		直線起點的x坐標值
*           y0		直線起點的y坐標值
*           x1          直線終點的x坐標值
*           y1          直線終點的y坐標值
*           color	顯示顏色(對于黑白色LCM,為0時滅,為1時顯示)
* 出口參數:無
* 說明:操作失敗原因是指定地址超出有效范圍。
****************************************************************************/
void  GUI_Line(uint32 x0, uint32 y0, uint32 x1, uint32 y1, TCOLOR color)
{
   int32   dx;						// 直線x軸差值變量
   int32   dy;          			        // 直線y軸差值變量
   int8    dx_sym;					// x軸增長方向,為-1時減值方向,為1時增值方向
   int8    dy_sym;					// y軸增長方向,為-1時減值方向,為1時增值方向
   int32   dx_x2;					// dx*2值變量,用于加快運算速度
   int32   dy_x2;					// dy*2值變量,用于加快運算速度
   int32   di;						// 決策變量

   dx = x1-x0;						// 求取兩點之間的差值
   dy = y1-y0;
   
   /* 判斷增長方向,或是否為水平線、垂直線、點 */
   if(dx>0)						// 判斷x軸方向
   {
      dx_sym = 1;					// dx>0,設置dx_sym=1
   }
   else
   {
      if(dx<0)
      {
         dx_sym = -1;				        // dx<0,設置dx_sym=-1
      }
      else
      {  // dx==0,畫垂直線,或一點
         GUI_RLine(x0, y0, y1, color);
      	 return;
      }
   }
   
   if(dy>0)						// 判斷y軸方向
   {
      dy_sym = 1;					// dy>0,設置dy_sym=1
   }
   else
   {
      if(dy<0)
      {
         dy_sym = -1;				        // dy<0,設置dy_sym=-1
      }
      else
      {  // dy==0,畫水平線,或一點
         GUI_HLine(x0, y0, x1, color);
      	 return;
      }
   }
    
   /* 將dx、dy取絕對值 */
   dx = dx_sym * dx;
   dy = dy_sym * dy;
 
   /* 計算2倍的dx及dy值 */
   dx_x2 = dx*2;
   dy_x2 = dy*2;
   
   /* 使用Bresenham法進行畫直線 */
   if(dx>=dy)						// 對于dx>=dy,則使用x軸為基準
   {
      di = dy_x2 - dx;
      while(x0!=x1)
      {
         GUI_Point(x0, y0, color);
         x0 += dx_sym;
         if(di<0)
         {
            di += dy_x2;			        // 計算出下一步的決策值
         }
         else
         {
            di += dy_x2 - dx_x2;
            y0 += dy_sym;
         }
      }
      GUI_Point(x0, y0, color);		                // 顯示最后一點
   }
   else							// 對于dx<dy,則使用y軸為基準
   {
      di = dx_x2 - dy;
      while(y0!=y1)
      {
         GUI_Point(x0, y0, color);
         y0 += dy_sym;
         if(di<0)
         {
            di += dx_x2;
         }
         else
         {
            di += dx_x2 - dy_x2;
            x0 += dx_sym;
         }
      }
      GUI_Point(x0, y0, color);		// 顯示最后一點
   }
}


#if	GUI_LineWith_EN==1
/****************************************************************************
* 名稱:GUI_LineWith()
* 功能:畫任意兩點之間的直線,并且可設置線的寬度。
* 入口參數:x0		直線起點的x坐標值
*           y0		直線起點的y坐標值
*           x1          直線終點的x坐標值
*           y1          直線終點的y坐標值
*           with        線寬(0-50)
*           color	顯示顏色
* 出口參數:無
* 說明:操作失敗原因是指定地址超出有效范圍。
****************************************************************************/
void  GUI_LineWith(uint32 x0, uint32 y0, uint32 x1, uint32 y1, uint8 with, TCOLOR color)
{
   int32   dx;						// 直線x軸差值變量
   int32   dy;          			        // 直線y軸差值變量
   int8    dx_sym;					// x軸增長方向,為-1時減值方向,為1時增值方向
   int8    dy_sym;					// y軸增長方向,為-1時減值方向,為1時增值方向
   int32   dx_x2;					// dx*2值變量,用于加快運算速度
   int32   dy_x2;					// dy*2值變量,用于加快運算速度
   int32   di;						// 決策變量
   
   int32   wx, wy;					// 線寬變量
   int32   draw_a, draw_b;
   
   /* 參數過濾 */
   if(with==0)
      return;
   if(with>50)
      with = 50;
   
   dx = x1-x0;						// 求取兩點之間的差值
   dy = y1-y0;
   
   wx = with/2;
   wy = with-wx-1;
   
   /* 判斷增長方向,或是否為水平線、垂直線、點 */
   if(dx>0)						// 判斷x軸方向
   {
      dx_sym = 1;					// dx>0,設置dx_sym=1
   }
   else
   {
      if(dx<0)
      {
         dx_sym = -1;				        // dx<0,設置dx_sym=-1
      }
      else
      {  /* dx==0,畫垂直線,或一點 */
         wx = x0-wx;
         if(wx<0)
            wx = 0;
         wy = x0+wy;
         
         while(1)
         {
            x0 = wx;
            GUI_RLine(x0, y0, y1, color);
            if(wx>=wy)
               break;
            wx++;
         }
      	 return;
      }
   }
   
   if(dy>0)						// 判斷y軸方向
   {
      dy_sym = 1;					// dy>0,設置dy_sym=1
   }
   else
   {
      if(dy<0)
      {
         dy_sym = -1;				        // dy<0,設置dy_sym=-1
      }
      else
      {  /* dy==0,畫水平線,或一點 */
         wx = y0-wx;
         if(wx<0) wx = 0;
         wy = y0+wy;
         
         while(1)
         {
            y0 = wx;
            GUI_HLine(x0, y0, x1, color);
            if(wx>=wy)
               break;
            wx++;
         }
      	 return;
      }
   }
    
   /* 將dx、dy取絕對值 */
   dx = dx_sym * dx;
   dy = dy_sym * dy;
 
   /* 計算2倍的dx及dy值 */
   dx_x2 = dx*2;
   dy_x2 = dy*2;
   
   /* 使用Bresenham法進行畫直線 */
   if(dx>=dy)						// 對于dx>=dy,則使用x軸為基準
   {
      di = dy_x2 - dx;
      while(x0!=x1)
      {  /* x軸向增長,則寬度在y方向,即畫垂直線 */
         draw_a = y0-wx;
         if(draw_a<0) draw_a = 0;
         draw_b = y0+wy;
         GUI_RLine(x0, draw_a, draw_b, color);
         
         x0 += dx_sym;				
         if(di<0)
         {
            di += dy_x2;			        // 計算出下一步的決策值
         }
         else
         {
            di += dy_x2 - dx_x2;
            y0 += dy_sym;
         }
      }
      draw_a = y0-wx;
      if(draw_a<0)
         draw_a = 0;
      draw_b = y0+wy;
      GUI_RLine(x0, draw_a, draw_b, color);
   }
   else							// 對于dx<dy,則使用y軸為基準
   {
      di = dx_x2 - dy;
      while(y0!=y1)
      {  /* y軸向增長,則寬度在x方向,即畫水平線 */
         draw_a = x0-wx;
         if(draw_a<0)
            draw_a = 0;
         draw_b = x0+wy;
         GUI_HLine(draw_a, y0, draw_b, color);
         
         y0 += dy_sym;
         if(di<0)
         {
            di += dx_x2;
         }
         else
         {
            di += dx_x2 - dy_x2;
            x0 += dx_sym;
         }
      }
      draw_a = x0-wx;
      if(draw_a<0)
         draw_a = 0;
      draw_b = x0+wy;
      GUI_HLine(draw_a, y0, draw_b, color);
   }
}
#endif

/****************************************************************************
* 名稱:GUI_LineS()
* 功能:多個點之間的連續連線。從第一點連到第二點,再連到第三點...
* 入口參數:points      多個點坐標數據的指針,數據排列為(x0,y0)、(x1,y1)、(x2,y2)...
*           no          點數目,至少要大于1
*           color	顯示顏色
* 出口參數:無
* 說明:操作失敗原因是指定地址超出有效范圍。
****************************************************************************/
void  GUI_LineS(uint32 const *points, uint8 no, TCOLOR color)
{
   uint32  x0, y0;
   uint32  x1, y1;
   uint8   i;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
蜜臂av日日欢夜夜爽一区| 欧美一级在线免费| 国产精品国产馆在线真实露脸 | 亚洲视频电影在线| 91在线视频官网| 亚洲福中文字幕伊人影院| 欧美精品视频www在线观看| 日韩精品一区第一页| 日韩欧美电影一二三| 国产成人综合亚洲91猫咪| 国产三级精品三级在线专区| jlzzjlzz亚洲女人18| 成人免费一区二区三区视频| 在线一区二区视频| 欧美aaaaaa午夜精品| 国产精品视频观看| 91福利在线播放| 久久草av在线| 专区另类欧美日韩| 欧美剧情片在线观看| 国产在线精品一区在线观看麻豆| 中文无字幕一区二区三区| 色欧美日韩亚洲| 裸体在线国模精品偷拍| 国产精品美女www爽爽爽| 欧美日韩精品一区二区在线播放| 精彩视频一区二区三区| 中文字幕亚洲一区二区av在线 | 韩国一区二区在线观看| 国产精品久久777777| 欧美三级电影在线看| 国产精品一区在线| 亚洲激情校园春色| 国产亚洲综合性久久久影院| 99免费精品在线| 免费人成精品欧美精品| 中文字幕乱码亚洲精品一区| 欧美精品一级二级三级| 成人国产精品免费观看动漫| 日本不卡视频在线| 亚洲免费大片在线观看| 久久蜜桃av一区精品变态类天堂| 99久久国产综合精品麻豆| 久久精品99国产精品| 亚洲成人自拍网| 国产精品国产馆在线真实露脸 | 色婷婷综合久久| 久久 天天综合| 亚洲一区免费在线观看| 国产性天天综合网| 日韩丝袜情趣美女图片| 91久久精品午夜一区二区| 国产白丝网站精品污在线入口 | 99re视频精品| 秋霞午夜鲁丝一区二区老狼| 亚洲欧洲另类国产综合| 久久理论电影网| 欧美草草影院在线视频| 欧美视频一区二区在线观看| 91影视在线播放| 懂色av中文一区二区三区| 久久www免费人成看片高清| 日韩av一级电影| 五月激情综合网| 午夜视频一区在线观看| 夜夜嗨av一区二区三区中文字幕| 国产精品久久精品日日| 国产精品不卡视频| 中文字幕一区二区三区在线播放| 亚洲国产精品t66y| 国产日韩视频一区二区三区| 国产午夜亚洲精品理论片色戒 | 中文字幕在线一区二区三区| 久久在线观看免费| 精品国产不卡一区二区三区| 宅男噜噜噜66一区二区66| 欧美三级三级三级| 欧美午夜理伦三级在线观看| 欧美三区免费完整视频在线观看| 在线日韩国产精品| 在线观看视频91| 欧美高清性hdvideosex| 69堂亚洲精品首页| 日韩美女一区二区三区四区| 久久综合色8888| 日本一区二区三区在线观看| 中文字幕一区二区三区蜜月| 一区二区三区在线视频观看| 亚洲国产一区二区三区| 青椒成人免费视频| 狠狠色狠狠色综合系列| 国v精品久久久网| 色综合久久88色综合天天免费| 欧美无乱码久久久免费午夜一区 | 欧美午夜宅男影院| 欧美三级电影网站| 欧美大片免费久久精品三p| 久久亚洲私人国产精品va媚药| 久久久久久久久久久久久夜| 国产精品免费av| 亚洲一区二区综合| 蜜桃av一区二区三区| 成人福利在线看| 在线观看三级视频欧美| 欧美精品久久久久久久多人混战| 欧美xxxxxxxxx| 亚洲欧洲国产专区| 视频一区二区不卡| 成人天堂资源www在线| 欧美图区在线视频| 国产亚洲精品免费| 亚洲电影激情视频网站| 国产精品一卡二卡在线观看| 91在线视频18| 日韩美女在线视频| 亚洲激情校园春色| 狠狠色丁香婷婷综合| 97超碰欧美中文字幕| 欧美一区二区三区在线电影 | 日本精品裸体写真集在线观看| 欧美人与禽zozo性伦| 国产欧美中文在线| 亚洲福中文字幕伊人影院| 国产精品亚洲人在线观看| 日本高清免费不卡视频| 久久亚洲综合色| 亚洲国产精品久久人人爱蜜臀| 国产一区二区日韩精品| 欧美无砖专区一中文字| 国产精品视频免费看| 麻豆极品一区二区三区| 在线观看日韩av先锋影音电影院| 久久夜色精品国产噜噜av| 亚洲国产另类av| aaa欧美大片| 国产视频一区二区在线| 免费美女久久99| 欧美日韩五月天| 国产精品大尺度| 国产成人综合精品三级| 日韩久久久久久| 天天色综合天天| 91成人免费电影| 亚洲色图丝袜美腿| 高清国产午夜精品久久久久久| 日韩欧美不卡在线观看视频| 亚洲成人你懂的| 欧美日韩一区二区在线观看| 最新成人av在线| av激情成人网| 国产精品久久毛片| 国产成人在线视频网址| 2023国产精品| 国产主播一区二区| 久久一日本道色综合| 激情综合色丁香一区二区| 日韩三级精品电影久久久 | 国产福利一区二区三区| 精品久久99ma| 狠狠色丁香久久婷婷综| 久久久亚洲精华液精华液精华液| 免费成人在线播放| 欧美一区二区在线免费观看| 日韩精品欧美精品| 欧美精品在线视频| 亚洲va欧美va国产va天堂影院| 欧美亚洲国产bt| 亚洲一区二区三区视频在线| 欧美在线视频不卡| 亚洲国产精品视频| 91精品国产综合久久久蜜臀图片| 日韩国产欧美在线播放| 在线成人高清不卡| 免费高清视频精品| 欧美精品一区二区精品网| 国产真实乱子伦精品视频| 国产亚洲欧美在线| 91亚洲精品久久久蜜桃| 亚洲一区二区三区国产| 欧美高清视频www夜色资源网| 免费在线观看不卡| 久久久久九九视频| 99久久夜色精品国产网站| 亚洲精品免费在线| 欧美高清激情brazzers| 精品亚洲国产成人av制服丝袜| 久久视频一区二区| av中文字幕亚洲| 亚洲成人免费看| 久久一区二区视频| 日本精品免费观看高清观看| 日韩电影在线一区| 国产日产欧美一区二区视频| 91看片淫黄大片一级| 日本成人在线电影网| 国产日韩欧美一区二区三区乱码 | 国产成人午夜精品5599| 中文字幕一区视频| 欧美美女一区二区在线观看| 久久99精品久久久久久动态图 |