本文实例为大家分享了OpenCv实现绘图功能的具体代码,供大家参考,具体内容如下
绘制一个图像在上面画线:
import numpy as np
import matplotlib.pyplot as plt
import cv2
#画图
def show(image):
plt.imshow(image)
plt.axis('off')
plt.show()
image = np.zeros((300,300,3),dtype='uint8')
#画线
green = (0,255,0)
cv2.line(image,(0,0),(300,300),green)#(0,0)开始点,(300,300)是结束点
#注意opencv的(0,0)点是从左上角开始的
blue = (0,0,225)
cv2.line(image,(300,0),(150,150),blue,5)#5表示线的宽度
show(image)
图像展示:
绘制一个矩形:
import numpy as np
import matplotlib.pyplot as plt
import cv2
#画图
def show(image):
plt.imshow(image)
plt.axis('off')
plt.show()
image = np.zeros((300,300,3),dtype='uint8')
#画线
green = (0,255,0)
cv2.line(image,(0,0),(300,300),green)#(0,0)开始点,(300,300)是结束点
#注意opencv的(0,0)点是从左上角开始的
blue = (0,0,225)
cv2.line(image,(300,0),(150,150),blue,5)#5表示线的宽度
#绘制矩形
red=(255,0,0)
cv2.rectangle(image,(10,10),(60,60),red,2)#2表示矩形框的宽度
#填充
green=(0,255,0)
cv2.rectangle(image,(40,40),(100,100),green,-1)#-1表示矩形框填充
show(image)
注意:填充和非填充的矩形画法
图形展示:
绘制一个圆形:
import numpy as np
import matplotlib.pyplot as plt
import cv2
#画图
def show(image):
plt.imshow(image)
plt.axis('off')
plt.show()
#绘制圆形
white=(255,255,255)
image1 =np.zeros((300,300,3),dtype='uint8')
#设置圆心位置shape[1]表示宽度,shape[0]表示高度
(cX,cY) = image1.shape[1]//2,image1.shape[0]//2
for r in range(0,151,15):#从0循环到151,步长是15,r表示半径
cv2.circle(image1,(cX,cY),r,white)
show(image1)
图形展示:
绘制一个填充圆形:
import numpy as np
import matplotlib.pyplot as plt
import cv2
#画图
def show(image):
plt.imshow(image)
plt.axis('off')
plt.show()
#绘制圆形填充
image2=np.zeros((300,300,3),dtype='uint8')
for i in range(10):
#半径取值
radiu=np.random.randint(5,200)
#颜色取值
color=np.random.randint(0,255,size=(3,)).tolist()
#圆心取值
pt=np.random.randint(0,300,size=(2,))
#画图
cv2.circle(image2,tuple(pt),radiu,color,-1)
show(image2)
图形展示:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持社区。 |