黄色网页视频 I 影音先锋日日狠狠久久 I 秋霞午夜毛片 I 秋霞一二三区 I 国产成人片无码视频 I 国产 精品 自在自线 I av免费观看网站 I 日本精品久久久久中文字幕5 I 91看视频 I 看全色黄大色黄女片18 I 精品不卡一区 I 亚洲最新精品 I 欧美 激情 在线 I 人妻少妇精品久久 I 国产99视频精品免费专区 I 欧美影院 I 欧美精品在欧美一区二区少妇 I av大片网站 I 国产精品黄色片 I 888久久 I 狠狠干最新 I 看看黄色一级片 I 黄色精品久久 I 三级av在线 I 69色综合 I 国产日韩欧美91 I 亚洲精品偷拍 I 激情小说亚洲图片 I 久久国产视频精品 I 国产综合精品一区二区三区 I 色婷婷国产 I 最新成人av在线 I 国产私拍精品 I 日韩成人影音 I 日日夜夜天天综合

Using OpenCV with Qt

系統(tǒng) 2325 0

The IplImage and Qt

In order to take advantage of the 500 algorithms offered by OpenCV, Qt applications have to manage ? iplImages . Therefore, converting ? QImage to/from ? iplImage ? is very important.

Converting QImage to iplImage

This snippet will convert ? QImages ? into ? iplImage ? with depth 8 and 3 channels. ? QImage ? can store data in several formats. This code accepts just 24-bit ? QImage::Format_RGB888 ? and the QImage::Format_RGB32 . Apha values in the 32-bit format will be removed during the conversion.

    static IplImage* qImage2IplImage(const QImage& qImage)

  {

    int width = qImage.width();

    int height = qImage.height();

 

    // Creates a iplImage with 3 channels

    IplImage *img = cvCreateImage(cvSize(width, height), IPL_DEPTH_8U, 3);

    char * imgBuffer = img->imageData;

 

    //Remove alpha channel

    int jump = (qImage.hasAlphaChannel()) ? 4 : 3;

 

    for (int y=0;y<img->height;y++){

      QByteArray a((const char*)qImage.scanLine(y), qImage.bytesPerLine());

      for (int i=0; i<a.size(); i+=jump){

          //Swap from RGB to BGR

          imgBuffer[2] = a[i];

          imgBuffer[1] = a[i+1];

          imgBuffer[0] = a[i+2];

          imgBuffer+=3;

      }

  }

 

  return img;

  }
  

Converting iplImage to QImage

This snippet will convert a ? iplImage ? with depth 8 and 1 or 3 channels into a 8/24-bit ? QImage .

Note: ?This code won't work for images with different depth and number of channels.
    static QImage IplImage2QImage(const IplImage *iplImage)

{

    int height = iplImage->height;

    int width = iplImage->width;

 

    if  (iplImage->depth == IPL_DEPTH_8U && iplImage->nChannels == 3)

    {

      const uchar *qImageBuffer = (const uchar*)iplImage->imageData;

      QImage img(qImageBuffer, width, height, QImage::Format_RGB888);

      return img.rgbSwapped();

    } else if  (iplImage->depth == IPL_DEPTH_8U && iplImage->nChannels == 1){

	const uchar *qImageBuffer = (const uchar*)iplImage->imageData;

	QImage img(qImageBuffer, width, height, QImage::Format_Indexed8);

 

	QVector<QRgb> colorTable;

	for (int i = 0; i < 256; i++){

	    colorTable.push_back(qRgb(i, i, i));

	}

	img.setColorTable(colorTable);

	return img;

    }else{

      qWarning() << "Image cannot be converted.";

      return QImage();

    }

}
  

?

http://www.developer.nokia.com/Community/Wiki/Using_OpenCV_with_Qt

?

Using OpenCV with Qt


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發(fā)表我的評論
最新評論 總共0條評論