基于PYQT5的HSV阈值提取器

1 篇文章 0 订阅
1 篇文章 0 订阅

一、主要界面

​​在这里插入图片描述

二、主要功能

打开图片后通过滑块调整图像的最低最高HSV值,右侧显示经过Opencv掩膜算法处理过后的图像。
右下角显示鼠标所在像素点的BGR值和点坐标。

三、Designer界面

在这里插入图片描述

四、核心代码

实现右侧图片更新:

def update_mask(self):
        # 获取滑块的值
        min_h = self.slider_min_h.value()
        min_s = self.slider_min_s.value()
        min_v = self.slider_min_v.value()
        max_h = self.slider_max_h.value()
        max_s = self.slider_max_s.value()
        max_v = self.slider_max_v.value()
        
        # 创建掩膜
        mask = cv2.inRange(self.img_hsv, np.array([min_h, min_s, min_v]), np.array([max_h, max_s, max_v]))
        
        # 生成二值化图片
        binary_img = cv2.bitwise_and(self.img_hsv, self.img_hsv, mask=mask)
        binary_img = cv2.cvtColor(binary_img, cv2.COLOR_HSV2RGB)
        binary_img = cv2.cvtColor(binary_img, cv2.COLOR_RGB2GRAY)
        
        # 显示二值化图片
        height, width = binary_img.shape
        bytesPerLine = width
        q_img = QtGui.QImage(binary_img.data, width, height, bytesPerLine, QtGui.QImage.Format_Grayscale8)
        self.binary_label.setPixmap(QtGui.QPixmap.fromImage(q_img))

        self.text_min.setText( "({},{},{})".format(min_h,min_s,min_v))
        self.text_max.setText( "({},{},{})".format(max_h,max_s,max_v))

实现获取鼠标位置处信息:

    def mouse_move_event(self, e):
        if not self.pixmap:
            return

        pos = e.pos()
        x = pos.x()
        y = pos.y()
        if x >= self.pixmap.width() or y >= self.pixmap.height():
            return

        color = self.pixmap.toImage().pixel(x, y)
        b = color & 0xFF
        g = (color >> 8) & 0xFF
        r = (color >> 16) & 0xFF

        self.text_pos.setText(f"({x}, {y})")
        self.text_hsv.setText(f" ({b}, {g},{r})")   

五、资源下载

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值