#include <opencv2/opencv.hpp>
#include <iostream>
using namespace cv;
using namespace std;
int main(int artc, char** argv) {
Mat src = imread("D:/test.png");
if (src.empty()) {
printf("could not load image...\n");
return -1;
}
namedWindow("input", CV_WINDOW_AUTOSIZE);
imshow("input", src);
// 直接读取图像像素
int height = src.rows;
int width = src.cols;
int ch = src.channels();
for (int c = 0; c < ch; c++) {
for (int row = 0; row < height; row++) {
for (int col = 0; col < width; col++) {
if (ch == 3) {
Vec3b bgr = src.at<Vec3b>(row, col);
bgr[0] = 255 - bgr[0];
bgr[1] = 255 - bgr[1];
bgr[2] = 255 - bgr[2];
src.at<Vec3b>(row, col) = bgr;
} else if(ch == 1) {
int gray = src.at<uchar>(row, col);
src.at<uchar>(row, col) = 255 - gray;
}
}
}
}
imshow("output", src);
waitKey(0);
return 0;
}
本文介绍了一个使用OpenCV库进行图像像素值反转的C++代码示例。通过读取图像的像素值并对其进行处理,实现图像的黑白反转效果。首先检查图像是否成功加载,然后创建窗口并显示原始图像。接着,遍历图像的每个像素,根据图像通道数进行相应的像素值反转操作。最后,显示处理后的图像并等待用户按键。
3万+

被折叠的 条评论
为什么被折叠?



