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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 3162|回復: 0
收起左側

基于stm3210x和ov7725二值化源程序

[復制鏈接]
ID:546245 發表于 2019-5-27 13:28 | 顯示全部樓層 |閱讀模式

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

關于圖像分科可以自己百度。。。。


首先進行攝像頭的圖像采集,使用的是野火帶FIFO的OV7725攝像頭,幀速率有點慢,但是勉強還能采集數據顯示。


單片機源程序如下:
  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];//消息緩存區

  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);//將顯示區域設置到屏幕中央
  35.                 LCD_WriteRAM_Prepare();     //開始寫入GRAM       
  36.                 OV7725_RRST=0;                                //開始復位讀指針
  37.                 OV7725_RCK_L;
  38.                 OV7725_RCK_H;
  39.                 OV7725_RCK_L;
  40.                 OV7725_RRST=1;                                //復位讀指針結束
  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;//讀數據
  48.                                 OV7725_RCK_H;
  49.                                 color<<=8;
  50.                                 OV7725_RCK_L;
  51.                                 color|=GPIOC->IDR&0XFF;//讀數據
  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;                                        //清零幀中斷標記
  71.                 ov_frame++;
  72.                 LCD_Scan_Dir(DFT_SCAN_DIR);        //恢復默認掃描方向
  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);//將顯示區域設置到屏幕中央
  83.                 LCD_WriteRAM_Prepare();     //開始寫入GRAM       
  84.                 OV7725_RRST=0;                                //開始復位讀指針
  85.                 OV7725_RCK_L;
  86.                 OV7725_RCK_H;
  87.                 OV7725_RCK_L;
  88.                 OV7725_RRST=1;                                //復位讀指針結束
  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;        //讀數據
  96.                                 OV7725_RCK_H;
  97.                                 color<<=8;  
  98.                                 OV7725_RCK_L;
  99.                                 color|=GPIOC->IDR&0XFF;        //讀數據
  100.                                 OV7725_RCK_H;
  101.                                 LCD->LCD_RAM=color;  
  102.                         }
  103.                
  104.                 }
  105.                 ov_sta=0;                                        //清零幀中斷標記
  106.                 ov_frame++;
  107.                 LCD_Scan_Dir(DFT_SCAN_DIR);        //恢復默認掃描方向
  108.         }
  109. }


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

  116.          
  117.                 delay_init();                             //延時函數初始化          
  118.                 NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);//設置中斷優先級分組為組2:2位搶占優先級,2位響應優先級
  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;                        //設置字體為紅色
  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計數頻率,1秒鐘中斷                                                                          
  165.                 EXTI8_Init();                                //使能定時器捕獲                               
  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. }
復制代碼

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

評分

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

查看全部評分

回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 日韩精品1区2区3区 国产精品国产成人国产三级 | 欧美在线视频一区二区 | 亚洲大片| 日本综合在线观看 | 中文字幕亚洲专区 | 一区二区视频 | 亚洲视频在线观看 | 国产精品欧美一区二区三区 | 日本免费一区二区三区 | 亚洲精品www久久久 www.蜜桃av | 国产日韩欧美精品一区二区三区 | 欧美亚洲网站 | 黑人精品欧美一区二区蜜桃 | 精品视频一区二区 | 二区精品 | 成人免费视频观看 | 亚洲淫视频 | 国产传媒在线观看 | 另类视频区 | 国产视频线观看永久免费 | 久草网址| 99久久久久国产精品免费 | 午夜丰满寂寞少妇精品 | 亚洲精品在线91 | 亚洲精彩视频在线观看 | 99久久亚洲| 一区二区三区视频在线 | 99re视频在线免费观看 | 欧美在线一区视频 | a视频在线观看 | 午夜a v电影 | 女人毛片a毛片久久人人 | 久久免费精品 | 国产馆 | 久久精品小视频 | 久久久久国产精品 | 欧美成人免费在线视频 | 在线观看中文字幕 | av网站免费观看 | 国产视频在线一区二区 | caoporn国产精品免费公开 |