opencvbase 实现opencv打开摄像头和初步处理等效果操作(附源码)
// TwoCameraOnTimer2Dlg.cpp : 实现文件
/*
CvMat, Mat, IplImage之间的互相转换 IpIImage -> CvMat
CvMat matheader;
CvMat * mat = cvGetMat(img, &matheader);
CvMat * mat = cvCreateMat(img->height, img->width, CV_64FC3);
cvConvert(img, mat) IplImage -> Mat
Mat::Mat(const IplImage* img, bool copyData=false);
IplImage* iplImg = cvLoadImage("greatwave.jpg", 1);
Mat mtx(iplImg); Mat -> IplImage
Mat M
IplImage iplimage = M; CvMat -> Mat
Mat::Mat(const CvMat* m, bool copyData=false); Mat -> CvMat
例子(假设Mat类型的imgMat图像数据存在):
CvMat cvMat = imgMat;
*/ #include "stdafx.h"
#include "TwoCameraOnTimer2.h"
#include "TwoCameraOnTimer2Dlg.h"
#include "afxdialogex.h"
#include <opencv/cv.h>
#include <opencv/highgui.h> #ifdef _DEBUG
#define new DEBUG_NEW
#endif // 用于应用程序“关于”菜单项的 CAboutDlg 对话框 class CAboutDlg : public CDialogEx
{
public:
CAboutDlg(); // 对话框数据
enum { IDD = IDD_ABOUTBOX }; protected:
virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV 支持 // 实现
protected:
DECLARE_MESSAGE_MAP()
}; CAboutDlg::CAboutDlg() : CDialogEx(CAboutDlg::IDD)
{
} void CAboutDlg::DoDataExchange(CDataExchange* pDX)
{
CDialogEx::DoDataExchange(pDX);
} BEGIN_MESSAGE_MAP(CAboutDlg, CDialogEx)
END_MESSAGE_MAP() // CTwoCameraOnTimer2Dlg 对话框 CTwoCameraOnTimer2Dlg::CTwoCameraOnTimer2Dlg(CWnd* pParent /*=NULL*/)
: CDialogEx(CTwoCameraOnTimer2Dlg::IDD, pParent)
, m_nCamCount(0)
, m_nLeftCamCount(0)
, m_nRightCamCount(0)
, m_nRAD_SELECT(0)
{
m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
} void CTwoCameraOnTimer2Dlg::DoDataExchange(CDataExchange* pDX)
{
CDialogEx::DoDataExchange(pDX);
DDX_Control(pDX, IDC_COMBO1, m_CBNCamList);
// DDX_Control(pDX, IDC_IMG_LOGO, m_imglogo);
} BEGIN_MESSAGE_MAP(CTwoCameraOnTimer2Dlg, CDialogEx)
ON_WM_SYSCOMMAND()
ON_WM_PAINT()
ON_WM_QUERYDRAGICON()
ON_BN_CLICKED(IDC_BTN_OPENCAM, &CTwoCameraOnTimer2Dlg::OnBnClickedBtnOpencam)
ON_CBN_SELCHANGE(IDC_COMBO1, &CTwoCameraOnTimer2Dlg::OnCbnSelchangeCombo1)
ON_WM_TIMER()
ON_BN_CLICKED(IDC_BTN_CLOSECAM, &CTwoCameraOnTimer2Dlg::OnBnClickedBtnClosecam)
ON_BN_CLICKED(IDC_BTN_CAPTURE, &CTwoCameraOnTimer2Dlg::OnBnClickedBtnCapture)
ON_BN_CLICKED(IDC_BTN_SAVE, &CTwoCameraOnTimer2Dlg::OnBnClickedBtnSave)
ON_BN_CLICKED(IDC_BTN_MIRROR, &CTwoCameraOnTimer2Dlg::OnBnClickedBtnMirror)
ON_BN_CLICKED(IDC_BTN_MIRROR2, &CTwoCameraOnTimer2Dlg::OnBnClickedBtnMirror2)
ON_BN_CLICKED(IDC_BTN_ROTATE, &CTwoCameraOnTimer2Dlg::OnBnClickedBtnRotate)
ON_BN_CLICKED(IDC_BTN_PRINT, &CTwoCameraOnTimer2Dlg::OnBnClickedBtnPrint)
ON_WM_DESTROY()
ON_BN_CLICKED(IDC_BTN_OPENCAM3, &CTwoCameraOnTimer2Dlg::OnBnClickedBtnOpencam3) ON_BN_CLICKED(IDC_BTN_SOBEL, &CTwoCameraOnTimer2Dlg::OnBnClickedBtnSobel)
ON_BN_CLICKED(IDC_BTN_EMPTY, &CTwoCameraOnTimer2Dlg::OnBnClickedBtnEmpty)
ON_BN_CLICKED(IDC_BTN_CANNY, &CTwoCameraOnTimer2Dlg::OnBnClickedBtnCanny)
ON_BN_CLICKED(IDC_BTN_BLACK, &CTwoCameraOnTimer2Dlg::OnBnClickedBtnBlack)
ON_BN_CLICKED(IDC_BTN_OPENCAM2, &CTwoCameraOnTimer2Dlg::OnBnClickedBtnOpencam2)
ON_BN_CLICKED(IDC_BTN_BIN, &CTwoCameraOnTimer2Dlg::OnBnClickedBtnBin)
ON_BN_CLICKED(IDC_BTN_PREWITTE, &CTwoCameraOnTimer2Dlg::OnBnClickedBtnPrewitte)
ON_BN_CLICKED(IDC_BTN_AUTOBIN, &CTwoCameraOnTimer2Dlg::OnBnClickedBtnAutobin) ON_BN_CLICKED(IDC_BTN_LOG, &CTwoCameraOnTimer2Dlg::OnBnClickedBtnLog) ON_BN_CLICKED(IDC_BTN_HIST, &CTwoCameraOnTimer2Dlg::OnBnClickedBtnHist)
ON_BN_CLICKED(IDC_BTN_WATER, &CTwoCameraOnTimer2Dlg::OnBnClickedBtnWater)
END_MESSAGE_MAP() // CTwoCameraOnTimer2Dlg 消息处理程序 BOOL CTwoCameraOnTimer2Dlg::OnInitDialog()
{
CDialogEx::OnInitDialog(); // 将“关于...”菜单项添加到系统菜单中。 // IDM_ABOUTBOX 必须在系统命令范围内。
ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);
ASSERT(IDM_ABOUTBOX < 0xF000); CMenu* pSysMenu = GetSystemMenu(FALSE);
if (pSysMenu != NULL)
{
BOOL bNameValid;
CString strAboutMenu;
bNameValid = strAboutMenu.LoadString(IDS_ABOUTBOX);
ASSERT(bNameValid);
if (!strAboutMenu.IsEmpty())
{
pSysMenu->AppendMenu(MF_SEPARATOR);
pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu);
}
} // 设置此对话框的图标。当应用程序主窗口不是对话框时,框架将自动
// 执行此操作
SetIcon(m_hIcon, TRUE); // 设置大图标
SetIcon(m_hIcon, FALSE); // 设置小图标 // TODO: 在此添加额外的初始化代码
//设置logo m_nCamCount = CCameraDS::CameraCount();//摄像头总数
m_nLeftCamCount = 1;//左边摄像头默认为1
m_nRightCamCount = 0;//右边摄像头默认为0
//在listbox中添加数据
char camera_name[1024];
char istr[25];
CString camstr;
for(int i=0; i < m_nCamCount; i++)
{
int retval = CCameraDS::CameraName(i, camera_name, sizeof(camera_name) );
sprintf_s(istr, " # %d", i);
strcat_s( camera_name, istr );
camstr = camera_name;
if(retval >0)
m_CBNCamList.AddString(camstr);
else
AfxMessageBox(_T("不能获取摄像头的名称"));
}
camstr.ReleaseBuffer();
// 初始化图像显示控件的图像
CRect rect;
GetDlgItem(IDC_PBRIGHT)->GetClientRect(&rect);
m_lfimage = Mat::zeros(rect.Height(),rect.Width(),CV_8UC3);
GetDlgItem(IDC_PBRIGHT)->GetClientRect(&rect); m_rightimage = Mat::zeros(rect.Height(),rect.Width(),CV_8UC3); return TRUE; // 除非将焦点设置到控件,否则返回 TRUE
} void CTwoCameraOnTimer2Dlg::OnSysCommand(UINT nID, LPARAM lParam)
{
if ((nID & 0xFFF0) == IDM_ABOUTBOX)
{
CAboutDlg dlgAbout;
dlgAbout.DoModal();
}
else
{
CDialogEx::OnSysCommand(nID, lParam);
}
} // 如果向对话框添加最小化按钮,则需要下面的代码
// 来绘制该图标。对于使用文档/视图模型的 MFC 应用程序,
// 这将由框架自动完成。 void CTwoCameraOnTimer2Dlg::OnPaint()
{
if (IsIconic())
{
CPaintDC dc(this); // 用于绘制的设备上下文 SendMessage(WM_ICONERASEBKGND, reinterpret_cast<WPARAM>(dc.GetSafeHdc()), 0); // 使图标在工作区矩形中居中
int cxIcon = GetSystemMetrics(SM_CXICON);
int cyIcon = GetSystemMetrics(SM_CYICON);
CRect rect;
GetClientRect(&rect);
int x = (rect.Width() - cxIcon + 1) / 2;
int y = (rect.Height() - cyIcon + 1) / 2; // 绘制图标
dc.DrawIcon(x, y, m_hIcon);
}
else
{
CDialogEx::OnPaint();
} //绘制logo
CString fileName="1.png";
std::string str = fileName;
Mat mat = imread(str);
F_ShowImage(mat,mat,IDC_IMG_LOGO);//打开并写入m_rightimage } //当用户拖动最小化窗口时系统调用此函数取得光标
//显示。
HCURSOR CTwoCameraOnTimer2Dlg::OnQueryDragIcon()
{
return static_cast<HCURSOR>(m_hIcon);
} //打开摄像头
void CTwoCameraOnTimer2Dlg::OnBnClickedBtnOpencam()
{ if (!leftcam.open(m_nLeftCamCount))
{
AfxMessageBox(_T("摄像头打开失败"));
}
else
{
AfxMessageBox(_T("摄像头打开成功"));
QueryCam();//开始摄像头
}
// if (m_nCamCount>=1)
// {
// //如果两个摄像头的开启号是不一样的
// if (m_nLeftCamCount != m_nRightCamCount)
// {
// if (!leftcam.open(m_nLeftCamCount))
// {
// AfxMessageBox(_T("左摄像头打开失败"));
// }
//
// if (!rightcam.open(m_nRightCamCount))
// {
// AfxMessageBox(_T("右摄像头打开失败"));
// }
//
// QueryCam();//开始摄像头
// }
// else
// {
// AfxMessageBox(_T("两个摄像头不能设定的一样"));
// }
// }
// else
// {
// AfxMessageBox(_T("请确认至少有一个摄像头连上了"));
// }
} void CTwoCameraOnTimer2Dlg::OnCbnSelchangeCombo1()
{
// TODO: 在此添加控件通知处理程序代码
// m_nRAD_SELECT = GetCheckedRadioButton(IDC_RADIOLEFT,IDC_PBRIGHT);
// if (m_nRAD_SELECT == IDC_RADIOLEFT)
// {
m_nLeftCamCount = m_CBNCamList.GetCurSel();
// }
// else
// {
// m_nRightCamCount = m_CBNCamList.GetCurSel();
// } } //打开timer,开始摄像头捕捉
void CTwoCameraOnTimer2Dlg::QueryCam(void)
{
SetTimer(1,50,NULL);//采用timer触发,进行摄像头操作
} void CTwoCameraOnTimer2Dlg::OnTimer(UINT_PTR nIDEvent)
{
// TODO: 在此添加消息处理程序代码和/或调用默认值
if (leftcam.isOpened())
{
Mat leftframe;
leftcam >>leftframe;
F_ShowImage(leftframe,m_lfimage,IDC_PBLEFT);
} F_ShowImage(m_rightimage,m_rightimage,IDC_PBRIGHT); // if (rightcam.isOpened())
// {
// Mat rightframe;
// rightcam>>rightframe;
// F_ShowImage(rightframe,m_rightimage,IDC_PBRIGHT);
// }
CDialogEx::OnTimer(nIDEvent);
} /*----------------------------
* 功能 : 显示图像
* 将要绘制的图像 src 复制到 des,然后绘制到控件号为 ID 的 Picture 控件
*----------------------------
* 函数 : CStereoVisionDlg::F_ShowImage
* 访问 : private
* 返回 : void
*
* 参数 : src [in] 待显示图像
* 参数 : des [in] 窗口图像
* 参数 : ID [in] 图像窗口控件ID
*/
void CTwoCameraOnTimer2Dlg::F_ShowImage(Mat& src, Mat& des, UINT ID)
{
if (src.empty())
{
return;
}
// 计算将图片缩放到 Image 区域所需的比例因子
double wRatio = des.cols / (double)src.cols;
double hRatio = des.rows / (double)src.rows;
double srcWH = src.cols / (double)src.rows;
double desWH = des.cols / (double)des.rows;
double scale = srcWH > desWH ? wRatio : hRatio;
// 缩放后图片的宽和高
int nw = (int)( src.cols * scale );
int nh = (int)( src.rows * scale );
// 为了将缩放后的图片存入 des 的正中部位,需计算图片在 des 左上角的期望坐标值
int tlx = (int)((des.cols - nw) / 2);
int tly = (int)((des.rows - nh) / 2);
// 设置 des 的 ROI 区域,用来存入图片 img
Mat desRoi = des(Rect(tlx, tly, nw, nh));
// 如果src是单通道图像,则转换为三通道图像
if (src.channels() == 1)
{
Mat src_c;
cvtColor(src, src_c, CV_GRAY2BGR);
// 对图片 src_t 进行缩放,并存入到 des 中
resize(src_c, desRoi, desRoi.size());
}
else
{
// 对图片 src 进行缩放,并存入到 des 中
resize( src, desRoi, desRoi.size() );
}
CDC* pDC = GetDlgItem( ID ) ->GetDC(); // 获得显示控件的 DC
HDC hDC = pDC ->GetSafeHdc(); // 获取 HDC(设备句柄) 来进行绘图操作
CRect rect;
GetDlgItem(ID) ->GetClientRect( &rect ); // 获取控件尺寸位置
CvvImage cimg;
IplImage cpy = des;
cimg.CopyOf( &cpy ); // 复制图片
cimg.DrawToHDC( hDC, &rect ); // 将图片绘制到显示控件的指定区域内
ReleaseDC( pDC );
} //关闭摄像头
void CTwoCameraOnTimer2Dlg::OnBnClickedBtnClosecam()
{
KillTimer(1);
if (leftcam.isOpened())
{
m_lfimage = Scalar(0);
F_ShowImage(m_lfimage,m_lfimage,IDC_PBLEFT);
leftcam.release();
AfxMessageBox(_T("摄像头关闭成功"));
}
// if (rightcam.isOpened())
// {
// m_rightimage = Scalar(0);
// F_ShowImage(m_rightimage,m_rightimage,IDC_PBRIGHT);
// rightcam.release();
// }
} //截获当前画面
void CTwoCameraOnTimer2Dlg::OnBnClickedBtnCapture()
{
// TODO: 在此添加控件通知处理程序代码
m_rightimage = NULL;
Mat rightframe;
leftcam >>rightframe;
F_ShowImage(rightframe,m_rightimage,IDC_PBRIGHT);
} //保存当前画面
void CTwoCameraOnTimer2Dlg::OnBnClickedBtnSave()
{
// TODO: 在此添加控件通知处理程序代码
// Mat rightframe;
// leftcam >>rightfram
IplImage iplimage =m_lfimage;
//打开保存界面,获得保存的地址
CString fileName;
CString szFilters="jpg(*.jpg)|*.jpg||";
CFileDialog dlgFile(TRUE,NULL,NULL,OFN_HIDEREADONLY|OFN_OVERWRITEPROMPT,szFilters,NULL,0,TRUE);
const int c_cMaxFiles = 100;
const int c_cbBuffSize = (c_cMaxFiles * (MAX_PATH + 1)) + 1;
dlgFile.GetOFN().lpstrFile = fileName.GetBuffer(c_cbBuffSize);
dlgFile.GetOFN().nMaxFile = c_cMaxFiles;
dlgFile.DoModal();
fileName.ReleaseBuffer(); fileName = fileName+".jpg";//加个后缀名
int i = cvSaveImage(fileName,&iplimage);
if (i!=0)
{
AfxMessageBox(_T("文件保存成功"));
}
} //镜像1
void CTwoCameraOnTimer2Dlg::OnBnClickedBtnMirror()
{
IplImage iplimage =m_rightimage;
cvFlip(&iplimage,&iplimage,1);//镜像
Mat img(&iplimage,0);
F_ShowImage(img,m_rightimage,IDC_PBRIGHT); } //镜像2
void CTwoCameraOnTimer2Dlg::OnBnClickedBtnMirror2()
{
IplImage iplimage =m_rightimage;
cvFlip(&iplimage,&iplimage,0);//镜像
Mat img(&iplimage,0);
F_ShowImage(img,m_rightimage,IDC_PBRIGHT);
} //旋转
void CTwoCameraOnTimer2Dlg::OnBnClickedBtnRotate()
{
// TODO: 在此添加控件通知处理程序代码
int rotation_degrees = 30;
Mat M = getRotationMatrix2D(Point(m_rightimage.cols/2,m_rightimage.rows/2),rotation_degrees,1);
warpAffine(m_rightimage,m_rightimage,M,m_rightimage.size(),INTER_LINEAR);
F_ShowImage(m_rightimage,m_rightimage,IDC_PBRIGHT);
void CTwoCameraOnTimer2Dlg::OnBnClickedBtnPrint()
{ } //destory就是关闭时候的情况
void CTwoCameraOnTimer2Dlg::OnDestroy()
{
CDialogEx::OnDestroy(); KillTimer(1);
if (leftcam.isOpened())
{
m_lfimage = Scalar(0);
F_ShowImage(m_lfimage,m_lfimage,IDC_PBLEFT);
leftcam.release();
AfxMessageBox(_T("摄像头关闭成功"));
} } //保存文件
void CTwoCameraOnTimer2Dlg::OnBnClickedBtnOpencam3()
{
// TODO: 在此添加控件通知处理程序代码
IplImage iplimage =m_rightimage;
//打开保存界面,获得保存的地址
CString fileName;
CString szFilters="jpg(*.jpg)|*.jpg||";
CFileDialog dlgFile(TRUE,NULL,NULL,OFN_HIDEREADONLY|OFN_OVERWRITEPROMPT,szFilters,NULL,0,TRUE);
const int c_cMaxFiles = 100;
const int c_cbBuffSize = (c_cMaxFiles * (MAX_PATH + 1)) + 1;
dlgFile.GetOFN().lpstrFile = fileName.GetBuffer(c_cbBuffSize);
dlgFile.GetOFN().nMaxFile = c_cMaxFiles;
dlgFile.DoModal();
fileName.ReleaseBuffer();
fileName = fileName+".jpg";//加个后缀名
int i = cvSaveImage(fileName,&iplimage);
if (i!=0)
{
AfxMessageBox(_T("文件保存成功"));
}
} //sobel
void CTwoCameraOnTimer2Dlg::OnBnClickedBtnSobel()
{
IplImage iplimage =m_rightimage; cvSobel(&iplimage,&iplimage,1,0,3); Mat img(&iplimage,0);
F_ShowImage(img,m_rightimage,IDC_PBRIGHT);
} //清空
void CTwoCameraOnTimer2Dlg::OnBnClickedBtnEmpty()
{
IplImage iplimage =m_rightimage;
m_rightimage = NULL;
F_ShowImage(m_rightimage,m_rightimage,IDC_PBRIGHT);
} //canny
void CTwoCameraOnTimer2Dlg::OnBnClickedBtnCanny()
{
IplImage iplimage =m_rightimage;
IplImage *src = &iplimage;
IplImage* src1=cvCreateImage(cvSize(src->width,src->height),IPL_DEPTH_8U,1);
cvCvtColor(src, src1, CV_BGR2GRAY);
cvCanny(src1,src1,50,200,3);//参数可以设定
Mat img(src1);
F_ShowImage(img,m_rightimage,IDC_PBRIGHT);
} //黑白
void CTwoCameraOnTimer2Dlg::OnBnClickedBtnBlack()
{
IplImage iplimage =m_rightimage;
IplImage *src = &iplimage;
IplImage* src1=cvCreateImage(cvSize(src->width,src->height),IPL_DEPTH_8U,1);
cvCvtColor(src, src1, CV_BGR2GRAY);
Mat img(src1);
F_ShowImage(img,m_rightimage,IDC_PBRIGHT);
} //打开文件
void CTwoCameraOnTimer2Dlg::OnBnClickedBtnOpencam2()
{m_rightimage = NULL;
CString fileName;
CString szFilters="jpg(*.jpg)|*.jpg||bmp(*.bmp)|*.bmp";
CFileDialog dlgFile(TRUE,NULL,NULL,OFN_HIDEREADONLY|OFN_OVERWRITEPROMPT,szFilters,NULL,0,TRUE);
const int c_cMaxFiles = 100;
const int c_cbBuffSize = (c_cMaxFiles * (MAX_PATH + 1)) + 1;
dlgFile.GetOFN().lpstrFile = fileName.GetBuffer(c_cbBuffSize);
dlgFile.GetOFN().nMaxFile = c_cMaxFiles;
dlgFile.DoModal();
fileName.ReleaseBuffer();
std::string str = fileName;
Mat mat = imread(str);
F_ShowImage(mat,m_rightimage,IDC_PBRIGHT);//打开并写入m_rightimage
SetTimer(1,50,NULL);//采用timer触发
} //二值化
void CTwoCameraOnTimer2Dlg::OnBnClickedBtnBin()
{
// TODO: 在此添加控件通知处理程序代码
IplImage iplimage =m_rightimage;
IplImage *src = &iplimage;
IplImage* src1=cvCreateImage(cvSize(src->width,src->height),IPL_DEPTH_8U,1);
cvCvtColor(src, src1, CV_BGR2GRAY);
cvThreshold(src1,src1,0,150,0);
Mat img(src1);
F_ShowImage(img,m_rightimage,IDC_PBRIGHT);
} //prewitte???
void CTwoCameraOnTimer2Dlg::OnBnClickedBtnPrewitte()
{
IplImage iplimage =m_rightimage;
IplImage *src = &iplimage;
IplImage* src1=cvCreateImage(cvSize(src->width,src->height),IPL_DEPTH_8U,1); cvCvtColor(src, src1, CV_BGR2GRAY);
cvCanny(src1,src1,50,200,3);//参数可以设定
Mat img(src1);
F_ShowImage(img,m_rightimage,IDC_PBRIGHT);
} void CTwoCameraOnTimer2Dlg::OnBnClickedBtnAutobin()
{
IplImage iplimage =m_rightimage;
IplImage *src = &iplimage;
IplImage* src1=cvCreateImage(cvSize(src->width,src->height),IPL_DEPTH_8U,1);
cvCvtColor(src, src1, CV_BGR2GRAY);
cvAdaptiveThreshold( src1, src1, 255, CV_ADAPTIVE_THRESH_MEAN_C, CV_THRESH_BINARY, 3, 5 );
Mat img(src1);
F_ShowImage(img,m_rightimage,IDC_PBRIGHT);
} void CTwoCameraOnTimer2Dlg::OnBnClickedBtnLog()
{
// TODO: 在此添加控件通知处理程序代码
IplImage iplimage =m_rightimage;
IplImage *src = &iplimage; IplImage* dst = cvCreateImage(cvGetSize(src),8,3);
//注意相关参数的设定
cvLogPolar(src,dst,cvPoint2D32f(10,10),40,CV_INTER_LINEAR+CV_WARP_FILL_OUTLIERS); Mat img(dst);
F_ShowImage(img,m_rightimage,IDC_PBRIGHT);
} void CTwoCameraOnTimer2Dlg::OnBnClickedBtnFouier()
{
// TODO: 在此添加控件通知处理程序代码
IplImage iplimage =m_rightimage;
IplImage *src = &iplimage; //注意相关参数的设定
cvDFT(&src,&src,CV_DXT_FORWARD,src->height); Mat img(src);
F_ShowImage(img,m_rightimage,IDC_PBRIGHT);
} void CTwoCameraOnTimer2Dlg::OnBnClickedBtnHist()
{
IplImage iplimage =m_rightimage;
IplImage *src = &iplimage;
IplImage* dst = cvCreateImage(cvGetSize(src),8,1);//必须为灰色 //注意相关参数的设定
cvCvtColor(src,dst,CV_RGB2GRAY);
cvEqualizeHist(dst,dst); Mat img(dst);
F_ShowImage(img,m_rightimage,IDC_PBRIGHT);
} void CTwoCameraOnTimer2Dlg::OnBnClickedBtnWater()
{
// TODO: 在此添加控件通知处理程序代码
IplImage iplimage =m_rightimage;
IplImage *src = &iplimage; IplImage* dst = cvCreateImage(cvGetSize(src),8,1);//必须为灰色 cvWatershed(dst,dst); Mat img(dst);
F_ShowImage(img,m_rightimage,IDC_PBRIGHT);
}
程序代码视频 http://pan.baidu.com/s/1dDINRnr o2p3
任何问题,请联系qq:1755311380
opencvbase 实现opencv打开摄像头和初步处理等效果操作(附源码)的更多相关文章
- 如何使用 OpenCV 打开摄像头获取图像数据?
OpenCV 如何打开摄像头获取图像数据? 代码运行环境:Qt 5.9.1 msvc2015 32bit OpenCV 3.3.0 #include "include/opencv2/ope ...
- OpenCV打开摄像头失败
<span style="font-family: Arial, Helvetica, sans-serif;">#include <stdio.h>< ...
- opencv打开摄像头获取视频程序
// // main.cpp // opencv3 // // Created by PKU on 14-9-16. // Copyright (c) 2014年 PKU. All rights re ...
- Android 音视频深入 十六 FFmpeg 推流手机摄像头,实现直播 (附源码下载)
源码地址https://github.com/979451341/RtmpCamera/tree/master 配置RMTP服务器,虽然之前说了,这里就直接粘贴过来吧 1.配置RTMP服务器 这个我不 ...
- 基于DevExpress的SpreadsheetControl实现对Excel的打开、预览、保存、另存为、打印(附源码下载)
场景 Winform控件-DevExpress18下载安装注册以及在VS中使用: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/1 ...
- 使用DevExpress的PdfViewer实现PDF打开、预览、另存为、打印(附源码下载)
场景 Winform控件-DevExpress18下载安装注册以及在VS中使用: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/1 ...
- C#推流RTMP,摄像头、麦克风、桌面、声卡(附源码)
这段时间一直都在研究推流的技术,经过断断续续将近两个月的摸索实践,终于能稳定地推流了. 这个demo的主要功能就是将采集到的摄像头或桌面的视频.以及麦克风或声卡的音频数据推到Nginx-RTMP服务器 ...
- 手把手教你使用LabVIEW OpenCV DNN实现手写数字识别(含源码)
@ 目录 前言 一.OpenCV DNN模块 1.OpenCV DNN简介 2.LabVIEW中DNN模块函数 二.TensorFlow pb文件的生成和调用 1.TensorFlow2 Keras模 ...
- opencv 打开摄像头(c++)
1,打开视频文件 2,打开IP摄像头 读取大华摄像头 大华的网络摄像头编号:DH-IPC-HFW1225M-I1-0600B,用的是RTSP协议. "rtsp://admin:dahua@1 ...
随机推荐
- selenium PO模式
思想: 1.定义basepage.py用来写公共方法,比如找元素,打开url,切换frame.这样的部分都写在这里.不必每次用都重写. 2.LoginPage.py 每个功能模块一个文件或者一个类 这 ...
- nodejs连接数据库的增删改查
连接数据库后需要用代码操作的是,传入mysql语句,和参数,然后就是回调了 新增 // 新增 app.post('/process_post', urlencodedParser, function ...
- spring之继承配置
我们有一下两个类,并且Gradate类继承了Student类 public class Student public class Gradate extends Student 在applicatio ...
- beego 初体验 - 环境搭建
首先,安装go运行时和beego beego,在git bash 运行命令: go get github.com/beego/bee go get github.com/astaxie/beego g ...
- jdbc连接oracle的几种格式
1. SID的方式.已经不推荐使用这种方式了. jdbc:oracle:thin:[<user>/<password>]@<host>[:<port>] ...
- 用Django实现Video页面分类查询
Model表创建,Url映射,Views函数处理,Html生成 根据上图,视频方向与视频分类是多对多的关系,视频分类与视频信息是一对多的关系,难度级别是单一的查询条件(与之前俩者并无关系) Model ...
- 【Scala学习之一】 Scala基础语法
环境 虚拟机:VMware 10 Linux版本:CentOS-6.5-x86_64 客户端:Xshell4 FTP:Xftp4 jdk1.8 scala-2.10.4(依赖jdk1.8) spark ...
- Linux基础命令---杀死进程pkill
pkill pkill可以给指定的进程发送信息,它可以结束某个执行的进程或者目录登录的用户. 此命令的适用范围:RedHat.RHEL.Ubuntu.CentOS.SUSE.openSUSE.Fedo ...
- php小数加减精度问题,比特币计算精度问题
php小数加减精度问题,比特币计算精度问题 在php开发时,有小数加减的场景.结果发现不能够等于预想的值,bccomp比较二个高精确度数字.语法: int bccomp(string left ope ...
- maven 入门 (一)
纠结了好久,到底要不要写一份maven入门的所谓“教程”,有好几次想写一下,但是都放弃了,因为网上的太多了,而且都很好,但是现在决定了,还是要写出来,因为者有我自己的理解.所以我想写一份教程出来. 首 ...