您好,登錄后才能下訂單哦!
在OpenCV C++中,直方圖均衡化是一種常用的圖像處理技術,用于增強圖像的視覺質量
#include <opencv2/opencv.hpp>
#include<iostream>
cv::Mat image = cv::imread("input.jpg", cv::IMREAD_COLOR);
cv::Mat gray_image;
cv::cvtColor(image, gray_image, cv::COLOR_BGR2GRAY);
int histSize = 256;
float range[] = {0, 256};
const float* histRange = {range};
cv::Mat hist;
calcHist(&gray_image, 1, 0, cv::Mat(), hist, 1, &histSize, &histRange, true, false);
cv::Mat norm_hist;
cv::normalize(hist, norm_hist, 0, 255, cv::NORM_MINMAX, -1, cv::Mat());
cv::Mat cumulative_hist(histSize, 1, CV_32F);
cumulative_hist.at<float>(0) = norm_hist.at<float>(0);
for (int i = 1; i< histSize; i++) {
cumulative_hist.at<float>(i) = cumulative_hist.at<float>(i - 1) + norm_hist.at<float>(i);
}
cv::Mat equalized_image(image.rows, image.cols, CV_8UC1);
for (int y = 0; y< image.rows; y++) {
for (int x = 0; x< image.cols; x++) {
int pixelValue = static_cast<int>(gray_image.at<uchar>(y, x));
equalized_image.at<uchar>(y, x) = static_cast<uchar>(cumulative_hist.at<float>(pixelValue));
}
}
cv::imshow("Original Image", image);
cv::imshow("Equalized Image", equalized_image);
cv::waitKey(0);
這個示例展示了如何使用OpenCV C++實現直方圖均衡化。請注意,這里我們只處理了灰度圖像。如果你想處理彩色圖像,可以先將其分解為多個通道(紅、綠、藍),然后對每個通道應用相同的操作。最后,將處理過的通道合并成一個新的彩色圖像。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。