亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
成人精品鲁一区一区二区| 久久99精品一区二区三区 | 国产精品日产欧美久久久久| 亚洲精品福利视频网站| 国产一区二区三区四区五区美女 | 成人深夜在线观看| 91福利视频久久久久| 欧美精品一区二区三区高清aⅴ| 亚洲一区二区三区自拍| 成人一区二区三区视频| 精品国产成人系列| 美女网站色91| 欧美一区午夜视频在线观看| 亚洲天堂2014| 成人看片黄a免费看在线| 精品乱码亚洲一区二区不卡| 日韩中文字幕麻豆| 精品视频免费在线| 亚洲国产欧美在线| 日本精品视频一区二区| 亚洲天堂福利av| 色综合久久久网| 国产精品美女久久久久久久久| 精品亚洲欧美一区| 精品久久久久久久久久久久久久久久久 | 欧美一区二区日韩| 视频一区视频二区中文字幕| 欧美精选一区二区| 天堂午夜影视日韩欧美一区二区| 色综合久久久久综合| 亚洲欧美日韩综合aⅴ视频| 波多野结衣视频一区| 中文子幕无线码一区tr| 99久久精品费精品国产一区二区| 国产精品超碰97尤物18| 91同城在线观看| 亚洲伊人色欲综合网| 欧美人与性动xxxx| 美女一区二区久久| 久久九九影视网| gogogo免费视频观看亚洲一| 亚洲欧洲av一区二区三区久久| 99热国产精品| 亚洲一二三专区| 777午夜精品免费视频| 麻豆专区一区二区三区四区五区| 精品女同一区二区| 成人一区二区视频| 亚洲线精品一区二区三区八戒| 欧美精品久久99久久在免费线| 日本va欧美va精品| 国产亚洲综合性久久久影院| 波多野结衣中文字幕一区二区三区| 综合欧美亚洲日本| 91精品国产综合久久小美女| 国产裸体歌舞团一区二区| 中文字幕一区二区不卡| 欧美日韩高清一区二区不卡| 国产美女主播视频一区| 亚洲同性gay激情无套| 欧美美女激情18p| 国产成人精品免费网站| 亚洲精品免费在线播放| 日韩欧美久久一区| 一本到三区不卡视频| 久久99这里只有精品| 亚洲欧美日韩小说| 久久综合一区二区| 91麻豆.com| 国产精品自产自拍| 亚洲高清一区二区三区| 欧美激情一区二区三区全黄| 欧美日韩你懂的| 99久精品国产| 九九在线精品视频| 亚洲一区二区三区影院| 久久精品欧美一区二区三区麻豆| 色88888久久久久久影院按摩 | 日本高清不卡一区| 国产乱理伦片在线观看夜一区| 亚洲午夜精品在线| 国产精品毛片久久久久久| 日韩精品中文字幕在线不卡尤物| 99热99精品| 懂色av一区二区三区免费看| 视频一区二区三区中文字幕| 亚洲人成精品久久久久| 欧美老女人第四色| 欧洲一区二区三区在线| 极品少妇xxxx精品少妇| 性做久久久久久久免费看| 亚洲色图色小说| 91精品国产免费| 欧美人与z0zoxxxx视频| 成人av高清在线| 国产精品1区2区3区| 石原莉奈在线亚洲二区| 亚洲成av人片| 亚洲人吸女人奶水| 中文字幕一区二区三区在线不卡| 亚洲精品一区二区三区在线观看| 欧美日韩亚洲另类| 色综合天天综合在线视频| 久99久精品视频免费观看| 午夜视频在线观看一区二区 | 国产精品丝袜一区| 久久综合久久鬼色| 日韩欧美亚洲国产另类| 3d成人动漫网站| 欧美乱妇23p| 欧美丰满少妇xxxxx高潮对白| 91福利小视频| 欧美性猛交xxxxxx富婆| 色狠狠色狠狠综合| 欧美亚洲日本一区| 欧美亚洲一区三区| 欧美日本乱大交xxxxx| 欧美一区二区三区思思人| 欧美三级电影网| 欧美日韩在线三区| 91麻豆精品国产无毒不卡在线观看| 在线观看一区二区精品视频| 欧美在线看片a免费观看| 欧美日韩久久久| 正在播放亚洲一区| 欧美一区二区三区在| 日韩精品一区二区在线观看| 久久夜色精品国产欧美乱极品| 精品久久久久久久人人人人传媒| 欧美精品一区二区久久婷婷| 久久精品一区二区三区不卡| 国产精品久久精品日日| 亚洲欧美日韩中文播放| 亚洲成人免费观看| 黄页视频在线91| 懂色av一区二区夜夜嗨| 在线观看成人免费视频| 91精品黄色片免费大全| 久久日韩粉嫩一区二区三区| 国产精品毛片久久久久久久| 夜夜嗨av一区二区三区中文字幕| 亚洲成人av一区二区| 九九在线精品视频| 91麻豆国产自产在线观看| 色综合天天综合色综合av| 欧美日韩欧美一区二区| 欧美xxxxx牲另类人与| 中文字幕一区二区在线播放| 亚洲国产精品久久久男人的天堂| 日本vs亚洲vs韩国一区三区二区| 国产福利一区在线观看| 欧美亚洲综合在线| 国产午夜精品一区二区三区视频 | 欧美日韩一级二级| 日韩欧美你懂的| 一区二区三区在线视频观看| 久久精品国产精品亚洲综合| 波多野结衣91| 欧美本精品男人aⅴ天堂| 亚洲欧洲成人精品av97| 久久精品国产精品亚洲精品| 99re热这里只有精品视频| 91精品国产一区二区三区蜜臀| 国产丝袜在线精品| 日韩电影免费一区| 91尤物视频在线观看| 日韩欧美一区二区三区在线| 国产精品你懂的| 激情文学综合丁香| 欧美日韩中字一区| 中文字幕一区二区三区不卡在线 | 色婷婷国产精品| 国产视频一区二区在线| 日韩精品国产欧美| 欧美又粗又大又爽| 1000部国产精品成人观看| 久久激情五月激情| 欧美日韩三级一区| 亚洲免费伊人电影| 懂色av一区二区三区免费观看| 日韩欧美中文字幕制服| 亚洲不卡在线观看| 91老司机福利 在线| 国产精品区一区二区三| 精品综合免费视频观看| 91精品国产一区二区人妖| 亚洲成av人片www| 91麻豆精品在线观看| 亚洲欧洲av在线| a美女胸又www黄视频久久| 久久精品一区二区三区不卡牛牛| 热久久免费视频| 91精品国产一区二区人妖| 午夜一区二区三区在线观看| 欧美伊人久久久久久久久影院 | www成人在线观看| 蜜臀av一区二区| 精品久久久久久久久久久久包黑料 | 国产.欧美.日韩| 久久久久亚洲综合|