VS2017&OPENCV4.0
#include <opencv2/opencv.hpp>
#include <iostream>
#include <math.h>
using namespace cv;
int main(int argc, char** argv) {
Mat src, dst1, dst2;
src = imread("D:\\time.jpg");
if (!src.data) {
printf("could not load image...\n");
return -1;
}
char INPUT_WIN[] = "input image";
char OUTPUT_WIN[] = "Border Demo";
namedWindow(INPUT_WIN, WINDOW_AUTOSIZE);
namedWindow(OUTPUT_WIN, WINDOW_AUTOSIZE);
imshow(INPUT_WIN, src);
//设置填充的像素值
int top = (int)(0.05*src.rows);
int bottom = (int)(0.05*src.rows);
int left = (int)(0.05*src.cols);
int right = (int)(0.05*src.cols);
RNG rng(12345);//随机数
int borderType = BORDER_DEFAULT;//填充的类型
int c = 0;
while (true) {
c = waitKey(500);
// ESC
if ((char)c == 27) {
break;
}
if ((char)c == 'r') {
borderType = BORDER_REPLICATE;//填充边缘像素用已知的边缘像素值
} else if((char)c == 'w') {
borderType = BORDER_WRAP;//用另外一边的像素来补偿填充
} else if((char)c == 'c') {
borderType = BORDER_CONSTANT;//填充边缘用指定像素值
}
Scalar color = Scalar(rng.uniform(0, 255), rng.uniform(0, 255), rng.uniform(0, 255));//颜色值用0~255的随机值来定
copyMakeBorder(src, dst1, top, bottom, left, right, borderType, color);
imshow(OUTPUT_WIN, dst1);
}
waitKey(0);
return 0;
}