Qt OpenCV显示的图片向右倾斜且灰色的错误

本文探讨了如何在Qt应用中使用OpenCV正确读取和显示图片,解决了Mat与QImage数据转换时的问题,并提供了关键代码和调整参数的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目录

问题描述

 问题分析与解决办法

完整代码

 参考


问题描述

        最近想读取图片并显示到QLabel和GraphicsView上,但是出现运行程序后发现不对劲,其效果如下:

原图片:

 Qt显示效果

 问题分析与解决办法

Mat和QImage的数据不相互对应,如果从Mat转换到QImage的过程中参数设置不对,数据就会出问题

在QImage中增加step的参数即可

QImage disImage_1 = QImage((const unsigned char*)(srcImage_1.data), srcImage_1.cols, srcImage_1.rows,srcImage_1.step, QImage::Format_RGB888);

完整代码

#ifndef MAINWINDOW_H
#define MAINWINDOW_H

#include <QMainWindow>

QT_BEGIN_NAMESPACE
namespace Ui { class MainWindow; }
QT_END_NAMESPACE

class MainWindow : public QMainWindow
{
    Q_OBJECT

public:
    MainWindow(QWidget *parent = nullptr);
    ~MainWindow();

private:
    Ui::MainWindow *ui;
};
#endif // MAINWINDOW_H
#include "mainwindow.h"
#include "ui_mainwindow.h"
#include "QDebug"
#include "QString"
#include "QGraphicsScene"

#include <opencv2/core/core.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <opencv2/imgproc/imgproc.hpp>
using namespace cv;

MainWindow::MainWindow(QWidget *parent)
    : QMainWindow(parent)
    , ui(new Ui::MainWindow)
{
    ui->setupUi(this);

//    右斜杠可以通过一定设置找到你存放资源的路径, path = QCoreApplication::applicationDirPath() + "/src/images"
//    Mat image=imread("E:/My_Files/Practice_Projects/Qt/Practice/Qt_Opencv_Model/src/imges/keji.jpeg",1);//一定要使用绝对路径,其他可以回报错

//    QString 和 String相互转换
//    QString qstr;
//    string str;
//    str = qstr.toStdString();
//    qstr = QString::fromStdString(str);

//    //读取图片
//    QString images_path = QCoreApplication::applicationDirPath() + "\\src\\images\\keji.jpeg";
//    String images_path_S = images_path.toStdString();
//    Mat image=cv::imread(images_path_S,1);

//    Mat image=cv::imread("E:\\My_Files\\Practice_Projects\\Qt\\Practice\\Qt_Opencv_Model\\src\\imges\\keji.jpeg",1);//一定要使用绝对路径,其他可以回报错
//    cv::namedWindow( "Display window", WINDOW_AUTOSIZE );
//    cv::imshow( "Display window", image );

//    1、程序所在路径
//    qDebug()<<QCoreApplication::applicationDirPath();

//    2、程序的完整名称
//    qDebug()<<QCoreApplication::applicationFilePath();

//    3、Qt的qrc里面资源的路径
//    qDebug()<<"../src/images";


    QString page_1 = QCoreApplication::applicationDirPath() + "/src/images/keji.jpg";
    QString page_2 = QCoreApplication::applicationDirPath() + "/src/images/keji.jpg";

    Mat srcImage_1 = imread(page_1.toLatin1().data(), 1);      // 读取图片数据
    Mat srcImage_2 = imread(page_2.toLatin1().data(), 1);

    cvtColor(srcImage_1, srcImage_1, COLOR_BGR2RGB);        // 图像格式转换
    cvtColor(srcImage_2, srcImage_2, COLOR_BGR2RGB);


    QImage disImage_1 = QImage((const unsigned char*)(srcImage_1.data), srcImage_1.cols, srcImage_1.rows,srcImage_1.step, QImage::Format_RGB888);
    QImage disImage_2 = QImage((const unsigned char*)(srcImage_2.data), srcImage_2.cols, srcImage_2.rows,srcImage_2.step, QImage::Format_RGB888);

    ui->label->setPixmap(QPixmap::fromImage(disImage_1.scaled(ui->label->size(), Qt::KeepAspectRatio)));  // label 显示图像

    QGraphicsScene *scene = new QGraphicsScene;             // graphicsView 显示图像
    scene->addPixmap(QPixmap::fromImage(disImage_2));
    ui->graphicsView->setScene(scene);
    ui->graphicsView->show();


}

MainWindow::~MainWindow()
{
    delete ui;
}

 参考

【1】Qt调用 OpenCV 显示图片_billy的博客-CSDN博客

【2】【OpenCV+Qt】在Qt界面中显示OpenCV处理的图像_チン昶的博客-CSDN博客_opencv qt

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

AutoURobot

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值