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

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

QQ登錄

只需一步,快速開始

搜索
查看: 9505|回復(fù): 6
打印 上一主題 下一主題
收起左側(cè)

ov7670攝像頭實(shí)驗(yàn)黑白二值化程序

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:226711 發(fā)表于 2017-8-10 20:06 | 只看該作者 回帖獎(jiǎng)勵(lì) |倒序?yàn)g覽 |閱讀模式
1.針對(duì)于ov7670輸出的rgb565格式進(jìn)行黑白二值化,可能會(huì)丟掉R、G、B中低3或2位的精確度,,實(shí)測(cè)中沒有太大影響;

2.試驗(yàn)環(huán)境針對(duì)于STM32F10的板子,理想計(jì)算幀數(shù)應(yīng)為每秒20幀左右,實(shí)際幀數(shù)達(dá)到每秒15幀左右;

3.此算法沒有綠波,相對(duì)較為簡單。

4.引腳連接請(qǐng)查看文件中README.TXT

5.圖像查看,請(qǐng)查看LCD屏


所有資料51hei提供下載:
ov7670攝像頭實(shí)驗(yàn)黑白二值化.rar (386.18 KB, 下載次數(shù): 165)

stm32單片機(jī)源程序(主程序)如下:
  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 "usmart.h"


  13. /************************************************
  14. ALIENTEK戰(zhàn)艦STM32開發(fā)板實(shí)驗(yàn)35
  15. 攝像頭OV7670 實(shí)驗(yàn)
  16. ************************************************/


  17. const u8*LMODE_TBL[5]={"Auto","Sunny","Cloudy","Office","Home"};                                                        //5種光照模式            
  18. const u8*EFFECTS_TBL[7]={"Normal","Negative","B&W","Redish","Greenish","Bluish","Antique"};        //7種特效
  19. extern u8 ov_sta;        //在exit.c里 面定義
  20. extern u8 ov_frame;        //在timer.c里面定義                 

  21. unsigned char txbuf[4];

  22. void camera_refresh(void)
  23. {
  24.         u8 v=140,h=105;
  25.                 u8 color_r,color_g,color_b;
  26.         u16 k;
  27.         u8 j;
  28.          u16 color;         
  29.         if(ov_sta)//有幀中斷更新?
  30.         {
  31.                 LCD_Scan_Dir(U2D_L2R);                //從上到下,從左到右  
  32.                 if(lcddev.id==0X1963)LCD_Set_Window((lcddev.width-240)/2,(lcddev.height-320)/2,240,320);//將顯示區(qū)域設(shè)置到屏幕中央
  33.                 else if(lcddev.id==0X5510||lcddev.id==0X5310)LCD_Set_Window((lcddev.width-320)/2,(lcddev.height-240)/2,320,240);//將顯示區(qū)域設(shè)置到屏幕中央
  34.                 LCD_WriteRAM_Prepare();     //開始寫入GRAM        
  35.                 OV7670_RRST=0;                                //開始復(fù)位讀指針
  36.                 OV7670_RCK_L;
  37.                 OV7670_RCK_H;
  38.                 OV7670_RCK_L;
  39.                 OV7670_RRST=1;                                //復(fù)位讀指針結(jié)束
  40.                 OV7670_RCK_H;
  41.                 for(j=0;j<240;j++)
  42.                 {
  43.                         for(k=0;k<320;k++){
  44.                                 OV7670_RCK_L;
  45.                                 color=GPIOC->IDR&0XFF;        //讀數(shù)據(jù)
  46.                                 OV7670_RCK_H;
  47.                                 color<<=8;  
  48.                                 OV7670_RCK_L;
  49.                                 color|=GPIOC->IDR&0XFF;        //讀數(shù)據(jù)
  50.                                 OV7670_RCK_H;
  51.                         
  52. //                                LCD->LCD_RAM=color;  
  53.                         

  54.                                         color_r=color>>11;
  55.                                         color_g=(color&0x07ff)>>5;
  56.                                         color_b=color&0x001f;

  57.                                 color_g=(color_g<<2)*58;
  58.                                 color_b=(color_b<<3)*11;
  59.                                 color=(color_r+color_g+color_b+50)/100;

  60.                                 if(color>100){
  61.                                         LCD->LCD_RAM=0xffff;
  62.                                 }
  63.                                 else{
  64.                                         LCD->LCD_RAM=0;

  65.                                 }

  66.                         
  67.                                 

  68.                                 }
  69.                         }

  70.                                 
  71.                 }        
  72.                  ov_sta=0;                                        //清零幀中斷標(biāo)記
  73.                 ov_frame++;
  74.                 LCD_Scan_Dir(DFT_SCAN_DIR);        //恢復(fù)默認(rèn)掃描方向
  75.         }
  76. }           



  77. int main(void)
  78. {         

  79.          
  80.         u8 key;
  81.         u8 lightmode=0,saturation=2,brightness=2,contrast=2;
  82.         u8 effect=0;         
  83.          u8 i=0;            
  84.         u8 msgbuf[15];                                //消息緩存區(qū)
  85.         u8 tm=0;

  86.                  txbuf[0]=0x01;
  87.                 txbuf[1]=0x02;
  88.                 txbuf[2]=0x03;
  89.                 txbuf[3]=0x04;
  90.          
  91.         delay_init();                     //延時(shí)函數(shù)初始化         
  92.   NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);//設(shè)置中斷優(yōu)先級(jí)分組為組2:2位搶占優(yōu)先級(jí),2位響應(yīng)優(yōu)先級(jí)
  93.         uart_init(115200);                 //串口初始化為 115200
  94.          usmart_dev.init(72);                //初始化USMART               
  95.          LED_Init();                                          //初始化與LED連接的硬件接口
  96.         KEY_Init();                                        //初始化按鍵
  97.         LCD_Init();                                           //初始化LCD  
  98.         TPAD_Init(6);                                //觸摸按鍵初始化
  99.          POINT_COLOR=RED;                        //設(shè)置字體為紅色
  100.         LCD_ShowString(30,50,200,16,16,"WarShip STM32");        
  101.         LCD_ShowString(30,70,200,16,16,"OV7670 TEST");        
  102.         LCD_ShowString(30,90,200,16,16,"ATOM@ALIENTEK");
  103.         LCD_ShowString(30,110,200,16,16,"2015/1/18");
  104.         LCD_ShowString(30,130,200,16,16,"KEY0:Light Mode");
  105.         LCD_ShowString(30,150,200,16,16,"KEY1:Saturation");
  106.         LCD_ShowString(30,170,200,16,16,"KEY2:Brightness");
  107.         LCD_ShowString(30,190,200,16,16,"KEY_UP:Contrast");
  108.         LCD_ShowString(30,210,200,16,16,"TPAD:Effects");         
  109.           LCD_ShowString(30,230,200,16,16,"OV7670 Init...");         
  110.         while(OV7670_Init())//初始化OV7670
  111.         {
  112.                 LCD_ShowString(30,230,200,16,16,"OV7670 Error!!");
  113.                 delay_ms(200);
  114.             LCD_Fill(30,230,239,246,WHITE);
  115.                 delay_ms(200);
  116.         }
  117.          LCD_ShowString(30,230,200,16,16,"OV7670 Init OK");
  118.         delay_ms(1500);                    
  119.         OV7670_Light_Mode(lightmode);
  120.         OV7670_Color_Saturation(saturation);
  121.         OV7670_Brightness(brightness);
  122.         OV7670_Contrast(contrast);
  123.          OV7670_Special_Effects(effect);         
  124.         TIM6_Int_Init(10000,7199);                        //10Khz計(jì)數(shù)頻率,1秒鐘中斷                                                                          
  125.         EXTI8_Init();                                                //使能定時(shí)器捕獲
  126.         OV7670_Window_Set(12,176,240,320);        //設(shè)置窗口         
  127.           OV7670_CS=0;                                       
  128.         LCD_Clear(BLACK);
  129.          while(1)
  130.         {        
  131.                 key=KEY_Scan(0);//不支持連按
  132.                 if(key)
  133.                 {
  134.                         tm=20;
  135.                         switch(key)
  136.                         {                                    
  137.                                 case KEY0_PRES:        //燈光模式Light Mode
  138.                                         lightmode++;
  139.                                         if(lightmode>4)lightmode=0;
  140.                                         OV7670_Light_Mode(lightmode);
  141.                                         sprintf((char*)msgbuf,"%s",LMODE_TBL[lightmode]);
  142.                                         break;
  143.                                 case KEY1_PRES:        //飽和度Saturation
  144.                                         saturation++;
  145.                                         if(saturation>4)saturation=0;
  146.                                         OV7670_Color_Saturation(saturation);
  147.                                         sprintf((char*)msgbuf,"Saturation:%d",(signed char)saturation-2);
  148.                                         break;
  149.                                 case KEY2_PRES:        //亮度Brightness                                 
  150.                                         brightness++;
  151.                                         if(brightness>4)brightness=0;
  152.                                         OV7670_Brightness(brightness);
  153.                                         sprintf((char*)msgbuf,"Brightness:%d",(signed char)brightness-2);
  154.                                         break;
  155.                                 case WKUP_PRES:        //對(duì)比度Contrast                           
  156.                                         contrast++;
  157.                                         if(contrast>4)contrast=0;
  158.                                         OV7670_Contrast(contrast);
  159.                                         sprintf((char*)msgbuf,"Contrast:%d",(signed char)contrast-2);
  160.                                         break;
  161.                         }
  162.                 }         
  163.                 if(TPAD_Scan(0))//檢測(cè)到觸摸按鍵
  164.                 {
  165.                         effect++;
  166.                         if(effect>6)effect=0;
  167.                         OV7670_Special_Effects(effect);//設(shè)置特效
  168.                          sprintf((char*)msgbuf,"%s",EFFECTS_TBL[effect]);
  169.                         tm=20;
  170.                 }
  171.                 camera_refresh();//更新顯示
  172.                  if(tm)
  173.                 {
  174.                         LCD_ShowString((lcddev.width-240)/2+30,(lcddev.height-320)/2+60,200,16,16,msgbuf);
  175.                         tm--;
  176.                 }
  177.                 i++;
  178.                 if(i==15)//DS0閃爍.
  179.                 {
  180.                         i=0;
  181.                         LED0=!LED0;
  182.                  }
  183.         }           
  184. }

復(fù)制代碼


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

使用道具 舉報(bào)

沙發(fā)
ID:278640 發(fā)表于 2018-1-22 17:13 | 只看該作者
lz,我用這個(gè)方法,然后LCD上全黑,是為什么?
回復(fù)

使用道具 舉報(bào)

板凳
ID:317116 發(fā)表于 2018-4-26 22:25 | 只看該作者
同問lz,我用這個(gè)方法,然后LCD上全黑,是為什么?你測(cè)試過嗎?而且還有一個(gè)錯(cuò)誤,我修改之后就是一片黑!
回復(fù)

使用道具 舉報(bào)

地板
ID:332838 發(fā)表于 2018-6-12 15:19 | 只看該作者
新視野 發(fā)表于 2018-4-26 22:25
同問lz,我用這個(gè)方法,然后LCD上全黑,是為什么?你測(cè)試過嗎?而且還有一個(gè)錯(cuò)誤,我修改之后就是一片黑!

修改閥值就行了
回復(fù)

使用道具 舉報(bào)

5#
ID:373575 發(fā)表于 2018-7-18 09:22 | 只看該作者
一片黑,怎么改都沒用,說是調(diào)閾值,但是那個(gè)是閾值也不交代清楚
回復(fù)

使用道具 舉報(bào)

6#
ID:226711 發(fā)表于 2018-12-19 13:34 | 只看該作者
看這里看這里
                                        color_r=color>>11;
                                        color_g=(color&0x07ff)>>5;
                                        color_b=color&0x001f;
//按照RGB5:6:5,分別取出紅綠藍(lán)三色
                                color_g=(color_g<<2)*58;
                                color_b=(color_b<<3)*11;
                                color=(color_r+color_g+color_b+50)/100;
//先將三色移位轉(zhuǎn)換成8位(會(huì)失去后2、3位的精度),按照公式計(jì)算得出灰度值
//    公式:Gray = R*0.299 + G*0.587 + B*0.114,,程序里少東西了
                                if(color>100){        //此處“100”,為閾值,黑白取值范圍0-255
                                        LCD->LCD_RAM=0xffff;
                                }
                                else{
                                        LCD->LCD_RAM=0;

                                }
回復(fù)

使用道具 舉報(bào)

7#
ID:138247 發(fā)表于 2019-5-2 15:24 | 只看該作者

謝謝樓主分享。。。
回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

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

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

快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 成人欧美一区二区三区白人 | 成人国产精品色哟哟 | 日韩精品一区二区三区中文在线 | 91视频在线观看 | 日韩欧美精品 | 99精品免费久久久久久久久日本 | 免费在线观看成人 | 欧美在线一区二区视频 | 精品一区二区三区在线观看 | 青娱乐av | v片网站 | 国产成人福利在线观看 | 欧美视频三区 | 亚洲精品欧美 | av天天干 | 夜夜精品浪潮av一区二区三区 | 久久久精品影院 | 日韩一级免费大片 | 国产欧美精品区一区二区三区 | 欧美精品一区二区三区在线 | 欧美日韩国产精品一区二区 | 日韩一区二区福利视频 | 热久久免费视频 | 亚欧精品一区 | 福利视频一区二区 | 久久99精品久久久久久国产越南 | 欧美一区二区在线 | 毛片一区二区三区 | 国产精品海角社区在线观看 | 伊人伊成久久人综合网站 | av黄在线观看| 欧美精品一区二区在线观看 | 在线观看视频91 | 成人h视频在线观看 | 久久9久| 亚洲精品乱码久久久久久9色 | 欧美日韩视频在线播放 | 色www精品视频在线观看 | 超碰操 | 国产精品免费一区二区三区 | 日韩欧美字幕 |