当前位置: 首页 > news >正文

【c++|opencv】二、灰度变换和空间滤波---2.直方图和均衡化

every blog every motto: You can do more than you think.
https://blog.csdn.net/weixin_39190382?type=blog

0. 前言

图像直方图、直方图均衡化

1. 图像直方图

#include <iostream>
#include <opencv2/opencv.hpp>using namespace cv;
using namespace std;int main(){Mat img, img_gray,hist;img = imread("/home/v/home.png");if (img.empty()){cout << "Could not open or find the image" << endl;return -1;}cvtColor(img, img_gray, COLOR_BGR2GRAY);imshow("img gray",img_gray);// 获取图像直方图int histSize = 256;float range[] = { 0, 256 };const float* histRange = { range };calcHist(&img_gray, 1, 0, Mat(), hist, 1, &histSize, &histRange, true, false);// 创建直方图int hist_h = 300;int hist_w = 512;int bin_w = hist_w / histSize; // 直方图的等级Mat hist_img(hist_h, hist_w, CV_8UC3, Scalar(0, 0, 0));// 绘制并显示直方图normalize(hist, hist, 0, hist_h, NORM_MINMAX, -1, Mat()); // 归一化直方图for (int i=1;i<histSize;i++){line(hist_img, Point(bin_w*(i-1), hist_h - cvRound(hist.at<float>(i-1))),Point(bin_w*(i), hist_h - cvRound(hist.at<float>(i))),Scalar(0, 0, 255), 2, 8, 0);}imshow("直方图",hist_img);waitKey(0);return 0;
}

在这里插入图片描述

2. 直方图均衡化

#include<iostream>
#include<opencv2/opencv.hpp>using namespace cv;
using namespace std;int main(){Mat img,img_gray,img_enhanced;img = imread("/home/v/home.png");if (img.empty()){cout<<"Error"<<endl;return -1;}cvtColor(img,img_gray,COLOR_BGR2GRAY);imshow("gray",img_gray);equalizeHist(img_gray,img_enhanced); // 直方图均衡化imshow("enhanced",img_enhanced);waitKey(0);return 0;
}

在这里插入图片描述

http://www.lryc.cn/news/213636.html

相关文章:

  • 【Windows】线程同步之信号量(Semaphores)
  • 二叉树问题——前中后遍历数组构建二叉树
  • Java保留n位小数的方法(超简洁)
  • JavaEE-博客系统1(数据库和后端的交互)
  • 【unity/vufornia】Duplicate virtual buttons with name.../同一个ImageTarget上多个按钮失灵
  • Apache ActiveMQ 远程代码执行漏洞复现(CNVD-2023-69477)
  • 项目管理-科学管理基础-线性规划介绍及例题
  • 如何利用自定义数据对象(元数据)实现全场景身份数据治理
  • 腾讯云轻量级服务器哪个镜像比较好?
  • SC密封件的材料成分
  • 常用 sqlite3 命令
  • SpringMVC Day 08 : 文件上传下载
  • 【热带气旋】基本介绍:定义、标准、结构等
  • ue5 右击.uproject generator vs project file 错误
  • 0X01
  • centos7 配置搭建 wordpress 博客
  • 掌握Android自定义View与独家优化技巧
  • 【T3】彻底关闭服宝
  • P2359 三素数数 , 线性dp
  • 【c语言】用C语言设计一个环形缓冲区。当环形缓冲区有一半占用未处理时,提示使用了50%.
  • Python的web自动化学习(四)Selenium的显性等待(元素定位)
  • X3DAudio1_7.dll是什么,解决计算机找不到X3DAudio1_7.dll文件的方法
  • 【Python】海龟图turtle.color() 方法有关RGB颜色设置详解
  • 中科院上高院,协鑫,和数“能源数字化智能管控”合作项目开启
  • 在Mac上安装MongoDB 5.0
  • 手把手教你如何实现TNAS与云盘之间的无缝同步技巧
  • 【约会云栖】从初中至大学,我见证了科技变革的历程。
  • 【MySQL索引与优化篇】索引优化与查询优化
  • DevChat:VSCode中基于大模型的AI智能编程助手
  • Scrum master的职责