python学opencv|读取图像(二十二)使用cv2.polylines()绘制多边形

news2025/1/1 7:58:55

【1】引言

前序学习进程中,已经掌握了使用python+opencv绘制线段、矩形和圆形的基本操作,相关链接包括且不限于:

python学opencv|读取图像(十八)使用cv2.line创造线段-CSDN博客

python学opencv|读取图像(十九)使用cv2.rectangle()绘制矩形-CSDN博客

python学opencv|读取图像(二十)使用cv2.circle()绘制圆形-CSDN博客

python学opencv|读取图像(二十一)使用cv2.circle()绘制圆形进阶-CSDN博客

在此基础上,我们进一步学习回合绘制多边形。

【2】官网教程

点击下述链接,直达官网:

OpenCV: Drawing Functions

在官网,会看到如下介绍:

图1 

这里的几个参数意义为:

void cv::polylines     (     InputOutputArray     img,  #输入的画布
        InputArrayOfArrays     pts, #多边形的各个端点
        bool     isClosed, #图形是否封闭,True为封闭图形,False为开放图形
        const Scalar &     color, #图形颜色
        int     thickness = 1, #图形线宽
        int     lineType = LINE_8, #线条存储类型
        int     shift = 0 ) #各个短点的坐标数据存储类型,暂无需关注

【3】代码测试

从这里,我们开始测试代码。

代码可以在绘制矩形的基础上稍作修改,这里先给出完整段落(代码里有大量的注释,方便大家直接调用后练习绘制线段、圆和矩形):

import numpy as np  # 引入numpy模块
import cv2 as cv  # 引入cv模块

canvas = np.ones((580, 580, 3), np.uint8) * 225  # 绘制一个580*580大小的画布,3代表有3个通道,unit8为图像存储格式
canvasa = np.ones((580, 580, 3), np.uint8) * 25  # 绘制一个580*580大小的画布,3代表有3个通道,unit8为图像存储格式

# 第一个通道值
#for i in range(0, 580, 1):
    #for j in range(0, 580, 1):
        #canvas[i, j, 0] = 0.2 * (i + j)  # 第一个通道值

# 第二个通道值
#for i in range(0, 580, 1):
    #for j in range(0, 580, 1):
        #canvas[i, j, 1] = 50 * np.cos(i ^ j) + 55 * np.sin(j ^ i) + 150 * np.sin(j - i)  # 第二个通道值

# 第三个通道值
for i in range(0, 580, 1):
    for j in range(0, 580, 1):
        canvas[i, j, 2] = 100 * np.tanh(i + j) + 100 * np.tanh(i - j) + 50 * np.cos(j - i)  # 第三个通道值

pts0=np.array([[100,50],[200,50],[250,250],[50,250]],np.int32)
pts1=np.array([[100,300],[250,500],[200,300],[50,500]],np.int32)
pts2=np.array([[350,150],[450,150],[500,350],[300,350]],np.int32)

canvas0=cv.polylines(canvas,[pts0],True,(120,100,25),5)
canvas1=cv.polylines(canvas,[pts1],False,(120,200,225),5)
canvas2=cv.polylines(canvas,[pts2],True,(120,100,25),5)

#x0=285 #圆心横坐标
#y0=285 #圆心横坐标
#r=160 #半径
#for i in range(0,10,1):
    #canvas = cv.circle(canvas, ((i-5)*5+280, (i-5)*5+280), (200+i,15*i,10*i), 2) #输出同心圆

#canvas = cv.circle(canvas, (285, 285), 80, (0, 0, 255), 3)  # 第一个圆形
#canvas = cv.circle(canvas, (100, 285), 80, (0, 255, 255), -1)  # 第二个圆形
#canvas = cv.circle(canvas, (470, 285), 80, (255, 0, 0), -1)  # 第三个圆形
# canvas = cv.rectangle(canvas, (50, 30), (530, 550), (155, 120, 60), 5)  # 矩形
# canvas = cv.rectangle(canvas, (80, 80), (500, 500), (55, 160, 230), 10)  # 矩形
# canvas = cv.rectangle(canvas, (150, 150), (430, 430), (50, 120, 90), -1)  # 矩形
# canvas = cv.line(canvas, (50, 550), (550, 550), (58, 50, 150), 15)  # 线段
# canvas = cv.line(canvas, (300, 50), (300, 550), (120, 150, 25), 20)  # 线段

cv.imshow('Polylines', canvas)  # 在屏幕展示绘制圆形的效果
#cv.imshow('Polylines1', canvas1)  # 在屏幕展示绘制圆形的效果
#cv.imshow('Polylines2', canvas2)  # 在屏幕展示绘制圆形的效果
cv.imwrite('Polylines.png', canvas)  # 保存图像
cv.waitKey()  # 图像不会自动关闭
cv.destroyAllWindows()  # 释放所有窗口

代码运行后获得的图像为:

图2

这里的核心行代码的意义是:

pts0=np.array([[100,50],[200,50],[250,250],[50,250]],np.int32) 是用于绘图的第一组点。

pts1=np.array([[100,300],[250,500],[200,300],[50,500]],np.int32) 是用于绘图的第二组点。

pts2=np.array([[350,150],[450,150],[500,350],[300,350]],np.int32) 是用于绘图的第三组点 。

canvas0=cv.polylines(canvas,[pts0],True,(120,100,25),5) 是调用第一组点绘制的多边形 。

canvas1=cv.polylines(canvas,[pts1],False,(120,200,225),5) 是调用第二组点绘制的多边形。

canvas2=cv.polylines(canvas,[pts2],True,(120,100,25),5) 是调用第三组点绘制的多边形。

在左下角看到一个不封闭交叉的图像,这是因为:

【a】canvas1=cv.polylines(canvas,[pts1],False,(120,200,225),5),这里的False约定了图像不封闭。

【b】pts1=np.array([[100,300],[250,500],[200,300],[50,500]],np.int32) 里面的点没有按照顺时针或者逆时针的顺序给定,所以点的连线出现了交叉。

【4】代码修改

继续增加代码,让背景颜色更加繁复:

# 第一个通道值
for i in range(0, 580, 1):
    for j in range(0, 580, 1):
        canvas[i, j, 0] = 0.2 * (i + j)  # 第一个通道值

# 第二个通道值
for i in range(0, 580, 1):
    for j in range(0, 580, 1):
        canvas[i, j, 1] = 50 * np.cos(i ^ 255) + 55 * np.sin(j ^ 255) + 150 * np.sin(255+j - i)  # 第二个通道值

# 第三个通道值
for i in range(0, 580, 1):
    for j in range(0, 580, 1):
        canvas[i, j, 2] = 100 * np.tanh(i + j+255) + 100 * np.tanh(i - j-255) + 50 * np.cos(j - i)  # 第三个通道值

运行代码后的图像为:

图3

此时的完整代码为:

import numpy as np  # 引入numpy模块
import cv2 as cv  # 引入cv模块

canvas = np.ones((580, 580, 3), np.uint8) * 225  # 绘制一个580*580大小的画布,3代表有3个通道,unit8为图像存储格式
canvasa = np.ones((580, 580, 3), np.uint8) * 25  # 绘制一个580*580大小的画布,3代表有3个通道,unit8为图像存储格式

# 第一个通道值
for i in range(0, 580, 1):
    for j in range(0, 580, 1):
        canvas[i, j, 0] = 0.2 * (i + j)  # 第一个通道值

# 第二个通道值
for i in range(0, 580, 1):
    for j in range(0, 580, 1):
        canvas[i, j, 1] = 50 * np.cos(i ^ 255) + 55 * np.sin(j ^ 255) + 150 * np.sin(255+j - i)  # 第二个通道值

# 第三个通道值
for i in range(0, 580, 1):
    for j in range(0, 580, 1):
        canvas[i, j, 2] = 100 * np.tanh(i + j+255) + 100 * np.tanh(i - j-255) + 50 * np.cos(j - i)  # 第三个通道值

pts0=np.array([[100,50],[200,50],[250,250],[50,250]],np.int32) #第一组点
pts1=np.array([[100,300],[250,500],[200,300],[50,500]],np.int32) #第二组点
pts2=np.array([[350,150],[450,150],[500,350],[300,350]],np.int32) #第三组点

canvas0=cv.polylines(canvas,[pts0],True,(120,100,25),5) #多边形
canvas1=cv.polylines(canvas,[pts1],False,(120,200,225),5) #多边形
canvas2=cv.polylines(canvas,[pts2],True,(120,100,25),5) #多边形

#x0=285 #圆心横坐标
#y0=285 #圆心横坐标
#r=160 #半径
#for i in range(0,10,1):
    #canvas = cv.circle(canvas, ((i-5)*5+280, (i-5)*5+280), (200+i,15*i,10*i), 2) #输出同心圆

#canvas = cv.circle(canvas, (285, 285), 80, (0, 0, 255), 3)  # 第一个圆形
#canvas = cv.circle(canvas, (100, 285), 80, (0, 255, 255), -1)  # 第二个圆形
#canvas = cv.circle(canvas, (470, 285), 80, (255, 0, 0), -1)  # 第三个圆形
# canvas = cv.rectangle(canvas, (50, 30), (530, 550), (155, 120, 60), 5)  # 矩形
# canvas = cv.rectangle(canvas, (80, 80), (500, 500), (55, 160, 230), 10)  # 矩形
# canvas = cv.rectangle(canvas, (150, 150), (430, 430), (50, 120, 90), -1)  # 矩形
# canvas = cv.line(canvas, (50, 550), (550, 550), (58, 50, 150), 15)  # 线段
# canvas = cv.line(canvas, (300, 50), (300, 550), (120, 150, 25), 20)  # 线段

cv.imshow('Polylines', canvas1)  # 在屏幕展示绘制圆形的效果
#cv.imshow('Polylines1', canvas1)  # 在屏幕展示绘制圆形的效果
#cv.imshow('Polylines2', canvas2)  # 在屏幕展示绘制圆形的效果
cv.imwrite('Polylines.png', canvas)  # 保存图像
cv.waitKey()  # 图像不会自动关闭
cv.destroyAllWindows()  # 释放所有窗口

【5】总结

掌握了python+opencv绘制多边形的基本技巧。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2267492.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

OCR实践-Table-Transformer

前言 书接上文 OCR实践—PaddleOCR Table-Transformer 与 PubTables-1M table-transformer,来自微软,基于Detr,在PubTables1M 数据集上进行训练,模型是在提出数据集同时的工作, paper PubTables-1M: Towards comp…

计算机毕业设计hadoop+spark+hive民宿推荐系统 酒店推荐系统 民宿价格预测 酒店价格 预测 机器学习 深度学习 Python爬虫 HDFS集群

温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 作者简介:Java领…

Java - 日志体系_Apache Commons Logging(JCL)日志接口库_桥接Logback 及 源码分析

文章目录 PreApache CommonsApache Commons ProperLogging (Apache Commons Logging ) JCL 集成logbackPOM依赖配置文件 logback.xml使用 源码分析jcl-over-slf4j 的工作原理1. LogFactory 的实现2. SLF4JLogFactory 和 Log 的实例化过程3. SLF4JLog 和 …

多模态论文笔记——LLaVA

大家好,这里是好评笔记,公主号:Goodnote,专栏文章私信限时Free。本文详细介绍多模态模型:LLaVA。处理包含图像和文本的多模态数据,并生成合理准确的回答。 文章目录 论文模型架构视觉编码器语言模型多模态融…

汽车的hmi设计还能有哪些创新?要从哪些方面下手

随着科技的不断发展,汽车的人机交互界面(HMI)设计也在不断演进。目前,汽车 HMI 已经从传统的物理按钮和仪表盘发展到了数字化、智能化的交互系统。然而,仍有许多创新的空间等待探索。那么,汽车的 HMI 设计还…

基于深度学习(HyperLPR3框架)的中文车牌识别系统-前言

参考链接: GitHub - szad670401/HyperLPR: 基于深度学习高性能中文车牌识别 High Performance Chinese License Plate Recognition Framework.基于深度学习高性能中文车牌识别 High Performance Chinese License Plate Recognition Framework. - szad670401/HyperL…

Python库中各种插值函数的使用

文章目录 Python库中各种插值函数的使用数据1: 随机的数据数据2: 从 cos轨迹中取值B样条三次样条Akmia画图显示数据1 的比较结果位置比较示意图速度比较示意图加速度比较示意图 数据2 的比较结果位置比较示意图速度比较示意图加速度比较示意图 全部代码如…

ip归属地怎么判定?如何查看自己ip属地

在当今数字化时代,IP地址作为互联网通信的基础,扮演着至关重要的角色。而IP归属地的判定与查看,不仅关乎网络安全、隐私保护,还直接影响到社交平台的信任机制与信息传播的真实性。本文将深入探讨IP归属地的判定原理以及如何查看自…

soular使用教程

用 soular 配置你的组织,工作更高效!以下是快速上手的简单步骤:  1. 账号管理 可以对账号信息进行多方面管理,包括分配不同的部门、用户组等,从而确保账号权限和职责的清晰分配。  1.1 用…

JS媒体查询之matchMedia API 实现跟随系统主题色切换效果

📊写在前面 在网页设计中,跟随系统主题切换可以通过CSS和JavaScript实现。可以通过定义两套CSS变量,根据系统主题的颜色来切换变量的生效,从而实现不同主题下的页面样式变化。 例如,可以使用媒体查询API来获取系统主题…

客户案例:基于慧集通的致远OA与海康威视智能会议设备集成方案

一、引言 本案例原型公司是我国生产纺织原料的大型上市企业,主导产品为再生纤维素长丝、氨纶等系列产品。公司产品不仅得到国内客户认可,还远销海外,合作伙伴遍布德国、意大利、日本、韩国、土耳其、印度等30多个国家和地区。 二、简介 &am…

【Leetcode】3046. 分割数组

文章目录 题目思路代码复杂度分析时间复杂度空间复杂度 结果 题目 题目链接🔗 给你一个长度为 偶数 的整数数组 n u m s nums nums 。你需要将这个数组分割成 n u m s 1 nums1 nums1 和 n u m s 2 nums2 nums2 两部分,要求: n u m s 1. l…

掌握软件工程基础:知识点全面解析【chap07、chap10】

chap07 软件设计基础 1.信息隐藏、内聚度和耦合度(在七种级别里应该注意什么原则)的概念 1.信息隐藏 模块独立的概念 o 模块应该设计得使其所含信息(过程和数据)对于那些不需要这些信息的模块不可访问; o 每个模块只完成一个相对独立的特定功能; o 模…

操作系统实验三 存储管理

实验三 存储管理 一、实验目的 通过实验使学生了解可变式分区管理使用的主要数据结构,分配、回收的主要技术,了解最优适应分配、最坏适应分配、最先适应分配和循环适应分配等分配算法。基本能达到下列具体的目标: 掌握初步进程在内存中的映…

40.2 预聚合和prometheus-record使用

本节重点介绍 : downsample降采样可以降低查询数据量 prometheus原生不支持downsample 实时查询/聚合 VS 预查询/聚合的优缺点 实时查询/聚合条件随意组合,性能差预查询/聚合 性能好,聚合条件需要提前定义 prometheus的预查询/聚合配置举例 downsample…

win11中win加方向键失效的原因

1、可能是你把win键锁了: 解决办法:先按Fn键,再按win键 2、可能是可能是 贴靠窗口设置 中将贴靠窗口关闭了,只需要将其打开就好了

【Rust自学】7.4. use关键字 Pt.2 :重导入与换国内镜像源教程

喜欢的话别忘了点赞、收藏加关注哦,对接下来的教程有兴趣的可以关注专栏。谢谢喵!(・ω・) 7.4.1. 使用pub use重新导入名称 使用use将路径导入作用域内后。该名称在词作用域内是私有的。 以上一篇文章的代码为例: m…

算法练习——模拟题

前言:模拟题的特点在于没有什么固定的技巧,完全考验自己的代码能力,因此有助于提升自己的代码水平。如果说一定有什么技巧的话,那就是有的模拟题能够通过找规律来简化算法。 一:替换所有问号 题目要求: 解…

三层交换机配置

✍作者:柒烨带你飞 💪格言:生活的情况越艰难,我越感到自己更坚强;我这个人走得很慢,但我从不后退。 📜系列专栏:网路安全入门系列 目录 一,三层交换二,实验案…

TCP-UDP调试工具推荐:Socket通信测试教程(附详细图解)

前言 在网络编程与应用开发中,调试始终是一项不可忽视的重要环节。尤其是在涉及TCP/IP、UDP等底层网络通信协议时,如何确保数据能够准确无误地在不同节点间传输,是许多开发者关注的核心问题。 调试的难点不仅在于定位连接建立、数据流控制及…