qt opencv 显示图片
时间: 2023-08-10 09:06:58 浏览: 123
在基于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;
}
// 将OpenCV的Mat对象转换为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 ]
阅读全文