cv::Mat calcMax(const cv::Mat& bgr) //求RGB三个通道的最大值
{
cv::Mat image(bgr.rows, bgr.cols, CV_8UC1, cv::Scalar(255));
if (bgr.channels() != 3)
{
return bgr;
}
uchar max = 0;
uchar* pSrc = nullptr;
uchar* pDst = image.data;
for (int y = 0; y < bgr.rows; y++) //遍历行
{
pSrc = bgr.data + y * bgr.step;
for (int x = 0; x < bgr.cols; x++)//遍历列
{
max = 0;
for (int v = 0; v < 3; v++)
{
if (pSrc[v] > max)
{
max = pSrc[v];
}
}
pSrc += 3;
pDst[y * bgr.cols + x] = max;
}
}
return image;
}
cv::Mat calcMin(const cv::Mat& bgr) //求RGB三个通道的最小值
{
cv::Mat image(bgr.rows, bgr.cols, CV_8UC1, cv::Scalar(255));
if (bgr.channels() != 3)
{
return bgr;
}
uchar min = 255;
uchar* pSrc = nullptr;
uchar* pDst = image.data;
for (int y = 0; y < bgr.rows; y++) //遍历行
{
pSrc = bgr.data + y * bgr.step;
for (int x = 0; x < bgr.cols; x++)//遍历列
{
min = 255;
for (int v = 0; v < 3; v++)
{
if (pSrc[v] < min)
{
min = pSrc[v];
}
}
pSrc += 3;
pDst[y * bgr.cols + x] = min;
}
}
return image;
}
int main(int argc, char* argv[])
{
std::string pattern = "D:\\allike\\*.jpg";
std::vector<std::string> filePaths;
cv::glob(pattern, filePaths, false);
for (int i = 0; i < filePaths.size(); i++)
{
std::string filePath = filePaths[i];
cv::Mat imageRaw = cv::imread(filePath, IMREAD_COLOR);
cv::Mat imageGray1;
cv::Mat imageGray2;
cv::Mat imageGray3;
//提取灰度
cv::cvtColor(imageRaw, imageGray1, COLOR_RGB2GRAY);
imageGray2 = calcMax(imageRaw);
imageGray3 = calcMin(imageRaw);
}
}
OpenCV遍历文件夹读取图片,并取RGB通道的最大和最小值
最新推荐文章于 2024-08-01 14:17:36 发布