python录制全屏和选择区域录屏

最近给客户演示程序运行结果,我就想到用Python写一个录屏程序,在网上能找到现成的源码,但是它的录屏是录制整个屏幕的。但是在屏幕桌面下方的任务栏工具栏里有些东西,不希望被录制到视频里,因此需要实现一个选择区域录屏,就像qq截图那样的。我编写的程序如下,在主函数的输入参数里有一个选项控制是全屏录制还是选择区域录制。在编写这个程序时,我有一个疑问,在初始化写视频VideoWriter函数的第4个参数,它表示视频帧的高和宽,全屏录制方式的参数是(height,width),选择区域录制的参数是(width,height)。我曾尝试过把这个参数统一写成(height,width)或者(width,height)。但是运行程序后,总有一种录屏方式保存的视频文件是无法打开的,文件大小是1kb,不知这是为何?

import cv2
from PIL import ImageGrab
import numpy as np
import argparse
import time

global img
global point1, point2

def on_mouse(event, x, y, flags, param):
    global img, point1, point2
    img2 = img.copy()
    if event == cv2.EVENT_LBUTTONDOWN:  # 左键点击
        point1 = (x, y)
        cv2.circle(img2, point1, 10, (0, 255, 0), thickness=2)
        cv2.imshow('image', img2)
    elif event == cv2.EVENT_MOUSEMOVE and (flags & cv2.EVENT_FLAG_LBUTTON):  # 按住左键拖曳
        cv2.rectangle(img2, point1, (x, y), (255, 0, 0), thickness=2)
        cv2.imshow('image', img2)
    elif event == cv2.EVENT_LBUTTONUP:  # 左键释放
        point2 = (x, y)
        cv2.rectangle(img2, point1, point2, (0, 0, 255), thickness=2)
        cv2.imshow('image', img2)

def select_roi(frame):
    global img, point1, point2
    img = cv2.cvtColor(np.array(frame), cv2.COLOR_RGB2BGR)
    winname = 'image'
    cv2.namedWindow(winname, cv2.WINDOW_NORMAL)
    cv2.setWindowProperty(winname, cv2.WND_PROP_FULLSCREEN, cv2.WINDOW_FULLSCREEN)
    cv2.setMouseCallback(winname, on_mouse)
    cv2.imshow(winname, img)
    cv2.waitKey(0)
    cv2.destroyAllWindows()
    return point1, point2

if __name__ == '__main__':
    parser = argparse.ArgumentParser()
    parser.add_argument('--fps', type=int, default=10, help='frame per second')
    parser.add_argument('--total_time', type=int, default=15, help='video total time')
    parser.add_argument('--savename', type=str, default='video.mp4', help='save file name')
    parser.add_argument('--screen_type', default=1, type=int, choices=[0, 1], help='1: full screen, 0: region screen')
    args = parser.parse_args()

    print('等到3秒,请切换到录屏的页面')
    if args.screen_type==0:
        print('Press Esc to close window')
    time.sleep(3)

    curScreen = ImageGrab.grab()  # 获取屏幕对象
    if args.screen_type:
        height, width = curScreen.size
        min_x, min_y, max_x, max_y = 0, 0, width, height
        fourcc = cv2.VideoWriter_fourcc(*'mp4v')
        video = cv2.VideoWriter(args.savename, fourcc, args.fps, (height, width))
    else:
        point1, point2 = select_roi(curScreen)
        min_x = min(point1[0], point2[0])
        min_y = min(point1[1], point2[1])
        max_x = max(point1[0], point2[0])
        max_y = max(point1[1], point2[1])
        height, width = max_y - min_y, max_x - min_x
        fourcc = cv2.VideoWriter_fourcc(*'mp4v')
        video = cv2.VideoWriter(args.savename, fourcc, args.fps, (width, height))

    imageNum = 0
    while True:
        imageNum += 1
        captureImage = ImageGrab.grab()  # 抓取屏幕
        frame = cv2.cvtColor(np.array(captureImage), cv2.COLOR_RGB2BGR)
        if args.screen_type==0:
            frame = frame[min_y:max_y, min_x:max_x, :]
        
        if imageNum < args.fps * args.total_time:
            video.write(frame)
        # 退出条件
        if cv2.waitKey(50) == ord('q') or imageNum > args.fps * args.total_time:
            break
    video.release()
    cv2.destroyAllWindows()
要实现 Python区域录屏功能,你可以使用 `autogui` 和 `opencv` 库来实现。下面是一个示例代码: ```python import cv2 import numpy as np import pyautogui # 设置区域的左上角和右下角坐标 top_left = (100, 100) bottom_right = (500, 500) # 获取区域的宽度和高度 width = bottom_right[0] - top_left[0] height = bottom_right[1] - top_left[1] # 设置视频编解码器和帧率 video_codec = cv2.VideoWriter_fourcc(*"XVID") fps = 30 # 创建视频写入对象 video_writer = cv2.VideoWriter('recorded_video.mp4', video_codec, fps, (width, height)) while True: # 截取屏幕指定区域的图像 screenshot = pyautogui.screenshot() frame = np.array(screenshot) # 截取指定区域的图像 region = frame[top_left[1]:bottom_right[1], top_left[0]:bottom_right[0]] # 将图像写入视频文件 video_writer.write(region) # 展示录制区域面 cv2.imshow('Recording', region) # 按下 'q' 键停止录制 if cv2.waitKey(1) == ord('q'): break # 释放资源 cv2.destroyAllWindows() video_writer.release() ``` 这段代码首先定义了要录制区域,即 `top_left` 和 `bottom_right` 坐标。然后,它设置了视频的编码器、帧率和保存路径。接下来,进入一个循环,不断截取屏幕指定区域的图像,并将其写入视频文件中。同时,通过 OpenCV 的 `imshow` 方法展示正在录制区域面。当按下 'q' 键时,循环退出,释放资源。 你可以根据需要调整区域的坐标和视频的参数。请注意,这只是一个简单的示例,可能还需要根据实际需求进行修改和扩展。
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值