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

 找回密碼
 立即注冊(cè)

QQ登錄

只需一步,快速開(kāi)始

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

基于stm32+ov7670的顏色識(shí)別源程序

  [復(fù)制鏈接]
ID:278940 發(fā)表于 2018-1-23 15:07 | 顯示全部樓層 |閱讀模式
這個(gè)工程的應(yīng)用很簡(jiǎn)單,通過(guò)該H,S,L的閾值來(lái)提取識(shí)別物。
如果要換rgb識(shí)別,則省去RGBtoHSL這個(gè)函數(shù),然后測(cè)出閾值,就一樣了。
是基于stm32f103rct6+ov7670的,通過(guò)該原子的固件庫(kù)歷程實(shí)現(xiàn)的,適合于新手學(xué)習(xí)。
//RGB轉(zhuǎn)HSL
單片機(jī)源程序如下:
  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 "hsl.h"
  8. #include "ov7670.h"
  9. #include "exti.h"
  10. #include "timer.h"

  11. extern u8 ov_sta;        //在exit.c里面定義
  12. extern u8 ov_frame;        //在timer.c里面定義
  13. //
  14. int h,s2,l;
  15. u16 get_date;
  16. COLOR_HSL Hsl1;
  17. #define min3v(v1, v2, v3)   ((v1)>(v2)? ((v2)>(v3)?(v3):(v2)):((v1)>(v3)?(v3):(v1)))//比較最小值
  18. #define max3v(v1, v2, v3)   ((v1)<(v2)? ((v2)<(v3)?(v3):(v2)):((v1)<(v3)?(v3):(v1)))//比較最大值
  19. RESULT Resu;//捕獲顏色設(shè)置       
  20. //        TARGET_CONDI Condition={60,100,20,120,10,160,40,40,320,240};
  21. //TARGET_CONDI Condition={0,200,0,34,20,30,40,40,320,240};
  22. //unsigned char i;
  23. //static volatile ErrorStatus HSEStartUpStatus = SUCCESS;
  24. int find_x,find_y;
  25. //unsigned int position=0;
  26. //typedef struct
  27. //        {
  28. //    int  x;      // [0,320]
  29. //                int  y;       // [0,240]
  30. //  }
  31. //ZUOBIAO;//HSL格式顏色
  32. //ZUOBIAO zuobiao_for_top;
  33. //ZUOBIAO zuobiao_for_down;
  34. //ZUOBIAO zuobiao_for_left;
  35. //ZUOBIAO zuobiao_for_right;
  36. //ZUOBIAO zuobiao_for_center;
  37. //       

  38. //更新LCD顯示
  39. void camera_refresh(void)
  40. {
  41.         u32 j;
  42.         u16 color;         
  43.         if(ov_sta==2)
  44.         {
  45.                 LCD_Scan_Dir(U2D_L2R);                //從上到下,從左到右
  46.                 LCD_SetCursor(0x00,0x0000);        //設(shè)置光標(biāo)位置
  47.                 LCD_WriteRAM_Prepare();     //開(kāi)始寫(xiě)入GRAM       
  48.                 OV7670_CS=0;         
  49.                 OV7670_RRST=0;                                //開(kāi)始復(fù)位讀指針
  50.                 OV7670_RCK=0;
  51.                 OV7670_RCK=1;
  52.                 OV7670_RCK=0;
  53.                 OV7670_RRST=1;                                //復(fù)位讀指針結(jié)束
  54.                 OV7670_RCK=1;  
  55.                 for(j=0;j<76800;j++)
  56.                 {
  57.                         GPIOB->CRL=0X88888888;                  
  58.                         OV7670_RCK=0;
  59.                         color=OV7670_DATA;                //讀數(shù)據(jù)
  60.                         OV7670_RCK=1;        
  61.                         color<<=8;                                          
  62.                         OV7670_RCK=0;
  63.                         color|=OV7670_DATA;                //讀數(shù)據(jù)                  
  64.                         OV7670_RCK=1;
  65.                         GPIOB->CRL=0X33333333;                                                          
  66.                         LCD_WR_DATA(color);         
  67.                 }  
  68.                 OV7670_CS=1;                                                          
  69.                 OV7670_RCK=0;
  70.                 OV7670_RCK=1;
  71.                 EXTI->PR=1<<15;                     //清除LINE8上的中斷標(biāo)志位
  72.                 ov_sta=0;                                        //開(kāi)始下一次采集
  73.                 ov_frame++;
  74.                 LCD_Scan_Dir(DFT_SCAN_DIR);        //恢復(fù)默認(rèn)掃描方向                                                     
  75.         }
  76. }          

  77. static void readcolor(unsigned int x,unsigned int y,COLOR_RGB *Rgb)
  78. {
  79.         unsigned short C16;

  80.         C16 = LCD_ReadPoint(x,y);

  81.         Rgb->red   =         (unsigned char)((C16&0xf800)>>8);
  82.         Rgb->green =         (unsigned char)((C16&0x07e0)>>3);
  83.         Rgb->blue  =     (unsigned char)((C16&0x001f)<<3);
  84. }

  85. //RGB轉(zhuǎn)HSL
  86. static void rGBtohSL(const COLOR_RGB *Rgb,COLOR_HSL *Hsl)
  87. {
  88.   int maxVal,minVal,difVal;
  89.         int r  = Rgb->red;
  90.         int g  = Rgb->green;
  91.     int b  = Rgb->blue;
  92.          int h,s2,l;
  93.         maxVal = max3v(r, g, b);
  94.         minVal = min3v(r, g, b);
  95.        
  96.         difVal = maxVal-minVal;
  97.        
  98.         //計(jì)算亮度
  99.     l = (maxVal+minVal)*240/255/2;
  100.        
  101.         if(maxVal == minVal)//若r=g=b
  102.         {
  103.                 h = 0;
  104.                 s2 = 0;
  105.         }
  106.         else
  107.         {
  108.                 //計(jì)算色調(diào)
  109.                 if(maxVal==r)
  110.                 {
  111.                         if(g>=b)
  112.                                 h = 40*(g-b)/(difVal);
  113.                         else
  114.                                 h = 40*(g-b)/(difVal) + 240;
  115.                 }
  116.                 else if(maxVal==g)
  117.                         h = 40*(b-r)/(difVal) + 80;
  118.                 else if(maxVal==b)
  119.                         h = 40*(r-g)/(difVal) + 160;
  120.                 //計(jì)算飽和度
  121.                 if(l == 0)
  122.                         s2 = 0;
  123.                 else if(l<=120)
  124.                         s2 = (difVal)*240/(maxVal+minVal);
  125.                 else
  126.                         s2 = (difVal)*240/(511 - (maxVal+minVal));
  127.         }
  128.     Hsl->hue =        (unsigned char)(((h>240)? 240 : ((h<0)?0:h)));
  129.     Hsl->saturation = (unsigned char)(((s2>240)? 240 : ((s2<0)?0:s2)));
  130.     Hsl->luminance =  (unsigned char)(((l>240)? 240 : ((l<0)?0:l)));
  131. }

  132. int main()
  133. {
  134.   COLOR_RGB Rgb;         
  135.          int sum_x=0,sum_y=0,i_xy = 0,n_i;
  136.          int X,Y;
  137. //         int led_flg = 0;
  138. //         int pointCnt=0;
  139. //         int val_exp = 500;
  140. //         int position_front_Cnt = 0,position_left_Cnt = 0,position_right_Cnt = 0,position_centre_Cnt = 0;
  141. //         int position_front_exp = val_exp,position_left_exp = val_exp,position_right_exp = val_exp,position_centre_exp = val_exp ,pointCnt_exp = 900;        //靈敏度,,就是有多少紅色(像素塊為單位)可以觸發(fā)條件。
  142.         ///pointcnt_exp 需要實(shí)際測(cè)試,來(lái)確定最終值
  143.          delay_init();                     //延時(shí)函數(shù)初始化
  144.         NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);// 設(shè)置中斷優(yōu)先級(jí)分組2
  145.         uart_init(9600);
  146.         OV7670_Init();       
  147.         LED_Init();                                  //初始化與LED連接的硬件接口
  148.         LCD_Init();                                   //初始化LCD
  149.         if(lcddev.id==0X6804||lcddev.id==0X5310||lcddev.id==0X5510||lcddev.id==0X1963) //強(qiáng)制設(shè)置屏幕分辨率為320*240.以支持3.5寸大屏
  150.         {
  151.                 lcddev.width=240;
  152.                 lcddev.height=320;
  153.         }
  154.         usmart_dev.init(72);        //初始化USMART       
  155.        
  156.         POINT_COLOR=BLACK;//設(shè)置字體為紅色

  157.         while(OV7670_Init())//初始化OV7670
  158.         {
  159.                 LCD_ShowString(60,150,200,200,16,"OV7670 Error!!");
  160.                 delay_ms(200);
  161.             LCD_Fill(60,150,239,166,WHITE);
  162.                 delay_ms(200);
  163.         }
  164.         LCD_ShowString(60,150,200,200,16,"camera, okey!");
  165.         TIM3_Int_Init(10000,7199);                        //TIM3,10Khz計(jì)數(shù)頻率,1秒鐘中斷                                                                          
  166.         EXTI15_Init();                                                //使能定時(shí)器捕獲
  167.         OV7670_Window_Set(10,174,240,320);        //設(shè)置窗口          
  168.           OV7670_CS=0;       
  169.                 uart_init(9600);         //串口初始化為9600
  170.        

  171.         while(1)
  172.         {       
  173.         for(find_y=0;find_y<320;find_y=find_y +4)//尋找測(cè)試點(diǎn)       
  174.          {
  175.                 for(find_x=0;find_x<240;find_x=find_x +4)
  176.                         {
  177.                                 get_date=LCD_ReadPoint(find_x,find_y);       
  178.                                 readcolor(find_x,find_y,&Rgb);
  179.                                 rGBtohSL(&Rgb,&Hsl1);// 完成了度rgb轉(zhuǎn)化為色調(diào),亮度,對(duì)比度
  180.                                
  181.                                 if(((Hsl1.hue>=0)&&(Hsl1.hue<=27))&&((Hsl1.saturation>=70)&&\
  182.                 (Hsl1.saturation<=100))&&((Hsl1.luminance>=70)&&(Hsl1.luminance<=150))) //紅色條件       
  183. //if(((Hsl1.hue>=220)&&(Hsl1.hue<=240))&&((Hsl1.saturation>=80)&&\
  184.         //        (Hsl1.saturation<=100))&&((Hsl1.luminance>=70)&&(Hsl1.luminance<=150))) //藍(lán)色條件                       
  185. //if(((Hsl1.hue>=50)&&(Hsl1.hue<=70))&&((Hsl1.saturation>=80)&&\
  186.         //        (Hsl1.saturation<=100))&&((Hsl1.luminance>=70)&&(Hsl1.luminance<=150))) //黃色                                       
  187.                         {
  188.                            sum_x = sum_x+find_x ;
  189.                                  sum_y = sum_y+find_y ;
  190.                                  i_xy++;
  191.                         }

  192.          }
  193.         }
  194. //            k++;
  195.             n_i=i_xy;
  196.       X=sum_x /n_i;               
  197.       Y=sum_y /n_i;
  198.         // 發(fā)送 命令
  199. //if(k==5)                                // 人為降低發(fā)送頻率 減少主控緩存壓力
  200. //        {
  201. ……………………

  202. …………限于本文篇幅 余下代碼請(qǐng)從51黑下載附件…………
復(fù)制代碼

所有資料51hei提供下載:
轉(zhuǎn)hsl識(shí)別.rar (381.77 KB, 下載次數(shù): 329)
回復(fù)

使用道具 舉報(bào)

ID:318535 發(fā)表于 2018-4-28 16:51 | 顯示全部樓層
謝謝分享!!!!
回復(fù)

使用道具 舉報(bào)

ID:308469 發(fā)表于 2018-6-3 19:33 | 顯示全部樓層
這東西用什么資料才能看懂顏色識(shí)別這部分
回復(fù)

使用道具 舉報(bào)

ID:258360 發(fā)表于 2018-7-22 18:51 | 顯示全部樓層
感謝樓主分享
回復(fù)

使用道具 舉報(bào)

ID:381742 發(fā)表于 2018-8-4 16:57 | 顯示全部樓層
好喜歡,就是樓主可以告訴我接線關(guān)系嗎
回復(fù)

使用道具 舉報(bào)

ID:362900 發(fā)表于 2018-10-28 14:33 | 顯示全部樓層
謝謝樓主分享!!!!
回復(fù)

使用道具 舉報(bào)

ID:413123 發(fā)表于 2018-10-31 10:51 | 顯示全部樓層
謝謝分享
回復(fù)

使用道具 舉報(bào)

ID:138247 發(fā)表于 2019-4-4 10:10 | 顯示全部樓層
謝謝分享。。。。
回復(fù)

使用道具 舉報(bào)

ID:545410 發(fā)表于 2019-5-23 10:53 | 顯示全部樓層
多謝分享
回復(fù)

使用道具 舉報(bào)

ID:542806 發(fā)表于 2019-6-15 22:22 | 顯示全部樓層
白屏一直響是什么原因
回復(fù)

使用道具 舉報(bào)

ID:237159 發(fā)表于 2019-9-5 21:35 | 顯示全部樓層
謝謝分享
回復(fù)

使用道具 舉報(bào)

ID:504404 發(fā)表于 2019-10-13 10:54 | 顯示全部樓層
zgx888444 發(fā)表于 2019-6-15 22:22
白屏一直響是什么原因

我也是這個(gè)事情呀,排查了好久
回復(fù)

使用道具 舉報(bào)

ID:519192 發(fā)表于 2019-11-1 00:08 | 顯示全部樓層
謝謝分享!!!!謝謝分享!!!!
回復(fù)

使用道具 舉報(bào)

ID:625412 發(fā)表于 2020-6-3 11:12 | 顯示全部樓層
識(shí)別紅色怎么調(diào)不出來(lái)
回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

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

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

快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 天天操天天干天天曰 | 国产精品久久久久久久久久久久久 | 日韩中文字幕在线视频 | 久久久久91| 精品国产乱码久久久久久果冻传媒 | 日朝毛片| 日韩日韩日韩日韩日韩日韩日韩 | 这里有精品 | 久久久久久亚洲 | 91精品国产麻豆 | 精品亚洲国产成av人片传媒 | 免费成人高清在线视频 | 久久久久久综合 | 日韩第1页| 欧洲在线视频 | 成人做爰999 | 国产欧美日韩一区 | 亚洲国产成人精品女人久久久 | 国产欧美精品一区二区三区 | 亚欧精品 | 国产成人一区二区三区久久久 | 精品在线免费观看视频 | 日本a视频 | 久久久久国产精品人 | 精品久久久久久久久久久 | 中文字幕欧美一区二区 | 欧美成人a∨高清免费观看 91伊人 | 亚洲精品www | 国产成人精品一区二区在线 | 午夜一区二区三区视频 | 国产午夜精品久久久久 | 中文字幕一级毛片 | 国产剧情一区 | 日本福利片 | 久久久久久久久久久久久久国产 | 欧美一区二区三区久久精品 | 国产伦精品一区二区三区视频金莲 | 国产精品呻吟久久av凹凸 | 国产精品国产a级 | 波多野结衣在线观看一区二区三区 | 亚洲一区二区国产 |