博客
关于我
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与AI深度学习 | 基于拉普拉斯金字塔实现图像融合(步骤 + 代码)
查看>>
OpenCV与AI深度学习 | 基于改进YOLOv8的景区行人检测算法
查看>>
OpenCV与AI深度学习 | 基于机器视觉的磁瓦表面缺陷检测方案
查看>>
OpenCV与AI深度学习 | 基于深度学习的轮胎缺陷检测系统
查看>>
OpenCV与AI深度学习 | 如何使用YOLO-World做目标检测
查看>>
OpenCV与AI深度学习 | 如何使用YOLOv9分割图像中的对象
查看>>
OpenCV与AI深度学习 | 如何使用YOLOv9检测图片和视频中的目标
查看>>
OpenCV与AI深度学习 | 如何在 Docker 容器中使用 GPU
查看>>
OpenCV与AI深度学习 | 实战 | OpenCV中更稳更快的找圆方法--EdgeDrawing使用演示(详细步骤 + 代码)
查看>>
OpenCV与AI深度学习 | 实战 | OpenCV传统方法实现密集圆形分割与计数(详细步骤 + 代码)
查看>>
OpenCV与AI深度学习 | 实战 | OpenCV实现扫描文本矫正应用与实现详解(附源码)
查看>>
OpenCV与AI深度学习 | 实战 | YOLO11自定义数据集训练实现缺陷检测 (标注+训练+预测 保姆级教程)
查看>>
OpenCV与AI深度学习 | 实战 | YOLOv10模型微调检测肾结石并提高准确率
查看>>
OpenCV与AI深度学习 | 实战 | 使用OpenCV和Streamlit搭建虚拟化妆应用程序(附源码)
查看>>
OpenCV与AI深度学习 | 实战 | 使用OpenCV确定对象的方向(附源码)
查看>>
OpenCV与AI深度学习 | 实战 | 使用YOLOv8 Pose实现瑜伽姿势识别
查看>>
OpenCV与AI深度学习 | 实战 | 使用YoloV8实例分割识别猪的姿态(含数据集)
查看>>
OpenCV与AI深度学习 | 实战 | 使用姿态估计算法构建简单的健身训练辅助应用程序
查看>>
OpenCV与AI深度学习 | 实战 | 基于OpenCV和K-Means聚类实现颜色分割(步骤 + 代码)
查看>>