标题: 分享一个有关OV7670的二值化STM32程序 [打印本页]

作者: 藤千盂    时间: 2018-3-7 12:55
标题: 分享一个有关OV7670的二值化STM32程序
单片机源程序如下:
  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. int main(void)
  15. {         
  16.         int i;
  17.         delay_init();                      //延时函数初始化
  18.         NVIC_Configuration();         //设置NVIC中断优先级
  19.         uart_init(9600);                         //串口初始化为9600
  20.          LED_Init();                              //LE端口初始化
  21.         LCD_Init();        
  22.         usmart_dev.init(72);        /初始化USMART                     
  23.          POINT_COLOR=BLUE;                        //字体设置为蓝色
  24.         LCD_ShowString(60,50,200,16,16,"ROBOT_Program");        
  25.         LCD_ShowString(60,70,200,16,16,"Testing.....");         
  26.         LCD_ShowString(60,230,200,16,16,"OV7670 Init......");        
  27.          
  28.         while(OV7670_Init())//初始化OV7670
  29.         {
  30.                 LCD_ShowString(60,230,200,16,16,"OV7670 Error!!");
  31.                 delay_ms(200);
  32.                 LCD_Fill(60,230,239,246,WHITE);
  33.                 delay_ms(200);
  34.         }
  35.         
  36.         LCD_ShowString(60,230,200,16,16,"OV7670 Init OK");
  37.         delay_ms(1500);
  38.                                                                           
  39.         EXTI8_Init();                                       
  40.         
  41.         OV7670_CS=0;        

  42.         while(1)
  43.         {
  44.         refresh_BW();        
  45.         }           
  46. }
  47. /*函数功能:黑白二值化(BLACK-WHITE)
  48. * 函数名称:refresh_BW();
  49. */
  50. void refresh_BW(void)//
  51. {
  52.     u32 j;
  53.     u16 color;
  54.       
  55.         if(ov_sta==2)
  56.         {      
  57.                 LCD_Scan_Dir(U2D_L2R);                //从上到下,从左到右 刷新
  58.                 LCD_SetCursor(0,0);        //设置光标
  59.                 LCD_WriteRAM_Prepare();     //开始写入GRAM
  60.                 OV7670_CS=0;
  61.                 OV7670_RRST=0;                                //开复位度指针
  62.                 OV7670_RCK=0;
  63.                 OV7670_RCK=1;
  64.                 OV7670_RCK=0;
  65.                 OV7670_RRST=1;                                //读指针结束
  66.                 OV7670_RCK=1;  
  67.                
  68.                                               for(j=0;j<76800;j++)
  69.                                     {               
  70.                                                 OV7670_RCK=0;   
  71.                                                 OV7670_RCK=1;
  72.                                                 color=GPIOC->IDR&0XFF;        //读数据               
  73.                                                 OV7670_RCK=0;
  74.                                                 OV7670_RCK=1;
  75.                                                 color=GPIOC->IDR&0XFF;        //读数据
  76.                                                 color>>=5;
  77.                        
  78.                                                 if(color>0x03)
  79.                                                 color=0xffff;   
  80.                                                 else
  81.                                                 color=0x0000;                       

  82.                                                 LCD->LCD_RAM=color;
  83.                               
  84.                                     }
  85.                                                 OV7670_CS=1;
  86.                                                 OV7670_RCK=0;
  87.                                                 OV7670_RCK=1;
  88.                                                 EXTI_ClearITPendingBit(EXTI_Line8);  //清除LINE8上的中断标志位
  89.                                                 ov_sta=0;                                        //开始下一次采集
  90.                
  91.                                                 LCD_Scan_Dir(DFT_SCAN_DIR);        //回复默认扫描方向
  92.         }
  93. }



复制代码

所有资料51hei提供下载:
黑白二值化.rar (357.12 KB, 下载次数: 27)







欢迎光临 (http://www.51hei.com/bbs/) Powered by Discuz! X3.1