当前位置: 代码迷 >> 驱动开发 >> 网络摄像头拍照的原理
  详细解决方案

网络摄像头拍照的原理

热度:35   发布时间:2016-04-28 10:23:32.0
求助:网络摄像头拍照的原理
一般的非微软的网络摄像头,本地打开摄像头进行拍照,我查看了一下摄像头使用的是still image capture method 2方式进行拍照,请问这种拍照方式的原理是什么?在线等解答。。。。非常感谢
摄像头 微软 拍照

------解决方案--------------------
摄像头支持的still image capture有三种方式:
still image capture method 1:
当拍照事件触发以后,摄像头直接从当前预览的video pipe中抓一帧图像作为still image,因此hardware不会中断和改变video stream。采用此方式进行静态拍照的话拍出来的图像的resolution和format总是和当前video stream是一致的。

still image capture method 2:
当拍照事件触发以后,驱动程序会停掉当前的video stream,然后重新根据application所选择的静态图片的图像的resolution和format和hardware沟通并重新分配usb带宽,发送VS_STILL_IMAGE_TRIGGER_CONTROL 的命令给hardware,然后准备着接收still image data。Device hardware这边接到命令后将still image data通过通过video pipe送出,并在这一帧的payload header中标记为still。当host driver接收到still image后就会恢复到拍照之前video的alternate setting,重新打开video stream。这种情况下在拍照时候有video 有一个明显停顿的动作。

still image capture method 3:
前两种方式都是只通过从video pipe传输still image data。这种方式的话still image data是通过专用的usb的bulk传输方式的still image pipe传输;因此video stream就不会被中断。
------解决方案--------------------
Host driver向camera device发送VS_STILL_IMAGE_TRIGGER_CONTROL命令这是USB传输中的控制传输,成功了device会回复握手包,NAK握手包(USB设备忙)、STALL握手包(USB设备有错误)和ACK(成功处理)。

关于alternate setting的区别很难说,alternate setting 是host driver根据与device在Video Probe and Commit Controls时沟通的frame 的MaxPayloadSize来确定的。
在我看来应该没什么意义去比较alternate setting的区别。
  相关解决方案