HDMI采集卡+Python+OpenCV实时显示画面
前言
视频采集卡:用来截断并捕获并复制视频信号,直接采集硬件视频输出接口的信号,从硬件层面去获取视频信号,再把视频信号返回到系统内生成视频文件。我们把原本输出到显示器的信号从中间截断,在中间复制一份,其中的一份照常输出给原来的显示设备,另一份通过一些特殊的手段拷贝下来,然后把这个拷贝的视频信号,重新编码成视频,输出到用来采集数据的机器上,就可以做到在显示器正常工作的情况下,我们依旧可以录制或者实时采集视频信号推流。
在使用USB视频采集卡将信号采集并传输到电脑上后,还需借助采集软件才可将信号储存下来。调用采集卡,选择好对应的视频和音频设备,存储分辨率、格式(MJPG)、码率等可以根据自己需求设置。 
提示:以下是本篇文章正文内容,下面案例可供参考
一、C+OpenCV获取采集卡索引号
使用c++获取USB采集卡的索引号,(一般为1)。
代码如下:
#include <opencv2/imgcodecs.hpp>
#include <opencv2/highgui.hpp>
#include "windows.h"
#include "dshow.h"
#include <iostream>
#pragma comment(lib, "strmiids.lib")
#pragma comment(lib, "quartz.lib")
using namespace cv;
using namespace std;
int listDevices(vector<string>& list) {
ICreateDevEnum *pDevEnum = NULL;
IEnumMoniker *pEnum = NULL;
int deviceCounter = 0;
CoInitialize(NULL);
HRESULT hr = CoCreateInstance(CLSID_SystemDeviceEnum, NULL,
CLSCTX_INPROC_SERVER, IID_ICreateDevEnum,
reinterpret_cast<void**>(&pDevEnum));
if (SUCCEEDED(hr))
{
hr = pDevEnum->CreateClassEnumerator(
CLSID_VideoInputDeviceCategory,
&pEnum, 0);
if (hr == S_OK) {
printf("SETUP: Looking For Capture Devices\n");
IMoniker *pMoniker = NULL;
while (pEnum->Next(1, &pMoniker, NULL) == S_OK) {
IPropertyBag *pPropBag;
hr = pMoniker->BindToStorage(0, 0, IID_IPropertyBag,
(void**)(&pPropBag));
if (FAILED(hr)) {
pMoniker->Release();
continue; // Skip this one, maybe the next one will work.
}
VARIANT varName;
VariantInit(&varName);
hr = pPropBag->Read(L"Description", &varName, 0);
if (FAILED(hr)) hr = pPropBag->Read(L"FriendlyName", &varName, 0);
if (SUCCEEDED(hr))
{
hr = pPropBag->Read(L"FriendlyName", &varName, 0);
int count = 0;
char tmp[255] = { 0 };
//int maxLen = sizeof(deviceNames[0]) / sizeof(deviceNames[0][0]) - 2;
while (varName.bstrVal[count] != 0x00 && count < 255)
{
tmp[count] = (char)varName.bstrVal[count];
count++;
}
list.push_back(tmp);
}
pPropBag->Release();
pPropBag = NULL;
pMoniker->Release();
pMoniker = NULL;
deviceCounter++;
}
pDevEnum->Release();
pDevEnum = NULL;
pEnum->Release();
pEnum = NULL;
}
}
return deviceCounter;
}
int main()
{
vector<string> list;
listDevices(list);
int capid0 = 0, capid1 = 0;
cout << "dev_size = " << list.size() << endl;
for (int i = 0; i<list.size(); i++)
{
if (list[i] == "3D Camera")
capid1 = i;
if (list[i] == "USB2.0 HD UVC WebCam")
capid0 = i;
cout << "device lists: " << list[i] << " i = " << i << endl;
}
getchar();
return 0;
}
运行代码,得到下图。
可见视频采集卡的索引号为1。
注:opencv的环境不用说自己配置还有两个系统库,需要额外的添加 #pragma comment(lib, “strmiids.lib”) #pragma comment(lib, “quartz.lib”)
参考: https://blog.csdn.net/Yancy_/article/details/107560034
二、Python+OpenCV使用步骤
1.引入库
代码如下:
#Python版本3.7.4
import cv2 #版本为4.5.2
import numpy as np
2.实时读取画面
代码如下:
cap0 = cv2.VideoCapture(1+ cv2.CAP_DSHOW) # 视频流
#cap0.set(cv2.CAP_PROP_FOURCC, cv2.VideoWriter_fourcc('M', 'J', 'P', 'G')) #读取视频格式
# 设置分辨率
cap0.set(cv2.CAP_PROP_FRAME_WIDTH, 1280)
cap0.set(cv2.CAP_PROP_FRAME_HEIGHT, 1024)
while(cap0.isOpened()):
ret,frame=cap0.read()
if ret==True:
cv2.imshow("frame", frame)
pass
if cv2.waitKey(1000)&0xFF==ord("q"):
break
pass
pass
cap0.release()
cv2.destroyAllWindows()
注意当cv2.VideoCapture(*)中取0时,调用的是本地的摄像头;取1时,调用外置的摄像头。USB采集卡实际上已经通过usb接口被识别为视频流设备,只不过需要设置分辨率来显示画面。
三、C++OpenCV的配置
1.采用VS2015+OpenCV3.4.11的配置
1.采用VS2015+OpenCV3.4.11的配置
分别可在VS官网和opencv官网下载两款软件,OpenCV版本如下。
2.安装OpenCV
安装OpenCV,哪个盘均可,本人把他放到了E:\Program Files\opencv\opencv(本人安装时多放了一个文件夹,不要介意)文件夹下,如下图:
3.OpenCV环境变量的配置
3 提取之后进行环境变量的配置,此电脑-属性-高级系统设置-环境变量-系统变量-path中添加E:\Program Files\opencv\opencv\build\x64\vc14及E:\Program Files\opencv\opencv\build\x64\vc14\bin.添加之后确定,退出。
4.VC2015包含目录和库目录的配置
对VC2015属性页,进行包含目录和库目录的配置。
5.VC2015链接器-输入-附加依赖项的配置
对链接器-输入-附加依赖项并进行配置
这样就可以使用“一”中的代码了。
参考:https://blog.csdn.net/zhaojinzhi1992/article/details/108259296
总结
初次撰写,如有错误,尽请指正,不胜感谢。。。