图像数字化基础

一、像素
1、获取图像指定位置的像素
import cv2
image = cv2.imread("E:\\images\\2.png")
px = image[291,218]
print("坐标(291,218)上的像素的BGR值是:",px)
(1)RGB色彩空间
  • R通道:红色通道

  • G通道:绿色通道

  • B通道:蓝色通道

(2)RGB的表示

通常使用一个三维数组来表示一幅图像中某一个像素的RGB值

(3)RGB图像

RGB图像时指用RGB色彩空间显示的图像,BGR图像是指使用BGR色彩空间显示的图像;RGB色彩空间和

BGR色彩空间的区别是图像在RGB色彩空间中的通道顺序是R->G->B,在BGR的色彩空间中的通道顺序是

B->G-R

2、修改像素的BGR值

对于RGB/BGR图像,当每个像素的R、G、B这3个值相等时,就可以得到灰度图像。其中。

R=G=B=0(B=G=R=0)为纯黑色;R=G=B=255(B=G=R=255)为纯白色

import cv2image = cv2.imread("E:/images/2.png")
cv2.imshow("2",image)for i in range(241,292):for j in range(168,219):image[i,j] = [255,255,255]cv2.imshow("3",image)
cv2.waitKey()
cv2.destroyWindow()
二、色彩空间
1、GRAY色彩空间
  • GRAY色彩空间通常指的是灰度图像,灰度图像是一种每个像素都是从黑到白,被处理为256个灰度级别的单

色图像。这256个灰度级别分别用区间[0,255]中的数值表示。其中“0”表示纯黑色,“255”表示纯白色,0~255之间

的数值表示不同的亮度(即色彩的深浅程度)的深灰色或浅灰色。因此,一幅灰度图像能够展示丰富的细节信息。

  • 从RGB/BGR色彩空间转换到GRAY色彩空间

dst  =  cv2.cvtColor(src,code)dst:转换后的图像src:转换前的初始图像code:色彩空间转换码
色彩空间转换码含义
cv2.COLOR_BGR2GRAY从BGR色彩空间转换到GRAY色彩空间
cv2.COLOR_RGB2GRAY从RGB色彩空间转换到GRAY色彩空间
import cv2image = cv2.imread("E:/images/2.png")
cv2.imshow("2.1",image)#将图像2.png从BGR色彩空间转换到GRAY色彩空间
gray_image = cv2.cvtColor(image,cv2.COLOR_BGR2GRAY)
cv2.imshow("GRAY",gray_image)
cv2.waitKey()
cv2.destroyWindow()
2、HSV色彩空间
  • HSV色彩空间是基于色调、饱和度和亮度而言的。其中,色调(H)是指光的颜色。在OpenCV中,色调在区间【0,180】内取值。例如,代表红色、黄色、绿色和蓝色的色调值分别为0、30、60和120

  • 从RGB/BGR色彩空间转换到HSV色彩空间

色彩空间转换码含义
cv2.COLOR_BGR2HSV从BGR色彩空间转换到HSV色彩空间
cv2.COLOR_RGB2HSV从RGB色彩空间转换到HSV色彩空间
import cv2image = cv2.imread("E:/images/2.png")
cv2.imshow("2.1",image)#将图像2.png从BGR色彩空间转换到GRAY色彩空间
hsv_image = cv2.cvtColor(image,cv2.COLOR_BGR2HSV)
cv2.imshow("HSV",hsv_image)
cv2.waitKey()
cv2.destroyWindow()
三、通道
1、拆分通道
  • 拆分一幅BGR图像中的通道
b,g,r = cv2.split(bgr_image)
参数说明:b:B通道图像g:G通道图像r: R通道图像bgr_image:一幅BGR图像 
import cv2bgr_image = cv2.imread("E:/images/2.png")
cv2.imshow("2.1",bgr_image)b,g,r = cv2.split(bgr_image)
cv2.imshow("B",b)
cv2.imshow("G",g)
cv2.imshow("R",r)cv2.waitKey()
cv2.destroyWindow()
  • 拆分一幅HSV图像中的通道
h,s,v = cv2.split(hsv_image)
参数说明:h:H通道图像s:S通道图像v:V通道图像hsv_image:一幅HSV图像 
import cv2bgr_image = cv2.imread("E:/images/avatar.png")
cv2.imshow("2.1",bgr_image)#把图2.1从BGR色彩空间转换到HSV色彩空间
hsv_image = cv2.cvtColor(bgr_image,cv2.COLOR_BGR2HSV)
h,s,v = cv2.split(hsv_image)
cv2.imshow("H",h)
cv2.imshow("S",s)
cv2.imshow("V",v)cv2.waitKey()
cv2.destroyWindow()
2、合并通道

合并通道是拆分通道的逆操作

  • 合并B、G、R通道图像

bgr = cv2.merge([b,g,r])
参数说明:bgr:按B->G->R的顺序合并通道后得到的图像r:R通道图像g:G通道图像b:B通道图像注意:合并通道的顺序不同,图像的显示效果也不同
import cv2bgr_image = cv2.imread("E:/images/avatar.png")
cv2.imshow("2.1",bgr_image)b,g,r = cv2.split(bgr_image) #拆分图2.1中的通道bgr = cv2.merge([b,g,r]) #按B->G->R的顺序合并通道
cv2.imshow("BGR",bgr)rgb = cv2.merge([r,g,b]) #按R->G->B的顺序合并通道
cv2.imshow("RGB",rgb)cv2.waitKey()
cv2.destroyWindow()
  • 合并H、S、V通道图像
hsv = cv2.merge([h,s,v])
参数说明:hsv:合并H通道图像、S通道图像和V通道图像后得到的图像h:H通道图像s:S通道图像v:V通道图像 
import cv2bgr_image = cv2.imread("E:/images/avatar.png")
cv2.imshow("avatar.png",bgr_image)
#把图像avatar.png从RGB色彩空间转换到HSV色彩空间
hsv_image = cv2.cvtColor(bgr_image,cv2.COLOR_BGR2HSV)
h,s,v = cv2.split(hsv_image) #拆分HSV图像中的通道
hsv = cv2.merge([h,s,v]) #合并拆分后的通道图像
cv2.imshow("HSV",hsv) #显示合并通道的HSV图像cv2.waitKey()
cv2.destroyWindow()
3、alpha通道

BGR色彩空间包含3个通道,即B通道、G通道、R通道。OpenCV在这3个通道的基础上增加了一个A通道,即alpha通道,用于设置图像的透明度。alpha通道在区间【0,255】内取值;其中,0表示透明,255表示不透明

import cv2bgr_image = cv2.imread("E:/images/avatar.png")
cv2.imshow("2.1",bgr_image)#把图像2.1从BGR色彩空间转换到BGRA色彩空间
bgra_image = cv2.cvtColor(bgr_image,cv2.COLOR_BGR2BGRA)
cv2.imshow("BGRA",bgra_image) #显示BGRA图像
r,g,b,a = cv2.split(bgra_image)
a[:,:] = 172
bgra_172 = cv2.merge([r,g,b,a])
a[:,:] = 0
bgra_0 = cv2.merge([r,g,b,a])cv2.imshow("A = 172",bgra_172)
cv2.imshow("A = 0",bgra_0)cv2.waitKey()
cv2.destroyWindow()
四、使用NumPy模块操作像素
1、NumPy概述

NumPy提供了一个高性能的数组对象,可以轻松创建一维数组、二维数组和多维数组等大量实用方法,帮助开发者轻松地进行数组计算。从而广泛的应用于数据分析、机器学习、图像处理和计算机图形学、数学任务等领域中

2、创建数组
numpy.array(object,dtype,copy,order,subok,ndmin)
参数说明:object:任何具有数组接口方法的对象dtype:数据类型copy:可选参数,布尔型,默认值为True,则object对象被复制order:元素在内存中的出现顺序subok:布尔型。如果值为True,则将传递子类ndmin:指定生成数组的最小维数 
  • 创建一维和二维数组
import numpy as npn1 = np.array([1,2,3]) #创建一个简单的一维数组
n2 = np.array([0.1,0.2,0.3]) #创建一个包含小数的一维数组
n3 = np.array([[1,2],[3,4]]) #创建一个简单的二维数组
  • 创建浮点型数组
import numpy as nplist = [1,2,3]#创建浮点型数组
n1 = np.array(list,dtype=np.float_)
print(n1)
print(n1.dtype)
print(type(n1[0]))
  • 创建三维数组
import numpy as nplist = [1,2,3]
nd1 = np.array(list,ndmin=3)
print(nd1)
3、操作数组
  • 数组加、减、乘、除
import numpy as npn1 = np.array([1,2])
n2 = np.array([3,4])print(n1 + n2)
print(n1 - n2)
print(n1 * n2)
print(n1 / n2)//输出
[4 6]
[-2 -2]
[3 8]
[0.33333333 0.5       ]
  • 幂运算
import numpy as npn1 = np.array([1,2])
n2 = np.array([3,4])print(n1 ** n2)//输出:[ 1 16]
  • 比较运算
import numpy as npn1 = np.array([1,2])
n2 = np.array([3,4])print(n1 >= n2)
print(n1 == n2)
print(n1 <= n2)
print(n1 != n2)//输出
[False False]
[False False]
[ True  True]
[ True  True]
  • 复制数组
import numpy as npn1 = np.array([1,2])
n2 = n1.copy()print(n1 == n2)
n2[0] = 9
print(n1)
print(n2)
print(n1 == n2)//输出
[ True  True]
[1 2]
[9 2]
[False  True]
  • 索引和切片
import numpy as npn1 = np.array([1,2,3])
print(n1[0])
print(n1[1])
print(n1[0:2])
print(n1[1:])
print(n1[:2])//输出
1
2
[1 2]
[2 3]
[1 2]
4、创建图像

在OpenCV中,黑白图像实际是一个二维数组,彩色图像是一个三维数组。数组中每个元素就是图像对应位置的像素值。因此修改图像像素的操作实际就是修改数组的操作

注意:数组索引、像素行列、像素坐标的关系如下数组行索引 = 像素所在行数 - 1 = 像素纵坐标数组列索引 = 像素所在列数 - 1 = 像素横坐标 
  • 创建纯黑色图像
import cv2
import numpy as npwidth = 200
height = 100#创建指定宽度、高度、像素值都为0的图像
img = np.zeros((height,width),np.uint8) #用0填充数组
cv2.imshow("img",img)cv2.waitKey()
cv2.destroyWindow()
  • 创建纯白色图像
import cv2
import numpy as npwidth = 200
height = 100#创建指定宽度、高度、像素值都为1的图像
img = np.ones((height,width),np.uint8)*255 #用1填充数组,然后再乘以255
cv2.imshow("img",img)cv2.waitKey()
cv2.destroyWindow()
  • 在黑色图像内部绘制白色矩形
import cv2
import numpy as npwidth = 200
height = 100#创建指定宽度、高度、像素值都为0的图像
img = np.zeros((height,width),np.uint8) #用0填充数组
# 图像纵坐标为25~75、横坐标为50~100之间的区域变为白色
img[25:75,50:100] = 255
cv2.imshow("img",img)cv2.waitKey()
cv2.destroyWindow()
  • 创建彩色图像
import cv2
import numpy as npwidth = 200
height = 100#创建指定宽度、高度、像素值都为0的图像
img = np.zeros((height,width,3),np.uint8) #用0填充数组
blue = img.copy()
blue[:,:,0] = 255
green = img.copy()
green[:,:,1] = 255
red = img.copy()
red[:,:,2] = 255cv2.imshow("blue",blue)
cv2.imshow("green",green)
cv2.imshow("red",red)cv2.waitKey()
cv2.destroyWindow()
5、图像拼接
  • 水平拼接数组

array  =  numpy.hstack(tup)
参数说明:tup:要拼接的数组元组
返回值说明:array:将参数元组中的数组水平拼接后生成的新数组
  • 垂直拼接数组
array = numpy.vstack(tup)
参数说明:tup:要拼接的数组元组
返回值说明:array:将参数元组中的数组垂直拼接后生成的新数组
  • 拼接图像
import cv2
import numpy as npimg = cv2.imread("E:/images/avatar.png")img_h = np.hstack((img,img))
img_v = np.vstack((img,img))cv2.imshow("img_h",img_h)
cv2.imshow("img_v",img_v)cv2.waitKey()
cv2.destroyWindow()
五、总结

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/30888.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

RH850---注意问题积累--1

硬件规格(引脚分配&#xff0c;内存映射&#xff0c;外设功能规格、电气特性、时序图)和操作说明 注意:有关使用的详细信息&#xff0c;请参阅应用说明 ---------外围函数。。。 1:存储指令完成与后续同步指令的一代 当控制寄存器被存储指令更新时&#xff0c;从存储的执行开始…

南京邮电大学计算机网络实验二(网络路由器配置RIP协议)

文章目录 一、 实验目的和要求二、 实验环境(实验设备)三、 实验步骤四、实验小结&#xff08;包括问题和解决方法、心得体会、意见与建议等&#xff09;五、报告资源 一、 实验目的和要求 掌握思科路由器的运行过程&#xff0c;掌握思科路由器的硬件连线与接口&#xff0c;掌…

VBA学习(13):获取多层文件夹内文件名并建立超链接

代码使用了FileSystemObject对象和递归的方法实现文件夹和文件的遍历功能。分别将文件夹名称和文件名提取在表格的A/B列&#xff0c;并对文件名创建了超链接。 示例代码如下&#xff1a; Sub AutoAddLink()Dim strFldPath As StringWith Application.FileDialog(msoFileDialog…

如何下载DVS Gesture数据集?解决tonic.datasets.DVSGesture错误HTTP Error 403: Forbidden

1 问题 DVSGesture数据集是一个专注于动态视觉传感&#xff08;Dynamic Vision Sensor, DVS&#xff09;技术的数据集&#xff0c;它包含了基于事件的图像记录&#xff0c;用于手势识别任务。DVSGesture数据集由一系列动态图像组成&#xff0c;这些图像是通过动态视觉传感器捕…

抖音矩阵系统搭建,AI剪辑短视频,一键管理矩阵账号

目录 前言&#xff1a; 一、抖音矩阵系统有哪些功能&#xff1f; 1.AI智能文案 2.多平台账号授权 3.多种剪辑模式 4. 矩阵一键发布&#xff0c;智能发布 5.抖音爆店码功能 6.私信实时互动 7.去水印及外链 二、抖音矩阵系统可以解决哪些问题&#xff1f; 总结&#xff…

理解HTTP请求格式

HTTP概念 HTTP全称HyperTextTransfer Protocol(超文本传输协议)是一种用于分布式、协作式和超媒体信息系统的应用层协议&#xff1b;HTTP是一个客户端&#xff08;用户&#xff09;和服务端&#xff08;网站&#xff09;之间请求和响应的标准。 HTTP 协议是以 ASCII 码传输&…

Gobject tutorial 八

The GObject base class Object memory management Gobject的内存管理相关的API很复杂&#xff0c;但其目标是提供一个基于引用计数的灵活的内存管理模式。 下面我们来介绍一下&#xff0c;与管理引用计数相关的函数。 Reference Count 函数g_object_ref和g_object_unref的…

怎么将几段音频合并在一起,试试这几个音频拼接小妙招

怎么将多个音频合并在一起呢&#xff1f;音频是我们日常工作生活中常见的文件&#xff0c;音频与我们息息相关&#xff0c;无论你是音乐爱好者&#xff0c;还是喜欢记录生活中的声音&#xff0c;都离不开音频。因此我们会遇到关于很多音频剪辑的难题&#xff0c;就像今天小编给…

usb摄像头应用编程

作者简介&#xff1a; 一个平凡而乐于分享的小比特&#xff0c;中南民族大学通信工程专业研究生在读&#xff0c;研究方向无线联邦学习 擅长领域&#xff1a;驱动开发&#xff0c;嵌入式软件开发&#xff0c;BSP开发 作者主页&#xff1a;一个平凡而乐于分享的小比特的个人主页…

conda install xformers -c xformers/label/dev 的安装问题

在StableSR项目框架中&#xff0c;需要执行 conda install xformers -c xformers/label/dev 但是报错&#xff0c;错误显示&#xff0c;版本不匹配&#xff0c;如下所示&#xff1a; 我改用pip来安装&#xff0c;好像就不报错了&#xff1a; pip install xformers

javaWeb项目-ssm+vue企业台账管理平台功能介绍

本项目源码&#xff1a;javaweb项目ssm-vue企业台账管理平台源码-说明文档资源-CSDN文库 项目关键技术 开发工具&#xff1a;IDEA 、Eclipse 编程语言: Java 数据库: MySQL5.7 框架&#xff1a;ssm、Springboot 前端&#xff1a;Vue、ElementUI 关键技术&#xff1a;springboo…

vue项目——前端CryptoJS加密、解密

1、vue项目需要安装CryptoJS安装包 npm install crypto-js 2、在项目中引入CryptoJS import CryptoJS from crypto-js 3、使用&#xff0c;代码如下 // 此处key为16进制let key jiajiajiajiajiajiajiajia;console.log(密钥&#xff1a;, key);// key格式化处理key Crypt…

【前端开发工具】VS Code安装和使用

文章目录 一、前言二、下载三、安装四、配置五、使用5.1 导入项目5.2 本地运行项目5.3 修改界面文案&#xff0c;验证效果5.4 添加日志打印5.5 代码调试5.6 代码提交到Git仓库 六、总结 一、前言 本文介绍一下在前端vue项目中&#xff0c;VS Code的安装和配置。 什么是VS Code…

【干货分享】25地学考研推免夏令营汇总表

​ 25考研学子们&#xff0c;考研准备要赶早。 小编给大家整合准备了25地信考研夏令营时间信息表&#xff0c;需要的宝子收藏起来。 ​ 话不多说&#xff0c;需要的小伙伴直接评论区留言 25地信考研择校信息表&#xff1a;

IT入门知识第一部分《IT基础知识》(1/10)

目录 IT入门知识第一部分《IT基础知识》&#xff08;1/10&#xff09; 1.引言 2.第一部分&#xff1a;IT基础知识 2.1 计算机硬件 CPU&#xff1a;计算机的心脏 内存&#xff1a;数据的临时居所 存储设备&#xff1a;数据的长期仓库 输入输出设备&#xff1a;与计算机的…

[Mysql] 的基础知识和sql 语句.教你速成(上)——逻辑清晰,涵盖完整

目录 前言 上篇的内容概况 下篇的内容概况 数据库的分类 关系型数据库 常见的关系型数据库系统 非关系型数据库 1. 键值对数据库&#xff08;Key-Value Stores&#xff09; 特点&#xff1a; 常见的键值对数据库&#xff1a; 2. 文档数据库&#xff08;Document Store…

【React】Axios请求头注入token

业务背景: Token作为用户的数据标识&#xff0c;在接口层面起到了接口权限控制的作用&#xff0c;也就是说后端有很多接口都需要通过查看当前请求头信息中是否含有token数据&#xff0c;来决定是否正常返回数据 // 添加请求拦截器 request.interceptors.request.use(config …

填坑-celery正常启动后能收到任务但不执行任务的解决办法

场景 Flask开发中用celery 6正常启动后能收到任务但不执行任务的解决办法&#xff0c;也没有错误提示…… INFO/MainProcess] Task app.add_together[ce406ed8-71b3-49e6-8556-f44bfe66549c] received [2024-06-20 19:38:10,632: INFO/SpawnPoolWorker-36] child process 2244…

求最小生成树的新算法

不管 prim 算法还是 kruskal 算法都基于 “当前可见最短边” 作贪心策略&#xff0c;但这并不适合分布式并行操作&#xff0c;比方说所有节点一起构建最小生成树&#xff0c;这些算法都显得同步开销过大&#xff0c;甚至导出错误的结果。 最近研究并构建最大流多路径传输协议的…

如何获得一个Oracle 23ai数据库(vagrant box)

准确的说&#xff0c;是Oracle 23ai Free Developer版&#xff0c;因为企业版目前只在云上&#xff08;OCI和Azure&#xff09;和ECC上提供。 前面我博客介绍了3种方法&#xff1a; Virtual ApplianceRPM安装Docker 今天介绍最近新出的一种方法&#xff0c;也是我最为推荐的…