openCV——阈值与平滑处理

import cv2
import matplotlib.pyplot as plt
%matplotlib inline
import numpy as np

阈值处理

ret, dst = cv2.threshold(src, thresh, maxval, type)
  • src: 输入图,只能输入单通道图像,通常来说为灰度图

  • dst: 输出图

  • thresh: 阈值

  • maxval: 当像素值超过了阈值(或者小于阈值,根据type来决定),所赋予的值

  • type:二值化操作的类型,包含以下5种类型: cv2.THRESH_BINARY; cv2.THRESH_BINARY_INV; cv2.THRESH_TRUNC; cv2.THRESH_TOZERO;cv2.THRESH_TOZERO_INV

  • cv2.THRESH_BINARY           超过阈值部分取maxval(最大值),否则取0

  • cv2.THRESH_BINARY_INV    THRESH_BINARY的反转

  • cv2.THRESH_TRUNC            大于阈值部分设为阈值,否则不变

  • cv2.THRESH_TOZERO          大于阈值部分不改变,否则设为0

  • cv2.THRESH_TOZERO_INV  THRESH_TOZERO的反转

def cvshow(name, ndarray):
    # 第一个参数表示显示窗口的名字,第二个参数表示数据
    cv2.imshow(name, ndarray)
    # 表示等待多久窗口关闭,毫秒单位。0表示按任意键结束
    cv2.waitKey(0)
    cv2.destroyAllWindows()
boom = cv2.imread("boom.jpg", cv2.IMREAD_GRAYSCALE)
cvshow("boom", boom)
boom.shape
(800, 1280)
# 二值化处理的结果就是黑白图
ret, dst_binary = cv2.threshold(boom, 127, 255, type=cv2.THRESH_BINARY)
ret, dst_binary_inv = cv2.threshold(boom, 127, 255, type=cv2.THRESH_BINARY_INV)
cvshow("binary", dst_binary)
cvshow("binary_inv", dst_binary_inv)
ret, dst_trunc = cv2.threshold(boom, 50, 255, type=cv2.THRESH_TRUNC)
cvshow("trunc", dst_trunc)
ret, dst_tozero = cv2.threshold(boom, 100, 255, type=cv2.THRESH_TOZERO)
cvshow("tozero", dst_tozero)

平滑处理

girl = cv2.imread("girl.jpg")
cvshow("girl", girl)
girl.shape
(333, 500, 3)
均值滤波
  • 卷积核的每一个元素都为1
blur = cv2.blur(girl, (3, 3))
cvshow("blur", blur)
高斯滤波
  • 中心点的上下左右的像素点权重大于左上,左下,右上,右下的像素点
gau = cv2.GaussianBlur(girl, (3, 3), 1)
cvshow("gau", gau)
中值滤波
  • 卷积核选中的像素点,进行排序,用中值代替中心点的值
median = cv2.medianBlur(girl, 5)
cvshow("median", median)

将所有的处理结果都一起展示

res = np.hstack((blur, gau, median))
cvshow("res", res)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值