#include <iostream>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <fcntl.h>
#include <sys/ioctl.h>
#include <linux/videodev2.h>
#include <string.h>
#include <sys/mman.h>
#include <assert.h>
#include <opencv2/opencv.hpp>
#include <opencv2/core.hpp>
#include <opencv2/imgcodecs.hpp>
#include <opencv2/highgui.hpp>
using namespace std;
using namespace cv;
typedef cv::Point3_<uint8_t> Pixel;
int main() {
Mat img = (Mat_<float>(4, 4) << 1, 2, 3, 4,
5, 6, 7, 8,
9, 10,11,12,
13,14,15,16);
Mat img2;
resize(img,img2,Size(2,2));
cout << img2 << endl;
return 0;
}
输出如下:
[3.5, 5.5;
11.5, 13.5]
可以很明显的看出 3.5 是 1, 2, 5, 6 这4个值的均值 , 5.5 是 3, 4, 7 ,8 的 均值,以此类推 。
可以做图片的缩放,如下:
#include <iostream>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <fcntl.h>
#include <sys/ioctl.h>
#include <linux/videodev2.h>
#include <string.h>
#include <sys/mman.h>
#include <assert.h>
#include <opencv2/opencv.hpp>
#include <opencv2/core.hpp>
#include <opencv2/imgcodecs.hpp>
#include <opencv2/highgui.hpp>
using namespace std;
using namespace cv;
typedef cv::Point3_<uint8_t> Pixel;
int main() {
Mat img = imread("in.jpg");
Mat img2;
resize(img, img2, Size(img.cols/2, img.rows/2));
imwrite("out.jpg", img2);
return 0;
}
上面的略显繁琐,也可以这样:
resize(img,img2,Size(),0.5,0.5);
完整的如下:
#include <iostream>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <fcntl.h>
#include <sys/ioctl.h>
#include <linux/videodev2.h>
#include <string.h>
#include <sys/mman.h>
#include <assert.h>
#include <opencv2/opencv.hpp>
#include <opencv2/core.hpp>
#include <opencv2/imgcodecs.hpp>
#include <opencv2/highgui.hpp>
using namespace std;
using namespace cv;
typedef cv::Point3_<uint8_t> Pixel;
int main2() {
Mat img =
(Mat_<float>(4, 4) << 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16);
Mat img2;
cout << img << endl;
resize(img, img2, Size(2, 2));
cout << img2 << endl;
return 0;
}
int main() {
Mat img = imread("in.jpg");
Mat img2;
resize(img,img2,Size(),0.5,0.5);
imwrite("out.jpg", img2);
return 0;
}