l输出图像的内存是自动分配的
l使用OpenCV的C++接口,不需要考虑内存分配问题
l赋值操作和拷贝构造函数只会复制头部分
l使用clone与copyTo两
cv::Mat::Mat构造函数 Mat M(2,2,CV_8UC3, Scalar(0,0,255)) 其中前两个参数分别表示行(row)跟列(column)、第三个CV_8UC3中的8表示每个通道占8位、U表示无符号、C表示Char类型、3表示通道数目是3,第四个参数是向量表示初始化每个像素值是多少,向量长度对应通道数目一致
创建多维数组cv::Mat::create int sz[3] = {2,2,2}; Mat L(3,sz, CV_8UC1, Scalar::all(0));
个函数实现数据完全复制
cv::Mat::Mat构造函数 Mat M(2,2,CV_8UC3, Scalar(0,0,255)) 其中前两个参数分别表示行(row)跟列(column)、第三个CV_8UC3中的8表示每个通道占8位、U表示无符号、C表示Char类型、3表示通道数目是3,第四个参数是向量表示初始化每个像素值是多少,向量长度对应通道数目一致
创建多维数组cv::Mat::create int sz[3] = {2,2,2}; Mat L(3,sz, CV_8UC1, Scalar::all(0));
cv::Mat::create实现 Mat M; M.create(4, 3, CV_8UC2); M = Scalar(127,127); cout << "M = " << endl << " " << M << endl << endl; uchar* firstRow = M.ptr<uchar>(0); printf("%d", *firstRow);
#include <opencv2/opencv.hpp>
#include <iostream>
#include <math.h>
using namespace cv;
int main(void) {
Mat src;
src = imread("C:/Users/Robin/Pictures/test.jpg");
if (src.empty()) {
std::cout << "could not load image..\n";
return -1;
}
namedWindow("input", CV_WINDOW_AUTOSIZE);
imshow("input", src);
//Mat dst;//创建空白图像
//dst = Mat(src.size(), src.type());
//dst = Scalar(127, 0, 255);
//namedWindow("output", CV_WINDOW_AUTOSIZE);
//imshow("output", dst);
/*Mat dst = src.clone();
namedWindow("output", CV_WINDOW_AUTOSIZE);
imshow("output", dst);*/
/*Mat dst = src.clone();//克隆一个图片
namedWindow("output", CV_WINDOW_AUTOSIZE);
imshow("output", dst);*/
Mat dst;
src.copyTo(dst);
namedWindow("output", CV_WINDOW_AUTOSIZE);
imshow("output", dst);
cvtColor(src, dst, CV_BGR2GRAY);
printf("input image channels :%d\n", src.channels());//查看通道数
printf("output image channels :%d\n", dst.channels());
int cols = dst.cols;//行列数
int rows = dst.rows;
std::cout << "cols = " << cols << " rows = " << rows << '\n';
const uchar* firstRow = dst.ptr<uchar>(0);//第一行
printf("first pixel value %d\n", *firstRow);
Mat m(100, 100, CV_8UC1, Scalar(127));//验证算法的正确性
/*std::cout << "M = " << '\n' << m << '\n';*/
Mat m1;//创建一个mat对象
m1.create(src.size(), src.type());
m1 = Scalar(0, 0, 255);
Mat csrc;
Mat kernel = (Mat_<float>(3, 3) << 0, -1, 0, -1, 5, -1, 0, -1, 0);
filter2D(src, csrc, -1, kernel);
//Mat m2 = Mat::zeros(src.size(), src.type());//存为黑色
/*Mat m2 = Mat::zeros(2, 2, CV_8UC1);*/
Mat m2 = Mat::eye(2, 2, CV_8UC1);
std::cout << "m2 = " << '\n' << m2 << '\n';
imshow("output", m2);
waitKey(0);
return 0;
}