妮儿1 2015-04-14 13:11 采纳率: 0%
浏览 4529

mfc中的picture控件不显示图像

这是我的程序在非mfc中已经能很好的显示图像,但是到了mfc中就显示不出来了,不知道到底是哪里出错了,还望大家帮帮忙!谢谢了。
void CMFCApplication17Dlg::OnClickedButton5()
{
{
// TODO: Add your control notification handler code here
//CFileDialog fDlg(TRUE,"bmp","*.bmp",OFN_HIDEREADONLY|OFN_OVERWRITEPROMPT,
//"原始图像(*.bmp)|*.bmp|所有文件(*.*)|*.*||",NULL);
//if (fDlg.DoModal() == TRUE)
//{
//Open_Filename = fDlg.GetFileName();
IplImage *image=NULL;
if(image)
cvReleaseImage(&image);
image = cvLoadImage("H:\lena.bmp",1);
if (image==0)
MessageBox("Reading Failed");
else
DrawPicToHDC(image, IDC_showimage);
cvReleaseImage(&image);
}
}

//}

void CMFCApplication17Dlg::DrawPicToHDC(IplImage img, UINT ID)
{
CDC *pDC = GetDlgItem(ID)->GetDC();
HDC hDC= pDC->GetSafeHdc();
CRect rect;
CWnd * pWnd;
pWnd=GetDlgItem(ID);
pWnd->SetWindowPos( NULL,0,0,img->width,img->height,SWP_NOZORDER | SWP_NOMOVE );
pWnd->GetClientRect(&rect);
CvvImage cimg;
cimg.CopyOf(img);
cimg.DrawToHDC(hDC,&rect);
ReleaseDC(pDC);
}
void CMFCApplication17Dlg::OnClickedButton1()
{
if( !lvboInitialize())

{

printf("Could not initialize !");

return ;

}
IplImage *image=NULL;
if(image)
cvReleaseImage(&image);
image = cvLoadImage("H:\lena.bmp",0);
IplImage
pTemp = cvCreateImage(cvSize(image->height, image->width), IPL_DEPTH_8U, 1); //n*m创建图像
cvTranspose(image, pTemp);//m*n->n*m,复制image中的数据到ptemp中
CvMat* pMat = cvCreateMat(pTemp->height, pTemp->width, CV_8UC1);//pmat:n*m分配矩阵空间
cvConvert(pTemp, pMat);//pmat:n*m,将图像转化为矩阵,任意类型数据的矩阵
mwArray a(pMat->width,pMat->height,mxUINT8_CLASS);
a.SetData(pMat->data.ptr, pMat->height*pMat->width);
mwArray h(pMat->width,pMat->height ,mxDOUBLE_CLASS);
cvReleaseMat( &pMat );

shiyan4(1,h,a);
IplImage* pTempL0 = cvCreateImage(cvSize(image->height, image->width), IPL_DEPTH_64F, 1); //n*m
CvMat* pMatL0 = cvCreateMat(pTempL0->height, pTempL0->width, CV_64FC1);//n*m
h.GetData(pMatL0->data.db,pMatL0->height*pMatL0->width);
cvConvert(pMatL0,pTempL0);
IplImage* pL0SmoothImg =cvCreateImage(cvSize(pTempL0->height, pTempL0->width),IPL_DEPTH_64F,1);//m*n

        //cvReleaseImage( &pTemp );
    cvTranspose(pTempL0, pL0SmoothImg); //n*m->m*n
    //mat->iplimage 

    IplImage* result =cvCreateImage(CvSize(cvGetSize(pL0SmoothImg)),IPL_DEPTH_8U,1);

cvNormalize(pL0SmoothImg,pL0SmoothImg,1,0,CV_MINMAX);

cvConvertScale(pL0SmoothImg,result,255,0);//62bit->8bit
//DrawPicToHDC(result, IDC_showimage2);
lvboTerminate();
if (result==0)
MessageBox("Reading Failed");
else
DrawPicToHDC(result, IDC_showimage2);
cvReleaseMat( &pMatL0 );
cvReleaseImage( &pTempL0 );
cvReleaseImage( &pL0SmoothImg);
cvReleaseImage( &result);

}

  • 写回答

3条回答

  • oyljerry 2015-04-14 13:54
    关注

    把画图,部分是不是要放到OnPaint中,防止刷新冲掉

    评论

报告相同问题?

悬赏问题

  • ¥15 运筹学排序问题中的在线排序
  • ¥15 关于#flink#的问题:关于docker部署flink集成hadoop的yarn,请教个问题flink启动yarn-session.sh连不上hadoop
  • ¥30 求一段fortran代码用IVF编译运行的结果
  • ¥15 深度学习根据CNN网络模型,搭建BP模型并训练MNIST数据集
  • ¥15 lammps拉伸应力应变曲线分析
  • ¥15 C++ 头文件/宏冲突问题解决
  • ¥15 用comsol模拟大气湍流通过底部加热(温度不同)的腔体
  • ¥50 安卓adb backup备份子用户应用数据失败
  • ¥20 有人能用聚类分析帮我分析一下文本内容嘛
  • ¥15 请问Lammps做复合材料拉伸模拟,应力应变曲线问题