opencv学习(三)——绘图功能
绘图功能
我们将学习以下函数:cv.line(),cv.circle(),cv.rectangle(),cv.ellipse(),cv.putText()
等。
在这些功能中,有一些相同的参数:
- img:你要绘制形状的图像。
- 形状的颜色。对于BGR,将其作为元组传递,例如:(255,0,0)对于蓝色。对于灰度,只需传递标量值即可。
- thickness: 线或圆等的厚度。如果传 -1 就是像圆的闭合图形,它将填充形状。默认 thickness = 1。
- lineType:线条类型,如 8 连接线,抗锯齿线等。默认情况下,是 8 连接线。
cv.LINE_AA
给出了抗锯齿的线条,看起来非常适合曲线。
一、画线
要绘制一条线,需要传递线的开始和结束坐标。我们将创建一个黑色图像,并从左上角到右下角在其上绘制一条蓝线。
import cv2
import numpy as np
def cv_show(name, img):
cv2.imshow(name, img)
cv2.waitKey(0)
cv2.destroyAllWindows()
#创建黑色的图像
img = np.zeros((512, 512, 3), np.uint8)
#绘制一条厚度为5的蓝色对角线
line = cv2.line(img, (0, 0), (511, 511), (255, 0, 0), 5)
cv_show('line', line)
二、画矩形
要绘制矩形,需要矩形的左上角和右下角。这次,我们将在图像的右上角绘制一个绿色矩形。
rectangle = cv2.rectangle(img, (384, 0), (510, 128), (0, 255, 0), 3)
cv_show('rectangle', rectangle)
三、画圆圈
要绘制一个圆,需要其中心坐标和半径。我们将在上面绘制的矩形内绘制一个圆。
circle = cv2.circle(img, (447, 63), 63, (0, 0, 255), -1)
cv_show('circle', circle)
四、画椭圆
要绘制椭圆,我们需要传递几个参数。一个参数是中心位置(x,y)。第二个参数是轴长度(长轴长度,短轴长度)。angle是椭圆沿逆时针方向旋转的角度。startAngle和endAngle表示从主轴沿顺时针方向测量的椭圆弧的开始和结束。如整圆就传 0 和 360。
elipse = cv2.ellipse(img, (256, 256), (100, 50), 0, 0, 180, (15, 255, 212), -1)
cv_show('elipse', elipse)
五、画多边形
要绘制多边形,首先需要顶点的坐标。将这些点组成形状为 ROWSx1x2
的数组,其中 ROWS
是顶点数,并且其类型应为int32。在这里,我们绘制了一个带有四个顶点的黄色小多边形。
pts = np.array([
[10, 5],
[20, 30],
[70, 20],
[50, 10]
], np.int32)
pts = pts.reshape((4, 1, 2))
polylines = cv2.polylines(img, [pts], True, (0, 255, 255))
cv_show('polylines', polylines)
如果第三个参数为False,您将获得一条连接所有点的折线,而不是闭合形状。cv.polylines()可用于绘制多条线。只需创建要绘制的所有线条的列表,然后将其传递给函数即可。所有线条将单独绘制。与为每条线调用cv.line相比,绘制一组线是一种更好,更快的方法。
六、向图像添加文本
在图像上加文字,你需要指定以下内容。
- 你想写的文字数据。
- 你想写的位置坐标 (如 左下角开始)。
- 字体类型。
- 常规的如颜色,粗细,线型等。为了更好看,线型使用 lintType = cv.LINE_AA。
我们将在图像上写一个白色的 ”OpenCV“。
font = cv2.FONT_HERSHEY_SIMPLEX
text = cv2.putText(img, 'OpenCV', (10, 500), font, 4, (255, 255, 255), 2, cv2.LINE_AA)
cv_show('text', text)
七、画OpenCV的logo
import cv2
import numpy as np
def cv_show(name, img):
cv2.imshow(name, img)
cv2.waitKey(0)
cv2.destroyAllWindows()
#创建黑色背景
background = np.zeros((512, 512, 3), np.uint8)
#画红圆
red_circle = cv2.circle(background, (256, 122), 50, (0, 0, 255), 40)
cv_show('red_circle', red_circle)
#画绿圆
green_circle = cv2.circle(background, (172, 282), 50, (0, 255, 0), 40)
cv_show('green_circle', green_circle)
#画蓝圆
blue_circle = cv2.circle(background, (342, 282), 50, (255, 0, 0), 40)
cv_show('blue_circle', blue_circle)
#画线(三角形)
pts1 = np.array([
[256, 122],
[202, 202],
[312, 202]
], np.int32)
pts1.reshape((3, 1, 2))
pts2 = np.array([
[162, 282],
[196, 202],
[270, 278]
], np.int32)
pts2.reshape((3, 1, 2))
pts3 = np.array([
[352, 282],
[292, 202],
[402, 202]
], np.int32)
pts3.reshape((3, 1, 2))
fillline = cv2.fillPoly(background, [pts1, pts2, pts3], (0, 0, 0))
cv_show('fillline', fillline)