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

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

?? gui_basic_.c

?? 基于飛利浦ARM7 LPC214X的u/COS+GUI
?? C
?? 第 1 頁 / 共 4 頁
字號:
/****************************************************************************************
* 文件名:GUI_BASIC.C
* 功能:GUI基本繪圖函數。進行基本繪圖運算,并調用相應的刷新程序更新LCD顯示。
* 日期:2004.02.26
* 備注:圖形操作層,進行各種圖形運算操作。
****************************************************************************************/
#include "..\APP\config.h"


/****************************************************************************
* 名稱:GUI_Rectangle()
* 功能:畫矩形。
* 入口參數: x0		矩形左上角的x坐標值
*           y0		矩形左上角的y坐標值
*           x1      矩形右下角的x坐標值
*           y1      矩形右下角的y坐標值
*           color	顯示顏色
* 出口參數:無
* 說明:操作失敗原因是指定地址超出有效范圍。
****************************************************************************/
void  GUI_Rectangle(uint8 x0, uint8 y0, uint8 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(uint8 x0, uint8 y0, uint8 x1, uint8 y1, TCOLOR color)
{  uint8  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(uint8 x0, uint8 y0, uint8  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(uint8 x0, uint8 y0, uint8 x1, uint8 y1, TCOLOR color)
{  int8   dx;						// 直線x軸差值變量
   int8   dy;          			// 直線y軸差值變量
   int8    dx_sym;					// x軸增長方向,為-1時減值方向,為1時增值方向
   int8    dy_sym;					// y軸增長方向,為-1時減值方向,為1時增值方向
   int8   dx_x2;					// dx*2值變量,用于加快運算速度
   int8   dy_x2;					// dy*2值變量,用于加快運算速度
   int8   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(uint8  *points, uint8 no, TCOLOR color)
{  uint8  x0, y0;
   uint8  x1, y1;
   uint8  i;

   /* 入口參數過濾 */
   if(0==no) return;
   if(1==no)						// 單點
   {  x0 = *points++;
      y0 = *points;
      GUI_Point(x0, y0, color);
   }
   
   /* 畫多條線條 */
   x0 = *points++;					// 取出第一點坐標值,作為原起點坐標值
   y0 = *points++;
   for(i=1; i<no; i++)
   {  x1 = *points++;				// 取出下一點坐標值
      y1 = *points++;
      GUI_Line(x0, y0, x1, y1, color);
      x0 = x1;						// 更新原起點坐標
      y0 = y1;
   }
}



#if  GUI_CircleX_EN==1
/****************************************************************************
* 名稱:GUI_Circle()
* 功能:指定圓心位置及半徑,畫圓。
* 入口參數: x0		圓心的x坐標值
*           y0		圓心的y坐標值
*           r       圓的半徑
*           color	顯示顏色
* 出口參數:無
* 說明:操作失敗原因是指定地址超出有效范圍。
****************************************************************************/
void  GUI_Circle(uint32 x0, uint32 y0, uint32 r, TCOLOR color)
{  int32  draw_x0, draw_y0;			// 劊圖點坐標變量
   int32  draw_x1, draw_y1;	
   int32  draw_x2, draw_y2;	
   int32  draw_x3, draw_y3;	
   int32  draw_x4, draw_y4;	
   int32  draw_x5, draw_y5;	
   int32  draw_x6, draw_y6;	
   int32  draw_x7, draw_y7;	
   int32  xx, yy;					// 畫圓控制變量
 
   int32  di;						// 決策變量
   
   /* 參數過濾 */
   if(0==r) return;
   
   /* 計算出8個特殊點(0、45、90、135、180、225、270度),進行顯示 */
   draw_x0 = draw_x1 = x0;
   draw_y0 = draw_y1 = y0 + r;
   if(draw_y0<GUI_LCM_YMAX) GUI_Point(draw_x0, draw_y0, color);	// 90度
	
   draw_x2 = draw_x3 = x0;
   draw_y2 = draw_y3 = y0 - r;
   if(draw_y2>=0) GUI_Point(draw_x2, draw_y2, color);			// 270度
   
	
   draw_x4 = draw_x6 = x0 + r;
   draw_y4 = draw_y6 = y0;
   if(draw_x4<GUI_LCM_XMAX) GUI_Point(draw_x4, draw_y4, color);	// 0度
   
   draw_x5 = draw_x7 = x0 - r;
   draw_y5 = draw_y7 = y0;
   if(draw_x5>=0) GUI_Point(draw_x5, draw_y5, color);			// 180度   
   if(1==r) return;					// 若半徑為1,則已圓畫完
   
   
   /* 使用Bresenham法進行畫圓 */
   di = 3 - 2*r;					// 初始化決策變量
   
   xx = 0;
   yy = r;	
   while(xx<yy)
   {  if(di<0)
	  {  di += 4*xx + 6;	      
	  }
	  else
	  {  di += 4*(xx - yy) + 10;
	  
	     yy--;	  
		 draw_y0--;
		 draw_y1--;
		 draw_y2++;
		 draw_y3++;
		 draw_x4--;
		 draw_x5++;
		 draw_x6--;
		 draw_x7++;	 	
	  }
	  
	  xx++;   
	  draw_x0++;
	  draw_x1--;
	  draw_x2++;
	  draw_x3--;
	  draw_y4++;
	  draw_y5++;
	  draw_y6--;
	  draw_y7--;
		
	
	  /* 要判斷當前點是否在有效范圍內 */
	  if( (draw_x0<=GUI_LCM_XMAX)&&(draw_y0>=0) )	
	  {  GUI_Point(draw_x0, draw_y0, color);
	  }	    
	  if( (draw_x1>=0)&&(draw_y1>=0) )	
	  {  GUI_Point(draw_x1, draw_y1, color);
	  }
	  if( (draw_x2<=GUI_LCM_XMAX)&&(draw_y2<=GUI_LCM_YMAX) )	
	  {  GUI_Point(draw_x2, draw_y2, color);   
	  }
	  if( (draw_x3>=0)&&(draw_y3<=GUI_LCM_YMAX) )	
	  {  GUI_Point(draw_x3, draw_y3, color);
	  }
	  if( (draw_x4<=GUI_LCM_XMAX)&&(draw_y4>=0) )	
	  {  GUI_Point(draw_x4, draw_y4, color);
	  }
	  if( (draw_x5>=0)&&(draw_y5>=0) )	
	  {  GUI_Point(draw_x5, draw_y5, color);
	  }
	  if( (draw_x6<=GUI_LCM_XMAX)&&(draw_y6<=GUI_LCM_YMAX) )	
	  {  GUI_Point(draw_x6, draw_y6, color);
	  }
	  if( (draw_x7>=0)&&(draw_y7<=GUI_LCM_YMAX) )	
	  {  GUI_Point(draw_x7, draw_y7, color);
	  }
   }
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品自产自拍| 国产精品午夜久久| 91精品国产综合久久香蕉麻豆| 色成人在线视频| 91蜜桃在线观看| 色婷婷久久久亚洲一区二区三区| www.欧美色图| av一二三不卡影片| 99国产精品国产精品毛片| 色综合久久综合中文综合网| 91精品福利在线| 欧美精品一卡二卡| 日韩欧美在线网站| 久久久国产综合精品女国产盗摄| 久久久亚洲欧洲日产国码αv| 久久精品日韩一区二区三区| 国产精品日韩成人| 亚洲免费观看高清在线观看| 亚洲电影一区二区三区| 日韩不卡一二三区| 精品在线亚洲视频| 国产成人精品影院| 色婷婷久久久综合中文字幕 | 国产成人精品三级麻豆| 成人性生交大片| 91麻豆蜜桃一区二区三区| 欧美日韩国产经典色站一区二区三区 | 国产999精品久久久久久绿帽| 成人高清视频在线观看| 91丨九色丨尤物| 欧美日韩大陆一区二区| 日韩视频在线观看一区二区| 久久久亚洲精品石原莉奈| 中文字幕日韩一区二区| 亚洲线精品一区二区三区| 九九久久精品视频| a亚洲天堂av| 制服丝袜中文字幕亚洲| 国产无遮挡一区二区三区毛片日本| 最新久久zyz资源站| 五月婷婷综合在线| 国产精品一区二区男女羞羞无遮挡 | 亚洲成在线观看| 国产在线精品免费| 色综合久久综合网97色综合| 日韩欧美不卡在线观看视频| 国产精品国产三级国产aⅴ无密码 国产精品国产三级国产aⅴ原创 | 久久影院视频免费| 亚洲综合小说图片| 久久电影国产免费久久电影| 91浏览器在线视频| 精品捆绑美女sm三区| 亚洲日本中文字幕区| 蜜臀99久久精品久久久久久软件| 99久久精品免费看国产免费软件| 欧美一区二区三区白人| 综合色中文字幕| 国产又黄又大久久| 欧美日韩大陆一区二区| 国产精品免费观看视频| 日韩精品乱码av一区二区| 99久久伊人久久99| 日韩视频免费观看高清完整版在线观看 | 色诱视频网站一区| 久久综合久久99| 午夜影院久久久| 91在线码无精品| 久久久不卡网国产精品二区| 石原莉奈在线亚洲三区| hitomi一区二区三区精品| 26uuu国产电影一区二区| 亚洲成年人网站在线观看| 99久久亚洲一区二区三区青草| 精品成人佐山爱一区二区| 亚洲国产日韩在线一区模特| 成人a级免费电影| 精品国产不卡一区二区三区| 午夜视频一区二区三区| 日本精品免费观看高清观看| 国产欧美综合在线| 精品一区二区在线看| 91精品一区二区三区在线观看| 亚洲一区影音先锋| 91丨九色丨蝌蚪丨老版| 一区在线播放视频| 成人av资源在线观看| 日本一区二区三区高清不卡| 国产乱妇无码大片在线观看| 欧美成人免费网站| 麻豆国产欧美一区二区三区| 日韩午夜精品视频| 日韩有码一区二区三区| 制服丝袜在线91| 日本不卡的三区四区五区| 欧美日韩五月天| 亚洲一区二区精品视频| 欧美性色aⅴ视频一区日韩精品| 亚洲三级在线播放| 色综合天天天天做夜夜夜夜做| 亚洲婷婷综合久久一本伊一区 | 2023国产精品| 国内精品在线播放| 久久亚洲精品国产精品紫薇| 国产一区二区三区精品欧美日韩一区二区三区 | 美女被吸乳得到大胸91| 91精品国产综合久久久蜜臀粉嫩| 视频一区中文字幕国产| 91精品国产综合久久蜜臀| 青青草国产成人99久久| 日韩一级片在线观看| 精彩视频一区二区三区| 国产日产欧美一区二区三区 | 国产日产亚洲精品系列| 东方欧美亚洲色图在线| 中文字幕av一区二区三区免费看| 国产成人亚洲综合a∨猫咪| 国产女人水真多18毛片18精品视频| 国产成人一区在线| 中文字幕在线不卡一区二区三区| 91丨国产丨九色丨pron| 亚洲午夜激情av| 日韩一区二区在线观看视频 | 成人精品鲁一区一区二区| 国产精品嫩草影院av蜜臀| 91在线你懂得| 午夜精彩视频在线观看不卡| 日韩欧美色综合| 国产精品一区二区男女羞羞无遮挡| 国产精品伦理在线| 色欧美乱欧美15图片| 日韩电影在线免费看| 久久婷婷综合激情| 99re亚洲国产精品| 亚洲成a人片综合在线| 精品成人佐山爱一区二区| 不卡的av电影在线观看| 夜夜夜精品看看| 欧美va亚洲va| 99v久久综合狠狠综合久久| 午夜欧美电影在线观看| 国产丝袜美腿一区二区三区| 色综合久久久久久久久久久| 美女在线一区二区| 国产精品动漫网站| 欧美久久一区二区| 国产成人精品免费网站| 亚洲一区二区三区精品在线| 欧美精品一区二区在线播放 | 精品成人一区二区三区四区| 不卡一区二区在线| 日日夜夜精品视频免费| 国产日本欧洲亚洲| 欧美色精品在线视频| 韩国女主播一区| 亚洲一区二区中文在线| 久久蜜桃av一区二区天堂| 色偷偷一区二区三区| 激情综合网av| 亚洲国产裸拍裸体视频在线观看乱了| 精品国产一区二区国模嫣然| 91蜜桃婷婷狠狠久久综合9色| 久久超碰97中文字幕| 亚洲男人电影天堂| 久久久久久久久久美女| 欧美日韩中文字幕一区二区| 国产成人av电影在线| 男女性色大片免费观看一区二区| 亚洲男人的天堂网| 久久青草欧美一区二区三区| 欧美剧情电影在线观看完整版免费励志电影| 国产福利一区二区三区视频| 亚洲午夜电影网| 国产精品久久一卡二卡| 精品日韩欧美在线| 精品视频免费看| 91免费小视频| 国产成人午夜99999| 日本在线播放一区二区三区| 一区二区在线观看视频| 国产精品色哟哟网站| 久久综合色播五月| 欧美一级午夜免费电影| 欧美日韩国产色站一区二区三区| 91在线观看视频| 国产v综合v亚洲欧| 国产一区欧美一区| 久久草av在线| 男人的天堂亚洲一区| 午夜亚洲国产au精品一区二区| 综合分类小说区另类春色亚洲小说欧美| 久久伊人中文字幕| 精品国产一区二区三区忘忧草 | 日本中文字幕一区二区有限公司| 亚洲激情中文1区| **网站欧美大片在线观看| 欧美激情一区二区三区全黄| 久久精品夜色噜噜亚洲aⅴ| 日韩一级完整毛片| 日韩写真欧美这视频| 91精品国产高清一区二区三区 |