环境:
Windows XP
QtCreator
Qt4.8.3
Opencv2.4.3
源代码下载:
《高版本Opencv内置的videoInput库的使用方法》
过程:
有些网友看了我《VideoInput库 + Opencv2.3.1 + 无线摄像头 + VC2010》这篇文章之后,提出了一些已经,
截取一个网友的问题如下:
*********************************************************************************************************************************************
**********************************************************************************************************************************************
对于这个问题,我翻阅了opencv的一些代码,并且做了一个测试,确实如opencv官网所说的,它们已经把videoInput融入到highgui库里面了。现在我就来说说这方面的东东。
先来验证一下videoInput库确实有在opencv里现身。
1、它的完整类定义在“opencv\modules\highgui\src\cap_dshow.cpp”里面,来一张图以示证明(风格所需)
这是在模块(modules)里的源码,主要是用于重新编译opencv用的。
再来看看这里(这就非常关键了)
在“opencv\build\include\opencv2\highgui\highgui_c.h”里,声明了我们熟悉的 cvCreateCameraCapture(int index)函数,
其中一部分enum很重要(因为里面包含CV_CAP_DSHOW这个东西)
看到没?图里面的阴影部分(它的注释才是亮点),
CV_CAP_DSHOW =700, // DirectShow (via videoInput)也就是说这样使用cvCreateCameraCapture(CV_CAP_DSHOW),就是通过videoInput方式实现摄像头的创建的。
关于opencv里面对于videoInput的信息就先列这么多。下来我就先写个小程序溜溜。
首先,我下载了至今最新一版的OpenCV-2.4.3.exe
直接解压缩,我的解压缩至F盘,(直接可以使用,不需要在编译),
当然,要使用的话还得加上系统环境变量:F:\opencv\build\x86\vc10\bin (路径视自己的解压缩路径而定)
下来就是在QtCreator上使用了。
使用时主要就是要正确设置opencv头文件和库的路径,它设置在工程的 *.pro文件里面:
(把我的列举出来以供参考)
#------------------------------------------------- # # Project created by QtCreator 2013-01-11T21:49:08 # #------------------------------------------------- QT += core gui greaterThan(QT_MAJOR_VERSION, 4): QT += widgets TARGET = opencvtest TEMPLATE = app SOURCES += main.cpp\ widget.cpp HEADERS += widget.h FORMS += widget.ui INCLUDEPATH += F:\opencv\build\include \ F:\opencv\build\include\opencv \ F:\opencv\build\include\opencv2 LIBS += F:\opencv\build\x86\vc10\lib\opencv_core243d.lib \ F:\opencv\build\x86\vc10\lib\opencv_highgui243d.lib \ F:\opencv\build\x86\vc10\lib\opencv_imgproc243d.lib
再下来就是上代码了:
#include "widget.h" #include "ui_widget.h" #include <opencv2/core/core.hpp> #include <opencv2/highgui/highgui.hpp> #include <stdio.h> #include <QMessageBox> using namespace cv; using namespace std; Widget::Widget(QWidget *parent) : QWidget(parent), ui(new Ui::Widget) { ui->setupUi(this); //CV_CAP_DSHOW在highgui_c.h头文件里面定义,代表摄像头是通过videoInput方式创建的 CvCapture* capture1 = cvCreateCameraCapture(CV_CAP_DSHOW); //将图像文件加载进内存 CvCapture* capture2 = cvCreateCameraCapture(CV_CAP_DSHOW + 1); CvCapture* capture3 = cvCreateCameraCapture(CV_CAP_DSHOW + 2); CvCapture* capture4 = cvCreateCameraCapture(CV_CAP_DSHOW + 3); cvNamedWindow("lovely1", CV_WINDOW_AUTOSIZE); //创建图像窗口,第一个参数作为与其他函数交互的索引 cvNamedWindow("lovely2", CV_WINDOW_AUTOSIZE); cvNamedWindow("lovely3", CV_WINDOW_AUTOSIZE); cvNamedWindow("lovely4", CV_WINDOW_AUTOSIZE); IplImage* img1, *img2, *img3, *img4; if (!capture1 || !capture2 || !capture3 || !capture4) //检测文件是否成功读入 { QMessageBox::information(this, "msg", "Camera Problem!"); } while(1) { img1= cvQueryFrame(capture1); img2= cvQueryFrame(capture2); img3= cvQueryFrame(capture3); img4= cvQueryFrame(capture4); cvShowImage("lovely1", img1); //把img图像显示在lovely的窗口中 cvShowImage("lovely2", img2); cvShowImage("lovely3", img3); cvShowImage("lovely4", img4); char c = cvWaitKey(40); //等待用户触发行为 if (c == 27) { break; //等待ESC键 } } // cvReleaseCapture(&capture4); //释放资源时出现运行错误,现在还没具体搞明白怎么回事 // cvReleaseCapture(&capture3); // cvReleaseCapture(&capture2); // cvReleaseCapture(&capture1); cvReleaseImage(&img1); //释放img所占据的内存,“lovely”窗口图像不会消失 cvReleaseImage(&img2); cvReleaseImage(&img3); cvReleaseImage(&img4); cvDestroyWindow("lovely1"); //销毁lovely窗口,同时释放为img的一个副本图像所开辟的内存,图像消失 cvDestroyWindow("lovely2"); cvDestroyWindow("lovely3"); cvDestroyWindow("lovely4"); } Widget::~Widget() { delete ui; } void Widget::on_pushButton_clicked() { }
再再下来就是运行结果啦:(其中一张是我的销魂照,大家勿吐,辛苦这么久了,等的就是亮相这一刻)
(看清楚啦,4个摄像头,3个外置+一个笔记本的)
有人会问,你怎么知道这里使用的就是videoInput库?CV_CAP_DSHOW说白了就是一个整型,我用
/*By Jiangong SUN*/
Export a oracle database for a specific schema in command line is an easy task.
Here is how I did:
-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
/*get a specific stored procedure*/
SELECT DBMS_METADATA.GET_DDL('PACKAGE','packageName') FROM dual;
/*get all schemas*/
SELECT * FROM dba_users;
/*get all packages for a specific user/schema*/
SELECT * FROM all_objects WHERE OBJECT_TYPE ='PACKAGE' and owner='schemaName' order by object_name asc;
/*command for export packages*/
expdp user/password schemas=schema_name include=package directory="d:\" dumpfile=exportPackages.dmp logfile=exportPackages.log
reference:
http://www.oracle-base.com/articles/10g/oracle-data-pump-10g.php
http://www.oracle-base.com/articles/misc/recompiling-invalid-schema-objects.php
http://docs.oracle.com/cd/B19306_01/appdev.102/b14261/sqloperations.htm#BABHICAF
Enjoy coding !
//数据 DataTable dtObject = dt; //保留列 string[] saveColumns = new string[5]; saveColumns[0] = "X";//保留列1 saveColumns[1] = "XX";//保留列2 saveColumns[2] = "XXX"; saveColumns[3] = "XXXX"; saveColumns[4] = "XXXXX"; //移除不需要的列 for (int i = dtObject.Columns.Count; i > 0; i--)//注意此处,一般习惯用i++则会引发OutOfIndex异常,由于部分列被移除,列索引减少,i++会超出不断减少的索引总数,注意。 { //移除指示器 bool remove = true; //是否在保留列中 for (int j = 0; j < saveColumns.Length; j++) { if (dtObject.Columns[i].ColumnName == saveColumns[j]) { //保留列不移除 remove = false; break; } } if (remove) { //移除列 dtObject.Columns.Remove(dtObject.Columns[i].ColumnName); } } return dtObject;
【End】
更多精彩博文请移步博客主页:http://blog.csdn.net/ls_man
更多精彩分享请收听博主腾讯微博@ls_man:http://t.qq.com/ls_man