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

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

?? gui_basic.c

?? 本人連續兩天調試UCOSII,將貪吃蛇的任務加到UCOS上,ARM選用的是LPC2414,貪吃蛇的關鍵算法調試得吐血,不過兩天得調試總算有了回報,多任務終于運行了,有四個任務運行,顯示用到了周立功的Z
?? C
?? 第 1 頁 / 共 4 頁
字號:
   
   draw_on = 0;								// 最開始關畫點開關
   /* 設置起始點及終點 */
   if(endangle>stangle) draw_on = 1;		// 若終點大于起點,則從一開始即畫點(359)
   stangle = (360-stangle)*pno_angle/45;
   endangle = (360-endangle)*pno_angle/45;
   if(stangle==0) stangle=1;
   if(endangle==0) endangle=1;
   
   /* 開始順時針畫弧,從359度開始(第4像限) */
   pno_angle = 0;
   
   draw_x = x+r;
   draw_y = y;         
   op_x = r;
   op_y = 0;
   while(1)
   {  /* 計算下一點 */
      op_y++;
      draw_y--;
      if( (2*op_x*op_x + 2*op_y*op_y - op_2rr - 2*op_x +1)>0 ) 	// 使用逐點比較法實現畫圓弧
      {  op_x--;
         draw_x--;
      }
      if(draw_on==1) GUI_Point(draw_x, draw_y, color);			// 開始畫圖
      pno_angle++;
      if( (pno_angle==stangle)||(pno_angle==endangle) )			// 若遇到起點或終點,畫點開關取反
      {  draw_on = 1-draw_on;
         if(draw_on==1) GUI_Point(draw_x, draw_y, color);
      } 
      if(op_y>=op_x)
      {  if(draw_on==1) GUI_Point(draw_x, draw_y, color);
         break;
      }
   }
   
   while(1)
   {  /* 計算下一點 */
      op_x--;
      draw_x--;
      if( (2*op_x*op_x + 2*op_y*op_y - op_2rr + 2*op_y +1)<=0 ) // 使用逐點比較法實現畫圓弧
      {  op_y++;
         draw_y--;
      }
      if(draw_on==1) GUI_Point(draw_x, draw_y, color);			// 開始畫圖
      pno_angle++;
      if( (pno_angle==stangle)||(pno_angle==endangle) )			// 若遇到起點或終點,畫點開關取反
      {  draw_on = 1-draw_on;
         if(draw_on==1) GUI_Point(draw_x, draw_y, color);
      } 
      
      if(op_x<=0)
      {  if(draw_on==1) GUI_Point(draw_x, draw_y, color);		// 開始畫圖
         break;
      }
   }
    
    
   /* 開始順時針畫弧,從269度開始(第3像限) */
   draw_y = y-r;
   draw_x = x;         
   op_y = r;
   op_x = 0;
   while(1)
   {  /* 計算下一點 */
      op_x++;
      draw_x--;
      if( (2*op_x*op_x + 2*op_y*op_y - op_2rr - 2*op_y +1)>0 ) // 使用逐點比較法實現畫圓弧
      {  op_y--;
         draw_y++;
      }
      if(draw_on==1) GUI_Point(draw_x, draw_y, color);			// 開始畫圖
      pno_angle++;
      if( (pno_angle==stangle)||(pno_angle==endangle) )			// 若遇到起點或終點,畫點開關取反
      {  draw_on = 1-draw_on;
         if(draw_on==1) GUI_Point(draw_x, draw_y, color);
      } 
      
      if(op_x>=op_y)
      {  if(draw_on==1) GUI_Point(draw_x, draw_y, color);		// 開始畫圖
         break;
      }
   }
   
   while(1)
   {  /* 計算下一點 */
      op_y--;
      draw_y++;
      if( (2*op_x*op_x + 2*op_y*op_y - op_2rr + 2*op_x +1)<=0 ) // 使用逐點比較法實現畫圓弧
      {  op_x++;
         draw_x--;
      }
      if(draw_on==1) GUI_Point(draw_x, draw_y, color);			// 開始畫圖
      pno_angle++;
      if( (pno_angle==stangle)||(pno_angle==endangle) )			// 若遇到起點或終點,畫點開關取反
      {  draw_on = 1-draw_on;
         if(draw_on==1) GUI_Point(draw_x, draw_y, color);
      } 
      if(op_y<=0)
      {  if(draw_on==1) GUI_Point(draw_x, draw_y, color);
         break;
      }
   }
   
   
   /* 開始順時針畫弧,從179度開始(第2像限) */
   draw_x = x-r;
   draw_y = y;         
   op_x = r;
   op_y = 0;
   while(1)
   {  /* 計算下一點 */
      op_y++;
      draw_y++;
      if( (2*op_x*op_x + 2*op_y*op_y - op_2rr - 2*op_x +1)>0 ) 	// 使用逐點比較法實現畫圓弧
      {  op_x--;
         draw_x++;
      }
      if(draw_on==1) GUI_Point(draw_x, draw_y, color);			// 開始畫圖
      pno_angle++;
      if( (pno_angle==stangle)||(pno_angle==endangle) )			// 若遇到起點或終點,畫點開關取反
      {  draw_on = 1-draw_on;
         if(draw_on==1) GUI_Point(draw_x, draw_y, color);
      } 
      if(op_y>=op_x)
      {  if(draw_on==1) GUI_Point(draw_x, draw_y, color);
         break;
      }
   }
   
   while(1)
   {  /* 計算下一點 */
      op_x--;
      draw_x++;
      if( (2*op_x*op_x + 2*op_y*op_y - op_2rr + 2*op_y +1)<=0 ) // 使用逐點比較法實現畫圓弧
      {  op_y++;
         draw_y++;
      }
      if(draw_on==1) GUI_Point(draw_x, draw_y, color);			// 開始畫圖
      pno_angle++;
      if( (pno_angle==stangle)||(pno_angle==endangle) )			// 若遇到起點或終點,畫點開關取反
      {  draw_on = 1-draw_on;
         if(draw_on==1) GUI_Point(draw_x, draw_y, color);
      } 
      
      if(op_x<=0)
      {  if(draw_on==1) GUI_Point(draw_x, draw_y, color);		// 開始畫圖
         break;
      }
   }
  
  
   /* 開始順時針畫弧,從89度開始(第1像限) */
   draw_y = y+r;
   draw_x = x;         
   op_y = r;
   op_x = 0;
   while(1)
   {  /* 計算下一點 */
      op_x++;
      draw_x++;
      if( (2*op_x*op_x + 2*op_y*op_y - op_2rr - 2*op_y +1)>0 ) // 使用逐點比較法實現畫圓弧
      {  op_y--;
         draw_y--;
      }
      if(draw_on==1) GUI_Point(draw_x, draw_y, color);			// 開始畫圖
      pno_angle++;
      if( (pno_angle==stangle)||(pno_angle==endangle) )			// 若遇到起點或終點,畫點開關取反
      {  draw_on = 1-draw_on;
         if(draw_on==1) GUI_Point(draw_x, draw_y, color);
      } 
      
      if(op_x>=op_y)
      {  if(draw_on==1) GUI_Point(draw_x, draw_y, color);		// 開始畫圖
         break;
      }
   }
   
   while(1)
   {  /* 計算下一點 */
      op_y--;
      draw_y--;
      if( (2*op_x*op_x + 2*op_y*op_y - op_2rr + 2*op_x +1)<=0 ) // 使用逐點比較法實現畫圓弧
      {  op_x++;
         draw_x++;
      }
      if(draw_on==1) GUI_Point(draw_x, draw_y, color);			// 開始畫圖
      pno_angle++;
      if( (pno_angle==stangle)||(pno_angle==endangle) )			// 若遇到起點或終點,畫點開關取反
      {  draw_on = 1-draw_on;
         if(draw_on==1) GUI_Point(draw_x, draw_y, color);
      } 
      if(op_y<=0)
      {  if(draw_on==1) GUI_Point(draw_x, draw_y, color);
         break;
      }
   }
   
}
#endif




#if  GUI_Pieslice_EN==1
/****************************************************************************
* 名稱:GUI_Pieslice()
* 功能:指定起點、終點及半徑扇形(不能畫圓)。使用的是順時針方向畫圖。
* 入口參數: x			圓心的x軸坐標值
*           y			圓心的y軸坐標值
*           stangle 	起始角度(0-359度)
*           endangle	終止角度(0-359度)
*           r  			圓的半徑終點
*           color		顯示顏色
* 出口參數:無
* 說明:操作失敗原因是指定地址超出有效范圍。
****************************************************************************/
void  GUI_Pieslice(uint32 x, uint32 y, uint32 r, uint32 stangle, uint32 endangle, TCOLOR color)
{  int32  draw_x, draw_y;					// 畫圖坐標變量
   int32  op_x, op_y;						// 操作坐標
   int32  op_2rr;							// 2*r*r值變量
   
   int32  pno_angle;						// 度角點的個數
   uint8  draw_on;							// 畫點開關,為1時畫點,為0時不畫
   
   
   /* 參數過濾 */
   if(r==0) return;							// 半徑為0則直接退出
   if(stangle==endangle) return;			// 起始角度與終止角度相同,退出
   if( (stangle>=360) || (endangle>=360) ) return;

   op_2rr = 2*r*r;							// 計算r平方乖以2
   pno_angle = 0;
   /* 先計算出在此半徑下的45度的圓弧的點數 */       
   op_x = r;
   op_y = 0;
   while(1)
   {  pno_angle++; 							// 畫點計數         
      /* 計算下一點 */
      op_y++;
      if( (2*op_x*op_x + 2*op_y*op_y - op_2rr - 2*op_x +1)>0 ) 	// 使用逐點比較法實現畫圓弧
      {  op_x--;
      }
      if(op_y>=op_x) break;
   }
   
   draw_on = 0;								// 最開始關畫點開關
   /* 設置起始點及終點 */
   if(endangle>stangle) draw_on = 1;		// 若終點大于起點,則從一開始即畫點(359)
   stangle = (360-stangle)*pno_angle/45;
   endangle = (360-endangle)*pno_angle/45;
   if(stangle==0) stangle=1;
   if(endangle==0) endangle=1;
   
   /* 開始順時針畫弧,從359度開始(第4像限) */
   pno_angle = 0;
   
   draw_x = x+r;
   draw_y = y;         
   op_x = r;
   op_y = 0;
   while(1)
   {  /* 計算下一點 */
      op_y++;
      draw_y--;
      if( (2*op_x*op_x + 2*op_y*op_y - op_2rr - 2*op_x +1)>0 ) 	// 使用逐點比較法實現畫圓弧
      {  op_x--;
         draw_x--;
      }
      if(draw_on==1) GUI_Point(draw_x, draw_y, color);			// 開始畫圖
      pno_angle++;
      if( (pno_angle==stangle)||(pno_angle==endangle) )			// 若遇到起點或終點,畫點開關取反
      {  draw_on = 1-draw_on;
         if(draw_on==1) GUI_Point(draw_x, draw_y, color);
         GUI_Line(x, y, draw_x, draw_y, color);
      } 
      if(op_y>=op_x)
      {  if(draw_on==1) GUI_Point(draw_x, draw_y, color);
         break;
      }
   }
   
   while(1)
   {  /* 計算下一點 */
      op_x--;
      draw_x--;
      if( (2*op_x*op_x + 2*op_y*op_y - op_2rr + 2*op_y +1)<=0 ) // 使用逐點比較法實現畫圓弧
      {  op_y++;
         draw_y--;
      }
      if(draw_on==1) GUI_Point(draw_x, draw_y, color);			// 開始畫圖
      pno_angle++;
      if( (pno_angle==stangle)||(pno_angle==endangle) )			// 若遇到起點或終點,畫點開關取反
      {  draw_on = 1-draw_on;
         if(draw_on==1) GUI_Point(draw_x, draw_y, color);
         GUI_Line(x, y, draw_x, draw_y, color);
      } 
      
      if(op_x<=0)
      {  if(draw_on==1) GUI_Point(draw_x, draw_y, color);		// 開始畫圖
         break;
      }
   }
    
    
   /* 開始順時針畫弧,從269度開始(第3像限) */
   draw_y = y-r;
   draw_x = x;         
   op_y = r;
   op_x = 0;
   while(1)
   {  /* 計算下一點 */
      op_x++;
      draw_x--;
      if( (2*op_x*op_x + 2*op_y*op_y - op_2rr - 2*op_y +1)>0 ) // 使用逐點比較法實現畫圓弧
      {  op_y--;
         draw_y++;
      }
      if(draw_on==1) GUI_Point(draw_x, draw_y, color);			// 開始畫圖
      pno_angle++;
      if( (pno_angle==stangle)||(pno_angle==endangle) )			// 若遇到起點或終點,畫點開關取反
      {  draw_on = 1-draw_on;
         if(draw_on==1) GUI_Point(draw_x, draw_y, color);
         GUI_Line(x, y, draw_x, draw_y, color);
      } 
      
      if(op_x>=op_y)
      {  if(draw_on==1) GUI_Point(draw_x, draw_y, color);		// 開始畫圖
         break;
      }
   }
   
   while(1)
   {  /* 計算下一點 */
      op_y--;
      draw_y++;
      if( (2*op_x*op_x + 2*op_y*op_y - op_2rr + 2*op_x +1)<=0 ) // 使用逐點比較法實現畫圓弧
      {  op_x++;
         draw_x--;
      }
      if(draw_on==1) GUI_Point(draw_x, draw_y, color);			// 開始畫圖
      pno_angle++;
      if( (pno_angle==stangle)||(pno_angle==endangle) )			// 若遇到起點或終點,畫點開關取反
      {  draw_on = 1-draw_on;
         if(draw_on==1) GUI_Point(draw_x, draw_y, color);
         GUI_Line(x, y, draw_x, draw_y, color);
      } 
      if(op_y<=0)
      {  if(draw_on==1) GUI_Point(draw_x, draw_y, color);
         break;
      }
   }
   
   
   /* 開始順時針畫弧,從179度開始(第2像限) */
   draw_x = x-r;
   draw_y = y;         
   op_x = r;
   op_y = 0;
   while(1)
   {  /* 計算下一點 */
      op_y++;
      draw_y++;
      if( (2*op_x*op_x + 2*op_y*op_y - op_2rr - 2*op_x +1)>0 ) 	// 使用逐點比較法實現畫圓弧
      {  op_x--;
         draw_x++;
      }
      if(draw_on==1) GUI_Point(draw_x, draw_y, color);			// 開始畫圖
      pno_angle++;
      if( (pno_angle==stangle)||(pno_angle==endangle) )			// 若遇到起點或終點,畫點開關取反
      {  draw_on = 1-draw_on;
         if(draw_on==1) GUI_Point(draw_x, draw_y, color);
         GUI_Line(x, y, draw_x, draw_y, color);
      } 
      if(op_y>=op_x)
      {  if(draw_on==1) GUI_Point(draw_x, draw_y, color);
         break;
      }
   }
   
   while(1)
   {  /* 計算下一點 */
      op_x--;
      draw_x++;
      if( (2*op_x*op_x + 2*op_y*op_y - op_2rr + 2*op_y +1)<=0 ) // 使用逐點比較法實現畫圓弧
      {  op_y++;
         draw_y++;
      }
      if(draw_on==1) GUI_Point(draw_x, draw_y, color);			// 開始畫圖
      pno_angle++;
      if( (pno_angle==stangle)||(pno_angle==endangle) )			// 若遇到起點或終點,畫點開關取反
      {  draw_on = 1-draw_on;
         if(draw_on==1) GUI_Point(draw_x, draw_y, color);
         GUI_Line(x, y, draw_x, draw_y, color);
      } 
      
      if(op_x<=0)
      {  if(draw_on==1) GUI_Point(draw_x, draw_y, color);		// 開始畫圖
         break;
      }
   }
  
  
   /* 開始順時針畫弧,從89度開始(第1像限) */
   draw_y = y+r;
   draw_x = x;         
   op_y = r;
   op_x = 0;
   while(1)
   {  /* 計算下一點 */
      op_x++;
      draw_x++;
      if( (2*op_x*op_x + 2*op_y*op_y - op_2rr - 2*op_y +1)>0 ) // 使用逐點比較法實現畫圓弧
      {  op_y--;
         draw_y--;
      }
      if(draw_on==1) GUI_Point(draw_x, draw_y, color);			// 開始畫圖
      pno_angle++;
      if( (pno_angle==stangle)||(pno_angle==endangle) )			// 若遇到起點或終點,畫點開關取反
      {  draw_on = 1-draw_on;
         if(draw_on==1) GUI_Point(draw_x, draw_y, color);
         GUI_Line(x, y, draw_x, draw_y, color);
      } 
      
      if(op_x>=op_y)
      {  if(draw_on==1) GUI_Point(draw_x, draw_y, color);		// 開始畫圖
         break;
      }
   }
   
   while(1)
   {  /* 計算下一點 */
      op_y--;
      draw_y--;
      if( (2*op_x*op_x + 2*op_y*op_y - op_2rr + 2*op_x +1)<=0 ) // 使用逐點比較法實現畫圓弧
      {  op_x++;
         draw_x++;
      }
      if(draw_on==1) GUI_Point(draw_x, draw_y, color);			// 開始畫圖
      pno_angle++;
      if( (pno_angle==stangle)||(pno_angle==endangle) )			// 若遇到起點或終點,畫點開關取反
      {  draw_on = 1-draw_on;
         if(draw_on==1) GUI_Point(draw_x, draw_y, color);
         GUI_Line(x, y, draw_x, draw_y, color);
      } 
      if(op_y<=0)
      {  if(draw_on==1) GUI_Point(draw_x, draw_y, color);
         break;
      }
   }
   
}
#endif





















?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一级精品视频在线观看宜春院 | 美腿丝袜亚洲三区| 一区二区欧美国产| 亚洲精品国产成人久久av盗摄| 国产精品水嫩水嫩| 国产精品久线在线观看| 国产午夜精品一区二区| 久久精品一区二区三区不卡| 久久综合久久鬼色| www国产成人| 国产色综合一区| 欧美激情自拍偷拍| 亚洲丝袜精品丝袜在线| 亚洲欧美一区二区在线观看| 亚洲欧美日韩系列| 一区二区高清视频在线观看| 亚洲一区二区三区四区在线观看| 一级精品视频在线观看宜春院| 亚洲动漫第一页| 日韩vs国产vs欧美| 黄色成人免费在线| 欧美精品黑人性xxxx| 欧美日本韩国一区二区三区视频 | 91免费在线看| 色婷婷综合久久久久中文一区二区| 91亚洲大成网污www| 91九色最新地址| 欧美高清视频一二三区| 日韩视频国产视频| 中国av一区二区三区| 一区二区三区中文在线| 七七婷婷婷婷精品国产| 国产东北露脸精品视频| 91久久精品午夜一区二区| 3d动漫精品啪啪一区二区竹菊| 久久色视频免费观看| 中文字幕一区在线观看视频| 亚洲妇熟xx妇色黄| 国产精品18久久久久久久久久久久| 99国产精品久久久| 91精品国产色综合久久不卡蜜臀| 久久久久久久综合| 亚洲一区二区三区四区在线免费观看| 蜜桃久久av一区| 94-欧美-setu| 欧美精品一区二| 亚洲午夜在线观看视频在线| 国产一区不卡精品| 精品视频123区在线观看| 国产婷婷色一区二区三区四区| 亚洲自拍偷拍图区| 成人中文字幕在线| 日韩三级av在线播放| 亚洲色图丝袜美腿| 久久99精品久久久久久| 欧美吻胸吃奶大尺度电影| 欧美国产禁国产网站cc| 日本va欧美va瓶| 欧美艳星brazzers| 中文字幕在线不卡视频| 国内一区二区在线| 欧美一区二区在线视频| 又紧又大又爽精品一区二区| 丁香六月综合激情| ww久久中文字幕| 免费xxxx性欧美18vr| 欧美三级韩国三级日本一级| 亚洲精品自拍动漫在线| 成人天堂资源www在线| 亚洲精品一区在线观看| 日韩1区2区3区| 在线播放中文字幕一区| 一区二区国产盗摄色噜噜| 一本久久a久久精品亚洲| 一区在线观看视频| 国产suv一区二区三区88区| 欧美xxxxxxxxx| 久久国产精品99久久久久久老狼| 欧美日韩成人综合| 国产成人鲁色资源国产91色综| 欧美zozozo| 精品综合免费视频观看| 日韩久久久久久| 久久99精品国产麻豆婷婷| 日韩一区二区三区免费观看| 日韩国产一二三区| 欧美一区二区三区视频免费| 免费人成在线不卡| 欧美一区二区播放| 黄页视频在线91| 欧美精品一区二区三区蜜臀| 国产一区二区美女诱惑| 久久久精品综合| 波多野结衣中文字幕一区| 中文字幕一区二区三区四区| 色老汉av一区二区三区| 亚洲一区二区av电影| 777xxx欧美| 国产一区二区三区电影在线观看| 久久婷婷国产综合国色天香| 成人性生交大片免费看视频在线| 国产精品欧美一区喷水| 91老师国产黑色丝袜在线| 亚洲福中文字幕伊人影院| 69堂亚洲精品首页| 国产精品99久久久久久久女警| 中文字幕中文在线不卡住| 日本韩国欧美国产| 免播放器亚洲一区| 国产精品盗摄一区二区三区| 欧美日韩精品欧美日韩精品一 | 一区二区不卡在线播放| 欧美一区二区三区视频在线 | 欧美高清在线一区二区| 日韩你懂的在线播放| 成人久久18免费网站麻豆 | 26uuu国产日韩综合| 国产精品中文欧美| 一区二区三区四区激情| 日韩欧美一区二区在线视频| 国产盗摄精品一区二区三区在线 | 91一区一区三区| 日本不卡在线视频| 中文字幕在线一区免费| 欧美一区三区二区| 91麻豆福利精品推荐| 国产在线播精品第三| 夜夜操天天操亚洲| 欧美国产在线观看| 欧美一区二区美女| 色婷婷av一区二区| 国产成人午夜99999| 午夜视频在线观看一区二区三区| 欧美国产1区2区| 欧美成人欧美edvon| 精品视频在线视频| av电影一区二区| 经典三级视频一区| 视频在线在亚洲| 亚洲在线观看免费| 国产精品国产成人国产三级| 久久久精品免费免费| 欧美一区二区三区不卡| 日韩视频中午一区| 欧美日韩mp4| 91传媒视频在线播放| 波多野结衣亚洲| 国产成a人亚洲精| 国产激情精品久久久第一区二区| 日本中文一区二区三区| 丝瓜av网站精品一区二区| 一级做a爱片久久| 一区二区三区日韩精品视频| 中文字幕一区二区三区不卡| 中文字幕av一区二区三区高| 欧美xxxx老人做受| 精品成人一区二区三区四区| 日韩一区二区免费视频| 欧美一区国产二区| 日韩午夜在线播放| 日韩欧美精品在线视频| 日韩视频一区在线观看| 欧美一区二区视频免费观看| 欧美二区三区91| 欧美一区二区视频在线观看2022| 91精品视频网| 日韩精品一区国产麻豆| 精品国产污网站| 久久久精品免费免费| 国产精品网站在线观看| 亚洲天堂av一区| 亚洲一区在线观看免费| 五月天国产精品| 九九久久精品视频| 国产成人一级电影| 99国产精品久久久久久久久久久 | 一级女性全黄久久生活片免费| 亚洲最大的成人av| 日本不卡免费在线视频| 久久国产麻豆精品| 成人动漫一区二区三区| 日本黄色一区二区| 欧美日韩高清在线播放| 久久奇米777| 亚洲特级片在线| 偷拍一区二区三区四区| 国产精品99久久久久久有的能看| 成人激情开心网| 欧美三级视频在线| 久久久久国产精品麻豆| 亚洲欧美一区二区视频| 青青草国产精品亚洲专区无| 国产精品自拍毛片| 日本乱人伦aⅴ精品| 日韩免费福利电影在线观看| 中文字幕在线不卡一区| 久久福利视频一区二区| 99久久99精品久久久久久| 日韩精品一区二区三区在线| 日韩美女精品在线|