QT界面上显示图片,可缩放和绘制矩形ROI框

QT界面上显示图片,可缩放和绘制矩形ROI框

鉴于搜了半天网站都没有我想实现的roi截取框,我就自己实现一个
用到了QGraphicsView、QGraphicsScene、QGraphicsPixmapItem、QGraphicsRectItem、QGraphicsTextItem类。
刚开始学QT,照猫画虎
实现效果如下:

QT界面显示图片

1.第一步,继承QGraphicsView创建自己的子类。

class MyGraphicsView: public QGraphicsView
{
	Q_OBJECT

public:
	MyGraphicsView(QWidget* parent = nullptr);
	~MyGraphicsView();
}

2.第二步,重写鼠标和滚轮事件

protected:
    void mousePressEvent(QMouseEvent* event);
    void mouseReleaseEvent(QMouseEvent* event);
    void mouseMoveEvent(QMouseEvent* event);
    void wheelEvent(QWheelEvent* event);

3.第三步,写传入图片的接口函数和发送roi坐标的信号函数

public:
    void setImage(QPixmap);    //外部传入图片
signals:
    void Send_rect(QPointF, QPointF);

4.使用的时候,在QT creater中将graphicsView提升为MyGraphicsView,并加载一张图片

ui->graphicsView->setImage(QPixmap("C:\\Users\\xxx\\Pictures\\1.bmp"));

整个头文件如下(cpp也上传了的):

#pragma once

#include <QGraphicsView>
#include <QGraphicsPixmapItem>
#include <QMouseEvent>
#include <QGraphicsRectItem>

class MyGraphicsView: public QGraphicsView
{
	Q_OBJECT

public:
	MyGraphicsView(QWidget* parent = nullptr);
	~MyGraphicsView();
    void setImage(QPixmap);    //外部传入图片
protected:
    void mousePressEvent(QMouseEvent* event);
    void mouseReleaseEvent(QMouseEvent* event);
    void mouseMoveEvent(QMouseEvent* event);
    void wheelEvent(QWheelEvent* event);
signals:
    void Send_rect(QPointF, QPointF);
private:
    QGraphicsScene* scene = nullptr;
    QPixmap m_image;
    QPointF start_point;
    QPointF end_point;
    QPointF move_point;
    QGraphicsPixmapItem* item = nullptr;
    QGraphicsRectItem* item_rect = nullptr;
    QGraphicsTextItem* item_text = nullptr;
    double ratio = 1.0;
    QRect paint_rect;           //绘画限制区域
    bool m_isDown = false;
};
  • 6
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在Qt显示OpenCV图像并框选ROI,可以按照以下步骤进行: 1.使用OpenCV读取图像文件: ```c++ cv::Mat image = cv::imread("image.jpg"); ``` 2.将图像转换为Qt格式: ```c++ QImage img(image.data, image.cols, image.rows, QImage::Format_RGB888); ``` 3.创建一个QLabel并设置图像: ```c++ QLabel* label = new QLabel(this); label->setPixmap(QPixmap::fromImage(img)); ``` 4.添加一个鼠标事件处理程序以框选ROI: ```c++ void MyWidget::mousePressEvent(QMouseEvent* event) { if (event->button() == Qt::LeftButton) { // 记录鼠标按下的位置 startPoint = event->pos(); } } void MyWidget::mouseReleaseEvent(QMouseEvent* event) { if (event->button() == Qt::LeftButton) { // 记录鼠标松开的位置 endPoint = event->pos(); // 计算矩形的左上角和右下角坐标 int x = qMin(startPoint.x(), endPoint.x()); int y = qMin(startPoint.y(), endPoint.y()); int width = qAbs(startPoint.x() - endPoint.x()); int height = qAbs(startPoint.y() - endPoint.y()); // 在图像上绘制矩形 cv::rectangle(image, cv::Rect(x, y, width, height), cv::Scalar(0, 255, 0), 2); // 将图像转换为Qt格式并设置到QLabel上 QImage img(image.data, image.cols, image.rows, QImage::Format_RGB888); label->setPixmap(QPixmap::fromImage(img)); } } ``` 在上面的代码中,我们记录鼠标按下和松开时的位置,并计算矩形的左上角和右下角坐标。然后,我们使用OpenCV在图像上绘制一个矩形,并将图像转换为Qt格式并设置到QLabel上。 完整的示例代码如下: ```c++ #include <QtWidgets> #include <opencv2/opencv.hpp> class MyWidget : public QWidget { public: MyWidget(QWidget* parent = nullptr) : QWidget(parent) { // 使用OpenCV读取图像文件 cv::Mat image = cv::imread("image.jpg"); // 将图像转换为Qt格式 QImage img(image.data, image.cols, image.rows, QImage::Format_RGB888); // 创建一个QLabel并设置图像 label = new QLabel(this); label->setPixmap(QPixmap::fromImage(img)); // 设置窗口大小 setFixedSize(image.cols, image.rows); // 设置鼠标跟踪 setMouseTracking(true); label->setMouseTracking(true); label->installEventFilter(this); } protected: void mousePressEvent(QMouseEvent* event) override { if (event->button() == Qt::LeftButton) { // 记录鼠标按下的位置 startPoint = event->pos(); } } void mouseReleaseEvent(QMouseEvent* event) override { if (event->button() == Qt::LeftButton) { // 记录鼠标松开的位置 endPoint = event->pos(); // 计算矩形的左上角和右下角坐标 int x = qMin(startPoint.x(), endPoint.x()); int y = qMin(startPoint.y(), endPoint.y()); int width = qAbs(startPoint.x() - endPoint.x()); int height = qAbs(startPoint.y() - endPoint.y()); // 在图像上绘制矩形 cv::Mat image = cv::imread("image.jpg"); cv::rectangle(image, cv::Rect(x, y, width, height), cv::Scalar(0, 255, 0), 2); // 将图像转换为Qt格式并设置到QLabel上 QImage img(image.data, image.cols, image.rows, QImage::Format_RGB888); label->setPixmap(QPixmap::fromImage(img)); } } private: QLabel* label; QPoint startPoint; QPoint endPoint; }; int main(int argc, char* argv[]) { QApplication app(argc, argv); MyWidget widget; widget.show(); return app.exec(); } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值