找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 20703|回復(fù): 51
收起左側(cè)

stm32攝像頭顏色識別+舵機(jī)控制ov7670

  [復(fù)制鏈接]
ID:226507 發(fā)表于 2017-8-10 12:47 | 顯示全部樓層 |閱讀模式
stm32f103,正點(diǎn)原子的mini板。配合ov7670,能夠進(jìn)行顏色識別+舵機(jī)控制。圈出顏色范圍

代碼下載:
顏色識別+舵機(jī)控制.7z (251.09 KB, 下載次數(shù): 779)


主程序:
  1. #include "sys.h"
  2. #include "usart.h"               
  3. #include "delay.h"        
  4. #include "led.h"
  5. #include "usmart.h"
  6. #include "lcd.h"
  7. #include "ov7670.h"
  8. #include "exti.h"
  9. #include "timer.h"
  10. #include "EasyTrace.h"
  11. #include "PWM.h"

  12. //ALIENTEK Mini STM32開發(fā)板擴(kuò)展實(shí)驗(yàn)9
  13. //攝像頭實(shí)驗(yàn)
  14. extern u8 ov_sta;        //在exit.c里面定義
  15. extern u8 ov_frame;        //在timer.c里面定義
  16. u16 r,y;
  17. //更新LCD顯示
  18. void camera_refresh(void)
  19. {
  20.         RESULT Resu;
  21.         TARGET_CONDI Condition={215,240,20,240,30,160,30,30,320,240};        //API參數(shù)  hls的閾值,識別時用的
  22.         
  23.         u32 j;
  24.          u16 color;         
  25.         if(ov_sta==2)
  26.         {
  27.                 LCD_Scan_Dir(U2D_L2R);                //從上到下,從左到右
  28.                 LCD_SetCursor(0x00,0x0000);        //設(shè)置光標(biāo)位置
  29.                 LCD_WriteRAM_Prepare();     //開始寫入GRAM        
  30.                  OV7670_CS=0;         
  31.                  OV7670_RRST=0;                                //開始復(fù)位讀指針
  32.                 OV7670_RCK=0;
  33.                 OV7670_RCK=1;
  34.                 OV7670_RCK=0;
  35.                 OV7670_RRST=1;                                //復(fù)位讀指針結(jié)束
  36.                 OV7670_RCK=1;  
  37.                 for(j=0;j<76800;j++)
  38.                 {
  39.                         GPIOB->CRL=0X88888888;                  
  40.                         OV7670_RCK=0;
  41.                         color=OV7670_DATA;                //讀數(shù)據(jù)
  42.                         OV7670_RCK=1;         
  43.                         color<<=8;                                          
  44.                          OV7670_RCK=0;
  45.                         color|=OV7670_DATA;                //讀數(shù)據(jù)                  
  46.                         OV7670_RCK=1;
  47.                         GPIOB->CRL=0X33333333;                                                         
  48.                         //
  49.                         //加算法,例灰階轉(zhuǎn)換,二值化之類的
  50.                   //
  51.                         LCD_WR_DATA(color);         
  52.                 }

  53.      if(Trace(&Condition,&Resu) )                      //API
  54.                         {
  55.                                 
  56.                                 
  57.                                 LCD_Fill(Resu.x-Resu.w/2,Resu.y-Resu.h/2,Resu.x+Resu.w/2,Resu.y-Resu.h/2+1,0xf800);//u16 x,u16 y,u16 width,u16 hight,u16 Color
  58.                                 LCD_Fill(Resu.x-Resu.w/2,Resu.y-Resu.h/2,Resu.x-Resu.w/2+1,Resu.y+Resu.h/2,0xf800);
  59.                                 LCD_Fill(Resu.x-Resu.w/2,Resu.y+Resu.h/2,Resu.x+Resu.w/2,Resu.y+Resu.h/2+1,0xf800);
  60.                                 LCD_Fill(Resu.x+Resu.w/2,Resu.y-Resu.h/2,Resu.x+Resu.w/2+1,Resu.y+Resu.h/2,0xf800);
  61.                                 LCD_Fill(Resu.x-2,Resu.y-2,Resu.x+2,Resu.y+2,0xf800);
  62.                         
  63.                                   LED1=!LED1;
  64.                                   r=Resu.x;
  65.                                   y=Resu.y;
  66.                         }
  67.                         
  68.                         
  69.                
  70.                
  71.                  OV7670_CS=1;                                                         
  72.                 OV7670_RCK=0;
  73.                 OV7670_RCK=1;
  74.                 EXTI->PR=1<<15;                     //清除LINE8上的中斷標(biāo)志位
  75.                 ov_sta=0;                                        //開始下一次采集
  76.                  ov_frame++;
  77.                 LCD_Scan_Dir(DFT_SCAN_DIR);        //恢復(fù)默認(rèn)掃描方向                                                     
  78.         }
  79. }         
  80. int main(void)
  81. {
  82.         u16 led0pwmval;
  83.         static int t=0;         
  84.         u8 i;        
  85.         delay_init();                     //延時函數(shù)初始化
  86.         NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);// 設(shè)置中斷優(yōu)先級分組2
  87.         uart_init(9600);
  88.         OV7670_Init();        
  89.         LED_Init();                                  //初始化與LED連接的硬件接口
  90.         LCD_Init();                 //初始化LCD
  91.   TIM2_PWM_Init(199,7199);                      //PWM定時器設(shè)置
  92.         if(lcddev.id==0X6804||lcddev.id==0X5310||lcddev.id==0X5510||lcddev.id==0X1963) //強(qiáng)制設(shè)置屏幕分辨率為320*240.以支持3.5寸大屏
  93.         {
  94.                 lcddev.width=240;
  95.                 lcddev.height=320;
  96.         }
  97.         usmart_dev.init(72);        //初始化USMART        
  98.         
  99.          POINT_COLOR=RED;//設(shè)置字體為紅色
  100.         LCD_ShowString(60,50,200,200,16,"Mini STM32");        
  101.         LCD_ShowString(60,70,200,200,16,"OV7670 TEST");        
  102.         LCD_ShowString(60,90,200,200,16,"ATOM@ALIENTEK");
  103.         LCD_ShowString(60,110,200,200,16,"2014/3/27");           
  104.         LCD_ShowString(60,130,200,200,16,"Use USMART To Set!");         
  105.           LCD_ShowString(60,150,200,200,16,"OV7670 Init...");         
  106.         while(OV7670_Init())//初始化OV7670
  107.         {
  108.                   LCD_ShowString(60,150,200,200,16,"OV7670 Error!!");
  109.                   delay_ms(200);
  110.             LCD_Fill(60,150,239,166,WHITE);
  111.             delay_ms(200);
  112.         }
  113.          LCD_ShowString(60,150,200,200,16,"OV7670 Init OK");
  114.         delay_ms(1500);                              
  115.         TIM3_Int_Init(10000,7199);                        //TIM3,10Khz計(jì)數(shù)頻率,1秒鐘中斷                                                                          
  116.         EXTI15_Init();                                                //使能定時器捕獲
  117.         OV7670_Window_Set(10,174,240,320);        //設(shè)置窗口         
  118.           OV7670_CS=0;


  119.          
  120.         
  121.          while(1)
  122.         {        
  123.                  camera_refresh();        //更新顯示         
  124.                  
  125.                         printf("Resu:%d-%d\r\n",r,y);
  126.                         if(y>120)
  127.                                 t++;
  128.                 if(t==0)
  129.                         led0pwmval=188;
  130.                 else if(t==1)
  131.                         led0pwmval=190;
  132.                 else if(t==2)
  133.                         led0pwmval=194;
  134.                 else
  135.                         led0pwmval=194;
  136.                   
  137.                         
  138.                     printf("Result:%d\r\n",t);
  139.                           delay_ms(10);
  140.                           delay_ms(10);
  141.                     
  142.                      TIM_SetCompare3(TIM2,led0pwmval);        
  143.                            printf("Re:%d\r\n",led0pwmval);
  144.                
  145.                 if(i!=ov_frame)                //DS0閃爍.
  146.                 {
  147.                         i=ov_frame;
  148.                         LED0=!LED0;
  149.                         
  150.                  }
  151.         }           
  152. }

復(fù)制代碼




評分

參與人數(shù) 1黑幣 +5 收起 理由
路梓孜 + 5 剛好有個需要用7670做顏色識別實(shí)驗(yàn),正好參.

查看全部評分

回復(fù)

使用道具 舉報(bào)

ID:226705 發(fā)表于 2017-8-10 19:45 | 顯示全部樓層
感謝分享
回復(fù)

使用道具 舉報(bào)

ID:226705 發(fā)表于 2017-8-10 20:30 | 顯示全部樓層
請問下這是什么型號的開發(fā)板啊,是stm32f407的嗎
回復(fù)

使用道具 舉報(bào)

ID:226705 發(fā)表于 2017-8-10 21:33 | 顯示全部樓層
你好能加我下qq向你請教下東西嗎,關(guān)于攝像頭小球定位的,290407985,很感謝
回復(fù)

使用道具 舉報(bào)

ID:108109 發(fā)表于 2017-8-12 09:31 | 顯示全部樓層
可以用嗎?
回復(fù)

使用道具 舉報(bào)

ID:227752 發(fā)表于 2017-8-16 15:58 | 顯示全部樓層
高手,技術(shù)nc
回復(fù)

使用道具 舉報(bào)

ID:227752 發(fā)表于 2017-8-16 15:59 | 顯示全部樓層
高手,技術(shù)nc
回復(fù)

使用道具 舉報(bào)

ID:240128 發(fā)表于 2017-10-19 18:59 | 顯示全部樓層
我看看你的文件正好我缺顏色識別
回復(fù)

使用道具 舉報(bào)

ID:244736 發(fā)表于 2017-11-1 07:12 | 顯示全部樓層
頂一下
回復(fù)

使用道具 舉報(bào)

ID:246070 發(fā)表于 2017-11-4 19:48 | 顯示全部樓層
頂。。。。。。。。。。
回復(fù)

使用道具 舉報(bào)

ID:246070 發(fā)表于 2017-11-5 11:32 | 顯示全部樓層
作者能否講解一下
回復(fù)

使用道具 舉報(bào)

ID:263355 發(fā)表于 2017-12-19 16:41 | 顯示全部樓層
不能下啊
回復(fù)

使用道具 舉報(bào)

ID:260390 發(fā)表于 2017-12-21 10:11 | 顯示全部樓層
不錯,下來看看,謝謝樓主
回復(fù)

使用道具 舉報(bào)

ID:264196 發(fā)表于 2017-12-27 19:11 | 顯示全部樓層
找了好久,用來學(xué)習(xí),謝謝!
回復(fù)

使用道具 舉報(bào)

ID:236898 發(fā)表于 2018-3-15 12:50 | 顯示全部樓層
您好,我想請教一下您,Trace(&Condition,&Resu) 這個函數(shù)是在哪里讀取到了我的圖像數(shù)據(jù)呢
回復(fù)

使用道具 舉報(bào)

ID:291267 發(fā)表于 2018-3-25 16:06 | 顯示全部樓層
回答的什么呀,看不了
回復(fù)

使用道具 舉報(bào)

ID:297945 發(fā)表于 2018-3-27 19:48 | 顯示全部樓層
作者好,我想用stm32設(shè)計(jì)一款關(guān)于攝像頭識別亮燈,小車舵機(jī)配合到亮燈旁邊,可以實(shí)現(xiàn)嗎?
回復(fù)

使用道具 舉報(bào)

ID:172280 發(fā)表于 2018-5-24 12:29 | 顯示全部樓層
謝謝樓主分享。。!
回復(fù)

使用道具 舉報(bào)

ID:336427 發(fā)表于 2018-5-25 17:38 | 顯示全部樓層
你好這個程序程序用103VET6能跑嗎
回復(fù)

使用道具 舉報(bào)

ID:353347 發(fā)表于 2018-6-21 13:47 | 顯示全部樓層
用不了,有錯誤。
回復(fù)

使用道具 舉報(bào)

ID:361916 發(fā)表于 2018-7-1 10:21 | 顯示全部樓層
f1系類用來控制攝像頭內(nèi)存夠用嗎
回復(fù)

使用道具 舉報(bào)

ID:366660 發(fā)表于 2018-7-7 09:47 來自手機(jī) | 顯示全部樓層
這個圖像顯示是灰度嗎?
回復(fù)

使用道具 舉報(bào)

ID:381742 發(fā)表于 2018-8-1 16:01 | 顯示全部樓層
贊。。。。。。。。。。。。。。。。

回復(fù)

使用道具 舉報(bào)

ID:380389 發(fā)表于 2018-8-1 22:32 來自手機(jī) | 顯示全部樓層
收藏一下,學(xué)習(xí)
回復(fù)

使用道具 舉報(bào)

ID:228731 發(fā)表于 2018-8-8 14:06 | 顯示全部樓層
厲害 謝謝樓主 辛苦了
回復(fù)

使用道具 舉報(bào)

ID:408914 發(fā)表于 2018-10-13 11:41 | 顯示全部樓層
大家不要下
回復(fù)

使用道具 舉報(bào)

ID:161033 發(fā)表于 2018-12-19 14:04 | 顯示全部樓層
先感謝。。。
回復(fù)

使用道具 舉報(bào)

ID:395676 發(fā)表于 2018-12-20 10:32 | 顯示全部樓層
謝謝樓主分享啦
回復(fù)

使用道具 舉報(bào)

ID:469634 發(fā)表于 2019-4-5 22:54 | 顯示全部樓層
感謝樓主的程序,但是有后面pwm輸出程序的話,識別容易卡主,不用的話建議去掉
回復(fù)

使用道具 舉報(bào)

ID:469634 發(fā)表于 2019-4-5 23:01 | 顯示全部樓層
感謝樓主的程序,就是有時識別時,容易卡主
回復(fù)

使用道具 舉報(bào)

ID:506294 發(fā)表于 2019-4-7 15:52 | 顯示全部樓層
這個顏色識別可以識別光源顏色嗎
就比如紅綠燈的顏色能識別嗎
回復(fù)

使用道具 舉報(bào)

ID:508945 發(fā)表于 2019-4-13 11:03 | 顯示全部樓層
這個下載以后怎么用啊
回復(fù)

使用道具 舉報(bào)

ID:498701 發(fā)表于 2019-4-13 17:27 來自手機(jī) | 顯示全部樓層
這個真不錯,下載看看。
回復(fù)

使用道具 舉報(bào)

ID:410445 發(fā)表于 2019-7-28 19:02 | 顯示全部樓層
很好用
回復(fù)

使用道具 舉報(bào)

ID:591840 發(fā)表于 2019-7-29 10:33 | 顯示全部樓層
請問我用的是103 zet6  有哪些需要改的地方
回復(fù)

使用道具 舉報(bào)

ID:405372 發(fā)表于 2019-8-1 19:49 | 顯示全部樓層
剛好用上,感謝樓主
回復(fù)

使用道具 舉報(bào)

ID:521067 發(fā)表于 2019-8-1 21:10 | 顯示全部樓層
請問有仿真圖嗎
回復(fù)

使用道具 舉報(bào)

ID:587606 發(fā)表于 2019-8-2 13:43 | 顯示全部樓層
請問,如果是ov7620 要改哪些地方呢?
回復(fù)

使用道具 舉報(bào)

ID:405372 發(fā)表于 2019-8-2 15:11 | 顯示全部樓層
這個怎么移植到精英版啊
回復(fù)

使用道具 舉報(bào)

ID:523334 發(fā)表于 2019-8-7 18:28 | 顯示全部樓層
正好寫出來不對,看看參考一下。
回復(fù)

使用道具 舉報(bào)

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

本版積分規(guī)則

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

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表