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

目录

问题描述

 问题分析与解决办法

完整代码

 参考


问题描述

        最近想读取图片并显示到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

在基于Qt的项目中,如果我们想要将OpenCV读取的图像显示Qt界面中,可以通过以下步骤实现。 首先,在mainwindow.h头文件中,我们需要包含OpenCV的头文件,并使用cv命名空间。同时,我们还需要声明一个用于显示图像的成员变量,例如QLabel或QGraphicsView。以下是一个示例的mainwindow.h头文件内容: ```cpp #ifndef MAINWINDOW_H #define MAINWINDOW_H #include <QMainWindow> #include <opencv2/opencv.hpp> // OpenCV文件包含 using namespace cv; // OpenCV命名空间 namespace Ui { class MainWindow; } class MainWindow : public QMainWindow { Q_OBJECT public: explicit MainWindow(QWidget *parent = 0); ~MainWindow(); private slots: void on_pushButton_clicked(); void on_pushButton_2_clicked(); private: Ui::MainWindow *ui; QLabel *imageLabel; // 用于显示图像的QLabel }; #endif // MAINWINDOW_H ``` 接下来,在mainwindow.cpp源文件中,我们需要在构造函数中创建一个QLabel对象,并将其添加到Qt界面中的布局中。在按钮点击事件的槽函数中,我们可以使用OpenCV的imread函数读取图像,并将其显示在QLabel上。以下是一个示例的mainwindow.cpp源文件内容: ```cpp #include "mainwindow.h" #include "ui_mainwindow.h" MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent), ui(new Ui::MainWindow) { ui->setupUi(this); // 创建一个QLabel对象用于显示图像 imageLabel = new QLabel(this); ui->centralWidget->layout()->addWidget(imageLabel); } MainWindow::~MainWindow() { delete ui; } void MainWindow::on_pushButton_clicked() { // 从文件中读取图像 Mat img = imread("image.jpg"); if (img.empty()) { fprintf(stderr, "Can not load image\n"); return; } // 将OpenCVMat对象转换为Qt的QImage对象 QImage qimg(img.data, img.cols, img.rows, img.step, QImage::Format_RGB888); // 将QImage对象显示在QLabel上 imageLabel->setPixmap(QPixmap::fromImage(qimg)); imageLabel->setScaledContents(true); } void MainWindow::on_pushButton_2_clicked() { // 清空QLabel上的图像 imageLabel->clear(); } ``` 在上述示例中,我们在按钮点击事件的槽函数中使用imread函数读取图像,并将其转换为QImage对象。然后,我们将QImage对象显示在QLabel上,从而实现在Qt界面中显示OpenCV读取的图像。 请注意,示例中的图像路径为"image.jpg",你需要根据实际情况修改为你的图像路径。另外,还需要在Qt的.pro文件中添加对OpenCV库的链接。 希望以上信息对你有帮助!\[1\]\[2\]\[3\] #### 引用[.reference_title] - *1* *3* [【Qt_OpenCV基础篇 - 002】Qt中使用OpenCV处理并显示图片程序框架(QMainWindow)](https://blog.csdn.net/qingyang8513/article/details/80378491)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [使用Qt显示OpenCV读取的图片](https://blog.csdn.net/QtCompany/article/details/129087366)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

维度攻城狮

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

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

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

打赏作者

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

抵扣说明:

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

余额充值