opencv——形态学变换_开闭运算

1、开运算

#!/usr/bin/env python3
# -*- coding: utf-8 -*-

"""
    开运算:先腐蚀后膨胀, 去除噪声,去除白色小点、空洞
    闭运算:先膨胀后腐蚀, 用来填充前景物体的小黑点
    形态学梯度:膨胀减去腐蚀, 可以得到前景物体的轮廓
    礼帽:原图减去开运算
    黑帽:闭运算减去原图

    使用函数morphologyEx()进行形态学其他操作
    函数原型为:morphologyEx(src, op, kernel[, dst[, anchor[, iterations[, borderType[, borderValue]]]]]) -> dst
        op参数:
            cv.MORPH_OPEN:开运算
            cv.MORPH_CLOSE:闭运算
            cv.MORPH_GRADIENT:形态学梯度
            cv.MORPH_TOPHAT:礼帽
            cv.MORPH_BLACKHAT:黑帽
        kernel:内核或结构化内核大小
            使用getStructuringElement(shape, ksize[, anchor]) -> retval获得结构化内核
                shape:
                    cv.MORPH_RECT  矩形结构化核
                    cv.MORPH_ELLIPSE 椭圆结构化核
                    cv.MORPH_CROSS 交叉结构化核
                ksize:
                    指定结构化核大小
                anchor:默认为Point(-1,-1),内核中心点。省略时为默认值
        anchor:默认为Point(-1,-1),内核中心点。省略时为默认值。
        iterations:腐蚀次数。省略时为默认值1。
        borderType:推断边缘类型,具体参见borderInterpolate函数。默认值为BORDER_DEFAULT 边缘值拷贝
        borderValue:边缘值,具体可参见createMorphoogyFilter函数,可省略
"""

'''
结构化元素
# Rectangular Kernel
>>> cv.getStructuringElement(cv.MORPH_RECT,(5,5))
array([[1, 1, 1, 1, 1],
       [1, 1, 1, 1, 1],
       [1, 1, 1, 1, 1],
       [1, 1, 1, 1, 1],
       [1, 1, 1, 1, 1]], dtype=uint8)
# Elliptical Kernel
>>> cv.getStructuringElement(cv.MORPH_ELLIPSE,(5,5))
array([[0, 0, 1, 0, 0],
       [1, 1, 1, 1, 1],
       [1, 1, 1, 1, 1],
       [1, 1, 1, 1, 1],
       [0, 0, 1, 0, 0]], dtype=uint8)
# Cross-shaped Kernel
>>> cv.getStructuringElement(cv.MORPH_CROSS,(5,5))
array([[0, 0, 1, 0, 0],
       [0, 0, 1, 0, 0],
       [1, 1, 1, 1, 1],
       [0, 0, 1, 0, 0],
       [0, 0, 1, 0, 0]], dtype=uint8)
'''

import cv2 as cv
import numpy as np

img_path = 'j_open.png'
img = cv.imread(img_path)
gray = cv.cvtColor(img, cv.COLOR_BGR2GRAY)


def nothing(x):
    pass


cv.namedWindow('OPEN')
# 创建滑动条
cv.createTrackbar('ks', 'OPEN', 2, 25, nothing)

while True:
    ks = cv.getTrackbarPos('ks', 'OPEN')
    if ks <= 1:
        ks += 1
    # Rectangular Kernel
    rectKernel = cv.getStructuringElement(cv.MORPH_RECT, (ks, ks))

    # Elliptical Kernel
    ellKernel = cv.getStructuringElement(cv.MORPH_ELLIPSE, (ks, ks))

    # Cross-shaped Kernel
    crossKernel = cv.getStructuringElement(cv.MORPH_CROSS, (ks, ks))

    rect = cv.morphologyEx(gray, cv.MORPH_OPEN, rectKernel)
    ellip = cv.morphologyEx(gray, cv.MORPH_OPEN, ellKernel)
    cross = cv.morphologyEx(gray, cv.MORPH_OPEN, crossKernel)

    cv.putText(rect, 'rect:' + str(ks), (80, 20), cv.FONT_HERSHEY_SIMPLEX, .65, (255, 255, 255), 2)
    cv.putText(ellip, 'ellip:' + str(ks), (80, 20), cv.FONT_HERSHEY_SIMPLEX, .65, (255, 255, 255), 2)
    cv.putText(cross, 'cross:' + str(ks), (80, 20), cv.FONT_HERSHEY_SIMPLEX, .65, (255, 255, 255), 2)
    cv.putText(cross, 'cross:' + str(ks), (80, 20), cv.FONT_HERSHEY_SIMPLEX, .65, (255, 255, 255), 2)

    h1 = np.hstack((gray, rect))
    h2 = np.hstack((ellip, cross))
    cv.imshow('OPEN', np.vstack((h1, h2)))
    k = cv.waitKey(100) & 0xff
    if chr(k) == 'q':
        break

    if chr(k) == 's':
        cv.imwrite('./outputs/ret_open' + str(ks) + '.jpg', rect)
        cv.imwrite('./outputs/ellip_open' + str(ks) + '.jpg', ellip)
        cv.imwrite('./outputs/cross_open' + str(ks) + '.jpg', cross)

2、开运算加深理解

#!/usr/bin/env python3
# -*- coding: utf-8 -*-

import cv2 as cv
import numpy as np

# 开运算 == 先腐蚀后膨胀
kernel = np.ones((3, 3), np.uint8)

eg = np.array(range(0, 25), np.uint8).reshape(5, 5)
print('原矩阵')
print(eg)
print('*' * 60)

open_rect = cv.morphologyEx(eg, cv.MORPH_OPEN, kernel)
print('开运算结果')
print(open_rect)
print('*' * 60)

erode = cv.erode(eg, kernel)
print('腐蚀结果')
print(erode)
print('*' * 60)
dilate = cv.dilate(erode, kernel)
print('膨胀结果')
print(dilate)
print('*' * 60)

3、闭运算

#!/usr/bin/env python3
# -*- coding: utf-8 -*-

"""
    开运算:先腐蚀后膨胀, 去除噪声,去除白色小点、空洞
    闭运算:先膨胀后腐蚀, 用来填充前景物体的小黑点
    形态学梯度:膨胀减去腐蚀, 可以得到前景物体的轮廓
    礼帽:原图减去开运算
    黑帽:闭运算减去原图

    使用函数morphologyEx()进行形态学其他操作
    函数原型为:morphologyEx(src, op, kernel[, dst[, anchor[, iterations[, borderType[, borderValue]]]]]) -> dst
        op参数:
            cv.MORPH_OPEN:开运算
            cv.MORPH_CLOSE:闭运算
            cv.MORPH_GRADIENT:形态学梯度
            cv.MORPH_TOPHAT:礼帽
            cv.MORPH_BLACKHAT:黑帽
        kernel:内核或结构化内核大小
            使用getStructuringElement(shape, ksize[, anchor]) -> retval获得结构化内核
                shape:
                    cv.MORPH_RECT  矩形结构化核
                    cv.MORPH_ELLIPSE 椭圆结构化核
                    cv.MORPH_CROSS 交叉结构化核
                ksize:
                    指定结构化核大小
                anchor:默认为Point(-1,-1),内核中心点。省略时为默认值
        anchor:默认为Point(-1,-1),内核中心点。省略时为默认值。
        iterations:腐蚀次数。省略时为默认值1。
        borderType:推断边缘类型,具体参见borderInterpolate函数。默认值为BORDER_DEFAULT 边缘值拷贝
        borderValue:边缘值,具体可参见createMorphoogyFilter函数,可省略
"""

'''
结构化元素
# Rectangular Kernel
>>> cv.getStructuringElement(cv.MORPH_RECT,(5,5))
array([[1, 1, 1, 1, 1],
       [1, 1, 1, 1, 1],
       [1, 1, 1, 1, 1],
       [1, 1, 1, 1, 1],
       [1, 1, 1, 1, 1]], dtype=uint8)
# Elliptical Kernel
>>> cv.getStructuringElement(cv.MORPH_ELLIPSE,(5,5))
array([[0, 0, 1, 0, 0],
       [1, 1, 1, 1, 1],
       [1, 1, 1, 1, 1],
       [1, 1, 1, 1, 1],
       [0, 0, 1, 0, 0]], dtype=uint8)
# Cross-shaped Kernel
>>> cv.getStructuringElement(cv.MORPH_CROSS,(5,5))
array([[0, 0, 1, 0, 0],
       [0, 0, 1, 0, 0],
       [1, 1, 1, 1, 1],
       [0, 0, 1, 0, 0],
       [0, 0, 1, 0, 0]], dtype=uint8)
'''

import cv2 as cv
import numpy as np

img_path = 'j_close.png'
img = cv.imread(img_path)
gray = cv.cvtColor(img, cv.COLOR_BGR2GRAY)


def nothing(x):
    pass


cv.namedWindow('CLOSE')
# 创建滑动条
cv.createTrackbar('ks', 'CLOSE', 2, 25, nothing)

while True:
    ks = cv.getTrackbarPos('ks', 'CLOSE')
    if ks <= 1:
        ks += 1
    # Rectangular Kernel
    rectKernel = cv.getStructuringElement(cv.MORPH_RECT, (ks, ks))

    # Elliptical Kernel
    ellKernel = cv.getStructuringElement(cv.MORPH_ELLIPSE, (ks, ks))

    # Cross-shaped Kernel
    crossKernel = cv.getStructuringElement(cv.MORPH_CROSS, (ks, ks))

    rect = cv.morphologyEx(gray, cv.MORPH_CLOSE, rectKernel)
    ellip = cv.morphologyEx(gray, cv.MORPH_CLOSE, ellKernel)
    cross = cv.morphologyEx(gray, cv.MORPH_CLOSE, crossKernel)

    # cv.putText(rect, 'rect:' + str(ks), (80, 20), cv.FONT_HERSHEY_SIMPLEX, .65, (255, 255, 255), 2)
    # cv.putText(ellip, 'ellip:' + str(ks), (80, 20), cv.FONT_HERSHEY_SIMPLEX, .65, (255, 255, 255), 2)
    # cv.putText(cross, 'cross:' + str(ks), (80, 20), cv.FONT_HERSHEY_SIMPLEX, .65, (255, 255, 255), 2)
    # cv.putText(cross, 'cross:' + str(ks), (80, 20), cv.FONT_HERSHEY_SIMPLEX, .65, (255, 255, 255), 2)

    h1 = np.hstack((gray, rect))
    h2 = np.hstack((ellip, cross))
    cv.imshow('CLOSE', np.vstack((h1, h2)))
    k = cv.waitKey(100) & 0xff
    if chr(k) == 'q':
        break

    if chr(k) == 's':
        cv.imwrite('./outputs/ret_close' + str(ks) + '.jpg', rect)
        cv.imwrite('./outputs/ellip_close' + str(ks) + '.jpg', ellip)
        cv.imwrite('./outputs/cross_close' + str(ks) + '.jpg', cross)

4、闭运算加深理解

#!/usr/bin/env python3
# -*- coding: utf-8 -*-

import cv2 as cv
import numpy as np

# 闭运算 == 先膨胀后腐蚀
kernel = np.ones((3, 3), np.uint8)

eg = np.array(range(0, 25), np.uint8).reshape(5, 5)
print('原矩阵')
print(eg)
print('*' * 60)

close_rect = cv.morphologyEx(eg, cv.MORPH_CLOSE, kernel)
print('闭运算结果')
print(close_rect)
print('*' * 60)

dilate = cv.dilate(eg, kernel)
print('膨胀结果')
print(dilate)
print('*' * 60)
erode = cv.erode(dilate, kernel)
print('腐蚀结果')
print(erode)
print('*' * 60)

 

  • 4
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Sam Chou

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值