当前位置: 首页 > article >正文

基于 PyQt5 和 OpenCV 进行图像处理操作的GUI工具初版

为了实现一个基于 PyQt5 和 OpenCV 的图形用户界面(GUI),要求如下:

左边显示加载的图片。
中间提供各种对图片进行处理的操作方法(如灰度化、模糊处理等)。
右边显示处理后的效果图。
接下来我将详细讲解如何实现这个界面。

1. 环境配置

确保你已经安装了 PyQt5 和 OpenCV:

pip install PyQt5
pip install opencv-python

2. 实现代码

以下是完整的代码实现,基于 PyQt5 创建 GUI,使用 OpenCV 进行图像处理操作:

import sys
import cv2
from PyQt5.QtWidgets import QApplication, QLabel, QPushButton, QVBoxLayout, QHBoxLayout, QWidget, QFileDialog
from PyQt5.QtGui import QImage, QPixmap
from PyQt5.QtCore import Qt


class ImageProcessorApp(QWidget):
    def __init__(self):
        super().__init__()

        # 初始化UI
        self.setWindowTitle("OpenCV Image Processing Tool")
        self.setGeometry(100, 100, 1200, 600)

        # 布局
        self.layout = QHBoxLayout()

        # 左侧:原始图片显示
        self.original_label = QLabel("Original Image")
        self.original_label.setAlignment(Qt.AlignCenter)
        self.layout.addWidget(self.original_label)

        # 中间:按钮操作
        self.button_layout = QVBoxLayout()
        self.open_button = QPushButton("Open Image")
        self.open_button.clicked.connect(self.open_image)
        self.button_layout.addWidget(self.open_button)

        self.gray_button = QPushButton("Grayscale")
        self.gray_button.clicked.connect(self.apply_grayscale)
        self.button_layout.addWidget(self.gray_button)

        self.blur_button = QPushButton("Blur Image")
        self.blur_button.clicked.connect(self.apply_blur)
        self.button_layout.addWidget(self.blur_button)

        self.reset_button = QPushButton("Reset Image")
        self.reset_button.clicked.connect(self.reset_image)
        self.button_layout.addWidget(self.reset_button)

        self.button_layout.addStretch()  # 中间空白拉伸
        self.layout.addLayout(self.button_layout)

        # 右侧:处理后的图像显示
        self.processed_label = QLabel("Processed Image")
        self.processed_label.setAlignment(Qt.AlignCenter)
        self.layout.addWidget(self.processed_label)

        # 设置主窗口布局
        self.setLayout(self.layout)

        # 变量用于存储加载和处理的图像
        self.original_image = None
        self.processed_image = None

    def open_image(self):
        # 打开文件对话框选择图片
        image_path = QFileDialog.getOpenFileName(self, "Open Image", "", "Image Files (*.png *.jpg *.jpeg *.bmp)")[0]
        if image_path:
            self.original_image = cv2.imread(image_path)
            self.processed_image = self.original_image.copy()
            self.display_image(self.original_image, self.original_label)

    def display_image(self, img, label):
        # 将 OpenCV BGR 图像转换为 RGB 图像
        rgb_image = cv2.cvtColor(img, cv2.COLOR_BGR2RGB)
        # 获取图像的尺寸
        h, w, ch = rgb_image.shape
        bytes_per_line = ch * w
        # 将 OpenCV 图像转换为 QImage
        qimg = QImage(rgb_image.data, w, h, bytes_per_line, QImage.Format_RGB888)
        # 将 QImage 转换为 QPixmap
        pixmap = QPixmap.fromImage(qimg)
        # 将图像设置为 QLabel
        label.setPixmap(pixmap.scaled(label.size(), Qt.KeepAspectRatio))

    def apply_grayscale(self):
        # 对图像应用灰度化处理
        if self.processed_image is not None:
            gray_image = cv2.cvtColor(self.processed_image, cv2.COLOR_BGR2GRAY)
            # 将单通道图像转回三通道以显示
            gray_3channel = cv2.cvtColor(gray_image, cv2.COLOR_GRAY2BGR)
            self.display_image(gray_3channel, self.processed_label)

    def apply_blur(self):
        # 对图像应用模糊处理
        if self.processed_image is not None:
            blurred_image = cv2.GaussianBlur(self.processed_image, (15, 15), 0)
            self.display_image(blurred_image, self.processed_label)

    def reset_image(self):
        # 恢复原始图像
        if self.original_image is not None:
            self.processed_image = self.original_image.copy()
            self.display_image(self.processed_image, self.processed_label)


if __name__ == '__main__':
    app = QApplication(sys.argv)
    window = ImageProcessorApp()
    window.show()
    sys.exit(app.exec_())

3. 代码详解

主窗口布局

QHBoxLayout 被用作主布局,分为三部分:
左侧:显示加载的原始图片。
中间:包含各类图像处理的按钮,比如打开图片、应用灰度化、模糊处理、重置图像。
右侧:显示处理后的效果图。

打开图片功能

点击 “Open Image” 按钮,打开文件对话框,用户选择一张图片后,将其加载并在左侧显示。
通过 OpenCV 读取图像后,使用 cv2.cvtColor 将 BGR 格式转换为 RGB 格式,并使用 QImage 和 QPixmap 将图像显示在 QLabel 上。
图像处理功能

Grayscale 按钮:应用灰度化处理,将图像从彩色转换为灰度图,并在右侧显示。
Blur Image 按钮:应用高斯模糊处理(cv2.GaussianBlur),并在右侧显示模糊后的图像。
Reset Image 按钮:恢复原始图像,重置所有处理效果。

图像显示

通过 display_image 函数,将 OpenCV 处理后的图像转换为 QImage,再通过 QLabel 显示在界面上。图像在 QLabel 中保持适当的缩放比例,保证图片内容不会失真。

4. 界面示例

左侧:加载的原始图像。
中间:有四个按钮,分别用于打开图片、灰度处理、模糊处理、重置。
右侧:显示经过处理的效果图。

5. 功能扩展

可以进一步扩展此应用,增加更多图像处理方法,例如:

边缘检测(Canny 算法)。
图像旋转、缩放。
图像滤镜(锐化、浮雕等效果)。
保存处理后的图像功能。

运行效果

在这里插入图片描述
灰度示例在这里插入图片描述

可以在这个基础上继续添加更多的opencv 的方法


http://www.kler.cn/a/307701.html

相关文章:

  • 精华帖分享|浅谈金融时间序列分析与股价随机游走
  • 等保测评怎么做?具体流程是什么?
  • 针对gitgitee的使用
  • Java 包装类
  • conda创建 、查看、 激活、删除 python 虚拟环境
  • 宗馥莉的接班挑战:内斗升级,竞品“偷家”
  • 初探全同态加密1 —— FHE的定义与历史回顾
  • Linux服务器上安装git lfs命令
  • 《深度学习》深度学习 框架、流程解析、动态展示及推导
  • 【LeetCode】每日一题 2024_9_16 公交站间的距离(模拟)
  • 云原生和非云原生哪个好?六大区别详细对比
  • Python编程 - 线程
  • 源代码审查范围为:
  • 【宠物小精灵之收服(待更新)】
  • leetcode 2398.预算内的最多机器人数目
  • 【机器学习】11——矩阵求导
  • 神经网络通俗理解学习笔记(5) 自然语言处理
  • Git bash使用
  • 解决RabbitMQ设置TTL过期后不进入死信队列
  • Java之线程篇四
  • 蓝桥杯—STM32G431RBT6(LCD的液晶显示,由原理及实践,配置及lcd函数)
  • 超高速传输 -- Fixed Grid与Flexible Grid
  • 除了C# 、C++,C++ cli 、还有一个Java版的 db
  • Python中的“Try...Except...Finally”:掌握异常处理的艺术
  • Linux - 探秘/proc/sys/net/ipv4/ip_local_port_range
  • 电基础理解