vs2015和opencv3.1.0在MFC上调开摄像头,摄像头阔以打开,但是显示不出图像

u014775364 2016-05-18 10:43:37
参考http://blog.csdn.net/watkinsong/article/details/7360941
// Fire2Dlg.cpp : 实现文件
//

#include "stdafx.h"
#include "Fire2.h"
#include "Fire2Dlg.h"
#include "afxdialogex.h"
#include "CvvImage.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#endif

CvCapture* capture;
HDC hDC;
CDC *pDC;
CWnd *pwnd;
CRect rect;
IplImage* fireImage;
CvvImage m_CvvImage;
IplImage *frame;

// 用于应用程序“关于”菜单项的 CAboutDlg 对话框

class CAboutDlg : public CDialogEx
{
public:
CAboutDlg();

// 对话框数据
#ifdef AFX_DESIGN_TIME
enum { IDD = IDD_ABOUTBOX };
#endif

protected:
virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV 支持

// 实现
protected:
DECLARE_MESSAGE_MAP()
};

CAboutDlg::CAboutDlg() : CDialogEx(IDD_ABOUTBOX)
{
}

void CAboutDlg::DoDataExchange(CDataExchange* pDX)
{
CDialogEx::DoDataExchange(pDX);
}

BEGIN_MESSAGE_MAP(CAboutDlg, CDialogEx)
END_MESSAGE_MAP()


// CFire2Dlg 对话框



CFire2Dlg::CFire2Dlg(CWnd* pParent /*=NULL*/)
: CDialogEx(IDD_FIRE2_DIALOG, pParent)
{
m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
}

void CFire2Dlg::DoDataExchange(CDataExchange* pDX)
{
CDialogEx::DoDataExchange(pDX);
}

BEGIN_MESSAGE_MAP(CFire2Dlg, CDialogEx)
ON_WM_SYSCOMMAND()
ON_WM_PAINT()
ON_WM_QUERYDRAGICON()
ON_BN_CLICKED(IDC_Camera, &CFire2Dlg::OnBnClickedCamera)
ON_WM_TIMER()
END_MESSAGE_MAP()


// CFire2Dlg 消息处理程序

BOOL CFire2Dlg::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); // 设置小图标

ShowWindow(SW_MINIMIZE);

// TODO: 在此添加额外的初始化代码
pwnd = GetDlgItem(IDC_STATIC);
this->MoveWindow(410, 160, 765, 598);
pwnd->MoveWindow(24, 85, 526, 416);

pDC = pwnd->GetDC();
hDC = pDC->GetSafeHdc();
pwnd->GetClientRect(&rect);

return TRUE; // 除非将焦点设置到控件,否则返回 TRUE
}

void CFire2Dlg::OnSysCommand(UINT nID, LPARAM lParam)
{
if ((nID & 0xFFF0) == IDM_ABOUTBOX)
{
CAboutDlg dlgAbout;
dlgAbout.DoModal();
}
else
{
CDialogEx::OnSysCommand(nID, lParam);
}
}

// 如果向对话框添加最小化按钮,则需要下面的代码
// 来绘制该图标。 对于使用文档/视图模型的 MFC 应用程序,
// 这将由框架自动完成。

void CFire2Dlg::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();
}
}

//当用户拖动最小化窗口时系统调用此函数取得光标
//显示。
HCURSOR CFire2Dlg::OnQueryDragIcon()
{
return static_cast<HCURSOR>(m_hIcon);
}



void CFire2Dlg::OnBnClickedCamera()
{
// TODO: 在此添加控件通知处理程序代码
capture = 0;
capture = cvCaptureFromCAM(0);//0代表电脑本身的摄像头,1,2,3,4,,,,,,代表外置摄像头
IplImage *frame = cvQueryFrame(capture);
m_CvvImage.CopyOf(frame, 1);
m_CvvImage.DrawToHDC(hDC, &rect);
SetTimer(2, 40, NULL);
}


void CFire2Dlg::OnTimer(UINT_PTR nIDEvent)
{


CRect rc;
CWnd* pWnd = GetDlgItem(IDC_STATIC);
pWnd->GetClientRect(rc);
IplImage *frame = cvQueryFrame(capture);
m_CvvImage.CopyOf(frame, 1);
m_CvvImage.DrawToHDC(hDC, &rect);


CDialogEx::OnTimer(nIDEvent);
}
...全文
211 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
Eleven 2016-05-25
  • 打赏
  • 举报
回复
你自己Debug调试一下看看,哪个函数失败了?或者打个断点,看看关键函数执行了没?或者执行到哪里失败了?
lx624909677 2016-05-25
  • 打赏
  • 举报
回复
都不是显示图像,怎么知道打开了的呢?另外你显示摄像头内容的代码呢?imshow?
赵4老师 2016-05-19
  • 打赏
  • 举报
回复
设备管理器中设置启用摄像头。 请检查每个函数调用的返回值。

16,471

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Web++
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧