weixin_44512976 2020-09-20 15:09 采纳率: 100%
浏览 143
已采纳

关于opencv()中的腐蚀操作,我操作过后会让原来的圆变形,怎么让圆腐蚀后不变形依旧保持圆形?

代码:
import cv2 as cv
import numpy as np
pie=cv.imread('d:/pic/pie.png')
kernel=np.ones((7,7),np.uint8)
dilate=cv.dilate(pie,kernel,iterations=10)
erosion=cv.erode(pie,kernel,iterations=10)
res=np.hstack((pie,dilate,erosion))
cv.imshow('res',res)
cv.waitKey(0)
cv.destroyAllWindows()

结果:图片说明

  • 写回答

2条回答 默认 最新

  • 艾尔_1222 2020-09-21 05:46
    关注

    这个原因是对于圆形的物体使用正方形的核去做膨胀和腐蚀就会变的像四边形,只要修改kernel变成圆形就好了;

    import cv2 as cv
        import numpy as np
        import math
    
        pie = cv.imread('0000.png')
        kernel = np.ones((7, 7), np.uint8)
        kernel_re = []
        rows, cols = kernel.shape
        for i in range(rows):
            result = [0 if math.sqrt((i-3)**2+(j-3)**2) > 3 else 1 for j in range(cols)]
            kernel_re.append(result)
        kernel_re = np.array(kernel_re, np.uint8)
        print(kernel_re, kernel)
        print(type(kernel_re), type(kernel))
        print(kernel_re.shape, kernel.shape)
        dilate = cv.dilate(pie, kernel, iterations=10)
        erosion = cv.erode(pie, kernel_re, iterations=10)
        res = np.hstack((pie, dilate, erosion))
        cv.imshow('res', res)
        cv.waitKey(0)
        cv.destroyAllWindows()
    

    图片说明

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)
编辑
预览

报告相同问题?

悬赏问题

  • ¥15 MATLAB解决问题
  • ¥20 哪位专业人士知道这是什么原件吗?哪里可以买到?
  • ¥15 关于#c##的问题:treenode反序列化后获取不到上一节点和下一节点,Fullpath和Handle报错
  • ¥15 一部手机能否同时用不同的app进入不同的直播间?
  • ¥15 没输出运行不了什么问题
  • ¥20 输入import torch显示Intel MKL FATAL ERROR,系统驱动1%,: Cannot load mkl_intel_thread.dll.
  • ¥15 点云密度大则包围盒小
  • ¥15 nginx使用nfs进行服务器的数据共享
  • ¥15 C#i编程中so-ir-192编码的字符集转码UTF8问题
  • ¥15 51嵌入式入门按键小项目