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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

stm32f103zet6紅外遙控OV7670控制的滾球控制系統程序

[復制鏈接]
跳轉到指定樓層
樓主


單片機源程序如下:
#include "led.h"
#include "delay.h"
#include "key.h"
#include "sys.h"
#include "lcd.h"
#include "usart.h"         
#include "string.h"
#include "ov7670.h"
#include "tpad.h"
#include "timer.h"
#include "exti.h"
#include "remote.h"
#include "control.h"

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

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

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

void camera_refresh(void)
{  
         u16 color;
        //u8 color_r,color_g,color_b;
        u16 i,j;

        if(ov_sta)//有幀中斷更新?
        {
                        LCD_Scan_Dir(U2D_L2R);                //從上到下,從左到右  
                        if(lcddev.id==0X1963)LCD_Set_Window((lcddev.width-240)/2,(lcddev.height-320)/2,240,320);//將顯示區域設置到屏幕中央
                        else if(lcddev.id==0X5510||lcddev.id==0X5310)LCD_Set_Window((lcddev.width-320)/2,(lcddev.height-240)/2,320,240);//將顯示區域設置到屏幕中央
                        LCD_WriteRAM_Prepare();     //開始寫入GRAM        
                        OV7670_RRST=0;                                //開始復位讀指針
                        OV7670_RCK_L;
                        OV7670_RCK_H;
                        OV7670_RCK_L;
                        OV7670_RRST=1;                                //復位讀指針結束
                        OV7670_RCK_H;
for(i=0;i<240;i++)
                  {
                          for(j=0;j<320;j++){
                                OV7670_RCK_L;
                                color=GPIOC->IDR&0XFF;        //讀數據
                                OV7670_RCK_H;
                                color<<=8;  
                                OV7670_RCK_L;
                                color|=GPIOC->IDR&0XFF;        //讀數據
                                OV7670_RCK_H;
                                        if(color<0x9000)
                                   {
                                         color=0x0000;
                                    }
                                else
                                 {
                                        color =0xffff;
                                        if(i>10&&i<230&&j<270&&j>50)  //此處遍歷圖像尋找小球最上最下 最左 最右四個點坐標
                                        {
                                        if(i>X_MAX) X_MAX=i;               
                                        if(i<X_MIN) X_MIN=i;
                                 
                                        if(j>Y_MAX) Y_MAX=j;        
                                        if(j<Y_MIN) Y_MIN=j;
                                       
                                 }
                               }
                                LCD->LCD_RAM=color;
                        
                                  X_MAX_LSAT =        X_MAX;    //更新pid的real坐標信息
                                  X_MIN_LSAT =        X_MIN;
                                
                                  Y_MAX_LSAT =        Y_MAX;
                                  Y_MIN_LSAT =        Y_MIN;
                                }
           }                                                
                  X_MAX=0;
                  X_MIN=240;
                  Y_MAX=0;
                  Y_MIN=320;   //清除掉本次坐標用于再次遍歷最大值 最小值
                                
                  X=(X_MAX_LSAT+X_MIN_LSAT)/2;
                  Y=(Y_MAX_LSAT+Y_MIN_LSAT)/2;
                   printf("坐標%3.0f,%3.0f\n ",X,Y);
                   printf("\n");
               
                 ov_sta=0;                                        //清零幀中斷標記
                ov_frame++;
                LCD_Scan_Dir(DFT_SCAN_DIR);        //恢復默認掃描方向
        }
        }

void TIM3_IRQHandler(void)
{                                                                  
        if (TIM_GetITStatus(TIM3, TIM_IT_Update) != RESET) //檢查指定的TIM中斷發生與否
  1. #include "control.h"
  2. #include "sys.h"
  3. #include "math.h"
  4. #include "delay.h"
  5. #include "timer.h"

  6. u16 Aim[9][2]={
  7.         {28 , 71 },{122 ,70 },{206, 73 },        //這個數組用來儲存板子上9個點的相對像素位置
  8.         {29 , 163},{121 ,159},{207, 160},
  9.         {30 , 241},{121 ,247},{207, 245}   
  10. };
  11. u16 PWMX[9]={
  12.         1480,1488,1570,
  13.         1555,1520,1600,
  14.         1540,1510,1600
  15. };
  16. u16 PWMY[9]={
  17.         1560,1490,1465,
  18.         1500,1510,1480,
  19.         1520,1540,1590
  20. };
  21. int Sum=0;
  22. double X=0,Y=0;      //小球的質心信息
  23. u16 Aim_X=120,Aim_Y=160,X_PWM=1500,Y_PWM=1540;
  24. int step=0,t_step=0;
  25. float Kp=0,Ki=0,Kd=0;
  26. int sum_x=0,sum_y=0;

  27. void Check(void)
  28. {
  29.         Aim_X=Aim[0][0];
  30.         Aim_Y=Aim[0][1];
  31.         X_PWM=PWMX[0];
  32.         Y_PWM=PWMY[0];        
  33.         Sum=0;
  34.         Kp=0;Ki=0;Kd=0;
  35.         sum_x=0;sum_y=0;
  36.         step=0,t_step=0;
  37. }

  38. void Question1(void)//在區域2停住
  39. {
  40. Aim_X=Aim[0][0];
  41. Aim_Y=Aim[0][1];
  42. X_PWM=PWMX[0];
  43. Y_PWM=PWMY[0];        
  44.         Kp=0;Ki=0;Kd=0;
  45.         sum_x=0;sum_y=0;
  46. }
  47. void Question2(void)//區域1到區域5(停2s)
  48. {
  49.         Aim_X=Aim[1][0];
  50.         Aim_Y=Aim[1][1];  
  51.         X_PWM=PWMX[1];
  52.         Y_PWM=PWMY[1];        
  53.         Kp=0;Ki=0;Kd=0;
  54.         sum_x=0;sum_y=0;        
  55. }

  56. void Question3(void)//區域1到區域4(停2s)再到區域5(停2s)
  57. {
  58.         Aim_X=Aim[2][0];
  59.         Aim_Y=Aim[2][1];  
  60.         X_PWM=PWMX[2];
  61.         Y_PWM=PWMY[2];        
  62.         Kp=0;Ki=0;Kd=0;
  63.         sum_x=0;sum_y=0;        
  64. }
復制代碼


        {        
            Err_X=X-Aim_X;
                Err_Y=Y-Aim_Y;
               
                /*if(abs(Err_X)>30&&abs(Err_Y)>30)
                {
                Kp=3.5;
                Kd=99;
                Ki=0;
                }
               
                if(abs(Err_X)>=15&&abs(Err_Y)>=15)
                {
                Kp=3.6;
                Ki=0.0;
                Kd=85;
                }
                if(abs(Err_X)<15&&abs(Err_Y)<15)*/
               
                Kp=4.2;
                Ki=0.055;
                Kd=95;
               
                sum_x+=Err_X;
                sum_y+=Err_Y;
               
                PWM_X=X_PWM-(Err_X*Kp+sum_x*Ki+(Err_X-Err_X_LASTP)*Kd);
                PWM_Y=Y_PWM+(Err_Y*Kp+sum_y*Ki+(Err_Y-Err_Y_LASTP)*Kd);
               
                if(PWM_Y>2300)PWM_Y=2300;      //限制幅度
                if(PWM_Y<600)PWM_Y=600;      //限制幅度
               
                if(PWM_X>2300)PWM_X=2300;      
                if(PWM_X<600)PWM_X=600;
               
                Err_X_LASTP=Err_X_LAST;
                Err_Y_LASTP=Err_Y_LAST;
               
                Err_X_LAST=Err_X;
                Err_Y_LAST=Err_Y;
               
                TIM_SetCompare1(TIM3,PWM_Y);        //修改比較值,修改占空比   
                TIM_SetCompare2(TIM3,PWM_X);        //修改比較值,修改占空比   
        

                }   
        TIM_ClearITPendingBit(TIM3, TIM_IT_Update  );  //清除TIMx的中斷待處理位:TIM 中斷源            
}
        
int main(void)
{               

        u8 effect=0;              
        //u8 msgbuf[15];                                //消息緩存區
        //u8 tm=0;
                txbuf[0]=0x01;
                txbuf[1]=0x02;
                txbuf[2]=0x03;
                txbuf[3]=0x04;
         
          TIM3_Int_Init(10000,7199);//10Khz計數,秒鐘中斷一次
      TIM3_PWM_Init(19999,71);         //分頻720  PWM頻率=100000/2000=50hz  =20ms
             TIM_SetCompare2(TIM3,1530);
          TIM_SetCompare1(TIM3,1580);
         Remote_Init();                        //紅外接收初始化               
     delay_init();                     //延時函數初始化         
      NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);//設置中斷優先級分組為組2:2位搶占優先級,2位響應優先級
        uart_init(115200);                 //串口初始化為 115200
           KEY_Init();                                                                                //按鍵初始化,控制模式更改。                                                   
        LCD_Init();                                           //初始化LCD  
     //   TPAD_Init(6);                                //觸摸按鍵初始化
         POINT_COLOR=RED;                        //設置字體為紅色
        OV7670_Init();

        OV7670_Special_Effects(effect);  
               
        TIM6_Int_Init(1000,71);                        //10Khz計數頻率,1秒鐘中斷                                                                          
        EXTI8_Init();                                                //使能定時器捕獲
        OV7670_Window_Set(12,176,240,320);        //設置窗口         
        OV7670_CS=0;                                       
        LCD_Clear(BLACK);
         while(1)
        {                    
         camera_refresh();//更新顯示
                        
                }      
                                }      

全部資料51hei下載地址:
OV7670串口傳回坐標希望品.7z (251.51 KB, 下載次數: 74)

評分

參與人數 1黑幣 +50 收起 理由
admin + 50 共享資料的黑幣獎勵!

查看全部評分

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

沙發
ID:496767 發表于 2019-7-26 14:53 | 只看該作者
非常好,謝謝樓主
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 国产精品久久久久久久三级 | 精品国产一区二区 | 黑人巨大精品欧美黑白配亚洲 | 亚洲国产aⅴ成人精品无吗 综合国产在线 | 成人av片在线观看 | 久久爱综合 | 精品福利一区二区三区 | 91精品国产91久久久久久丝袜 | 国户精品久久久久久久久久久不卡 | 国产四区 | 国产精品视频一二三 | 人人九九精 | 中文字幕在线观看一区 | 亚洲精品综合一区二区 | 亚洲人成在线观看 | 日日骚网 | 中文字幕高清av | 91久久夜色 | 亚洲一区二区免费 | 在线欧美日韩 | 亚洲导航深夜福利涩涩屋 | 在线成人精品视频 | 久久国产麻豆 | 欧美综合国产精品久久丁香 | 欧美精品tv | 亚洲在线一区 | 精品国产一区二区三区久久 | 欧美精品一区二区三区在线 | 91精品国产一区二区 | 国产美女一区 | 亚洲va在线va天堂va狼色在线 | 久久久久久久综合色一本 | 丁香婷婷久久久综合精品国产 | 青青久草| 精品欧美一区二区三区 | 欧美日韩高清在线观看 | 国产电影一区二区 | 国内精品久久久久 | 日韩av手机在线观看 | 国产亚洲一区在线 | 一区二区三区四区在线免费观看 |