zoukankan      html  css  js  c++  java
  • opencv:直方图操作

    示例程序:

    #include <opencv.hpp>
    using namespace cv;
    using namespace std;
    int main()
    {
        Mat src, dst;
        //load img;
        src = imread("001.jpg",1);
        if (!src.data)
        {
            printf("error");
            return -1;
            
        }
        imshow("1", src);
        //分成三个通道
        vector<Mat> rgb_planes; // 保存在stl容器里
        split(src, rgb_planes);
        // 设置直方图尺寸 
        int histSize = 255;
        
        Mat histImage(400, 400, CV_8UC1, Scalar(0));
        int bin_w = cvRound((double)400 / histSize);
        //设置范围
        float range[] = { 0, 255 };
        const float * histRange = { range };
        bool uniform = true; bool accumulate = false;
        Mat r_hist, g_hist, b_hist; // 用于保存三个通道的直方图
        //计算直方图
        calcHist(&rgb_planes[1], 1,0,Mat(),r_hist,1, &histSize, &histRange, uniform, accumulate);
        normalize(r_hist, r_hist, 0, histImage.rows, NORM_MINMAX, -1, Mat());  // 直方图归一化
        for (int i = 1; i < histSize; i++)
        {
            line(histImage, Point(bin_w * (i - 1), 400 - cvRound(r_hist.at<float>(i - 1))), Point(bin_w * (i), 400 - cvRound(r_hist.at<float>(i))), Scalar(255), 1, 8, 0);
        }
        imshow("dst", histImage);
        waitKey(0);
        
        return 0;
    }

      

    ------------ 转载请注明出处 ------------
  • 相关阅读:
    责任
    人生
    有感
    冲突无处不在
    中科院玉泉路攻略——吃篇(校外)
    兄弟
    (18)[转载]:跳台阶问题
    Excel表格加下列选择框
    (转载)(c#)数据结构与算法分析 数组、向量和表
    [转载] 趣味算法:字符串反转的N种方法
  • 原文地址:https://www.cnblogs.com/whlook/p/6476948.html
Copyright © 2011-2022 走看看