opencv学习之图像的算术运算

图像加法:
cv2.add()将两幅图像进行加法运算,也可以直接使用numpy,res=img1+img2.两幅图像的大小,类型必须一致,或者第二个图像可以是一个简单的标量值。
openCV的加法是一种饱和操作,而numpy的加法是一种模操作。

import numpy as np
import cv2


x=np.uint8([250])
y=np.uint8([10])
print(cv2.add(x,y))#250+10=260>=255
#结果为[[255]]
print (x+y)#250+10=260%255=4

图像混合:
cv2.addWeighted()

import numpy as np
import cv2


img1=cv2.imread("1.jpg")
img2=cv2.imread("fish.jpg")

dst=cv2.addWeighted(img1,0.3,img2,0.7,0)
cv2.imshow("image",dst)
cv2.waitKey(0)
cv2.destroyAllWindows

注意:
在图像的加法与混合中,图片尺寸大小应该一样。

按位运算:
这里包括按位操作有:AND,OR,NOT,XOR等,当我们提取图像的一部分,选择非矩形ROI时,会很有用(下章)。下面进行如何改变一幅图的特定区域。

import cv2
import numpy as np
import matplotlib.pyplot as plt
img1=cv2.imread('1.jpg')
img2=cv2.imread('2.jpg')
 
plt.subplot(231),plt.axis("off"),plt.imshow(img1)
plt.subplot(232),plt.axis("off"),plt.imshow(img2)
 
# I want to put logo on top-left corner, So I create a ROI
rows,cols,channels = img2.shape
roi = img1[0:rows,0:cols]
 
# Now create a mask of logo and create its inverse mask also
img2gray = cv2.cvtColor(img2,cv2.COLOR_BGR2GRAY)
ret,mask = cv2.threshold(img2gray,175,255,cv2.THRESH_BINARY)
mask_inv = cv2.bitwise_not(mask)
 
# Now black-out the area of logo in ROI
#取ROI中与mask中不为零的值对应的像素的值,其让值为0 。
#注意这里必须有mask=mask或者mask=mask_inv,其中mask=不能忽略
img1_bg = cv2.bitwise_and(roi,roi,mask=mask)
#取roi中与mask_inv中不为零的值对应的像素的值,其他值为0
# Take only region of logo from logo image.
img2_fg = cv2.bitwise_and(img2,img2,mask=mask_inv)
 
# Put logo in ROI and modify the main image
dst = cv2.add(img1_bg,img2_fg)
img1[0:rows,0:cols] =dst
 
plt.subplot(233),plt.axis("off"),plt.imshow(img1)
plt.subplot(234),plt.axis("off"),plt.imshow(img2)
plt.subplot(235),plt.axis("off"),plt.imshow(dst)
cv2.waitKey(0)
cv2.destroyAllWindows()

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值