一、 基本图形绘制

1. 基本函数与参数

cv2.line(): 线

cv2.circle(): 圆

cv2.rectangle(): 矩形

cv2.ellipse(): 椭圆

cv2.putText(): 文字

  • img:需要绘制形状的图像。
  • color:颜色的形式,对于BGR,将作为元组传递比如(255,0,0)表示蓝色;对于灰度图,只需要传递标量值。
  • thickness: 线或圆形等图像的厚度,如果对闭合图像像圆形传递“-1”,它将填充形状, 默认厚度 = 1。
  • lineType:线的类型,默认情况下为8连接,cv2.LINE_AA 是适合曲线的抗锯齿线。

2. 画线

line(img, pt1, pt2, color, thickness=None, lineType=None, shift=None)

  • pt1:直线起点
  • pt2:直线终点

创建一个白色图像,并在其上从左上角到右下角绘制一条蓝线。

代码

import numpy as np
import cv2 # 创建黑底图像(像素值【0,255】,白色为255)
img = np.ones((512, 512, 3), np.uint8) * 255 # 绘制宽度为 5 px 的蓝线(B,G,R)
cv2.line(img, (0, 0), (511, 511), (255, 0, 0), 5)
cv2.imshow('line', img)
cv2.waitKey()

3. 矩形

rectangle(img, pt1, pt2, color, thickness=None, lineType=None, shift=None)

  • pt1:矩形左上角坐标
  • pt2:矩形右下角坐标

在图像的右上角绘制一个绿色矩形。

代码

import numpy as np
import cv2 # Create a black image
img = np.zeros((512, 512, 3), np.uint8) cv2.rectangle(img, (384, 0), (510, 128), (0, 255, 0), 3) cv2.imshow('rectangle', img)
cv2.waitKey()

4. 画圆

circle(img, center, radius, color, thickness=None, lineType=None, shift=None)

  • center:圆心位置
  • radius:半径

在图像的右上角绘制一个绿色矩形。

代码

import numpy as np
import cv2 # Create a black image
img = np.zeros((512, 512, 3), np.uint8) cv2.rectangle(img, (384, 0), (510, 128), (0, 255, 0), 3)
cv2.circle(img, (447, 63), 63, (0, 0, 255), -1) cv2.imshow('circle',img)
cv2.waitKey()

5. 椭圆

ellipse(img, center, axes, angle, startAngle, endAngle, color, thickness=None, lineType=None, shift=None)

  • center:中心位置
  • axes:轴长度(长轴长度,短轴长度)
  • angle:椭圆在逆时针方向上的旋转角度
  • startAngle:主轴顺时针方向测量的椭圆弧的起点
  • endAngle:主轴顺时针方向测量的椭圆弧的终点

在图像的右上角绘制一个绿色矩形。

代码

import numpy as np
import cv2 # Create a black image
img = np.zeros((512, 512, 3), np.uint8) cv2.ellipse(img, (256, 256), (100, 50), 0, 0, 180, 255, -1) cv2.imshow('ellipse', img)
cv2.waitKey()

6. 多边形

polylines(img, pts, isClosed, color, thickness=None, lineType=None, shift=None)

要绘制多边形,首先需要顶点坐标.将这些点转换为ROWSx1x2形状的数组,其中ROWS是顶点数,它应该是int32类型.

绘制一个带有四个黄色顶点的小多边形。

代码

import numpy as np
import cv2 # Create a black image
img = np.zeros((512, 512, 3), np.uint8) pts = np.array([[10,5],[20,30],[70,20],[50,10]], np.int32)
pts = pts.reshape((-1,1,2))
cv2.polylines(img,[pts],True,(0,255,255)) cv2.imshow('polylines',img)
cv2.waitKey()

Note:

如果第三个参数为False,您将获得连接所有点的折线,而不是闭合形状。

cv2.polylines()可用于绘制多条线,只需创建要绘制的所有行的列表并将其传递给函数, 所有线条都将单独绘制,绘制一组行比为每行调用cv2.line() 要好得多,速度更快。

7. 添加文字

putText(img, text, org, fontFace, fontScale, color, thickness=None, lineType=None, bottomLeftOrigin=None)

要将文本放入图像中,您需要指定以下内容。

  • text:要写入的文本数据
  • org:您想要放置它的位置坐标(即数据开始的左下角)。
  • fontFace:字体类型(检查cv2.putText() 文档以获取支持的字体)
  • fontScale:字体比例(指定字体大小)

常规的东西,如颜色,粗细,线型等。为了更好看,建议使用lineType = cv.LINE_AA。

图像上写白色的opencv几个字母

代码

import numpy as np
import cv2 # Create a black image
img = np.zeros((512, 512, 3), np.uint8) font = cv2.FONT_HERSHEY_SIMPLEX
cv2.putText(img, 'OpenCV', (10, 500), font, 4, (255, 255, 255), 2 , cv2.LINE_AA) cv2.imshow('text', img)
cv2.waitKey()

【opencv系列04】OpenCV4.X图形绘制的更多相关文章

  1. Win10系列:VC++ Direct3D图形绘制1

    通过前面的介绍,相信读者已经了解了如何新建一个用于开发Direct3D应用程序的项目模版,以及这个项目模版中用于绘制立体图形的主要函数.在本小节中,将通过一个具体的示例来介绍如何使用Visual St ...

  2. 【Windows编程】系列第五篇:GDI图形绘制

    上两篇我们学习了文本字符输出以及Unicode编写程序,知道如何用常见Win32输出文本字符串,这一篇我们来学习Windows编程中另一个非常重要的部分GDI图形绘图.Windows的GDI函数包含数 ...

  3. 【D3.V3.js系列教程】--(十五)SVG基本图形绘制

    [D3.V3.js系列教程]--(十五)SVG基本图形绘制 1.path <!DOCTYPE html> <html> <head> <meta charse ...

  4. Android画图系列(二)——自己定义View绘制基本图形

    这个系列主要是介绍下Android自己定义View和Android画图机制.自己能力有限.假设在介绍过程中有什么错误.欢迎指正 前言 在上一篇Android画图系列(一)--自己定义View基础中我们 ...

  5. 【Silverlight】Bing Maps学习系列(五):绘制多边形(Polygon)图形(转)

    [Silverlight]Bing Maps学习系列(五):绘制多边形(Polygon)图形 Bing Maps Silverlight Control支持用户自定义绘制多边形(Polygon)图形, ...

  6. 【opencv系列02】OpenCV4.X图像读取与显示

    一.读取图片 opencv中采用imread() 函数读取图像 imread(filename, flags=None)     filename 图片的路径     flags 图像读取方式 ● c ...

  7. 推荐12个最好的 JavaScript 图形绘制库

    众多周知,图形和图表要比文本更具表现力和说服力.图表是数据图形化的表示,通过形象的图表来展示数据,比如条形图,折线图,饼图等等.可视化图表可以帮助开发者更容易理解复杂的数据,提高生产的效率和 Web  ...

  8. css3之图形绘制

    由于近期的项目中出现了不规则的边框和图形, 所以重新温习一下CSS3的图形绘制...样式绘制的图形比图片的性能要好,体验更佳,关键一点是更加有趣! 以下几个例子主要是运用了css3中border.bo ...

  9. 从零开始openGL—— 二、 基本图形绘制

    前言 这是从零开始openGL系列文章的第二篇,在上篇文章中介绍了基本的环境配置,这篇文章将介绍如何绘制基本图形(圆.三角形.立方体.圆柱.圆锥). 基本框架 下面这里我先给出opengl的3D绘图的 ...

随机推荐

  1. 网络编程之C10K

    网络编程之C10K 虽然在过去的十几年里C10K问题已经可以很好的解决,但学习网络编程时研究C10K问题仍然价值巨大,因为技术的发展都是有规律和线索可循的,了解C10K问题及其解决思路,通过举一反三, ...

  2. 痞子衡嵌入式:恩智浦i.MX RT1xxx系列MCU启动那些事(11.2)- FlexSPI NOR连接方式大全(RT1060/1064(SIP))

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是恩智浦i.MX RT1060/1064(SIP)两款MCU的FlexSPI NOR启动的连接方式. 上一篇文章<FlexSPI N ...

  3. 性能测试之Mysql数据库调优

    一.前言 性能调优前提:无监控不调优,对于mysql性能的监控前几天有文章提到过,有兴趣的朋友可以去看一下 二.Mysql性能指标及问题分析和定位 1.我们在监控图表中关注的性能指标大概有这么几个:C ...

  4. 一篇带你看懂Flutter叠加组件Stack

    注意:无特殊说明,Flutter版本及Dart版本如下: Flutter版本: 1.12.13+hotfix.5 Dart版本: 2.7.0 Stack Stack组件可以将子组件叠加显示,根据子组件 ...

  5. sql01

    1.简介 2.外键 1)主键: 3.表间关联与外键 上面的两个表格通过厂家编号联系在一起,彼此相对独立.厂家编号就称为外键.厂家编号是厂家表的主键. 4.SQL 1)数据库登录 服务器名称选择:①机器 ...

  6. 【Amaple教程】6. 路由配置

    在 第1节<启动路由> 章节中为了能让单页应用顺利跑起来,我们提前介绍了简单的路由配置方法.我们已了解路由配置的目的是指定不同的url下对应的 模块节点(也叫做模块容器)内应该显示哪个模块 ...

  7. Python3关于current_app传递给子线程

    在学习Flask的时候,<Flask Web开发>这本书中有一个异步发送email的例子,其中用到了线程 from . import mail,create_app def send_as ...

  8. Vue+axios(interceptors) 实现http拦截 + router路由拦截 (双拦截)+ 请求自带loading效果

    axios interceptors 拦截器 //interceptors.js // vue axios配置 发起请求加载loading请求结束关闭loading // http request 请 ...

  9. Flutter保持页面状态AutomaticKeepAliveClientMixin

    使用bottomNavigationBar切换底部tab,再切换回来就会丢失之前的状态(重新渲染列表,丢失滚动条位置). 解决方法 使用 AutomaticKeepAliveClientMixin 重 ...

  10. django 从零开始 12 快速集合queryset对象

    使用序列化将查询到的quweyset对象进行一个格式转换          还没看文档理解 待写 from django.core.serializers import serializers 导入该 ...