计算机视觉及图像预处理 06-形态变换(三)

目录

链接

代码

 透视变换

变换回去

图像腐蚀

膨胀运算

开运算

 闭运算

 形态学梯度


链接

跟着峰哥学计算机视觉所有需要用到的图片-深度学习文档类资源-CSDN下载

代码

 透视变换

 

import numpy as np
import cv2

im = cv2.imread("../data/pers.png")
rows, cols = im.shape[:2]
print(rows, cols)
cv2.imshow("im", im)

# 指定映射坐标
pts1 = np.float32([[58, 2], [167, 9], [9, 196], [126, 196]])#原坐标点
pts2 = np.float32([[16, 2], [167, 8], [8, 196], [169, 196]])#目标点坐标

# 生成透视变换矩阵
M = cv2.getPerspectiveTransform(pts1, pts2)

# 执行变换
dst = cv2.warpPerspective(im,  # 原始图像
                          M,  # 变换矩阵
                          (cols, rows))  # 输出图像大小
cv2.imshow("dst", dst)

# 手动设置阻塞函数
cv2.waitKey() # 等待用户按下任意键
cv2.destroyAllWindows() # 销毁所有的窗口

变换回去

import numpy as np
import cv2

im = cv2.imread("../data/pers.png")
rows, cols = im.shape[:2]
print(rows, cols)
cv2.imshow("im", im)

# 指定映射坐标
pts1 = np.float32([[58, 2], [167, 9], [9, 196], [126, 196]])
pts2 = np.float32([[16, 2], [167, 8], [8, 196], [169, 196]])

# 生成透视变换矩阵
M = cv2.getPerspectiveTransform(pts1, pts2)

# 执行变换
dst = cv2.warpPerspective(im,  # 原始图像
                          M,  # 变换矩阵
                          (cols, rows))  # 输出图像大小
cv2.imshow("dst", dst)

# 将矩形变成平行四边形
M = cv2.getPerspectiveTransform(pts2, pts1)
dst2 = cv2.warpPerspective(im,  # 原始图像
                          M,  # 变换矩阵
                          (cols, rows))  # 输出图像大小
cv2.imshow("dst2", dst2)

# 手动设置阻塞函数
cv2.waitKey()  # 等待用户按下任意键
cv2.destroyAllWindows()  # 销毁所有的窗口

图像腐蚀

 腐蚀核是腐蚀区域的大小,参与腐蚀计算的一个参数

iteration 迭代次数,迭代次数越多,腐蚀的越厉害

# 图像腐蚀
import cv2
import numpy as np

im = cv2.imread("../data/5.png")
cv2.imshow("im", im)

# 腐蚀
kernel = np.ones((3, 3),  # 腐蚀核的大小,3×3的大小
                 np.uint8)  # 类型
erosion = cv2.erode(im,  # 腐蚀图像
                    kernel,  # 腐蚀核
                    iterations=3)  # 迭代次数
cv2.imshow("erosion",erosion)

cv2.waitKey()
cv2.destroyAllWindows()

膨胀运算

import cv2
import numpy as np

im = cv2.imread("../data/6.png")
cv2.imshow("im", im)

# 膨胀
kernel = np.ones((3, 3), np.uint8)
dilation = cv2.dilate(im,  # 图像
                      kernel,  # 膨胀核数
                      iterations=7)  # 迭代次数
cv2.imshow("dilation", dilation)

cv2.waitKey()
cv2.destroyAllWindows()

开运算

import cv2
import numpy as np

im1 = cv2.imread("../data/7.png")
im2 = cv2.imread("../data/8.png")

# 执行开运算
k = np.ones((10, 10), np.uint8)  # 计算核
r1 = cv2.morphologyEx(im1, cv2.MORPH_OPEN, k)
r2 = cv2.morphologyEx(im2, cv2.MORPH_OPEN, k)

cv2.imshow("im1", im1)
cv2.imshow("im2", im2)
cv2.imshow("r1", r1)
cv2.imshow("r2", r2)
cv2.waitKey()  # 等待用户按某个按键
cv2.destroyAllWindows()  # 销毁所有创建的窗口

 闭运算

import cv2
import numpy as np

im1 = cv2.imread("../data/9.png")
im2 = cv2.imread("../data/10.png")

# 执行开运算
k = np.ones((8, 8), np.uint8)  # 计算核
r1 = cv2.morphologyEx(im1, cv2.MORPH_CLOSE, k)
r2 = cv2.morphologyEx(im2, cv2.MORPH_CLOSE, k)

cv2.imshow("im1", im1)
cv2.imshow("im2", im2)
cv2.imshow("r1", r1)
cv2.imshow("r2", r2)
cv2.waitKey()  # 等待用户按某个按键
cv2.destroyAllWindows()  # 销毁所有创建的窗口

 形态学梯度

# 形态学梯度,膨胀的图像减腐蚀的图像
import cv2
import numpy as np

o = cv2.imread("../data/6.png")
k = np.ones((3, 3), np.uint8)  # 计算核
r = cv2.morphologyEx(o, cv2.MORPH_GRADIENT, k)  # 计算形态学梯度

cv2.imshow("o",o)
cv2.imshow("r",r)

cv2.waitKey()
cv2.destroyAllWindows()

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值