久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 1140|回復: 1
打印 上一主題 下一主題
收起左側

OV7670串口調試滾球系統程序

[復制鏈接]
跳轉到指定樓層
樓主
ID:506480 發表于 2019-7-1 10:07 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
  1. #include "led.h"
  2. #include "delay.h"
  3. #include "key.h"
  4. #include "sys.h"
  5. #include "lcd.h"
  6. #include "usart.h"         
  7. #include "string.h"
  8. #include "ov7670.h"
  9. #include "tpad.h"
  10. #include "timer.h"
  11. #include "exti.h"
  12. #include "remote.h"
  13. #include "control.h"

  14. u16 PWM_X,PWM_Y=0;          //pid參數初始化
  15. double Err_X=0,Err_Y=0;
  16. double Err_X_LAST,Err_Y_LAST=0,Err_X_LASTP=0,Err_Y_LASTP=0;

  17. extern u8 key;
  18. extern float Kp,Ki,Kd;
  19. u32 X_MAX,Y_MAX=0;    //小球的坐標信息
  20. u32 X_MAX_LSAT, X_MIN_LSAT, Y_MAX_LSAT, Y_MIN_LSAT=0;   //上一次小球坐標位置信息
  21. extern float X,Y;      //小球的質心信息
  22. u32 X_MIN=180,Y_MIN=180;
  23. extern int sum_x,sum_y;

  24. extern u8 ov_sta;        //在exit.c里 面定義
  25. extern u8 ov_frame;        //在timer.c里面定義                 
  26. extern u16 Aim_X,Aim_Y;
  27. extern u16 X_PWM,Y_PWM;
  28. unsigned char txbuf[4];

  29. void camera_refresh(void)
  30. {  
  31.          u16 color;
  32.         //u8 color_r,color_g,color_b;
  33.         u16 i,j;
  34.                
  35.         if(ov_sta)//有幀中斷更新?
  36.         {
  37.                         LCD_Scan_Dir(U2D_L2R);                //從上到下,從左到右  
  38.                         if(lcddev.id==0X1963)LCD_Set_Window((lcddev.width-240)/2,(lcddev.height-320)/2,240,320);//將顯示區域設置到屏幕中央
  39.                         else if(lcddev.id==0X5510||lcddev.id==0X5310)LCD_Set_Window((lcddev.width-320)/2,(lcddev.height-240)/2,320,240);//將顯示區域設置到屏幕中央
  40.                         LCD_WriteRAM_Prepare();     //開始寫入GRAM        
  41.                         OV7670_RRST=0;                                //開始復位讀指針
  42.                         OV7670_RCK_L;
  43.                         OV7670_RCK_H;
  44.                         OV7670_RCK_L;
  45.                         OV7670_RRST=1;                                //復位讀指針結束
  46.                         OV7670_RCK_H;
  47. for(i=0;i<240;i++)
  48.                   {
  49.                           for(j=0;j<320;j++){
  50.                                 OV7670_RCK_L;
  51.                                 color=GPIOC->IDR&0XFF;        //讀數據
  52.                                 OV7670_RCK_H;
  53.                                 color<<=8;  
  54.                                 OV7670_RCK_L;
  55.                                 color|=GPIOC->IDR&0XFF;        //讀數據
  56.                                 OV7670_RCK_H;
  57.                                         if(color<0x9000)
  58.                                    {
  59.                                          color=0x0000;
  60.                                     }
  61.                                 else
  62.                                  {
  63.                                         color =0xffff;
  64.                                         if(i>10&&i<230&&j<270&&j>50)  //此處遍歷圖像尋找小球最上最下 最左 最右四個點坐標
  65.                                         {
  66.                                         if(i>X_MAX) X_MAX=i;               
  67.                                         if(i<X_MIN) X_MIN=i;
  68.                                  
  69.                                         if(j>Y_MAX) Y_MAX=j;        
  70.                                         if(j<Y_MIN) Y_MIN=j;
  71.                                        
  72.                                  }
  73.                                }
  74.                                 LCD->LCD_RAM=color;
  75.                         
  76.                                   X_MAX_LSAT =        X_MAX;    //更新pid的real坐標信息
  77.                                   X_MIN_LSAT =        X_MIN;
  78.                                 
  79.                                   Y_MAX_LSAT =        Y_MAX;
  80.                                   Y_MIN_LSAT =        Y_MIN;
  81.                                 }
  82.            }                                                
  83.                   X_MAX=0;
  84.                   X_MIN=240;
  85.                   Y_MAX=0;
  86.                   Y_MIN=320;   //清除掉本次坐標用于再次遍歷最大值 最小值
  87.                                 
  88.                   X=(X_MAX_LSAT+X_MIN_LSAT)/2;
  89.                   Y=(Y_MAX_LSAT+Y_MIN_LSAT)/2;
  90.                    printf("坐標%3.0f,%3.0f\n ",X,Y);
  91.                    printf("\n");
  92.                
  93.                  ov_sta=0;                                        //清零幀中斷標記
  94.                 ov_frame++;
  95.                 LCD_Scan_Dir(DFT_SCAN_DIR);        //恢復默認掃描方向
  96.         }
  97.         }

  98. void TIM3_IRQHandler(void)
  99. {                                                                  
  100.         if (TIM_GetITStatus(TIM3, TIM_IT_Update) != RESET) //檢查指定的TIM中斷發生與否:TIM 中斷源
  101.         {        
  102.             Err_X=X-Aim_X;
  103.                 Err_Y=Y-Aim_Y;
  104.                
  105.                 /*if(abs(Err_X)>30&&abs(Err_Y)>30)
  106.                 {
  107.                 Kp=3.5;
  108.                 Kd=99;
  109.                 Ki=0;
  110.                 }
  111.                
  112.                 if(abs(Err_X)>=15&&abs(Err_Y)>=15)
  113.                 {
  114.                 Kp=3.6;
  115.                 Ki=0.0;
  116.                 Kd=85;
  117.                 }
  118.                 if(abs(Err_X)<15&&abs(Err_Y)<15)*/
  119.                
  120.                 Kp=4.2;
  121.                 Ki=0.055;
  122.                 Kd=95;
  123.                
  124.                 sum_x+=Err_X;
  125.                 sum_y+=Err_Y;
  126.                
  127.                 PWM_X=X_PWM-(Err_X*Kp+sum_x*Ki+(Err_X-Err_X_LASTP)*Kd);
  128.                 PWM_Y=Y_PWM+(Err_Y*Kp+sum_y*Ki+(Err_Y-Err_Y_LASTP)*Kd);
  129.                
  130.                 if(PWM_Y>2300)PWM_Y=2300;      //限制幅度,預防抽風
  131.                 if(PWM_Y<600)PWM_Y=600;      //限制幅度,預防抽風
  132.                
  133.                 if(PWM_X>2300)PWM_X=2300;      
  134.                 if(PWM_X<600)PWM_X=600;
  135.                
  136.                 Err_X_LASTP=Err_X_LAST;
  137.                 Err_Y_LASTP=Err_Y_LAST;
  138.                
  139.                 Err_X_LAST=Err_X;
  140.                 Err_Y_LAST=Err_Y;
  141.                
  142.                 TIM_SetCompare1(TIM3,PWM_Y);        //修改比較值,修改占空比    //9140
  143.                 TIM_SetCompare2(TIM3,PWM_X);        //修改比較值,修改占空比    //9450
  144.         

  145.                 }   
  146.         TIM_ClearITPendingBit(TIM3, TIM_IT_Update  );  //清除TIMx的中斷待處理位:TIM 中斷源            
  147. }
  148.         
  149. int main(void)
  150. {               
  151.         
  152.         u8 effect=0;              
  153.         //u8 msgbuf[15];                                //消息緩存區
  154.         //u8 tm=0;
  155.                 txbuf[0]=0x01;
  156.                 txbuf[1]=0x02;
  157.                 txbuf[2]=0x03;
  158.                 txbuf[3]=0x04;
  159.          
  160.           TIM3_Int_Init(10000,7199);//10Khz計數,秒鐘中斷一次
  161.       TIM3_PWM_Init(19999,71);         //分頻720  PWM頻率=100000/2000=50hz  =20ms
  162.              TIM_SetCompare2(TIM3,1530);
  163.           TIM_SetCompare1(TIM3,1580);
  164.          Remote_Init();                        //紅外接收初始化               
  165.      delay_init();                     //延時函數初始化         
  166.       NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);//設置中斷優先級分組為組2:2位搶占優先級,2位響應優先級
  167.         uart_init(115200);                 //串口初始化為 115200
  168.            KEY_Init();                                                                                //按鍵初始化,控制模式更改。                                                   
  169.         LCD_Init();                                           //初始化LCD  
  170.      //   TPAD_Init(6);                                //觸摸按鍵初始化
  171.          POINT_COLOR=RED;                        //設置字體為紅色
  172.         OV7670_Init();
  173.    
  174.         OV7670_Special_Effects(effect);  
  175.                
  176.         TIM6_Int_Init(1000,71);                        //10Khz計數頻率,1秒鐘中斷                                                                          
  177.         EXTI8_Init();                                                //使能定時器捕獲
  178.         OV7670_Window_Set(12,176,240,320);        //設置窗口         
  179.         OV7670_CS=0;                                       
  180.         LCD_Clear(BLACK);
  181.          while(1)
  182.         {                    
  183.          camera_refresh();//更新顯示
  184.                         
  185.                 }      
  186.                                 }      
復制代碼

全部資料51hei下載地址:
OV7670串口控制的滾球系統.7z (252.18 KB, 下載次數: 20)
分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

沙發
ID:1 發表于 2019-7-1 16:20 | 只看該作者
本帖需要重新編輯補全電路原理圖,源碼,詳細說明與圖片即可獲得100+黑幣(帖子下方有編輯按鈕)
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 99re在线播放| 成人午夜免费视频 | 手机av在线 | av在线免费观看不卡 | 国产欧美视频一区二区三区 | 日韩在线观看中文字幕 | 成人激情视频免费在线观看 | 毛片区| 九九亚洲精品 | 九一在线观看 | 亚洲精品欧美一区二区三区 | 高清一区二区 | 天堂久久网| 91人人爽 | 欧美一区精品 | 欧美亚洲国产日韩 | 麻豆精品国产91久久久久久 | 欧美在线视频免费 | 日韩高清成人 | 亚洲成在线观看 | 午夜久草 | 91精品久久久久久综合五月天 | 欧美自拍一区 | 在线观看成人小视频 | 桃色五月 | 免费电影av | 亚洲日韩中文字幕一区 | 亚洲高清成人 | 国产在线一区二 | 中文字幕一区二区三区四区五区 | 伊人艹 | 男女免费在线观看视频 | 久久久久国产一级毛片 | 国产91亚洲精品一区二区三区 | 亚洲a视| 久久精品电影 | 男女羞羞视频在线免费观看 | 国产日韩欧美精品 | 激情国产 | 天堂久久一区 | 中文字幕日韩欧美一区二区三区 |