OpenCV图像算术位运算

一 图像相加

cpp 复制代码
import cv2
import numpy as np

girl=cv2.imread('./2037548.jpg')

#图像的加法运算就是矩阵的加法运算
#因此加法运算的两张图必须是相等的

print(girl.shape)

img=np.ones((1920,1080,3),np.uint8)*50
cv2.imshow('girl',girl)
result=cv2.add(girl,img)
cv2.imshow('result',result)
cv2.waitKey(0)

二 图像减法运算

subtract(A,B)

含义是A减B

cpp 复制代码
import cv2
import numpy as np

girl=cv2.imread('./2037548.jpg')

#图像的加法运算就是矩阵的加法运算
#因此加法运算的两张图必须是相等的

print(girl.shape)

img=np.ones((1920,1080,3),np.uint8)*50
cv2.imshow('girl',girl)
result=cv2.subtract(girl,img)
cv2.imshow('result',result)
cv2.waitKey(0)

三 图像的融合

addWeigthed(A,alpha,B,bate,gamma)

alpha和beta是权重

gamma 静态权重

四 图像位运算

cpp 复制代码
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)

cv2.waitKey(0)

五 图像的与运算

cpp 复制代码
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[50:150,50:150]=255

new_img=cv2.bitwise_and(img,img2)

cv2.imshow('img',img)

cv2.imshow('new_img',new_img)

cv2.waitKey(0)

六 图像的或与异或运算

bitwise_or(img1,img2)

bitwise_xor(img1,img2)

总结 添加水印

cpp 复制代码
# 引入一副图片
# 要有一个Logo,需要自己创建
# 水印添加,在什么地方添加,在添加的地方变成黑色
# 利用add 将logo 与图形叠加到一起

import cv2
import numpy as np

girl=cv2.imread('./2037548.jpg')

# 创建LOGO
logo=np.zeros((200,200,3),np.uint8)
mask=np.zeros((200,200),np.uint8)

# 绘制LOGO
logo[20:120,20:120]=[0,0,255]
logo[80:180,80:180]=[0,255,0]

mask[20:120,20:120]=255
logo[80:180,80:180]=255

# 对mask按位取反
m=cv2.bitwise_not(mask)

# 选择girl添加logo的位置
roi=girl[0:200,0:200]

# 与m进行操作
tmp=cv2.bitwise_and(roi,roi,mask=m)
dst=cv2.add(tmp,logo)

girl[0:200,0:200]=dst

cv2.imshow('girl',girl)
#cv2.imshow('tmp',tmp)
#how('mask',mask)
#cv2.imshow('logo',logo)
cv2.waitKey(0)
相关推荐
ConardLi10 分钟前
MCP + 数据库,一种比 RAG 检索效果更好的新方式!
javascript·数据库·人工智能
火车叼位11 分钟前
初中生也能懂的贝叶斯定理:拆解一个改变世界的公式
人工智能·数学·算法
小白的高手之路12 分钟前
torch.nn中的非线性激活介绍合集——Pytorch中的非线性激活
人工智能·pytorch·python·深度学习·神经网络·机器学习·cnn
视觉语言导航14 分钟前
华东师范地面机器人融合空中无人机视角的具身导航!KiteRunner:语言驱动的户外环境合作式局部-全局导航策略
人工智能·深度学习·机器人·无人机·具身智能
是娜个二叉树!25 分钟前
听课笔记-nlp
人工智能·笔记·自然语言处理
秣厉科技26 分钟前
【秣厉科技】LabVIEW工具包——OpenCV 教程(18):highgui 模块
科技·opencv·labview
galileo201636 分钟前
多智能体优秀开发框架
人工智能
DUTBenjamin1 小时前
计算机视觉5——运动估计和光流估计
人工智能·计算机视觉
HNU混子1 小时前
手搓多模态-03 顶层和嵌入层的搭建
python·机器学习·计算机视觉
HuggingFace2 小时前
Open R1 项目进展第三期
人工智能