OpenCV学习(2.1) 初识图像

news/2024/9/23 10:04:48/

1.图像对象

图像是由一个个像素组成的,像素越多,体现到图像就是更加清晰,有更多的细节。举个例子,通常来说的分辨率,1080P,720P,480P就是指像素的数量,数量越多就越清晰。

2.打印图像的像素值

import cv2image = 'D:\papercode\AI\Ai-Dentist-Sample-Code-main\opencv\car_recognition\car.jpg'
#读取图片
image = cv2.imread(image)print("image0",image)
print("image1",image[0])
print("image2",image[0][0])
print("image3",image[0][0][0])print("image0",image.shape)
print("image1",image[0].shape)
print("image2",image[0][0].shape)
print("image3",image[0][0][0].shape)

结果展示:

image1 [[ 52  81  85]
 [ 75 102 106]
 [ 91 110 113]
 ...
 [229 208 193]
 [229 208 193]
 [229 208 193]]
image2 [52 81 85]
image3 52
image0 (861, 697, 3)
image1 (697, 3)
image2 (3,)
image3 ()

输出的image0没有打印出来,太长了,不过可以从shape中看到是(861,697,3),代表的是长和宽以及通道数;image1是指定了长的位置,显示的是长为序列【0】时宽以及三个通道上的数值,对应的形状就是(697,3);image2就是选定了长和宽的位置,显示的是在该位置上的三个通道的数值,对应形状就是(3,); image3就是选定了长和宽以及通道的值,其形状说明这个元素是一个标量(scalar),而不是一个具有维度的数组或张量。

3.其他读取方式

import cv2image = 'D:\papercode\AI\Ai-Dentist-Sample-Code-main\opencv\car_recognition\car.jpg'#其它加载图像的方式
image1 = cv2.imread(image, cv2.IMREAD_COLOR)
image2 = cv2.imread(image,cv2.IMREAD_GRAYSCALE)
image3 = cv2.imread(image,cv2.IMREAD_UNCHANGED)
print('image1',image1.shape)
print('image2',image2.shape)
print('image3',image3.shape)
cv2.imshow('image1',image1)
cv2.imshow('image2',image2)
cv2.imshow('image3',image2)cv2.waitKey(0)
cv2.destroyAllWindows()

输出结果:

image1 (861, 697, 3)
image2 (861, 697)
image3 (861, 697, 3)

cv2.imread(image, cv2.IMREAD_COLOR)

  • 这行代码将以彩色模式读取图像,即使图像是多通道的,也会被读取为彩色图像。
  • 如果图像是多通道的(例如RGB图像),则image1将会是一个三通道的彩色图像。

cv2.imread(image, cv2.IMREAD_GRAYSCALE)

  • 这行代码将以灰度模式读取图像,将图像转换为单通道的灰度图像。
  • 无论输入的图像是多通道还是单通道,image2都将是一个单通道的灰度图像。

cv2.IMREAD_UNCHANGED

  • 是 OpenCV 中的一个常量,用于指定读取图像时保持原始图像的通道数和深度。这意味着,如果图像是一个多通道图像,那么读取后的图像将保持多通道,如果是单通道图像,也会保持单通道。
  • 所以,cv2.imread(image, cv2.IMREAD_UNCHANGED) 将以不变的方式读取图像,保持图像的通道和深度不变。

cv.waitKey()是一个键盘绑定函数。其参数是以毫秒为单位的时间。该函数等待任何键盘事件指定的毫秒。如果您在这段时间内按下任何键,程序将继续运行。如果**0**被传递,它将无限期地等待一次敲击键。它也可以设置为检测特定的按键,例如,如果按下键 a 等,我们将在下面讨论。

cv.destroyAllWindows()只会破坏我们创建的所有窗口。如果要销毁任何特定的窗口,请使用函数 cv.destroyWindow()在其中传递确切的窗口名称作为参数。

4.图像存储

#图像存储
cv2.imwrite('messigray.png', image2)

输出显示:存放到当前路径

使用函数**cv.imwrite**()保存图像。

第一个参数是文件名,第二个参数是要保存的图像。 cv.imwrite('messigray.png',img)

这会将图像以PNG格式保存在工作目录中。

5.图像灰度化的原理

图像的灰度化是将彩色图像转换为灰度图像的过程。灰度图像是一种单通道图像,每个像素只有一个数值,代表了该像素的亮度或灰度级别。灰度化的原理可以通过不同的方法实现,其中最常见的包括加权平均法、亮度法和取值法。

  1. YUV亮度灰度化

    • YUV 是一种颜色编码方法,其中 Y 通道表示亮度,而 U 和 V 通道表示色度。Y 通道包含了图像的亮度信息,因此可以将 Y 通道视为灰度图像的近似。
    • YUV 亮度灰度化方法直接使用 Y 通道作为灰度图像的值,忽略 U 和 V 通道。这种方法简单快速,适用于需要快速处理的场景。
    • 灰度值(Gray) = 0.299 * R + 0.587 * G + 0.114 * B
  2. 最大值灰度化

    • 最大值灰度化方法将彩色图像的每个像素的 R、G、B 三个通道的最大值作为灰度值。这种方法可以保留图像中的最亮部分,适用于需要突出图像亮度信息的场景。
    • 灰度值(Gray) =B = G = R = m a x ( [ B , G , R ] ) 

  3. 平均值灰度化

    • 平均值灰度化方法将彩色图像的每个像素的 R、G、B 三个通道的值取平均作为灰度值。这种方法简单粗暴,会使图像失去一些细节,但可以保留整体的亮度信息。
    • 灰度值(Gray)= (R + G + B) / 3
  4. Gamma校正灰度化

    • Gamma 校正是一种非线性操作,可以调整图像的亮度和对比度。在灰度化中,Gamma 校正可以通过以下公式进行:
      灰度值 = 255 * (原始值 / 255) ^ Gamma 其中,Gamma 为大于 0 的参数,通常在 0.5 到 2.0 之间。Gamma 值越大,图像越暗;Gamma 值越小,图像越亮。Gamma 校正可以调整图像的整体亮度和对比度,适用于需要对图像进行调色和增强的场景。
      

灰度化的目的是降低图像的复杂度,减少处理的计算量,同时保留图像的主要特征和结构。在许多图像处理和计算机视觉任务中,灰度化是一个常见的预处理步骤,可以大大简化后续处理的复杂度。


http://www.ppmy.cn/news/1463688.html

相关文章

pip安装报错解决之后,手动安装太麻烦,怎么办

在使用pip install package_name安装公共库的时候,经常会报错: Microsoft Windows [版本 6.1.7601] 版权所有 (c) 2009 Microsoft Corporation。保留所有权利。C:\Users\Administrator>pip install hatch WARNING: Ignoring invalid distribution -ip (d:\soft\python\py…

日拱一卒,功不唐捐

"日拱一卒,功不唐捐"是一句富有哲理的成语,源自中国的文化背景,结合了象棋术语和佛家理念,具有深刻的寓意。 日拱一卒:这里的“卒”指的是中国象棋中的兵(或卒),按照规则…

初级爬虫的总结一

初级爬虫的总结一之百度网页爬虫 一、寻找正确的sugrec二、url拼接出问题,解决办法 我遇到的问题: 1、没有找对网页sugrec,导致connect-type没有找对,以及一些小问题 2、url拼接时候出现乱码 一、寻找正确的sugrec 1、打开百度网…

组合惯导串口数据解析

首先是给串口usb以权限: sudo chmod 666 /dev/ttyUSB0但是不能每次启动都执行一次,所以需要给一个永久的权限指令: sudo gedit /etc/udev/rules.d/70-ttyusb.rulesKERNEL“ttyUSB[0-9]*”, MODE“0666”然后就能让ttyUSB0-ttyUSB9默认的权限…

常用目标检测预训练模型大小及准确度比较

目标检测是计算机视觉领域中的一项重要任务,旨在检测和定位图像或者视频中的目标对象。当人类观看图像或视频时,我们可以在瞬间识别和定位感兴趣的对象。目标检测的目标是使用计算机复制这种智能。 近年来,目标检测网络的发展日益成熟&#…

C语言从头学12——流程控制(一)

C语言程序的执行顺序是从前到后依次序执行的。如果想要控制程序执行的流程,就必须使用 流程控制的语法结构,分为条件执行和循环执行。 1、if语句 if 语句在前面的举例中曾经出现过,这里做详细介绍。该语句用于条件判断,满…

【译】MySQL复制入门: 探索不同类型的MySQL复制解决方案

原文地址:An Introduction to MySQL Replication: Exploring Different Types of MySQL Replication Solutions 在这篇博文中,我将深入介绍 MySQL 复制,回答它是什么、如何工作、它的优势和挑战,并回顾作为 MySQL 环境&#xff0…

python 使用OCR 识别woff字体文件

做数据获取安**时发现请求返回的数据跟woff字体有关,这里写一个使用OCR识别方法, 1、重要部分的原理是解析woff文件,并将woff字体转为图片,并将字体编码与字体图片相对应,便于之后的数据解密解析。 2、使用的是muggl…