一、 基本图形绘制

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. JQuery之选择器篇(一)

      今天回顾了之前学习的JQuery选择器,现在简单的总结一下. JQuery选择器类型   主要分为四类 基本选择器 层级选择器 过滤选择器 表单选择器 基本选择器   基本选择器是jQuery中最 ...

  2. The Integers and the Real Numbers

    以上我們談了一些 邏輯的基礎,接下來我們會談一些 數學的基礎,也就是整數與實數系統.其實我們已經用了很多,非正式地,接下來我們會正式地討論他們. 要 建構 實數系統的一個方法就是利用公理跟集合論來建構 ...

  3. C++程序设计--运算符重载

    目录 1, 运算符重载2, 赋值运算符的重载3, 流插入运算符重载4,自加/自减运算符的重载 运算符重载 作用:对抽象数据类型也能够直接使用C++提供的运算符.使得程序更简洁.代码更容易理解. 运算符 ...

  4. Android注解支持Support Annotations详解

    ###注解支持(Support Annotations)Android support library从19.1版本开始引入了一个新的注解库,它包含很多有用的元注解,你能用它们修饰你的代码,帮助你发现 ...

  5. iPhone7会点燃苹果内战吗?

    ​ 苹果第十代手机产品iPhone7或者叫iPhone6 SE注定是设计上的平庸之作,与之前的产品相比,这两款产品只是进行了小幅度地升级,对于一些需要靠苹果logo标榜身份的人来说,几乎是没有吸引力的 ...

  6. Python——4Dict和Set类型

    */ * Copyright (c) 2016,烟台大学计算机与控制工程学院 * All rights reserved. * 文件名:text.cpp * 作者:常轩 * 微信公众号:Worldhe ...

  7. 在Linux上显示正在运行的进程的线程ID

    在Linux上显示正在运行的进程的线程ID 在上Linux," ps -T"可以显示正在运行的进程的线程信息: # ps -T 2739 PID SPID TTY STAT TIM ...

  8. 初学qt——提示窗体

    带选择的窗体 QMessageBox::StandardButton rb = QMessageBox::critical(NULL, QString::fromLocal8Bit("提示& ...

  9. Python开发(一):Python介绍与基础知识

    Python开发(一):Python介绍与基础知识 本次内容 一:Python介绍: 二:Python是一门什么语言 三:Python:安装 四:第一个程序 “Hello world” 五:Pytho ...

  10. k8s环境部署.net core web项目(docker本地仓库)

    在之前的文档中,我们部署了.net core web在k8s环境下,达成了集群管理项目的目的.但是,由于是本地部署,需要在所有的node节点都拉取好镜像,这是非常麻烦的,为了只维护一份代码,同步更新. ...