opencv 之图像的边界填充及一些数据计算

图像的边界填充就是在图像的皱纹填充一些东西,使得图像中间的内容更靠近中间

import cv2
import matplotlib.pyplot as plt

img = cv2.imread('test.png')
a = b = c = d = 50
# 这里用a ,b ,c ,d分别表示上下左右要填充的宽度

replicate = cv2.copyMakeBorder(img, a, b, c, d, borderType=cv2.BORDER_REPLICATE)
reflect = cv2.copyMakeBorder(img, a, b, c, d, borderType=cv2.BORDER_REFLECT)
reflect101 = cv2.copyMakeBorder(img, a, b, c ,d, borderType=cv2.BORDER_REFLECT_101)
wrap = cv2.copyMakeBorder(img, a, b, c, d, borderType=cv2.BORDER_WRAP)
constant = cv2.copyMakeBorder(img, a, b, c, d, cv2.BORDER_CONSTANT, value=0)

plt.subplot(231), plt.imshow(img, 'gray'), plt.title('original')
plt.subplot(232), plt.imshow(replicate, 'gray'), plt.title('replicate')
plt.subplot(233), plt.imshow(reflect, 'gray'), plt.title('reflect')
plt.subplot(234), plt.imshow(reflect101, 'gray'), plt.title('reflet101')
plt.subplot(235), plt.imshow(wrap, 'gray'), plt.title('wrap')
plt.subplot(236), plt.imshow(constant, 'gray'), plt.title('constant')

plt.show()

上边分别用五种填充方式展示了边缘填充的效果,效果如下
在这里插入图片描述
这五种

  1. replicate 表示的是边界赋值,你可以看到填充的基本就是把边缘复制了一下
  2. reflect 则是反射了,可以看到轴对称过去的部分,反射效果 cba | abc | cba
  3. reflect101这种反射和上边一种稍有区别 反射效果 cb | abc | ba
  4. wrap 外包装法,简单说就是 cdefg | abcdefg | abcde
  5. constant 则是常亮填充,比如本例子则使用的value= 0就是纯黑色来填充

除了边界填充,还有一些常用的数值计算,比如

  1. 我们让一个图片加上一个数,就是图片的每一个像素块的值加上一个数,如果超过255那么就用结果 % 256 得到的余数就是像素值
  2. 一个图片加上另一个图片,前提,俩图片的维度是一模一样的才可以进行相加,如果超出255,那么就是进行求余操作
  3. cv2.add(img1, img2)
    俩图片像素值相加,如果超过255,那么结果就是255
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值