图像处理软件开发记录(三) QT图像显示

来源:互联网 发布:大麦盒子装软件 编辑:程序博客网 时间:2024/05/18 02:14

专栏地址:http://blog.csdn.net/column/details/imagep.html

这一篇文章记录有关图像显示的问题。

因为对QT的研究不深,所以在QT上显示图像的设计过程真是坎坎坷坷。


在最开始,我用的显示方法最简单,就是用label来显示,就是下面这个:


ui->label->setPixmap(QPixmap::fromImage(img));


可是发现显示效果太差,为什么呢?
原因是图片的显示被束缚在我原始所画的label大小之下,当我想要显示比这个label更大的图片时,比如我输入一张完整的lena图像,无法显示完整。如下所示:


然后,我就得想办法解决这个问题。
很明显,把label的大小设置的大一点不是一个好的解决方案。
那么,我后来就想,把图片的大小压缩显示,这个思路清晰简单。

    ui->label->setPixmap(QPixmap::fromImage(img));    ui->label->setScaledContents(true);    ui->label->resize(ui->label->width(),ui->label->height());

可是还是遇到一个问题:图片变形了,如下所示


在以上问题出现后,我曾经这么想:选择一个合适的压缩比显示图片,就是说,我比较图片的大小和label的大小,然后根据它们之间的比例关系按图片的原始长宽比例缩减图片大小:

float cols_temp = image.cols;    float wid_temp = ui->Imagedisplaylabel->width();    float rows_temp = image.rows;    float hei_temp = ui->Imagedisplaylabel->height();    float ratio1 = cols_temp/wid_temp;    float ratio2 = rows_temp/hei_temp;    float ratio = 0.0;    if (ratio1 > ratio2)         ratio = ratio1;    else         ratio = ratio2;    int width_re = ui->Imagedisplaylabel->width()/ratio;    int height_re = ui->Imagedisplaylabel->height()/ratio;    ui->Imagedisplaylabel->resize(width_re,height_re);

可是很不幸,无法达到好的效果。

最后,我在浏览博客 基础学习笔记之opencv(15):离散傅里叶变换的时候看到它的显示效果居然没有变形:


然后才发现,原来用Text Browser也可以显示图片。




Code如下:

void MainWindow::on_actionOpen_triggered(){    QString filename = QFileDialog::getOpenFileName(this,tr("Open Image"),".",tr("Image Files(*.png *.jpg *.jepg *.bmg)"));    image = cv::imread(filename.toLatin1().data());    cv::Mat temp;    cv::cvtColor(image,temp,CV_BGR2RGB);    //QImage img = QImage((const unsigned char*)(temp.data),temp.cols,temp.rows,QImage::Format_RGB888);    QString path = QString("<img src=\"%1\"/>").arg(filename);    ui->textBrowser->setFixedHeight(image.rows);    ui->textBrowser->setFixedWidth(image.cols);    ui->textBrowser->clear();    ui->textBrowser->append(path);}

显示效果如下:



另外,其实在最开始的时候我还没意识到使用布局方法,最后才发现布局方法的使用能够使窗口的结构布局适应窗口的变化。




References:

QTextEdit/QTextBrowser添加彩色文字与图片

基础学习笔记之opencv(15):离散傅里叶变换


更多图像处理、机器学习资源,请关注博客:LinJM-机器视觉  微博:林建民-机器视觉
0 0
原创粉丝点击