这几天在做利用C++调用matlab的程序,并把结果图像利用MFC进行显示,我是做图像处理的,恳请各位大神给点指点,我应该怎么改,才能显示出来,万分感谢!下面是我目前的代码,及错误。void CIILView::OnStripenoiseRemoval()
{
// TODO: 在此添加命令处理程序代码
    CIILDoc* pDoc = GetDocument();
CImage* pDib = pDoc->GetPDib();
if(pDib->IsNull())
return;
int width = pDib->GetWidth();
int height = pDib->GetHeight();
int ichannels = pDib->GetBPP()/8;
if(ichannels==3)
     im24to8(pDib);       //这个函数已定于24位转8位 mclInitializeApplication(NULL,0);
// 初始化库
libaInitialize(); CImage imgin;
CImage imgout;
//byteImage imgin;      //有问题?????
//byteImage imgout;
//imgin.Load(_T("1.jpg"));
int pit = imgin.GetPitch();    //返回大小为图像宽所占有的字节数
int h = imgin.GetHeight();
int w = imgin.GetWidth();
//unsigned char* pImgin =  (unsigned char*)imgin.GetPixelAddress(0,h-1);
imgout.Create(w,h,8);
//unsigned char* pImgout = (unsigned char*)imgout.GetPixelAddress(0,h-1);
unsigned char* p1 = (unsigned char*)imgin.GetBits();    //0-255 返回左上角或者左下角地址
unsigned char* p2 = (unsigned char*)imgout.GetBits();
int bits = sizeof(unsigned char);          //8位返回一个字节
unsigned char* pImgin = new unsigned char[w*h*8*sizeof(unsigned char)];     
unsigned char* pImgout = new unsigned char[w*h*8*sizeof(unsigned char)];   
for (int i=0;i<h;i++)
{
for (int j=0;j<w;j++)
{
pImgin[i*w+j] = p1[i*pit+j];          //保存输入图像数据值的大小
}
}
// 创建输入mx字符串数组
mwArray DataIn(w,h,mxUINT8_CLASS);   
mwArray DataOut(w,h,mxUINT8_CLASS);
mwArray W(1,1,mxUINT8_CLASS);
mwArray H(1,1,mxUINT8_CLASS);

DataIn.SetData((mxUint8*)pImgin,w*h);
W.SetData(&w,1);
H.SetData(&h,1);
// 调用演示函数 
solveV(1,DataOut,DataIn);       /////这边输入输出参数是没有问题的 DataOut.GetData((mxUint8*)pImgout,w*h);
for (int i=0;i<h;i++)
{
for (int j=0;j<w;j++)
{
p2[i*pit+j] = pImgout[i*w+j];
}
}    
//PaletteChangedToGray(&imgout);
//imgout.Save(_T("out.jpg"));
    pDoc->PaletteChangedToGray(pDib);
pDoc->AddHistroyResult(pDib);
//FreebyteImageObj(imgin);
//FreebyteImageObj(imgout);
Invalidate(true);
}
我觉得我代码写得有点问题,而且目前的错误是

解决方案 »

  1.   

    参看 《matlab与c/c++混合编程》 第4版 (刚出的)
      

  2.   

    我代码如果只是C++调用matlab,如果只是save保存,结果是正确的,只是目前我不知道怎么利用MFC把结果显示出来,谢谢您。
      

  3.   

    不要做A语言代码修改为B语言代码的无用功。
    也不要做用A语言代码直接调用B语言代码库这样复杂、这样容易出错的傻事。
    只需让A、B语言代码的输入输出重定向到文本文件,或修改A、B语言代码让其通过文本文件输入输出。
    即可很方便地让A、B两种语言之间协调工作。
    比如:
    A将请求数据写到文件a.txt,写完后改名为aa.txt
    B发现aa.txt存在时,读取其内容,调用相应功能,将结果写到文件b.txt,写完后删除aa.txt,改名为bb.txt
    A发现bb.txt存在时,读取其内容,读完后删除bb.txt
    以上A可以替换为任何一种开发语言或开发环境,B可以替换为任何一种与A不同的开发语言或开发环境。
    除非A或B不支持判断文件是否存在、文件读写和文件更名。
    但是谁又能举出不支持判断文件是否存在、文件读写和文件更名的开发语言或开发环境呢?
    可以将临时文件放在RamDisk上提高效率减少磨损磁盘。
    数据的结构很复杂的话,文本文件的格式问题可参考json或xml共享临时文本文件这种进程之间的通讯方法相比其它方法的优点有很多,下面仅列出我现在能想到的:
    ·进程之间松耦合
    ·进程可在同一台机器上,也可跨机,跨操作系统,跨硬件平台,甚至跨国。
    ·方便调试和监视,只需让第三方或人工查看该临时文本文件即可。
    ·方便在线开关服务,只需删除或创建该临时文本文件即可。
    ·方便实现分布式和负载均衡。
    ·方便队列化提供服务,而且几乎不可能发生队列满的情况(除非硬盘空间满)
    ·……“跨语言、跨机,跨操作系统,跨硬件平台,跨国,跨*.*的”苦海无边,
    回头是“使用共享纯文本文件进行信息交流”的岸!