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的权重对图片进行相加
相关推荐
格林威1 分钟前
UV紫外相机的简单介绍和场景应用
人工智能·数码相机·计算机视觉·视觉检测·制造·uv·工业相机
番石榴AI37 分钟前
自己动手做一款ChatExcel数据分析系统,智能分析 Excel 数据
人工智能·python·数据挖掘·excel
laopeng30140 分钟前
基于Spring AI Deep Researcher Agent
java·人工智能·spring
lzptouch1 小时前
数据预处理(音频/图像/视频/文字)及多模态统一大模型输入方案
人工智能·音视频
星期天要睡觉1 小时前
深度学习——循环神经网络(RNN)
人工智能·python·rnn·深度学习·神经网络
jieba121381 小时前
CAA机器学习
人工智能
TextIn智能文档云平台1 小时前
LLM 文档处理:如何让 AI 更好地理解中文 PDF 中的复杂格式?
人工智能·pdf
Blossom.1181 小时前
把AI“撒”进农田:基于极值量化与状态机的1KB边缘灌溉决策树
人工智能·python·深度学习·算法·目标检测·决策树·机器学习
takashi_void1 小时前
本地实现斯坦福小镇(利用大语言模型使虚拟角色自主发展剧情)类似项目“Microverse”
人工智能·语言模型·自然语言处理·godot·游戏程序·斯坦福小镇
zxsz_com_cn2 小时前
设备健康管理大数据平台:工业智能化的核心数据引擎
运维·人工智能