• 操作系统:ubuntu22.04
  • OpenCV版本:OpenCV4.9
  • IDE:Visual Studio Code
  • 编程语言:C++11

前言

判断一张图片是否有过高的明暗变化,可以通过分析图像的亮度分布一致性来实现。一种常见的做法是计算图像的亮度标准差(Standard Deviation)。标准差越大,表示图像中的亮度差异越大,即明暗变化可能较为剧烈。

代码实现

在C++中,你可以直接使用OpenCV库与C++标准库或Boost等数学库结合来计算图像的亮度标准差。虽然OpenCV的cv::Mat类本身不直接提供标准差计算函数,但你可以利用OpenCV的数据结构配合C++ STL中的算法来实现这一功能。以下是一个使用C++和OpenCV计算图像亮度标准差的例子:

#include <iostream>
#include <opencv2/opencv.hpp>
#include <vector>

/**
 * 计算灰度图像的亮度标准差
 * @param imgGray 输入的灰度图像,必须是单通道的8位无符号整型图像。
 * @return 返回图像亮度的标准差。
 * 
 * 该函数接收一个灰度图像作为输入,首先验证图像的类型是否满足要求,
 * 然后使用OpenCV的meanStdDev函数计算图像亮度的均值和标准差。
 * 最后,函数返回计算得到的亮度标准差。
 */
double calculateBrightnessStdDev( const cv::Mat& imgGray )
{
    // 确保输入图像为单通道的8位无符号整型灰度图像
    CV_Assert( imgGray.type() == CV_8UC1 );

    // 计算图像的均值和标准差
    cv::Scalar mean, stddev;
    cv::meanStdDev( imgGray, mean, stddev );

    // 返回图像亮度的标准差
    return stddev.val[ 0 ];
}

int main( int argc, char** argv )
{
    // 读取图像并转换为灰度
    cv::Mat img = cv::imread( "/media/dingxin/data/study/OpenCV/sources/images/fruit.jpg", cv::IMREAD_GRAYSCALE );
    if ( img.empty() )
    {
        std::cerr << "Could not open or find the image" << std::endl;
        return -1;
    }

    // 计算并打印图像的亮度标准差
    double stdDev = calculateBrightnessStdDev( img );
    std::cout << "The standard deviation of brightness in the image fruit is: " << stdDev << std::endl;

    img    = cv::imread( "/media/dingxin/data/study/OpenCV/sources/images/black.jpg", cv::IMREAD_GRAYSCALE );
    stdDev = calculateBrightnessStdDev( img );
    std::cout << "The standard deviation of brightness in the image black is: " << stdDev << std::endl;

    return 0;
}


运行结果

我拿了两张图进行计算,如下:
在这里插入图片描述

在这里插入图片描述

运行结果如下:
在这里插入图片描述
从结果看出第一张的明暗变化度明显大于第二张图像的明暗变化度

GitHub 加速计划 / opencv31 / opencv
77.38 K
55.71 K
下载
OpenCV: 开源计算机视觉库
最近提交(Master分支:2 个月前 )
48668119 dnn: use dispatching for Winograd optimizations 1 天前
3dace76c flann: remove unused hdf5 header 1 天前
Logo

旨在为数千万中国开发者提供一个无缝且高效的云端环境,以支持学习、使用和贡献开源项目。

更多推荐