opencv-python 1 图像、视频入门&绘图&鼠标做画笔&调色盘

参考地址:https://opencv-python-tutorials.readthedocs.io/zh/latest/

安装

pip install opencv-python

import cv2 as cv

以下所有内容来自上边连接中整理,使用中参考上边连接中的文档

图片

import cv2 as cv
from matplotlib import pyplot as plt

def image():
    # 以灰度方式打开图片
    img = cv.imread('C:\\Users\\yuyalong\\Pictures\\Camera Roll\\15.jpg', 0)
    print(img)

    # 用pyplot显示
    plt.imshow(img, cmap='gray', interpolation='bicubic')
    plt.xticks([]), plt.yticks([])  # to hide tick values on X and Y axis
    plt.show()

    # 用opencv显示
    cv.imshow('image', img)
    k = cv.waitKey(0)
    if k == 27:  # wait for ESC key to exit
        cv.destroyAllWindows()
    elif k == ord('s'):  # wait for 's' key to save and exit
        cv.imwrite('messigray.png', img)
        cv.destroyAllWindows()

    # 保存图片
    cv.imwrite('my.png', img)

pyplot显示
image
opencv显示
image

视频

用摄像头捕获视频
import cv2 as cv

def video():
    cap = cv.VideoCapture(0)
    # Define the codec and create VideoWriter object
    fourcc = cv.VideoWriter_fourcc(*'XVID')
    out = cv.VideoWriter('output.avi', fourcc, 20.0, (640, 480))
    while cap.isOpened():
        ret, frame = cap.read()

        if not ret:
            print('摄像头捕获图像失败')
            break

        gray = cv.cvtColor(frame, cv.COLOR_BGR2GRAY)
        # 显示
        cv.imshow('frame', gray)
        # 保存
        out.write(frame)
        if cv.waitKey(1) & 0xFF == ord('q'):
            break

    # When everything done, release the capture
    cap.release()
    out.release()
    cv.destroyAllWindows()

image

读取视频文件
def read_video():
    cap = cv.VideoCapture('output.avi')
    while cap.isOpened():
        res, frame = cap.read()
        if not res:
            print('读取视频失败')
            break
        gray = cv.cvtColor(frame, cv.COLOR_BGR2GRAY)
        cv.imshow('gray', gray)
        if cv.waitKey(25) & 0xFF == ord('q'):
            # cv.waitKey()参数 如果它太小,视频将非常快,如果它太高,视频将会很慢。在正常情况下,25毫秒就可以了
            break
    cap.release()
    cv.destroyAllWindows()

绘图功能

def draw_image():
    # Create a black image
    img = np.zeros((512, 512, 3), np.uint8)
    # Draw a diagonal blue line with thickness of 5 px
    # 直线 第一个参数是背景,第二个参数是线的起始点,第三个是终止点,第四个是线的颜色,第5个是线宽
    # cv.polylines()可用于绘制多条线。 只需创建要绘制的所有行的列表并将其传递给函数。 所有线条都将单独绘制。 绘制一组直线比每行调用cv.line()要好得多,速度更快。
    cv.line(img, (0, 0), (511, 511), (255, 0, 0), 5)

    # 矩形框
    cv.rectangle(img, (384, 0), (510, 128), (0, 255, 0), 3)

    # 圆
    cv.circle(img, (447, 63), 63, (0, 0, 255), -1)

    # 椭圆
    # 要绘制椭圆,我们需要传递几个参数,一个参数是椭圆中心位置(x,y),下一个是长轴长度和断轴长度(a,b),角度是椭圆在逆时针方向上的旋转角度,
    # startAngle和endAngle表示从主轴顺时针方向测量的椭圆弧的起点和终点,即给出值0和360给出完整的椭圆,给出值180则画出半个椭圆
    cv.ellipse(img, (256, 256), (100, 50), 0, 0, 180, 255, -1)

    # 多边形
    # 要绘制多边形,首先需要顶点坐标。 将这些点转换为ROWSx1x2的数组,其中ROWS是顶点数,它应该是int32类型。在这里,我们绘制一个带有四个黄色顶点的小多边形。
    # 注意:如果第三个参数为False,则绘制所有点的相连图形而不是闭合图形
    pts = np.array([[10, 5], [20, 30], [70, 20], [50, 10]], np.int32)
    pts = pts.reshape((-1, 1, 2))
    cv.polylines(img, [pts], True, (0, 255, 255))

    # 添加文字
    font = cv.FONT_HERSHEY_SIMPLEX
    cv.putText(img, 'OpenCV', (10, 500), font, 4, (255, 255, 255), 2, cv.LINE_AA)

    cv.imshow('image', img)
    if cv.waitKey(0) & 0xFF == ord('q'):
        cv.destroyAllWindows()

image

鼠标做画笔

查看所有支持的事件
events = [i for i in dir(cv) if 'EVENT' in i]
print(events)

--res

中文解释
cv.EVENT_MOUSEMOVE 0 鼠标移动事件
cv.EVENT_LBUTTONDOWN 1 鼠标左键按下事件
cv.EVENT_RBUTTONDOWN 2 鼠标右键按下事件
cv.EVENT_MBUTTONDOWN 3 鼠标中键按下事件
cv.EVENT_LBUTTONUP 4 鼠标左键释放事件
cv.EVENT_RBUTTONUP 5 鼠标右键释放事件
cv.EVENT_MBUTTONUP 6 鼠标中键释放事件
cv.EVENT_LBUTTONBLCLK 7 鼠标左键双击事件
cv.EVENT_RBUTTONBLCLK 8 鼠标右键双击事件
cv.EVENT_MBUTTONBLCLK 9 鼠标中键双击事件
cv.EVENT_MOUSEWHEEL 10 滑动滚轮上下滚动
cv.EVENT_MOUSEHWHEEL 11 滑动滚轮左右滚动

鼠标事件回调
def mouse_event():
    # mouse callback function
    def draw_circle(event, x, y, flags, param):
        # 左键双击画圆
        if event == cv.EVENT_LBUTTONDBLCLK:
            cv.circle(img, (x, y), 10, (255, 0, 0), -1)
        # 当左键按下并移动时绘制图形,event可以查看移动,flag查看是否按下
        elif event == cv.EVENT_MOUSEMOVE and flags == cv.EVENT_FLAG_LBUTTON:
            cv.circle(img, (x, y), 10, (255, 0, 0), -1)

    # Create a black image, a window and bind the function to window
    img = np.zeros((512, 512, 3), np.uint8)
    cv.namedWindow('image')

    # 鼠标事件回调
    cv.setMouseCallback('image', draw_circle)
    while True:
        cv.imshow('image', img)
        if cv.waitKey(20) & 0xFF == 27:  # esc
            break
    cv.destroyAllWindows()

双击画圆
image
按下左键移动画轨迹
image

调色盘
def nothing(x):
    pass

# Create a black image, a window
img = np.zeros((300, 512, 3), np.uint8)
cv.namedWindow('image')

# create trackbars for color change
cv.createTrackbar('R', 'image', 0, 255, nothing)
cv.createTrackbar('G', 'image', 0, 255, nothing)
cv.createTrackbar('B', 'image', 0, 255, nothing)

# create switch for ON/OFF functionality
switch = 'switch'
cv.createTrackbar(switch, 'image', 0, 1, nothing)

while True:
    cv.imshow('image', img)
    k = cv.waitKey(1) & 0xFF
    if k == 27:
        break

    # get current positions of four trackbars
    r = cv.getTrackbarPos('R', 'image')
    g = cv.getTrackbarPos('G', 'image')
    b = cv.getTrackbarPos('B', 'image')
    s = cv.getTrackbarPos(switch, 'image')
    if s == 0:
        img[:] = 0
    else:
        img[:] = [b, g, r]

cv.destroyAllWindows()

image

posted @ 2023-03-23 17:37  一枚码农  阅读(89)  评论(0编辑  收藏  举报