【OpenCV C++20 学习笔记】给图片加边框-copyMakeBorder

给图片加边框

原理

在卷积的过程中,图片边缘的处理总是一个问题。因为卷积核的锚点无法覆盖图片的边缘像素,硬要覆盖的话,卷积核就会有一部分超出图片的范围。

OpenCV中的大部分方法都会将图片的边缘像素进行扩充,从而扩大原有的图片。这样卷积核就能覆盖原来的边缘像素了。

本文将介绍两种对图片边缘像素进行扩充的方法:

  • BORDER_CONSTANT:用一个常量(比如表示黑色的0)对图片边缘进行扩充
  • BORDER_REPLICATE:图片的边缘像素被复制,从而形成图片的边框

API

以上两种边缘扩充的方法都可以用copyMakeBorder()函数来实现,其函数原型如下:

cpp 复制代码
void cv::copyMakeBorder(InputArray		src,				//输入图片
						OutputArray		dst,				//输出图片
						int				top,				//上边框宽度
						int				bottom,				//下边框宽度
						int				left,				//左边框宽度
						int				right,				//有边框宽度
						int				borderType,			//边框扩充类型
						const Scalar&	value = Scalar());	//如果扩充类型是BORDER_CONSTANT,这个参数用来指定常量

实例

这个例子分别用第一节讲的两种方法给图片扩充边框:

  • 上下边框的宽度为原图高度的5%,左右边框的宽度为原图宽度的5%;
  • 用常量扩充边框时,边框的颜色随机生成

完整代码如下:

cpp 复制代码
#include <opencv2/imgproc.hpp>
#include <opencv2/imgcodecs.hpp>
#include <opencv2/highgui.hpp>

using namespace cv;

int main() {
	Mat src{ imread("lena.jpg") };

	int top{ static_cast<int>(0.05 * src.rows) }, bottom{ top };	//初始化上下边框的宽度
	int left{ static_cast<int>(0.05 * src.cols) }, right{ left };	//初始化左右边框的宽度

	RNG rng{ 12345 };	//随机数生成器

	//常量边框
	Scalar value(rng.uniform(0, 255), rng.uniform(0,255), rng.uniform(0, 255));	//生成随机的BGR颜色
	Mat const_border;
	copyMakeBorder(src,
		const_border,
		top,
		bottom,
		left,
		right,
		BORDER_CONSTANT,
		value);			//需要指定value参数

	//复制边框
	Mat rep_border;
	copyMakeBorder(src,
		rep_border,
		top,
		bottom,
		left,
		right,
		BORDER_REPLICATE);	//注意这里并没有value这个参数

	imshow("原图", src);
	imshow("常量边框", const_border);
	imshow("复制边框", rep_border);
	waitKey(0);
}

运行结果如下:

相关推荐
IVEN_6 天前
Python OpenCV: RGB三色识别的最佳工程实践
python·opencv
西岸行者11 天前
学习笔记:SKILLS 能帮助更好的vibe coding
笔记·学习
悠哉悠哉愿意11 天前
【单片机学习笔记】串口、超声波、NE555的同时使用
笔记·单片机·学习
别催小唐敲代码11 天前
嵌入式学习路线
学习
毛小茛11 天前
计算机系统概论——校验码
学习
babe小鑫11 天前
大专经济信息管理专业学习数据分析的必要性
学习·数据挖掘·数据分析
winfreedoms11 天前
ROS2知识大白话
笔记·学习·ros2
在这habit之下11 天前
Linux Virtual Server(LVS)学习总结
linux·学习·lvs
我想我不够好。11 天前
2026.2.25监控学习
学习
im_AMBER11 天前
Leetcode 127 删除有序数组中的重复项 | 删除有序数组中的重复项 II
数据结构·学习·算法·leetcode