【OpenCv-Python】七、Arithmetic Operations on Images

图像上的算数运算

目标

  • 学习图像上的算术 算 加法 减法 位 算等。
  • 我们将 学习的函数有 cv2.add() cv2.addWeighted() 等。

7.1 图像加法

你可以使用OpenCv中的函数 cv2.add() 将两幅图像进行加法运算,当然也可以直接使用 numpy,如 res=img1+img。两幅图像的大小类型必 一致 或者第二个图像可以使一个简单的标量值。

注意

OpenCV 中的加法与 Numpy 的加法是有所不同的。OpenCV 的加法是一种饱和操作,而 Numpy 的加法是一种模操作。

例如,思考以下示例:

x = np.uint8([250])
y = np.uint8([10])

print (cv2.add(x,y)) # 250+10 = 260 => 255
[[255]]

print (x+y)         # 250+10 = 260 % 256 = 4
[4]

这种差别在你对两幅图像进行加法时会更加明显。OpenCV 的结果会更好一点。所以我们尽量使用 OpenCV 中的函数。

7.2 图像混合

其实也是加法,但是不同的是两幅图像的权重不同 ,就会给人一种混
合或者透明的感觉。图像混合的运算公式如下:

g(x) = (1 - \alpha)f_{0}(x) + \alpha f_{1}(x)

修改 α 的值(0 → 1 )可以实现非常酷的混合。
现在我们把两幅图混合在一起。第一幅图的权重是 0.7 第二幅图的权重是 0.3。函数 cv2.addWeighted() 可以按下面的公式对图片进行混合操作。

dst = \alpha \cdot img1 + \beta \cdot img2 + \gamma

这里γ 的取值为 0。

img1 = cv2.imread('ml.png')
img2 = cv2.imread('opencv_logo.jpg')

dst = cv2.addWeighted(img1,0.7,img2,0.3,0)

cv2.imshow('dst',dst)
cv2.waitKey(0)
cv2.destroyAllWindows()

7.3 按位运算

包括的按位操作有:AND OR NOT XOR 等。当我们提取图像的一部分选择非矩形 ROI 时这些操作会很有用(下一章你就会明白)。下面的例子就是教给我们如何改变一幅图的特定区域。
我想把 OpenCV 的标志放到另一幅图像上。如果我使用加法颜色会改变,如果使用混合,会得到透明效果,但是我不想透明。如果他是矩形我可以像上一章一样使用 ROI。但是他不是矩形。但是我们可以通过下面的按位运算实现

# 加载两张图片
img1 = cv2.imread('messi5.jpg')
img2 = cv2.imread('opencv_logo.png')

# 我想将logo 放到图片的左上角, 所以我创建一个 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, 10, 255, cv2.THRESH_BINARY)
mask_inv = cv2.bitwise_not(mask)

# Now black-out the area of logo in ROI
img1_bg = cv2.bitwise_and(roi,roi,mask = mask_inv)

# Take only region of logo from logo image.
img2_fg = cv2.bitwise_and(img2,img2,mask = mask)

# Put logo in ROI and modify the main image
dst = cv2.add(img1_bg,img2_fg)
img1[0:rows, 0:cols ] = dst

cv2.imshow('res',img1)
cv2.waitKey(0)
cv2.destroyAllWindows()

阅读更多

扫码向博主提问

去开通我的Chat快问

vcx08

非学,无以致疑;非问,无以广识
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/vcx08/article/details/79074086
所属专栏: OpenCv-Python 中文手册
上一篇【OpenCv-Python】六、Basic Operations on Images
下一篇【OpenCv-Python】八、Performance Measurement and Improvement Techniques
想对作者说点什么? 我来说一句

蒙哥马利求模逆

2017年09月29日 236KB 下载

Opencv-Python教程

2017年01月26日 4.48MB 下载

没有更多推荐了,返回首页

关闭
关闭