OpenCV的基础操作

OenCV的一些基础操作

  • 1.将图片转换为灰度图
  • 2.图片裁剪
  • 3.图片打码
  • 4.图片组合
  • 5.图片相加
    • [5.1 对一张图片整体像素值相加](#5.1 对一张图片整体像素值相加)
    • [5.2 对两张图片的像素值相加](#5.2 对两张图片的像素值相加)
    • [5.3 使用cv2.add( )函数对两张图片进行相加](#5.3 使用cv2.add( )函数对两张图片进行相加)
    • [5.4 对图片进行加权运算](#5.4 对图片进行加权运算)

1.将图片转换为灰度图

python 复制代码
import cv2
image = cv2.imread('qi e.png')#读取原图
image_gray = cv2.cvtColor(image,cv2.COLOR_BGR2GRAY)#灰度图的处理
cv2.imshow('gray',image_gray)

这里我们读取一张企鹅图片,运行结果如下,左图为原图,右图为灰度图

2.图片裁剪

python 复制代码
a = cv2.imread(r'qi e.png')
b = a[40:260,350:600]  
cv2.imshow('yuantu',a)
cv2.imshow('qiepian',b)
cv2.waitKey(0)
cv2.destroyAllWindows()
  • b = a[40:260,350:600] 这段代码是指在图片a中的 40-259 行、350-599 列这个范围的图片裁剪下来。运行结果如下:

3.图片打码

python 复制代码
import cv2
import numpy as np

a = cv2.imread(r'1.jpg')
a[100:200,200:300] = np.random.randint(0,256,(100,100,3))  
cv2.imshow('masaike',a)
cv2.waitKey(1000000)
cv2.destroyAllWindows()
  • a[100:200,200:300] = np.random.randint(0,256,(100,100,3)) 这段代码是指在图片a中选取了行索引从 100 到 199(共100行),列索引从 200 到 299(共100列)的区域。并且在这区域内生成一个随机数组,数值范围是 [0, 256)(即0到255,适合表示像素值)。数组的形状是 (100, 100, 3),即100行、100列、3个通道(RGB)。这个随机数组会覆盖 a 的切片区域。
  • 运行结果如下:

4.图片组合

python 复制代码
import cv2
import numpy as np
# 图片组合
a = cv2.imread('1.png')
b = cv2.imread('qi e.png')
b[200:350,200:350] = a[50:200,100:250]  #注意:矩阵的大小必须要统一
cv2.imshow('b',b)
cv2.imshow('a',a)
cv2.waitKey(0)
cv2.destroyAllWindows()
  • b[200:350,200:350] = a[50:200,100:250] 这段代码是指将图片 a 中的 50 到 199行(共150行)、 100 到 249(共150列)的区域覆盖到 b 中的200 到 349行(共150行)、 200 到 349(共150列)。并且这个区域上组合区域的矩阵大小必须要统一
  • 图片 b 还是企鹅图片
  • 图片 a 如下:
  • 图片a与b的组合:

5.图片相加

5.1 对一张图片整体像素值相加

python 复制代码
import cv2
a = cv2.imread('qi e.png')
c = a+10
cv2.imshow('yuan',a)
cv2.imshow('a+10',c)
cv2.waitKey(0)
  • 这段代码是对图片 a 中的所有区域像素值进行加 10 的操作,得到 c
  • 如下是运行结果:

5.2 对两张图片的像素值相加

python 复制代码
import cv2
a = cv2.imread('qi e.png')
b = cv2.imread('1.jpg')
c = a[50:450,50:400]+b[50:450,50:400]
cv2.imshow('a+b',c)
cv2.waitKey(0)
  • 两张图片相加的区域中矩阵大小必须统一
  • 下图是图片 a 与图片 b 的相加结果:

5.3 使用cv2.add( )函数对两张图片进行相加

python 复制代码
a = cv2.imread('qi e.png')
b = cv2.imread('1.jpg')
b = cv2.resize(b,(400,400))
a = cv2.resize(a,(400,400))
c = cv2.add(a,b)  #也可以这样使用
cv2.imshow('a add b',c)
cv2.waitKey(0)
cv2.destroyAllWindows()
  • 对于cv2.add()运算,当对图像a,图像b进行加法求和时,遵循以下规则:当某位置像素相加得到的数值小于255时,该位置数值为两图像该位置像素相加之和 当某位置像素相加得到的数值大于255时,该位置数值为255。
  • 下图是结果:

5.4 对图片进行加权运算

python 复制代码
a = cv2.imread('qi e.png')
b = cv2.imread('1.jpg')
b = cv2.resize(b,(400,400))
a = cv2.resize(a,(400,400))

c = cv2.addWeighted(a,0.2,b,0.8,10) #
cv2.imshow('addWrighted',c)
cv2.waitKey(0)
cv2.destroyAllWindows()
  • 图片加权运算就是在计算两幅图像的像素值之和时,对两幅图像的权重考虑进来,可以用公式表示为dst = src1×a+src×b+y
  • 可以通过调整a和b的权重对图片进行相加
相关推荐
阿里云大数据AI技术3 分钟前
【AAAI2026】阿里云人工智能平台PAI视频编辑算法论文入选
人工智能
玄同7654 分钟前
我的 Trae Skill 实践|使用 UV 工具一键搭建 Python 项目开发环境
开发语言·人工智能·python·langchain·uv·trae·vibe coding
苍何26 分钟前
腾讯重磅开源!混元图像 3.0 图生图真香!
人工智能
千里马也想飞29 分钟前
人工智能在医疗领域的应用与研究论文写作实操:AI辅助快速完成框架+正文创作
人工智能
Rorsion34 分钟前
PyTorch实现二分类(单特征输出+单层神经网络)
人工智能·pytorch·分类
勾股导航41 分钟前
K-means
人工智能·机器学习·kmeans
liliangcsdn42 分钟前
Diff2Flow中扩散和流匹配的对齐探索
人工智能
SmartBrain1 小时前
战略洞察:以AI为代表的第四次工业革命
人工智能·语言模型·aigc
一个处女座的程序猿1 小时前
AI之Agent之VibeCoding:《Vibe Coding Kills Open Source》翻译与解读
人工智能·开源·vibecoding·氛围编程
Jay Kay1 小时前
GVPO:Group Variance Policy Optimization
人工智能·算法·机器学习