找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 2553|回复: 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 共享资料的黑币奖励!

查看全部评分

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏1 分享淘帖 顶 踩
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表