📅  最后修改于: 2021-01-07 06:35:20             🧑  作者: Mango
我们可以在图像上绘制各种形状,例如圆形,矩形,椭圆形,折线,凸形等。当要突出显示输入图像中的任何对象时,可以使用它。 OpenCV提供每种形状的功能。在这里,我们将了解绘图功能。
我们可以使用cv2.circle()函数在图像上绘制圆。语法如下:
cv2.circle(img, center, radius, color[,thickness [, lineType[,shift]]])
考虑以下示例:
import numpy as np
import cv2
img = cv2.imread(r"C:\Users\DEVANSH SHARMA\cat.jpeg",1)
cv2.circle(img,(80,80), 55, (0,255,0), -1)
cv2.imshow('image',img)
cv2.waitKey(0)
cv2.destroyAllWindows()
输出:
的OpenCV提供一个函数来绘制一个简单的,厚或填充右矩形。语法如下:
cv2.rectangle(img, pt1, pt2, color[, thickness[,lineType[,shift]]])
考虑以下示例:
import numpy as np
import cv2
img = cv2.imread(r"C:\Users\DEVANSH SHARMA\cat.jpeg",1)
cv2.rectangle(img,(15,25),(200,150),(0,255,255),15)
cv2.imshow('image',img)
cv2.waitKey(0)
cv2.destroyAllWindows()
输出:
我们可以使用cv2.ellipse()函数在图像上绘制椭圆。它可以绘制简单或粗略的椭圆弧,也可以填充椭圆扇形。
cv2.ellipse(img, center, axes, angle, startAngle, endAngle, color[, thickness[, lineType[, shift]]])
cv2.ellipse(img, box, color[, thickness[, lineType]])
考虑以下示例:
import numpy as np
import cv2
img = cv2.imread(r"C:\Users\DEVANSH SHARMA\cat.jpeg",1)
cv2.ellipse(img, (250, 150), (80, 20), 5, 0, 360, (0,0,255), -1)
cv2.imshow('image',img)
cv2.waitKey(0)
cv2.destroyAllWindows()
输出:
有两个绘制椭圆的功能。第一个函数用于绘制整个椭圆,而不是绕过startAngle = 0和endAngle = 360的圆弧。椭圆的第二个函数用于绘制椭圆轮廓,实心椭圆,椭圆弧或实心椭圆扇形。
OpenCV提供line()函数在图像上绘制线条。它在图像中的ptr1和ptr2点之间绘制线段。图像边界剪切线。
cv2.line(img, pt1, pt2, color[, thickness[, lineType[, shift]]])
考虑以下示例:
import numpy as np
import cv2
img = cv2.imread(r"C:\Users\DEVANSH SHARMA\cat.jpeg",1)
cv2.line(img,(10,0),(150,150),(0,0,0),15)
cv2.imshow('image',img)
cv2.waitKey(0)
cv2.destroyAllWindows()
输出:
我们可以使用putText()函数在图像上写文本。语法如下。
cv2.putText(img, text, org, font, color)
考虑以下示例。
import numpy as np
import cv2
font = cv2.FONT_HERSHEY_SIMPLEX
# Create a black image.
img = cv2.imread(r"C:\Users\DEVANSH SHARMA\cat.jpeg",1)
cv2.putText(img,'Hack Projects',(10,500), font, 1,(255,255,255),2)
#Display the image
cv2.imshow("image",img)
cv2.waitKey(0)
输出:
我们可以在图像上绘制折线。 OpenCV提供了polylines()函数,该函数用于在图像上绘制多边形曲线。语法如下:
cv2.polyLine(img, polys, is_closed, color, thickness=1, lineType=8, shift=0)
考虑以下程序在图像中绘制折线:
import numpy as np
import cv2
img = cv2.imread(r'C:\Users\DEVANSH SHARMA\forest.jpg',cv2.IMREAD_COLOR)
#defining points for polylines
pts = np.array([[100,50],[200,300],[700,200],[500,100]], np.int32)
# pts = pts.reshape((-1,1,2))
cv2.polylines(img, [pts], True, (0,255,255), 3)
cv2.imshow('image',img)
cv2.waitKey(0)
cv2.destroyAllWindows()
输出: