一、绘图基础
下面是关于OpenCV绘图基础函数的说明和举例:
-
cv2.line():绘制直线
cv2.line(img, pt1, pt2, color, thickness, lineType)
-
img: 需要绘制直线的图像。
-
pt1: 直线起始点坐标。
-
pt2: 直线结束点坐标。
-
color: 直线颜色,可以是BGR格式的元组(如(255, 0, 0)表示蓝色)。
-
thickness: 直线的粗细,默认值为1。
-
lineType(可选参数): 直线的类型。默认情况下使用8连接线(cv2.LINE_8)。
-
cv2.rectangle():绘制矩形
cv2.rectangle(img, pt1, pt2, color, thickness, lineType)
-
img: 需要绘制矩形的图像。
-
pt1: 矩形左上角的坐标。
-
pt2: 矩形右下角的坐标。
-
color: 矩形颜色,可以是BGR格式的元组。
-
thickness: 矩形边框的粗细,默认值为1。
-
lineType(可选参数): 线条的类型。
-
cv2.circle():绘制圆形
cv2.circle(img, center, radius, color, thickness, lineType)
-
img: 需要绘制圆形的图像。
-
center: 圆心坐标。
-
radius: 圆的半径。
-
color: 圆形颜色,可以是BGR格式的元组。
-
thickness: 线条粗细,默认值为1。
-
lineType(可选参数): 线条的类型。
-
cv2.putText():在图像中绘制文本
cv2.putText(img, text, org, fontFace, fontScale, color, thickness, lineType[, bottomLeftOrigin])
-
img: 需要绘制文本的图像。
-
text: 要绘制的文本字符串。
-
org: 文本字符串的起始位置坐标,以左下角为原点。
-
fontFace: 字体类型,例如cv2.FONT_HERSHEY_SIMPLEX。
-
fontScale: 字体缩放因子。
-
color: 文本颜色,可以是BGR格式的元组。
-
thickness: 文本线条粗细,默认值为1。
-
lineType(可选参数): 线条的类型。
-
bottomLeftOrigin(可选参数): 如果设置为True,则坐标org表示左上角的坐标。
下面是一个示例代码,展示如何使用OpenCV进行基本绘图:
import cv2
import numpy as np创建一张空白图像
img = np.zeros((400, 400, 3), dtype=np.uint8)
绘制直线
cv2.line(img, (50, 50), (200, 50), (0, 255, 0), 3)
绘制矩形
cv2.rectangle(img, (100, 100), (300, 200), (0, 0, 255), 2)
绘制圆形
cv2.circle(img, (250, 150), 50, (255, 0, 0), -1)
绘制文本
cv2.putText(img, 'OpenCV', (50, 300), cv2.FONT_HERSHEY_SIMPLEX, 1, (255, 255, 255), 2)
显示图像
cv2.imshow('Image', img)
cv2.waitKey(0)
cv2.destroyAllWindows()
以上示例代码创建了一张空白图像,并在其中绘制了一条直线、一个矩形、一个圆形和一个文本。最后,显示出绘制结果。
二、鼠标交互
-
cv2.setMouseCallback():设置鼠标回调函数
cv2.setMouseCallback(winname, onMouse[, param])
-
winname: 窗口名称。
-
onMouse: 鼠标事件的回调函数,可以自定义。
-
param(可选参数): 传递给回调函数的额外参数。
- 鼠标回调函数常用的事件类型:
-
cv2.EVENT_MOUSEMOVE: 鼠标移动事件。
-
cv2.EVENT_LBUTTONDOWN: 左键按下事件。
-
cv2.EVENT_RBUTTONDOWN: 右键按下事件。
-
cv2.EVENT_MBUTTONDOWN: 中键按下事件。
-
cv2.EVENT_LBUTTONUP: 左键释放事件。
-
cv2.EVENT_RBUTTONUP: 右键释放事件。
-
cv2.EVENT_MBUTTONUP: 中键释放事件。
下面是一个示例代码,展示如何使用鼠标交互函数进行简单的绘图:
import cv2
# 鼠标回调函数
def draw_circle(event, x, y, flags, param):
if event == cv2.EVENT_LBUTTONDOWN:
cv2.circle(img, (x, y), 20, (0, 0, 255), -1)
elif event == cv2.EVENT_RBUTTONDOWN:
cv2.circle(img, (x, y), 20, (255, 0, 0), -1)
# 创建一张空白图像
img = np.zeros((400, 400, 3), dtype=np.uint8)
# 创建窗口并设置鼠标回调函数
cv2.namedWindow('Image')
cv2.setMouseCallback('Image', draw_circle)
while True:
# 显示图像
cv2.imshow('Image', img)
# 按下 'q' 键退出循环
if cv2.waitKey(1) & 0xFF == ord('q'):
break
# 关闭窗口
cv2.destroyAllWindows()
上述示例代码创建了一张空白图像,在鼠标左键按下时,在鼠标位置绘制一个红色的圆形;在鼠标右键按下时,在鼠标位置绘制一个蓝色的圆形。通过设置鼠标回调函数`draw_circle`,实现了简单的绘图交互功能。
三、滚动条
-
cv2.createTrackbar():创建滚动条
cv2.createTrackbar(trackbarName, windowName, value, count, onChange)
-
trackbarName: 滚动条的名称。
-
windowName: 包含滚动条的窗口名称。
-
value: 滚动条的初始值。
-
count: 滚动条的最大值(最小值默认为0)。
-
onChange: 滚动条事件回调函数。
-
onChange回调函数:
def onChange(value): # 处理滚动条变化时的操作 pass
下面是一个示例代码,展示如何使用滚动条函数进行图像亮度调节:
import cv2
# 回调函数,修改图像亮度
def update_brightness(value):
brightness = value - 100 # 调整范围为[-100, 100]
new_image = cv2.add(image, brightness) # 修改图像亮度
cv2.imshow('Image', new_image)
# 读取图像
image = cv2.imread('image.jpg')
# 创建窗口并显示图像
cv2.namedWindow('Image')
cv2.imshow('Image', image)
# 创建滚动条并设置回调函数
cv2.createTrackbar('Brightness', 'Image', 100, 200, update_brightness)
cv2.waitKey(0)
cv2.destroyAllWindows()
上述示例代码读取一张图像,并在窗口中显示图像。创建了一个名为"Brightness"的滚动条,范围为[-100, 100],初始值为100。通过设置回调函数`update_brightness`,当滚动条的值发生变化时,根据滚动条值的变化修改图像的亮度,并在窗口中实时显示调节后的图像。