传统CV算法——基于Opencv的图像绘制

2024-09-04 02:28

本文主要是介绍传统CV算法——基于Opencv的图像绘制,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

直线绘制

参数解析:

  • (图像矩阵,直线起始坐标, 直线终止坐标、颜色、线条厚度)
    cv2.line()是OpenCV中用于绘制直线的函数。
    参数说明:
  • img:要绘制直线的图像矩阵。
  • (100,30):直线的起点坐标。
  • (210,180):直线的终点坐标。
  • color:直线的颜色,三个值分别表示蓝色、绿色和红色通道的强度。这里(0,0,255)表示纯蓝色。
  • thickness:直线的宽度。默认为1,如果设置为大于1的整数,将绘制实心直线。

以上参数可以根据需要调整,以绘制不同颜色、宽度和位置的直线。

import cv2
import numpy as npimg  = cv2.imread(r"./images/1.jpg")cv2.line(img,(100,30),(210,180),color=(0,0,255),thickness=2)cv2.imshow("pic show",img)
cv2.waitKey(0)

在这里插入图片描述

圆形绘制

  • 参数 (图像,圆心,半径,颜色,线条厚度)
    cv2.circle()是OpenCV库中用于绘制圆的函数,它可以在图像上绘制一个圆。

参数如下:

  • img:需要绘制圆的图像。
  • center:圆心的坐标,可以用一个元组(x,y)表示。
  • radius:圆的半径,以像素为单位。
  • color:圆的颜色,可以是一个元组(B,G,R)表示,或者是一个整数值,表示灰度值。
  • thickness:圆的边框线的粗细,如果为负值,表示圆填充颜色。
  • lineType:线的类型,可以是8常数代表8位连接,也可以是4常数代表4位连接。
  • shift:圆心坐标和半径的小数点位数。

注意:在绘制圆时,需要保证圆心坐标和半径都在图像范围内,否则可能会导致绘制失败。

import cv2
import numpy as npimg  = cv2.imread(r"./images/1.jpg")# cv2.line(img,(100,30),(210,180),color=(0,0,255),thickness=2)
cv2.circle(img,center=(50,50),radius=30,color=(0,0,255),thickness=2)cv2.imshow("pic show",img)
cv2.waitKey(0)

在这里插入图片描述

矩形绘制

  • 参数(图像,左上角坐标,右下角坐标,颜色,线条厚度)
    cv2.rectangle函数是OpenCV中用于绘制矩形的函数。以下是cv2.rectangle函数的参数说明:

  • image:要绘制矩形的图像。这个参数必须是一个NumPy数组,即一个图像。

  • pt1:矩形的左上角顶点坐标。可以通过一个元组或一个列表来指定。例如(10, 10)或 [10, 10]。

  • pt2:矩形的右下角顶点坐标。同样可以通过一个元组或一个列表来指定。

  • color:矩形的颜色。可以是一个整数或一个元组。如果是一个整数,它代表了灰度值。如果是一个元组,它代表了RGB值。

  • thickness:矩形的边框线的宽度。默认值为1,表示绘制一个实心矩形。

  • lineType:矩形边框线的类型。默认值为cv2.LINE_8,表示8邻域连接。

  • shift:坐标点的小数点位数。默认值为0,表示坐标点的小数点位数为0。

cv2.rectangle函数可以用于绘制矩形的轮廓线,也可以用于填充矩形的颜色。

import cv2
import numpy as npimg  = cv2.imread(r"./images/1.jpg")# cv2.line(img,(100,30),(210,180),color=(0,0,255),thickness=2)
# cv2.circle(img,center=(50,50),radius=30,color=(0,0,255),thickness=2)
cv2.rectangle(img,(100,30),(210,180),color=(0,0,255),thickness=2)cv2.imshow("pic show",img)
cv2.waitKey(0)

在这里插入图片描述

椭圆型绘制

  • image:它是要在其上绘制椭圆的图像。

centerCoordinates:它是椭圆的中心坐标。坐标表示为两个值的元组,即(X坐标值,Y坐标值)。
axesLength:它包含两个变量的元组,分别包含椭圆的长轴和短轴(长轴长度,短轴长度)。
angle:椭圆旋转角度,以度为单位。
startAngle:椭圆弧的起始角度,以度为单位。
endAngle:椭圆弧的终止角度,以度为单位。
color:它是要绘制的形状边界线的颜色。对于BGR,我们通过一个元组。例如:(255,0,0)为蓝色。
thickness:是形状边界线的粗细像素。厚度-1像素将用指定的颜色填充形状。
lineType:这是一个可选参数,它给出了椭圆边界的类型。
shift:这是一个可选参数。它表示中心坐标中的小数位数和轴的值。

import cv2
import numpy as npimg  = cv2.imread(r"./images/1.jpg")# cv2.line(img,(100,30),(210,180),color=(0,0,255),thickness=2)
# cv2.circle(img,center=(50,50),radius=30,color=(0,0,255),thickness=2)
# cv2.rectangle(img,(100,30),(210,180),color=(0,0,255),thickness=2)
cv2.ellipse(img,center=(100,100),axes=(100,50),angle=0,startAngle=0,endAngle=360,color=(255,0,0),thickness=2)
cv2.imshow("pic show",img)
cv2.waitKey(0)

在这里插入图片描述

自定义形状

  • 多边形,isClosed 代表是否是封闭
    cv2.polylines函数用于绘制多边形线条。它的参数如下:

image: 要绘制线条的图像。
pts: 一个由多个多边形点的列表组成的列表,每个多边形点由(x, y)坐标表示。
isClosed: 一个布尔值,指示多边形是否是闭合的。如果为True,函数将在绘制最后一个点和第一个点之间绘制一条线条来闭合多边形。
color: 线条的颜色,可以是一个整数列表表示RGB颜色,或者可以是一个名为cv2.COLOR_*的预定义常量。
thickness: 线条的粗细,以像素为单位。
lineType: 线条的类型,可以是cv2.LINE_*的预定义常量。
shift: 点坐标的小数位数。

注意:pts参数必须是一个整数类型的数组,所以需要使用np.int32()函数将坐标数组中的元素转换为整数。

import cv2
import numpy as npimg  = cv2.imread(r"./images/1.jpg")# cv2.line(img,(100,30),(210,180),color=(0,0,255),thickness=2)
# cv2.circle(img,center=(50,50),radius=30,color=(0,0,255),thickness=2)
# cv2.rectangle(img,(100,30),(210,180),color=(0,0,255),thickness=2)
# cv2.ellipse(img,center=(100,100),axes=(100,50),angle=0,startAngle=0,endAngle=360,color=(255,0,0),thickness=2)
pts = np.array([[10,5],[50,10],[70,20],[20,30]],dtype=np.int32)
pts = pts.reshape((-1,1,2))
cv2.polylines(img,[pts],isClosed=True,color=(0,0,255),thickness=2)cv2.imshow("pic show",img)
cv2.waitKey(0)

在这里插入图片描述

绘制文本

cv2.putText()是OpenCV中用于在图像上绘制文字的函数。它有以下几个参数:

  1. img:需要绘制文字的图像。

  2. text:要绘制的文本内容。

  3. org:绘制文本的起始位置,是一个包含两个元素的元组,如(x, y)。

  4. fontFace:文本字体的类型,可以是预定义的字体类型(如cv2.FONT_HERSHEY_SIMPLEX,cv2.FONT_HERSHEY_PLAIN等),也可以是自定义的字体,使用字体文件的路径。

  5. fontScale:字体的缩放比例。

  6. color:文本的颜色,是一个包含三个元素的元组,表示B、G、R三个分量的值。

  7. thickness:文本的粗细线宽。

  8. lineType:线条的类型,可以是cv2.LINE_AA(抗锯齿线条)或cv2.LINE_8(8连接线条)。

  9. bottomLeftOrigin:一个布尔值,用于指定文本坐标相对于绘制原点的位置。如果为True,则文本坐标相对于图像的左下角;如果为False,则文本坐标相对于图像的左上角。

调用cv2.putText()函数后,会在指定的图像上绘制出文本。

import cv2
import numpy as npimg  = cv2.imread(r"./images/1.jpg")# cv2.line(img,(100,30),(210,180),color=(0,0,255),thickness=2)
# cv2.circle(img,center=(50,50),radius=30,color=(0,0,255),thickness=2)
# cv2.rectangle(img,(100,30),(210,180),color=(0,0,255),thickness=2)
# cv2.ellipse(img,center=(100,100),axes=(100,50),angle=0,startAngle=0,endAngle=360,color=(255,0,0),thickness=2)
# pts = np.array([[10,5],[50,10],[70,20],[20,30]],dtype=np.int32)
# pts = pts.reshape((-1,1,2))
# cv2.polylines(img,[pts],isClosed=True,color=(0,0,255),thickness=2)cv2.putText(img,"gril",(10,30),cv2.FONT_HERSHEY_SIMPLEX,fontScale=1,color=(0,0,255),thickness=1,lineType=cv2.LINE_AA)cv2.imshow("pic show",img)
cv2.waitKey(0)

在这里插入图片描述

其他类型

ellipse():用于绘制椭圆或圆形的函数。它接受四个参数:(x, y, width, height)。其中,x和y是椭圆中心的坐标,width和height分别是椭圆的宽度和高度。

arc():用于绘制弧线的函数。它接受六个参数:(x, y, width, height, start, stop)。其中,x和y是弧线的中心坐标,width和height分别是弧线的宽度和高度,start和stop是弧线的起始角度和终止角度。

triangle():用于绘制三角形的函数。它接受六个参数:(x1, y1, x2, y2, x3, y3)。其中,(x1, y1),(x2, y2),(x3, y3)是三个顶点的坐标。

rect():用于绘制矩形的函数。它接受四个参数:(x, y, width, height)。其中,x和y是矩形的左上角坐标,width和height分别是矩形的宽度和高度。

quad():用于绘制四边形的函数。它接受八个参数:(x1, y1, x2, y2, x3, y3, x4, y4)。其中,(x1, y1),(x2, y2),(x3, y3),(x4, y4)是四个顶点的坐标。

这篇关于传统CV算法——基于Opencv的图像绘制的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1134736

相关文章

OpenCV在Java中的完整集成指南分享

《OpenCV在Java中的完整集成指南分享》本文详解了在Java中集成OpenCV的方法,涵盖jar包导入、dll配置、JNI路径设置及跨平台兼容性处理,提供了图像处理、特征检测、实时视频分析等应用... 目录1. OpenCV简介与应用领域1.1 OpenCV的诞生与发展1.2 OpenCV的应用领域2

在Java中使用OpenCV实践

《在Java中使用OpenCV实践》用户分享了在Java项目中集成OpenCV4.10.0的实践经验,涵盖库简介、Windows安装、依赖配置及灰度图测试,强调其在图像处理领域的多功能性,并计划后续探... 目录前言一 、OpenCV1.简介2.下载与安装3.目录说明二、在Java项目中使用三 、测试1.测

详解MySQL中JSON数据类型用法及与传统JSON字符串对比

《详解MySQL中JSON数据类型用法及与传统JSON字符串对比》MySQL从5.7版本开始引入了JSON数据类型,专门用于存储JSON格式的数据,本文将为大家简单介绍一下MySQL中JSON数据类型... 目录前言基本用法jsON数据类型 vs 传统JSON字符串1. 存储方式2. 查询方式对比3. 索引

基于Python开发一个图像水印批量添加工具

《基于Python开发一个图像水印批量添加工具》在当今数字化内容爆炸式增长的时代,图像版权保护已成为创作者和企业的核心需求,本方案将详细介绍一个基于PythonPIL库的工业级图像水印解决方案,有需要... 目录一、系统架构设计1.1 整体处理流程1.2 类结构设计(扩展版本)二、核心算法深入解析2.1 自

Python使用OpenCV实现获取视频时长的小工具

《Python使用OpenCV实现获取视频时长的小工具》在处理视频数据时,获取视频的时长是一项常见且基础的需求,本文将详细介绍如何使用Python和OpenCV获取视频时长,并对每一行代码进行深入解析... 目录一、代码实现二、代码解析1. 导入 OpenCV 库2. 定义获取视频时长的函数3. 打开视频文

Java中的雪花算法Snowflake解析与实践技巧

《Java中的雪花算法Snowflake解析与实践技巧》本文解析了雪花算法的原理、Java实现及生产实践,涵盖ID结构、位运算技巧、时钟回拨处理、WorkerId分配等关键点,并探讨了百度UidGen... 目录一、雪花算法核心原理1.1 算法起源1.2 ID结构详解1.3 核心特性二、Java实现解析2.

使用Python绘制3D堆叠条形图全解析

《使用Python绘制3D堆叠条形图全解析》在数据可视化的工具箱里,3D图表总能带来眼前一亮的效果,本文就来和大家聊聊如何使用Python实现绘制3D堆叠条形图,感兴趣的小伙伴可以了解下... 目录为什么选择 3D 堆叠条形图代码实现:从数据到 3D 世界的搭建核心代码逐行解析细节优化应用场景:3D 堆叠图

Python如何将OpenCV摄像头视频流通过浏览器播放

《Python如何将OpenCV摄像头视频流通过浏览器播放》:本文主要介绍Python如何将OpenCV摄像头视频流通过浏览器播放的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完... 目录方法1:使用Flask + MJPEG流实现代码使用方法优点缺点方法2:使用WebSocket传输视

使用Python和OpenCV库实现实时颜色识别系统

《使用Python和OpenCV库实现实时颜色识别系统》:本文主要介绍使用Python和OpenCV库实现的实时颜色识别系统,这个系统能够通过摄像头捕捉视频流,并在视频中指定区域内识别主要颜色(红... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间详解

OpenCV实现实时颜色检测的示例

《OpenCV实现实时颜色检测的示例》本文主要介绍了OpenCV实现实时颜色检测的示例,通过HSV色彩空间转换和色调范围判断实现红黄绿蓝颜色检测,包含视频捕捉、区域标记、颜色分析等功能,具有一定的参考... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间