博客
关于我
C++ opencv小练习绘制点,直线,圆,椭圆等基本图像
阅读量:258 次
发布时间:2019-03-01

本文共 1451 字,大约阅读时间需要 4 分钟。

OpenCV图形绘制教程:通过代码实现多种图形

OpenCV是一个强大的图像处理库,能够帮助开发者快速实现图形绘制和图像操作。以下将通过OpenCV代码示例,详细说明如何绘制多种常见图形,包括直线、圆、椭圆和矩形。

1.1 初始化图像

首先,我们需要创建一个空的图像矩阵,并设置其背景颜色。以下代码示例:

Mat img = Mat::zeros(Size(800, 600), CV_8UC3);img.setTo(255);
  • Mat::zeros(Size(800, 600), CV_8UC3) 创建一个800x600像素、8位深度的彩色图像。
  • img.setTo(255) 将整个图像设置为白色背景。

1.2 绘制直线

OpenCV提供了line()函数用于绘制直线。以下是绘制两点之间直线的代码:

Point p1(100, 100);Point p2(758, 50);line(img, p1, p2, Scalar(0, 0, 255), 2);
  • Point p1(100, 100) 定义第一个点的坐标。
  • Point p2(758, 50) 定义第二个点的坐标。
  • line(img, p1, p2, Scalar(0, 0, 255), 2) 绘制连接两点的红色直线,线宽为2。

1.3 绘制圆

使用circle()函数绘制圆。以下是绘制圆的代码:

Point p(20, 20);circle(img, p, 1, Scalar(0, 255, 0), -1);
  • Point p(20, 20) 定义圆心坐标。
  • circle(img, p, 1, Scalar(0, 255, 0), -1) 绘制半径为1的绿色圆,-1 表示圆周不闭合。

1.4 绘制椭圆

通过ellipse()函数绘制椭圆。以下是绘制椭圆的代码:

Point center(100, 100);Size ellipseSize(90, 60);ellipse(img, center, ellipseSize, 30, 0, 360, Scalar(255, 255, 0), 3, 8);
  • Point center(100, 100) 定义椭圆中心坐标。
  • Size ellipseSize(90, 60) 定义椭圆的长宽。
  • ellipse(img, center, ellipseSize, 30, 0, 360, Scalar(255, 255, 0), 3, 8) 绘制黄色椭圆,角度为30度,线宽为3,线类型为8。

1.5 绘制矩形

使用rectangle()函数绘制矩形。以下是绘制矩形的代码:

Rect rect(250, 250, 120, 200);rectangle(img, rect, Scalar(0, 255, 255), 3);
  • Rect rect(250, 250, 120, 200) 定义矩形的坐标和尺寸。
  • rectangle(img, rect, Scalar(0, 255, 255), 3) 绘制 cyan 矩形,线宽为3。

1.6 显示图像

最后,使用imshow()函数显示图像:

imshow("画板", img);waitKey();
  • imshow("画板", img) 显示图像窗口标题为"画板"。
  • waitKey() 绘制完成后,按下任意键继续。

通过以上代码示例,可以轻松绘制多种常见图形。OpenCV提供了丰富的绘图功能,允许开发者快速实现复杂的图形操作。

转载地址:http://xvhv.baihongyu.com/

你可能感兴趣的文章
OpenCV与AI深度学习 | OpenCV常用图像拼接方法(四):基于Stitcher类拼接
查看>>
OpenCV与AI深度学习 | OpenCV快速傅里叶变换(FFT)用于图像和视频流的模糊检测(建议收藏!)
查看>>
OpenCV与AI深度学习 | PaddleOCR 2.9 发布, 正式开源文本图像智能分析利器
查看>>
OpenCV与AI深度学习 | SAM2(Segment Anything Model 2)新一代分割一切大模型介绍与使用(步骤 + 代码)
查看>>
OpenCV与AI深度学习 | T-Rex Label !超震撼 AI 自动标注工具,开箱即用、检测一切
查看>>
OpenCV与AI深度学习 | YOLO11介绍及五大任务推理演示(目标检测,图像分割,图像分类,姿态检测,带方向目标检测)
查看>>
OpenCV与AI深度学习 | YOLOv10在PyTorch和OpenVINO中推理对比
查看>>
OpenCV与AI深度学习 | YOLOv11来了:将重新定义AI的可能性
查看>>
OpenCV与AI深度学习 | YOLOv8自定义数据集训练实现火焰和烟雾检测(代码+数据集!)
查看>>
OpenCV与AI深度学习 | YOLOv8重磅升级,新增旋转目标检测,又该学习了!
查看>>
OpenCV与AI深度学习 | 一文带你读懂YOLOv1~YOLOv11(建议收藏!)
查看>>
OpenCV与AI深度学习 | 五分钟快速搭建一个实时人脸口罩检测系统(OpenCV+PaddleHub 含源码)
查看>>
OpenCV与AI深度学习 | 什么是 COCO 数据集?
查看>>
OpenCV与AI深度学习 | 低对比度缺陷检测应用实例--LCD屏幕脏污检测
查看>>
OpenCV与AI深度学习 | 使用 MoveNet Lightning 和 OpenCV 实现实时姿势检测
查看>>
OpenCV与AI深度学习 | 使用 OpenCV 创建自定义图像滤镜
查看>>
OpenCV与AI深度学习 | 使用 SAM 和 Grounding DINO 分割卫星图像
查看>>
OpenCV与AI深度学习 | 使用OpenCV图像修复技术去除眩光
查看>>
OpenCV与AI深度学习 | 使用OpenCV检测并计算直线角度
查看>>
OpenCV与AI深度学习 | 使用OpenCV轮廓检测提取图像前景
查看>>