Open cv图像处理关于阈值的相关知识

目录

1.代码案例

2.运行结果:


1.代码案例

import cv2 as cv2
import matplotlib.pyplot as plt
import  numpy as np
def cv_show(name,img):
    cv2.imshow(name,img)
    cv2.waitKey(0)
    cv2.destroyAllWindows()


if __name__ == "__main__":
    img2 = cv2.imread(r'E:\pre_noise.JPG',cv2.IMREAD_GRAYSCALE)#灰度图
    ret, thresh1 = cv2.threshold(img2,150,255,cv2.THRESH_BINARY)     #超过阈值的部分取maxval(最大值),否则为0
    ret, thresh2 = cv2.threshold(img2, 150, 255, cv2.THRESH_BINARY_INV)  # 超过阈值的部分取0,否则为最大值
    ret, thresh3 = cv2.threshold(img2, 150, 255, cv2.THRESH_TRUNC)  # 超过阈值的部分取阈值本身,否则不变
    ret, thresh4 = cv2.threshold(img2, 150, 255, cv2.THRESH_TOZERO)  # 超过阈值的部分不变(最大值),否则为0
    ret, thresh5 = cv2.threshold(img2, 150, 255, cv2.THRESH_TOZERO_INV)  # 超过阈值的部分取0,否则为不变
    titles = ['pre','binary','birnary_inv','trunc','tozero','tozero_inv']
    images=[img2,thresh1,thresh2,thresh3 ,thresh4,thresh5]
    for i in range(0, 6, 1):
        plt.subplot(3,2, i+1) 
        plt.imshow(images[i],"gray")
    plt.show()


2.运行结果:

 通过和原图对比可以看出,不同的阈值的处理方式得到的图像结果完全不同

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值