QImage与IplImage之间的转换

网上很多的QImageIplImage之间的转换代码,不知道别人能否顺利的用过,反正我是没顺利的使用过。主要问题是图像数据排列问题,最重要的是关注图像数据每行占多少个字节,因为涉及到对齐问题。两种不同的数据结构中都有相关的成员变量来表示,这个必须得统一,否则会发生错位或者segment fault的错误。

目前为止,嵌入式Linux 中并没有完全实现openCV类库,所以不能正常使用像cvLoadImage这类函数。我的大体思路是使用QT来读入、显示和存储图像,用openCV的库函数来处理图像。

使用openCV中绝大部分图像处理函数的输入都是IplImage类型的灰度图像,其中涉及最重要的代码就是QImage与IplImage之间的转换,在借鉴其他网友的代码基础上做了适合自己应用的修改,代码如下:

IplImage *Lplimage2QImage::QImageToIplImageRGB(const QImage * qImage)
{
    int width = qImage->width();
    int height = qImage->height();
    CvSize Size;
    Size.height = height;
    Size.width = width;
    IplImage *IplImageBuffer = cvCreateImage(Size, IPL_DEPTH_8U, 3);
    for (int y = 0; y < height; ++y)
    {
        for (int x = 0; x < width; ++x)
        {
            QRgb rgb = qImage->pixel(x, y);
            cvSet2D(IplImageBuffer, y, x, CV_RGB(qRed(rgb), qGreen(rgb), qBlue(rgb)));
        }
    }
    return IplImageBuffer;
}


IplImage *Lplimage2QImage::QImageToIplImageGray(const QImage * qImage)
{
    int width = qImage->width();
    int height = qImage->height();
    int widthStep = 0;

    CvSize Size;
    Size.height = height;
    Size.width = width;

    IplImage *charIplImageBuffer = cvCreateImage(Size, IPL_DEPTH_8U, 1);
    widthStep = charIplImageBuffer->widthStep;
    char *charTemp = (char *) charIplImageBuffer->imageData;

    for (int y = 0; y < height; ++y)
    {
        for (int x = 0; x < width; ++x)
        {
            int index = y * widthStep + x;
            charTemp[index] = (char) qGray(qImage->pixel(x, y));
        }
    }

    return charIplImageBuffer;
}


QImage *Lplimage2QImage::IplImageToQImageGray(const IplImage * iplImage)
{
    int width = iplImage->width;
    int widthStep = iplImage->widthStep;
    int height = iplImage->height;

    QImage *qImage = new QImage((uchar*)iplImage->imageData,width,height, \
                                        widthStep,QImage::Format_Indexed8);
    QVector<QRgb> grayColourTable;
    for(int i = 0; i < 256; i++)
       grayColourTable.append(qRgb(i, i, i));
    qImage->setColorTable(grayColourTable);
    return qImage;
}

QImage *Lplimage2QImage::IplImageToQImageRGB(const IplImage * iplImage)
{
    int width = iplImage->width;
    int widthStep = iplImage->widthStep;
    int height = iplImage->height;

    uchar *qImageBuffer = (uchar *) malloc(width*height*4*sizeof(uchar));
    uchar *QImagePtr = qImageBuffer;
    const uchar *iplImagePtr = (const uchar *) iplImage->imageData;
    for (int y = 0; y < height; y++)
    {
        for (int x = 0; x < width; x++)
        {
            QImagePtr[0] = iplImagePtr[0];
            QImagePtr[1] = iplImagePtr[1];
            QImagePtr[2] = iplImagePtr[2];
            QImagePtr[3] = 0;

            QImagePtr += 4;
            iplImagePtr += 3;
        }
    iplImagePtr += widthStep-3*width;
    }
    QImage *qImage = new QImage(qImageBuffer, width, height, QImage::Format_RGB32);
    return qImage;

}






  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值