xml地图|网站地图|网站标签 [设为首页] [加入收藏]
来自 公司产品 2020-02-11 00:41 的文章
当前位置: 阜新市调制模块有限公司 > 公司产品 > 正文

基于STM32的OV7670摄像头总结

  传感器:CMOS器件;标准的SCCB接口,兼容IIC接口;内置感光阵列,时序发生器,AD转换器,模拟信号处理,数字信号处理器.....

  大致工作过程:光照射到感光阵列产生相应电荷,传输到相应的模拟信号处理单元,再由AD转换为数字信号,在经由数字信号处理器插值到RGB信号,最后传输到屏幕上......

  先了解一下基础知识:现在市面上的OV7670模块分两种:1、带FIFO芯片;2、不带FIFO芯片。当然带FIFO的要贵一点~下面介绍带FIFO和不带FIFO的工作原理:

  不带FIFO:这种方法最简单,最直接,但是最不好实现的方法,原因是多数的CMOS芯片(如OV7670)的时钟速度可以高达24M,一般单片机的IO口速度根本达不到(stm32的IO速度,寄存器比库函数快,博主之前测,用库函数IO口速度好像是2.5Mhz,而用寄存器IO口速度是8M吧,速度相差较大~)。当然,高级的MCU,如ARM9以上或者DSP图像处理芯片等,本身处理速度快,内存大而且有的还带camera接口,可以不用带FIFO。主要是人家价格也高啊~

  但也不是不是完全没有办法在低速上实现采集,方法也很简单,那么就是降低CMOS的输出速度,不过这需要靠外部的晶振和内部的PLL电路以及像素时钟速度,帧速等多个寄存器共同设置,并且要和MCU的IO速度匹配才可实现。但不建议这么做,原因是:这种寄存器设置将带来更多的学习困难和理解困难,并导致硬件图像的采集速度可能下降到0.5帧以下,同时带来图像失真的可能。

  还有一种方法就是DMA方式采集,代码复杂,速度在5-10帧左右。(博主本来想用该方法的,可是基础差,领导模块碎调试困难。会接着调试~)

  注:部分CMOS时钟速度不快,可以单片机直接采集,如OV7660,但该芯片已经停产。

  带FIFO:由于采用了FIFO做为数据缓冲,数据采集大大简便,用户只需要关心是如何读取即可,不需要关心具体数据是如何采集到的,这样可减小甚至不用关心CMOS的控制以及时序关系,就能够实现图像的采集。

  注意:FIFO不具备地址功能,因此他也就不具备数据的定位(选址)读取功能,领导模块碎所以不可能有真正的数据处理能力!

  总的来说:带FIFO比不带FIFO操作起来更简单,8位MCU也能胜任。下面我们参考战舰摄像头实验(带FIFO的OV7670模块)

  图3中,图像数据在href为高的时候输出,当href变高后,每一个PCLK时钟,输出一个字节数据。比如我们采用VGA时序,RGB565格式输出,每两个字节组成一个像素的颜色(高字节在前,低字节在后),这样每行输出总共有640*2个PCLK周期,输出640*2个字节。

  在图4中,VSYNC位高时产生一个帧同步信号,故当产生两个帧同步信号时,一帧数据输出完成。注意:图中的HSYNC和href其实是一个引脚产生的信号,只是在不同的场合下面,使用不同的信号方式。

  在图5中,我们用3种颜色的线模块原理图中几个重要芯片同MCU“连”了起来。不多说,看图~

  战舰OV7670模块存储图像数据的过程为:等待OV767同步信号-FIFO写指针复位-FIFO写使能-等待第二个同步信号-FIFO写禁止,通过以上5个步骤就可以完成一帧图像的存储

  比如QVGA模式,RGB565格式,我们总共循环读取320*240*2次,就可以读取一帧数据,把这些数据写入LCD模块,就可以看到摄像头的画面了。

  程序讲解:(主要是OV7670对FIFO的写控制和MCU从FIFO中读取数据)

  手把手教你学ARM-STM32 第三讲 系统时钟初始化函数与延时函数的实现

  意法半导体推出STM32神经网络开发工具箱,将 AI技术引入边缘和节点嵌入式设备

  意法半导体扩大对亚马逊FreeRTOS的支持,推出集成蓝牙®、以太网、LTE Cat-M / NB-IoT的开发入门套件

本文由阜新市调制模块有限公司发布于公司产品,转载请注明出处:基于STM32的OV7670摄像头总结

关键词: 领导模块碎