python 图像判断,清晰度(明暗),彩色与黑白实例
作者:风泽茹岚 时间:2023-09-04 12:58:00
1,判断图像清晰度,明暗,
原理,Laplacian算法。偏暗的图片,二阶导数小,区域变化小;偏亮的图片,二阶导数大,区域变化快。
import cv2
def getImageVar(imgPath):
image = cv2.imread(imgPath)
img2gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)
imageVar = cv2.Laplacian(img2gray, cv2.CV_64F).var()
return imageVar
imageVar = getImageVar("./lena.jpg")
print(imageVar)
输出结果:
2119.0913581351697
2,判断黑白或彩色图片
原理,通道变化
def is_color_image(url):
im=Image.open(url)
pix=im.convert('RGB')
width=im.size[0]
height=im.size[1]
oimage_color_type="Grey Image"
is_color=[]
for x in range(width):
for y in range(height):
r,g,b=pix.getpixel((x,y))
r=int(r)
g=int(g)
b=int(b)
if (r==g) and (g==b):
pass
else:
oimage_color_type='Color Image'
return oimage_color_type
补充知识:求图片的平均亮度
图像相关开发中,有时我们需要知道和了解图片的 亮度 这一信息,例如判断图片是否曝光严重过度或者太黑什么都看不清。
那么怎么去获取到图片的 平均亮度 这一信息呢?
一、YUV 图片
一般相机的原始数据类型就是 YUV 格式,这种格式下很容易求得亮度,因为它的 Y 通道就是亮度通道,我们只需要求得 Y 通道的平均值就可以了。
由于 YUV 图片前 width * height 个字节存放的就是 Y 的值,所以其均值计算如下:
void calculate_average_brightness(const unsigned char* image, const int width, const int height, double* brightness) {
int length = width * height;
double sum;
for (int i = 0; i < length; ++i) {
sum += image[i];
}
brightness = sum / length; // brightness value: [0, 255]
}
注意这样计算得到的亮度值范围为 0~255,如果要归一化的话,再除以 255 即可。
二、RGB 图片
RGB 图片的计算理论和上述差不多,不过我们需要先求得 R、G、B 三个通道的均值。
RGB 图片的亮度计算公式为:
Y = 0.299 * R + 0.587 * G + 0.114 * B
来源:https://blog.csdn.net/luolinll1212/article/details/84107066
标签:python,图像,彩色,黑白
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
vue如何获取指定元素
2024-05-09 15:15:19
详解在vue-cli中引用jQuery、bootstrap以及使用sass、less编写css
2023-07-02 17:08:08
![](https://img.aspxhome.com/file/2023/3/139943_0s.png)
Eclipse配置python默认头过程图解
2022-03-11 10:52:59
![](https://img.aspxhome.com/file/2023/9/127869_0s.png)
Python制作动态字符图的实例
2023-11-02 07:17:18
![](https://img.aspxhome.com/file/2023/7/131687_0s.png)
在 Django/Flask 开发服务器上使用 HTTPS
2023-02-21 22:15:33
Python NumPy随机抽模块介绍及方法
2021-04-21 16:47:03
python中的随机数种子seed()用法说明
2021-11-15 17:16:34
![](https://img.aspxhome.com/file/2023/4/92334_0s.png)
解决SQLServer最大流水号的两个好方法
2009-01-13 14:15:00
Python设计模式创建型原型模式
2023-07-21 21:19:25
![](https://img.aspxhome.com/file/2023/4/59124_0s.png)
详解Python类和对象内容
2021-03-12 23:38:55
![](https://img.aspxhome.com/file/2023/5/83705_0s.jpg)
php查找指定目录下指定大小文件的方法
2023-09-03 17:53:36
Go语言入门13之runtime包案例讲解
2024-02-02 05:54:08
asp网站生成静态页面攻略
2007-11-04 15:09:00
基于jquery的15款幻灯片插件
2024-04-09 19:47:56
![](https://img.aspxhome.com/file/2023/5/137095_0s.png)
Vue的el-scrollbar实现自定义滚动
2021-08-16 19:06:22
![](https://img.aspxhome.com/file/2023/2/125022_0s.jpg)
详解Python 字符串相似性的几种度量方法
2023-06-19 14:12:39
Django model重写save方法及update踩坑详解
2021-01-21 08:45:52
Python响应对象text属性乱码解决方案
2023-07-31 13:06:41
![](https://img.aspxhome.com/file/2023/0/61170_0s.png)
python线程池的实现实例
2022-11-21 11:24:27
非常不错的SQL语句学习手册实例版第1/3页
2024-01-25 23:31:01
![](https://img.aspxhome.com/file/2023/6/113576_0s.gif)