python-图像边缘化处理

本文由本人原创,仅作为自己的学习记录

主要利用Sobel,用作边缘检测,它是一离散性差分算子,用来运算图像亮度函数的灰度值。在图像的任何一点使用此算子,将会产生对应的灰度矢量或是其法矢量。

Sobel边缘检测通常带有方向性,可以只检测竖直边缘或垂直边缘或都检测。

本文先对图片进行大小处理,使得都是一个大小的图片

然后从XY两个方向检测,然后利用addweight进行图像混合

然后设置阈值,进行图像二值化处理,本,文中设置的是100,如果原灰度值大于100,把灰度值设为0(黑色),因为边缘为白色要变成黑色,如果小于100,设为255(白色)THRESH_BINARY_INV(二值化取反)

下面是代码

#coding=utf-8  
import cv2 as cv
import os
import matplotlib.pyplot as plt

def set_img_size(path,file):
    src_img = cv.imread(file, cv.IMREAD_GRAYSCALE)
    dst_img= cv.resize(src_img,(220,350))
    cv.imwrite(path+'\\2_tmp.jpg',dst_img)
    return path+'\\2_tmp.jpg'
if __name__=="__main__":
    path=os.getcwd()
    file = path+'\\2.jpg'
    file_name = set_img_size(path,file)
    sobel_img = cv.imread(file_name, cv.IMREAD_GRAYSCALE)
    
    x= cv.Sobel(sobel_img,cv.CV_16S,1,0)#x方向边缘检测
    y= cv.Sobel(sobel_img,cv.CV_16S,0,1)
    #x,y方向分辨转换为uint8(8位无符号)类型
    ux = cv.convertScaleAbs(x)
    uy = cv.convertScaleAbs(y)
    #x,y合并
    sb_img = cv.addWeighted(ux,0.5,uy,0.5,0)
    
    #设置阈值,如果原值大于100,设为0,因为边缘为白色要变成黑色,如果小于100,设为255ֵ
    retval,sb_img = cv.threshold(sb_img,100,255.0, cv.THRESH_BINARY_INV)
    
    cv.imshow("result",sb_img)
    #cv.waitKey(0)  
    cv.destroyAllWindows()
    cv.imwrite(path+'\\2_result.jpg',sb_img)

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值