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

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

QQ登錄

只需一步,快速開始

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

基于stm3210x和ov7725二值化源程序

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:546245 發(fā)表于 2019-5-27 13:28 | 只看該作者 回帖獎(jiǎng)勵(lì) |倒序?yàn)g覽 |閱讀模式

使用OV7725進(jìn)行采集數(shù)據(jù),顯示到LCD屏幕上面,再進(jìn)行灰度處理,然后再尋找圖像分割的灰度閾值,進(jìn)行圖像二值化。

關(guān)于圖像分科可以自己百度。。。。


首先進(jìn)行攝像頭的圖像采集,使用的是野火帶FIFO的OV7725攝像頭,幀速率有點(diǎn)慢,但是勉強(qiáng)還能采集數(shù)據(jù)顯示。


單片機(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 "ov7725.h"
  9. #include "tpad.h"
  10. #include "timer.h"
  11. #include "exti.h"
  12. #include "usmart.h"


  13. #define  OV7725 1
  14. #define  OV7725_WINDOW_WIDTH                320 // <=320
  15. #define  OV7725_WINDOW_HEIGHT                240 // <=240


  16. u32 j,i,x=0,y=0;
  17. u16 color;
  18. u8 gm_red, gm_green, gm_blue;
  19. u8 tm=0;
  20. int r,tt;
  21. u8 lightmode=0,saturation=2,contrast=2;
  22. u8 effect=0,brightness=0;
  23. u8 showmode=0;
  24. u8 msgbuf[15];//消息緩存區(qū)

  25. extern u8 ov_sta;        //在exit.c里 面定義
  26. extern u8 ov_frame;        //在timer.c里面定義


  27. //更新LCD顯示(OV7725)
  28. void OV7725_camera_refresh(void)
  29. {
  30.         if(ov_sta)                        //有幀中斷更新
  31.         {
  32.                 LCD_Scan_Dir(U2D_L2R);                //從上到下,從左到右
  33.                 if(lcddev.id==0X1963)
  34.                         LCD_Set_Window((lcddev.width-OV7725_WINDOW_WIDTH)/2,(lcddev.height-OV7725_WINDOW_HEIGHT)/2,OV7725_WINDOW_HEIGHT,OV7725_WINDOW_WIDTH);//將顯示區(qū)域設(shè)置到屏幕中央
  35.                 LCD_WriteRAM_Prepare();     //開始寫入GRAM       
  36.                 OV7725_RRST=0;                                //開始復(fù)位讀指針
  37.                 OV7725_RCK_L;
  38.                 OV7725_RCK_H;
  39.                 OV7725_RCK_L;
  40.                 OV7725_RRST=1;                                //復(fù)位讀指針結(jié)束
  41.                 OV7725_RCK_H;
  42.                 for(i=0;i<OV7725_WINDOW_HEIGHT;i++)
  43.                 {
  44.                         for(j=0;j<OV7725_WINDOW_WIDTH;j++)
  45.                         {
  46.                                 OV7725_RCK_L;
  47.                                 color=GPIOC->IDR&0XFF;//讀數(shù)據(jù)
  48.                                 OV7725_RCK_H;
  49.                                 color<<=8;
  50.                                 OV7725_RCK_L;
  51.                                 color|=GPIOC->IDR&0XFF;//讀數(shù)據(jù)
  52.                                 OV7725_RCK_H;
  53.                                
  54.                                 gm_red = color>>11;
  55.                                 gm_green = (color&0x07E0)>>5;
  56.                                 gm_blue = (color&0x001F);
  57.                                
  58.                                 if((gm_red<0X0008)&&(gm_blue<0X0020)&&(gm_green<0X0020))
  59.                                         {
  60.                                                 color =0x0000;
  61.                                         }
  62.                                 else
  63.                                         {
  64.                                                 color=0xffff;
  65.                                         }
  66.                                 LCD->LCD_RAM=color;
  67.                         }
  68.                
  69.                 }
  70.                 ov_sta=0;                                        //清零幀中斷標(biāo)記
  71.                 ov_frame++;
  72.                 LCD_Scan_Dir(DFT_SCAN_DIR);        //恢復(fù)默認(rèn)掃描方向
  73.         }
  74. }

  75. //更新LCD顯示(OV7725)
  76. void OV7726_camera_refresh(void)
  77. {
  78.         if(ov_sta)                        //有幀中斷更新
  79.         {
  80.                 LCD_Scan_Dir(U2D_L2R);                //從上到下,從左到右
  81.                 if(lcddev.id==0X1963)
  82.                         LCD_Set_Window((lcddev.width-OV7725_WINDOW_WIDTH)/2,(lcddev.height-OV7725_WINDOW_HEIGHT)/2,OV7725_WINDOW_HEIGHT,OV7725_WINDOW_WIDTH);//將顯示區(qū)域設(shè)置到屏幕中央
  83.                 LCD_WriteRAM_Prepare();     //開始寫入GRAM       
  84.                 OV7725_RRST=0;                                //開始復(fù)位讀指針
  85.                 OV7725_RCK_L;
  86.                 OV7725_RCK_H;
  87.                 OV7725_RCK_L;
  88.                 OV7725_RRST=1;                                //復(fù)位讀指針結(jié)束
  89.                 OV7725_RCK_H;
  90.                 for(i=0;i<OV7725_WINDOW_HEIGHT;i++)
  91.                 {
  92.                         for(j=0;j<OV7725_WINDOW_WIDTH;j++)
  93.                         {
  94.                                 OV7725_RCK_L;
  95.                                 color=GPIOC->IDR&0XFF;        //讀數(shù)據(jù)
  96.                                 OV7725_RCK_H;
  97.                                 color<<=8;  
  98.                                 OV7725_RCK_L;
  99.                                 color|=GPIOC->IDR&0XFF;        //讀數(shù)據(jù)
  100.                                 OV7725_RCK_H;
  101.                                 LCD->LCD_RAM=color;  
  102.                         }
  103.                
  104.                 }
  105.                 ov_sta=0;                                        //清零幀中斷標(biāo)記
  106.                 ov_frame++;
  107.                 LCD_Scan_Dir(DFT_SCAN_DIR);        //恢復(fù)默認(rèn)掃描方向
  108.         }
  109. }


  110. int main(void)
  111.         {         
  112.                 u8 sensor=0;
  113.                 u8 key;
  114.                 u8 i=0;            
  115.                 u8 msgbuf[15];//消息緩存區(qū)

  116.          
  117.                 delay_init();                             //延時(shí)函數(shù)初始化          
  118.                 NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);//設(shè)置中斷優(yōu)先級(jí)分組為組2:2位搶占優(yōu)先級(jí),2位響應(yīng)優(yōu)先級(jí)
  119.                 uart_init(115200);                         //串口初始化為 115200
  120.                 usmart_dev.init(72);                //初始化USMART               
  121.                 LED_Init();                                          //初始化與LED連接的硬件接口
  122.                 KEY_Init();                                        //初始化按鍵
  123.                 LCD_Init();                                           //初始化LCD  
  124.                 TPAD_Init(6);                                //觸摸按鍵初始化
  125.                 POINT_COLOR=RED;                        //設(shè)置字體為紅色
  126.                 LCD_ShowString(30,50,200,16,16,"AHUT");       
  127.                 LCD_ShowString(30,70,200,16,16,"OV7725");       
  128.                 LCD_ShowString(30,110,200,16,16,"2019/5/22");
  129.                 LCD_ShowString(30,210,200,16,16,"TPAD(SD2):Effects");         
  130.           LCD_ShowString(30,230,200,16,16,"OV7725 Init...");       
  131.                 while(1)//初始化OV7725
  132.                         {
  133.                                 if(OV7725_Init()==0)
  134.                                         {
  135.                                                 sensor=OV7725;
  136.                                                 LCD_ShowString(30,230,200,16,16,"OV7725 Init OK       ");
  137.                                                 OV7725_Light_Mode(lightmode);
  138.                                                 OV7725_Color_Saturation(saturation);
  139.                                                 OV7725_Brightness(brightness);
  140.                                                 OV7725_Contrast(contrast);
  141.                                                 OV7725_Special_Effects(effect);
  142.                                                 while(1)
  143.                                                         {
  144.                                                                 key=KEY_Scan(0);
  145.                                                                 if(key==S1)
  146.                                                                         {
  147.                                                                                 OV7725_Window_Set(OV7725_WINDOW_WIDTH,OV7725_WINDOW_HEIGHT,0);//QVGA模式輸出
  148.                                                                                 break;
  149.                                                                         }
  150.                                                                 i++;
  151.                                                                 if(i==100)
  152.                                                                         LCD_ShowString(30,250,210,16,16,"S1:QVGA"); //閃爍顯示提示信息
  153.                                                                 if(i==200)
  154.                                                                         {       
  155.                                                                                 LCD_Fill(30,250,210,250+16,WHITE);
  156.                                                                                 i=0;
  157.                                                                         }
  158.                                                                 delay_ms(5);
  159.                                                         }                                               

  160.                                         OV7725_CS=0;
  161.                                         break;
  162.                                 }
  163.                         }
  164.                 TIM6_Int_Init(10000,7199);        //10Khz計(jì)數(shù)頻率,1秒鐘中斷                                                                          
  165.                 EXTI8_Init();                                //使能定時(shí)器捕獲                               
  166.                 LCD_Clear(BLACK);
  167.                 while(1)
  168.                         {       
  169.                                                 key=KEY_Scan(0);//不支持連按
  170.                 if(key)
  171.                 {
  172.                         tm=20;
  173.                         switch(key)
  174.                         {                                    
  175.                                 case S1:       
  176.                                         showmode++;
  177.                                         if(sensor==OV7725)
  178.                                         {
  179.                                                 if(showmode>1)showmode=0;
  180.                                         }
  181.                                         break;
  182.                         }
  183.                 }
  184.                                 if(sensor==OV7725)
  185.                                 {
  186.                                         if(showmode==0)
  187.                                         OV7725_camera_refresh();//更新顯示
  188.                                         else
  189.                                         OV7726_camera_refresh();//更新顯示;
  190.                                 }
  191.                                 if(tm)
  192.                                         {
  193.                                                 LCD_ShowString((lcddev.width-240)/2+30,(lcddev.height-320)/2+60,200,16,16,msgbuf);
  194.                                                 tm--;
  195.                                         }
  196.                                 i++;
  197.                                 if(i>=15)//DS0閃爍.
  198.                                         {
  199.                                                 i=0;
  200.                                                 LED0=!LED0;
  201.                                         }
  202.                         }          
  203. }
復(fù)制代碼

所有資料51hei提供下載:
erzhi2.7z (238.56 KB, 下載次數(shù): 61)

評(píng)分

參與人數(shù) 1黑幣 +50 收起 理由
admin + 50 共享資料的黑幣獎(jiǎng)勵(lì)!

查看全部評(píng)分

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

使用道具 舉報(bào)

本版積分規(guī)則

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

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

快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 亚洲精品一区二区在线观看 | 黑人精品欧美一区二区蜜桃 | 不卡在线视频 | 欧美九九 | 久久99精品久久久久久青青日本 | 99久久免费观看 | 夜夜av| 久久伊人精品一区二区三区 | 中文精品视频 | 搞黄视频免费看 | 欧美日韩亚洲系列 | av毛片在线| 伊人免费网 | 亚洲电影成人 | 波多野结衣在线观看一区二区三区 | 粉嫩高清一区二区三区 | 亚洲大片在线观看 | 中文字幕一区在线观看视频 | 久久6| 成人二区 | 日韩成人免费视频 | 欧美日韩一区二区三区在线观看 | www.国产精 | 成年人在线观看 | 成人3d动漫一区二区三区91 | 国产精品美女久久久久久久网站 | 一级免费视频 | 中文字幕欧美一区 | 日韩一区二区三区在线观看 | 男人天堂网av | 色综合视频 | 国产欧美在线视频 | av在线播放国产 | 国产午夜影院 | 中文字幕视频一区二区 | 国产美女自拍视频 | 一区二区手机在线 | 精品久久久久久久久久久久久久 | 在线观看免费av网站 | 成人在线精品 | 日韩高清www|