文章目录
data:image/s3,"s3://crabby-images/9050a/9050ac3f01ef20052edb5f96a0255e9e123e649f" alt=""
图像的加法运算
python
# -*- coding: utf-8 -*-
import cv2
import numpy as np
img = cv2.imread('E://pic//4.jpg')
# 图的加法运算就是矩阵的加法运算
# 因此,加法运算的两张图必须是相同的形状
# print(img.shape)
# (600, 480, 3)
img2 = np.ones((600, 480, 3), np.uint8) * 100
cv2.imshow('origin', img)
res = cv2.add(img, img2)
cv2.imshow('result', res)
key = cv2.waitKey(0) & 0xff
if key == ord('q'):
cv2.destroyAllWindows()
data:image/s3,"s3://crabby-images/f96e4/f96e45e4ea993177ca289ba09321c73bb43851f1" alt=""
图像的减法运算
data:image/s3,"s3://crabby-images/1ceeb/1ceebf442cae5e75fd276bf21e69d43f1d2b5ed3" alt=""
python
# -*- coding: utf-8 -*-
import cv2
import numpy as np
img = cv2.imread('E://pic//4.jpg')
# 图的加法运算就是矩阵的加法运算
# 因此,加法运算的两张图必须是相同的形状
# print(img.shape)
# (600, 480, 3)
img2 = np.ones((600, 480, 3), np.uint8) * 100
cv2.imshow('origin', img)
res = cv2.add(img, img2)
cv2.imshow('result', res)
img3 = cv2.subtract(res, img2)
cv2.imshow('origin2', img3)
key = cv2.waitKey(0) & 0xff
if key == ord('q'):
cv2.destroyAllWindows()
data:image/s3,"s3://crabby-images/5b28e/5b28e1e62b59e61b125b6176b130c4f76a4d436e" alt=""
python
# -*- coding: utf-8 -*-
import cv2
import numpy as np
img = cv2.imread('E://pic//4.jpg')
# 图的加法运算就是矩阵的加法运算
# 因此,加法运算的两张图必须是相同的形状
# print(img.shape)
# (600, 480, 3)
img2 = np.ones((600, 480, 3), np.uint8) * 100
cv2.imshow('origin', img)
res = cv2.add(img, img2)
cv2.imshow('result', res)
img3 = cv2.subtract(res, img2)
cv2.imshow('origin2', img3)
img3 = cv2.subtract(img, img2)
cv2.imshow('origin3', img3)
key = cv2.waitKey(0) & 0xff
if key == ord('q'):
cv2.destroyAllWindows()
可以看出,给一张图做加法运算,它可以变亮一些,做减法运算,可以变暗一些
图像的乘除运算
无非是让图片亮得更快一些和亮得更慢一些
图像的融合
data:image/s3,"s3://crabby-images/7d599/7d5996ae34725f7b772b5f4d7b34def429142ad3" alt=""
python
# -*- coding: utf-8 -*-
import cv2
import numpy as np
cv2.namedWindow('img', cv2.WINDOW_NORMAL)
back = cv2.imread('E://pic//Nurburgring_1920x1080.jpg')
superman = cv2.imread('E://pic//Man_Of_Steel_superman_superhero_____f_1920x1080.jpg')
# 只有两张图片的属性一样才可以融合
# print(back.shape)
# print(superman.shape)
# (1080, 1920, 3)
# (1080, 1920, 3)
res = cv2.addWeighted(superman, 0.7, back, 0.3, 0)
cv2.imshow('img', res)
key = cv2.waitKey(0) & 0xff
if key == ord('q'):
cv2.destroyAllWindows()
data:image/s3,"s3://crabby-images/74b7b/74b7bb70e72e226ead4fe10d2fcc7e9e909eae63" alt=""
OpenCV位运算-非操作
data:image/s3,"s3://crabby-images/24af7/24af7d695b4c09c97d9b6ae0097fcfb149e5752a" alt=""
python
# -*- coding: utf-8 -*-
import cv2
import numpy as np
img = np.zeros((200, 200), np.uint8)
img[50:150, 50:150] = 255
cv2.imshow('img', img)
key = cv2.waitKey(0) & 0xff
if key == ord('q'):
cv2.destroyAllWindows()
data:image/s3,"s3://crabby-images/0d332/0d3326b6798327c1d3e9ab760189b170b69fa8a3" alt=""
python
# -*- coding: utf-8 -*-
import cv2
import numpy as np
img = np.zeros((200, 200), np.uint8)
img[50:150, 50:150] = 255
new_img = cv2.bitwise_not(img)
cv2.imshow('img', img)
cv2.imshow('new_img', new_img)
key = cv2.waitKey(0) & 0xff
if key == ord('q'):
cv2.destroyAllWindows()
data:image/s3,"s3://crabby-images/bbae3/bbae31a291d724f1b029180b4628b82756385156" alt=""
OpenCV位操作-与运算
data:image/s3,"s3://crabby-images/067cf/067cf39e1a6cd46ed95074e42f18bb6b0360e0e4" alt=""
python
# -*- coding: utf-8 -*-
import cv2
import numpy as np
img = np.zeros((200, 200), np.uint8)
img2 = np.zeros((200, 200), np.uint8)
img[20:120, 20:120] = 255
img2[80:180, 80:180] = 255
# new_img = cv2.bitwise_not(img)
cv2.imshow('img', img)
cv2.imshow('img2', img2)
key = cv2.waitKey(0) & 0xff
if key == ord('q'):
cv2.destroyAllWindows()
data:image/s3,"s3://crabby-images/9be77/9be773224f738f2a1d4af597950be5ceaabac9a9" alt=""
python
# -*- coding: utf-8 -*-
import cv2
import numpy as np
img = np.zeros((200, 200), np.uint8)
img2 = np.zeros((200, 200), np.uint8)
img[20:120, 20:120] = 255
img2[80:180, 80:180] = 255
# new_img = cv2.bitwise_not(img)
new_img = cv2.bitwise_and(img, img2)
cv2.imshow('img', img)
cv2.imshow('img2', img2)
cv2.imshow('new_img', new_img)
key = cv2.waitKey(0) & 0xff
if key == ord('q'):
cv2.destroyAllWindows()
data:image/s3,"s3://crabby-images/cb585/cb5856499ed462615b3a0e657d3279d3055d365d" alt=""
OpenCV位操作-或与异或
data:image/s3,"s3://crabby-images/07617/076172e55927cbaf12bb57bd4ee760168aeb2023" alt=""
python
# -*- coding: utf-8 -*-
import cv2
import numpy as np
img = np.zeros((200, 200), np.uint8)
img2 = np.zeros((200, 200), np.uint8)
img[20:120, 20:120] = 255
img2[80:180, 80:180] = 255
# new_img = cv2.bitwise_not(img)
# new_img = cv2.bitwise_and(img, img2)
new_img = cv2.bitwise_or(img, img2)
new_img2 = cv2.bitwise_xor(img, img2)
cv2.imshow('img', img)
cv2.imshow('img2', img2)
cv2.imshow('new_img', new_img)
cv2.imshow('new_img2', new_img2)
key = cv2.waitKey(0) & 0xff
if key == ord('q'):
cv2.destroyAllWindows()
data:image/s3,"s3://crabby-images/35855/358550ed9d70a78e89e4b4b7ad4f49f8ef24e153" alt=""
为图像添加水印
python
# -*- coding: utf-8 -*-
import cv2
import numpy as np
#1. 引入一幅图片
#2. 要有一个LOGO,需要自己创建
#3. 计算图片在什么地方添加,在添加的地方变成黑色
#4. 利用add,将logo 与 图处叠加到一起
cv2.namedWindow('img', cv2.WINDOW_NORMAL)
superman = cv2.imread('E://pic//Man_Of_Steel_superman_superhero_____f_1920x1080.jpg')
# 创建水印
logo = np.zeros((200, 200, 3), np.uint8)
mask = np.zeros((200, 200), np.uint8)
# 绘制水印
logo[20:120, 20:120] = [0, 0, 255]
logo[80:180, 80:180] = [255, 255, 0]
mask[20:120, 20:120] = 255
mask[80:180, 80:180] = 255
# 对mask按位取反
m = cv2.bitwise_not(mask)
# 选择添加logo的位置
roi = superman[0:200, 0: 200]
# 和m进行按位与操作
# 因为roi是三通道,而m是单通道,不能直接相与
tmp = cv2.bitwise_and(roi, roi, mask=m)
dst = cv2.add(tmp, logo)
superman[0:200, 0:200] = dst
cv2.imshow('dst', dst)
cv2.imshow('tmp', tmp)
cv2.imshow('mask', mask)
cv2.imshow('logo', logo)
cv2.imshow('img', superman)
cv2.imshow('m', m)
key = cv2.waitKey(0) & 0xff
if key == ord('q'):
cv2.destroyAllWindows()
data:image/s3,"s3://crabby-images/0df2a/0df2adec6d8d380f932bd5bc577cb4f46f5b5b8a" alt=""
之后我会持续更新,如果喜欢我的文章,请记得一键三连哦,点赞关注收藏,你的每一个赞每一份关注每一次收藏都将是我前进路上的无限动力 !!!↖(▔▽▔)↗感谢支持!