opencv初步学习——图像处理2

这一部分主要讲解如何初步地创建一个图像,以及彩色图像我们的一些基本处理方法

一、创建一个灰度图像

1-1、zeros()函数 [NumPy库]

要用到这一个函数,首先我们需要调用我们的NumPy库,这一个函数的作用是可以帮助我们生成一个元素值都是0的二维数组,如果我们把这些数据放到一张图片里面去,那么就对应着我们的一个黑色图像。当然我们也可以通过修改数组中的数字大小来改变图像的颜色(但还是灰度图像)

(1)构成

该函数的具体构成如下:

python 复制代码
numpy.zeros(shape, dtype=float, order='C')  

shape:即我们需要设置的二维数组(元组或者列表)的大小

dtype:即我们需要设置的元组里面的数据的类型,一般默认为float;当然我们也可以变为其他(比如我们的int,bool);当然实际在写的时候可以不写dtype = ~~

order:这个跟存储有关,暂且不做介绍(因为我也不知道哈)


1-2、生成

(1)正确示范:

python 复制代码
import cv2
import numpy as np

img = np.zeros((80,80),dtype=np.uint8)

img[40,40] = 255

cv2.imshow("one",img)
cv2.waitKey()
cv2.destroyAllWindows()

于是我们生成的图像如下:

可以看到我们在中间修改成了一个白点

此外我们也可以使用切片来帮助我们更好地进行操作

(2)可能会错误的操作

1、没有 np. 前缀

这个现象代码如下:

python 复制代码
img = np.zeros((80,80),uint8)

为什么直接写uint8不可以呢,因为python里面是没有内置这些数据类型的,这些数据类型只在NumPy里面有,所以如果我们想要去引用这些数据类型我们需要加上我们的np.前缀:(前面已经设置NumPy为np了)

python 复制代码
img = np.zeros((80,80),np.uint8)
2、直接使用int

这个现象的代码如下:

python 复制代码
img = np.zeros((80,80,80),dtype=int)

在 NumPy 里,int一般是指 np.int32 或者 np.int64(这取决于你的系统),不过 OpenCV 的 cv2.imshow 函数不支持 CV_32S(32 位有符号整数)这类数据类型用于图像显示。此函数要求输入的图像数据类型为 CV_8U(8 位无符号整数),也就是 np.uint8 类型。



二、彩色图像的简单处理

1-1、基础知识

在opencv中的彩色图像是以BGR模式的三维数组的形式进行存储的,例如:

python 复制代码
img = [0,0,0]

第一个0指第0行;第二个0指0列;第三个0指的是第0个颜色通道(B,蓝色)

0、1、2分别对应BGR(蓝色、绿色、红色)


1-2、简单的颜色修改

例如我们现在还是采用如下图片:

我们可以进行如下操作:

python 复制代码
import cv2
img = cv2.imread("D:\\photo\\mountain.png")

img[300:440 , 0:100 , 0:3] = 255

cv2.imshow("one",img)
cv2.waitKey()
cv2.destroyAllWindows()

由于我们现在是彩色图像采取的是BGR三通道,那么我们这里的操作就是把300行到440行,0列到100列的三个通道全部设置为255,即我们的每个像素点的三个通道的值为(255,255,255),那么就会变成白色。具体显示出来的结果如下;

当然我们还可以这么处理:

python 复制代码
import cv2
img = cv2.imread("D:\\photo\\mountain.png")

img[300:440 , 0:100 ] = (0,0,255)
img[300:440 , 100:200 ] = (0,255,0)
img[300:440 , 200:300 ] = (255,0,0)

cv2.imshow("one",img)
cv2.waitKey()
cv2.destroyAllWindows()

这样即对每一个在我们指定区域的像素点的BGR通道进行修改,结果如下:

总结:在彩色图像中,每一个像素点都有三个通道(BGR)


1-3、通道处理

(1)通道拆分

在我们的opencv中,我们可以通过索引把我们的三个通道全部提取出来:

python 复制代码
b = img[:,:,0]
g = img[:,:,1]
r = img[:,:,2]

此时如果我们再去用cv2.imshow()函数将其展现出来,得到的是灰度图像,因为此时你的b、g、r中的数据只是单个通道的数据了,而不是三个通道了,这里我们就不过多地去展示。

除了使用索引去拆分,我们还可以通过如下方式去拆分:

python 复制代码
b,g,r = cv2.split(img)  这里直接分配了

(2)通道合并

既然我们可以拆分,那么我们也肯定可以合并,我们需要用到这个函数:

python 复制代码
cv2.merge([b,g,r])

正如上所示,你只需要将每个通道按照上面的形式摆放就可以了,当然你也不排除你把它的顺序搞反了,那么我们就很难绷了

相关推荐
知识分享小能手4 分钟前
R语言入门学习教程,从入门到精通,R语言数据计算与分组统计(9)
开发语言·学习·r语言
山居秋暝LS18 分钟前
安装C++版opencv和opencv_contrib
开发语言·c++·opencv
lizhihai_9923 分钟前
股市学习心得—半导体12种核心材料
大数据·人工智能·学习
STLearner24 分钟前
SIGIR 2026 | LLM × Graph论文总结(图增强LLM,GraphRAG,Agent,多模态,知识图谱,搜索,推
人工智能·python·深度学习·神经网络·机器学习·数据挖掘·知识图谱
FreakStudio26 分钟前
MicroPython 内核开发者直接狂喜!这个 Claude 插件市场,把开发全流程做成了「对话式外挂」
python·单片机·嵌入式·面向对象·并行计算·电子diy
老陈说编程44 分钟前
12. LangChain 6大核心调用方法:invoke/stream/batch同步异步全解析,新手也能轻松学会
开发语言·人工智能·python·深度学习·机器学习·ai·langchain
给自己做减法1 小时前
rag混合检索
人工智能·python·rag
sakiko_1 小时前
UIKit学习笔记3-布局、滚动视图、隐藏或显示视图
前端·笔记·学习·objective-c·swift·uikit
嵌入式-老费2 小时前
瑞芯微soc的学习和应用(题外话之esp32开发)
学习
2301_812539672 小时前
Golang怎么实现网页爬虫抓取数据_Golang如何用colly框架快速构建爬虫采集程序【教程】
jvm·数据库·python