Python的Open CV学习四

Python的Open CV学习一(准备工作)https://blog.csdn.net/m0_55868453/article/details/122823865Python的Open CV学习二(显示图片)https://blog.csdn.net/m0_55868453/article/details/122826126Python的Open CV学习三(显示视频和摄像头图像)https://blog.csdn.net/m0_55868453/article/details/122848220今天我们学习可将其图片转换为灰度图、模糊图、边缘检测图、膨胀图、变薄图;并且显示图片大小并且改变图片大小和裁剪大小

第一步:导入cv2库

#导入CV2库q
import cv2.cv2 as cv2

第二步:导入图片

#将图片导入
img = cv2.imread('mofang2.jpg')

第三步:使用cv2.cvtColor()将其图片转换想要的类型

#将彩色图像转换为灰度图像   原图像   指定转换类型(将bgr转换为灰度图)
imgGray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)

第四步:显示图片

#展示图片
cv2.imshow('Gray Image',imgGray)    #显示灰度图
cv2.waitKey(0)

 如法炮制,如果想将其图片进行模糊处理或者边缘检测则用下面的cv2.GaussianBlur()和 cv2.Canny()函数来得到自己想要的

#导入CV2库q
import cv2.cv2 as cv2

#将图片导入
img = cv2.imread('mofang2.jpg')

#将其进行模糊处理  ossian模糊函数  图像  高斯内核大小(得是正数或者奇数) 高斯核标准偏差(其中xy设置为0)
imgBlur =cv2.GaussianBlur(img,(9,9),0)
#将运用canny函数进行边缘检测器  后面为阈值
imgCanny = cv2.Canny(img,50,50)


cv2.imshow('Blur Image',imgBlur)    #显示模糊图
cv2.imshow('Canny Image',imgCanny)  #显示边缘化图
cv2.waitKey(0)

但是如果我们想要将其图像边缘变厚变薄则需要设置矩阵,得添加numpy库,然后我们再使用cv2.dilate()函数来对边缘进行膨胀,使用cv2.erode()进行变薄

#导入CV2库q
import cv2.cv2 as cv2
#导入numpy库
import numpy as np

#将图片导入
img = cv2.imread('mofang2.jpg')
#定义矩阵大小5*5 无符号
kernel = np.ones((3,3),np.uint8)

#将运用canny函数进行边缘检测器  后面为阈值
imgCanny = cv2.Canny(img,50,50)
#将其图像进行膨胀 需要定义矩阵大小的值[图像  方框大小  迭代次数 ]
imgDialation = cv2.dilate(imgCanny,kernel,iterations=1)
#将其图像进行变薄[图像  方框大小  迭代次数 ]
imgEroded = cv2.erode(imgDialation,kernel,iterations=1)

cv2.imshow('Dialation image',imgDialation)  #显示膨胀图像
cv2.imshow('Eroded image',imgEroded)  #显示变薄图像
cv2.waitKey(0)

如果想要改变图片大小或者裁剪图片,可以使用cv2.resize()改变图片整体大小,裁剪图片可用img[0:250,0:250]来指定想要裁剪的位置

"""
功能:显示图片大小并且改变图片大小和裁剪大小
"""

#导入CV2库q
import cv2.cv2 as cv2

#读取图片,并显示大小
img = cv2.imread('mofang2.jpg')
print(img.shape)
#改变图像大小
imgResize = cv2.resize(img,(300,300))
print(imgResize.shape)

imgCropped = img[0:250,0:250]

cv2.imshow('Image',img)
cv2.imshow('imgResize Image',imgResize)
cv2.imshow('imgCropped Image',imgCropped)

cv2.waitKey(0)

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值