最近在学习opencv,小白入门,纯是乐趣,入坑了
安装opencv比较简单,配置visual studio 开发环境可折腾死了,
第一次安装visual stduio踩过了不少坑。安装visual studio 2015,第一次安装在更新的情况下用了很久,最后无法使用,原来是缺少win32控制台应用。 立马寻找教程去修改,本来固态系统c盘内存就30g,这一修改直接导致c盘满了。so格式化系统,打算在普通硬盘上安装操作系统,可安装完毕后发现,没有固态硬盘的笔记本(用了3年了)缺少灵魂···太卡了,so再次格式化系统,这次,开始了最小开发安装(能用viusal c++即可)。不负我的折腾,环境搭配好了,c盘还保存了7个g··· 电脑还能和我的研究生生涯再战3年哈哈~~~
今天在跟着流浪的鱼(51cto网站的视频),学习了一节opencv,挺有乐趣,记录下.
读取rgb图像的每个通道,将通道的值赋予新图像···
#include <opencv2/opencv.hpp>
#include <iostream>
using namespace std;
using namespace cv;
int main(int argc, char ** argv) {
Mat src ;
src = imread("D:/lena.jpg"); //图像加载
if (src.empty()) {
cout << "could not load image..." << endl;
return -1;
}
else cout << "load succsessful." << endl;
imshow("input", src);
Mat dst;
dst.create(src.size(), src.type()); //创建类型一样的图片
int height = src.rows; //获取图像的行
int width = src.cols; //获取图像的列
int nc = src.channels(); //通道
for (int row = 0; row < height; row++)
for (int col = 0; col < width; col++) {
if (nc == 1) {
int gray = src.at<uchar>(row, col);
src.at<uchar>(row, col) = 255 - gray;
}
else if( nc == 3){
int b = src.at<Vec3b>(row, col)[0]; //读取通道值
int g = src.at<Vec3b>(row, col)[1];
int r = src.at<Vec3b>(row, col)[2];
dst.at<Vec3b>(row, col)[0] = b; //给新图像赋值
dst.at<Vec3b>(row, col)[1] = 0; //这个通道清零
dst.at<Vec3b>(row, col)[2] = r;
}
}
//bitwise_not(src, dst);
imshow("output", dst);
waitKey(0);
return 0;
}