【端午安康】龙舟争渡Plug-In

文章目录

  • 正文
  • 附录A:关于Python的录屏方法总结(来自DeepSeek的回答)
    • 1. 使用 `pyautogui` 和 `OpenCV` 录制屏幕
    • 2. 使用 `mss` 库(高效屏幕捕获)
    • 3. 使用 `PIL.ImageGrab` 录制屏幕
      • 4. 使用 Windows 原生快捷键录制(非 Python 方案)
    • 5. 结合 GUI 实现录屏工具(高级方案)
    • 总结
  • 附录B:关于视频格式转换(以avi2mp4为例)
    • 方法1:使用 `moviepy` 库(推荐)
    • 方法2:使用 `OpenCV` + `FFmpeg`
    • 方法3:直接使用 `FFmpeg` 命令行(最高效)
    • 方法4:使用 `PyAV`(高级控制)
      • 常见问题解决
      • 总结


正文

端午整个烂活。

龙舟争渡2025

旗帜颜色的识别方法选了个最笨的,直接截取那块,然后矩阵相减求F范数(二模),匹配差距最小的那个即可,因此需要提前把所有情况的截图准备好,完整的图片材料和演示视频在https://github.com/caoyang-sufe/LongZhouZhengDu2025

目前速度不是特别快,但也基本够用了。如果间隔取太小容易出错,因为截屏速度跟不上。

# -*- coding: utf-8 -*-
# @author: caoyang
# @email: caoyang@stu.sufe.edu.cnimport cv2
import time
import numpy
import pyautoguifrom PIL import Image
from numpy.linalg import norm
from pynput.keyboard import Key, Controller as KeyController
from pynput.mouse import Button, Controller as MouseControllerimport numpy as npY1, Y2, X1, X2 = 200, 400, 830, 1090	# 这组参数适配1920×1080尺寸的屏幕jcolor_to_key = {'y': 'd', 'r': 'f', 'b': 'j', 'g': 'k'}def easy_show(image: numpy.ndarray, window_title: str="image") -> None:"""Show a image in a new window."""cv2.imshow(window_title,image)cv2.waitKey(0)cv2.destroyAllWindows()def get_screenshot():image = pyautogui.screenshot()image = cv2.cvtColor(np.asarray(image), cv2.COLOR_RGB2BGR)return imagedef load_labels():labels = dict()for color in "yrbg":for n in "12":image = Image.open(f"./temp/{color}{n}.png")image = cv2.cvtColor(np.asarray(image), cv2.COLOR_RGB2BGR)clipped_image = image[Y1: Y2, X1: X2, :]labels[f"{color}{n}"] = clipped_imagereturn labels# 判断旗帜颜色及点击次数
def classify_label(screenshot, labels):clipped_image = screenshot[Y1: Y2, X1: X2, :]diffs = {}for key, label in labels.items():diff = norm(label - clipped_image)diffs[key] = diffprint(diffs)predicted_label = min(diffs, key = lambda x: diffs[x])return predicted_labeldef run():keyboard_controller = KeyController()while True:screenshot = get_screenshot()labels = load_labels()predicted_label = classify_label(screenshot, labels)color = predicted_label[0]key_char = color_to_key[color]n = int(predicted_label[1])for _ in range(n):keyboard_controller.press(key_char)time.sleep(.05)keyboard_controller.release(key_char)time.sleep(.05)time.sleep(.1)time.sleep(2)
run()

烂活完了顺便延申一点,感觉录屏还是有点问题,cv2.waitKey()总是捕获不到键位,之前就发现过这个问题,不知道怎么回事,问了一下deepseek,还是得用ffmpeg才行


附录A:关于Python的录屏方法总结(来自DeepSeek的回答)


1. 使用 pyautoguiOpenCV 录制屏幕

这种方法通过不断截取屏幕画面并将其合成为视频文件来实现录屏。

import pyautogui
import cv2
import numpy as np# 设置录屏参数
screen_size = pyautogui.size()  # 获取屏幕分辨率
fps = 30.0
output_file = "screen_recording.avi"# 创建视频编码器
fourcc = cv2.VideoWriter_fourcc(*"XVID")
out = cv2.VideoWriter(output_file, fourcc, fps, screen_size)# 开始录屏
while True:img = pyautogui.screenshot()  # 截取屏幕frame = np.array(img)frame = cv2.cvtColor(frame, cv2.COLOR_RGB2BGR)  # 转换颜色格式out.write(frame)  # 写入视频文件# 按下 'q' 键停止录制if cv2.waitKey(1) == ord('q'):break# 释放资源
out.release()
cv2.destroyAllWindows()

优点:简单易用,适合基础录屏需求。
缺点:性能较低,可能在高分辨率或高帧率下卡顿。


2. 使用 mss 库(高效屏幕捕获)

mss 是一个高效的跨平台屏幕捕获库,适合高性能录屏。

import mss
import cv2
import numpy as npdef record_screen(output_filename="output.avi", fps=20.0):with mss.mss() as sct:monitor = sct.monitors[1]  # 获取主屏幕fourcc = cv2.VideoWriter_fourcc(*"XVID")out = cv2.VideoWriter(output_filename, fourcc, fps, (monitor["width"], monitor["height"]))while True:img = np.array(sct.grab(monitor))  # 捕获屏幕frame = cv2.cvtColor(img, cv2.COLOR_BGRA2BGR)  # 转换颜色格式out.write(frame)  # 写入视频文件# 按下 'q' 键停止录制if cv2.waitKey(1) & 0xFF == ord("q"):breakout.release()cv2.destroyAllWindows()if __name__ == "__main__":record_screen()

优点:性能较好,支持多显示器。
缺点:需要额外安装 mss 库。


3. 使用 PIL.ImageGrab 录制屏幕

PIL.ImageGrab 是 Python 图像处理库的一部分,适合简单的屏幕捕获。

from PIL import ImageGrab
import cv2
import numpy as npfps = 20
output_file = "recording.avi"# 获取屏幕尺寸
screen = ImageGrab.grab()
width, height = screen.size# 创建视频编码器
fourcc = cv2.VideoWriter_fourcc(*"XVID")
out = cv2.VideoWriter(output_file, fourcc, fps, (width, height))while True:img = ImageGrab.grab()  # 捕获屏幕frame = cv2.cvtColor(np.array(img), cv2.COLOR_RGB2BGR)  # 转换颜色格式out.write(frame)  # 写入视频文件# 按下 'q' 键停止录制if cv2.waitKey(1) == ord('q'):breakout.release()
cv2.destroyAllWindows()

优点:无需额外安装复杂库。
缺点:性能一般,不适合高帧率录制。


4. 使用 Windows 原生快捷键录制(非 Python 方案)

Win11 自带录屏功能:

  • 按下 Win + Shift + S 可调用截图和录屏工具。
  • 录制完成后,可手动保存为 MP4 文件,再用 Python 转换为 GIF(如使用 moviepy 库)。
from moviepy.editor import VideoFileClipdef convert_mp4_to_gif(input_path, output_path, fps=10):clip = VideoFileClip(input_path)clip.write_gif(output_path, fps=fps)# 示例
convert_mp4_to_gif("input.mp4", "output.gif")

优点:无需编程,适合简单需求。
缺点:依赖 Windows 自带功能,灵活性较低。


5. 结合 GUI 实现录屏工具(高级方案)

如果需要更友好的界面,可以结合 PyQt5OpenCV 开发一个录屏工具,支持开始/停止录制、选择区域等功能。


总结

方法适用场景性能复杂度
pyautogui + OpenCV基础录屏较低简单
mss + OpenCV高性能录屏较高中等
PIL.ImageGrab简单录屏一般简单
Windows 原生录屏快速录制无需代码
GUI 工具开发自定义功能复杂

选择哪种方法取决于你的具体需求(如是否需要高帧率、是否要录制音频等)。如果需要更高级的功能(如音频录制),可以结合 pyaudio 库实现。


附录B:关于视频格式转换(以avi2mp4为例)

在Python中,你可以使用多种方法将AVI格式的视频转换为MP4格式。以下是几种常见且高效的方式:

方法1:使用 moviepy 库(推荐)

moviepy 是一个强大的视频处理库,适合简单的格式转换。

from moviepy.editor import VideoFileClipdef avi_to_mp4(input_path, output_path):# 加载AVI视频video = VideoFileClip(input_path)# 写入MP4文件(默认使用H.264编码)video.write_videofile(output_path, codec="libx264", audio_codec="aac")# 关闭视频对象video.close()# 示例
avi_to_mp4("input.avi", "output.mp4")

优点

  • 简单易用,支持音频保留。
  • 自动处理编码兼容性问题(默认使用H.264和AAC)。

安装依赖

pip install moviepy

方法2:使用 OpenCV + FFmpeg

如果已安装FFmpeg,可以通过OpenCV调用FFmpeg进行转换。

import cv2def avi_to_mp4_opencv(input_path, output_path):# 读取AVI视频cap = cv2.VideoCapture(input_path)# 获取视频参数(帧率、分辨率等)fps = cap.get(cv2.CAP_PROP_FPS)width = int(cap.get(cv2.CAP_PROP_FRAME_WIDTH))height = int(cap.get(cv2.CAP_PROP_FRAME_HEIGHT))# 创建MP4视频写入器(需FFmpeg支持)fourcc = cv2.VideoWriter_fourcc(*'mp4v')  # 或 'avc1'out = cv2.VideoWriter(output_path, fourcc, fps, (width, height))# 逐帧转换while cap.isOpened():ret, frame = cap.read()if not ret:breakout.write(frame)# 释放资源cap.release()out.release()# 示例
avi_to_mp4_opencv("input.avi", "output.mp4")

注意

  • 确保系统已安装FFmpeg(Windows用户需下载并添加环境变量)。
  • OpenCV的MP4编码器(mp4v)可能在某些平台兼容性较差,建议优先用moviepy

方法3:直接使用 FFmpeg 命令行(最高效)

如果追求转换速度或处理大文件,直接调用FFmpeg命令行是最佳选择。

import subprocessdef avi_to_mp4_ffmpeg(input_path, output_path):command = ['ffmpeg','-i', input_path,      # 输入文件'-c:v', 'libx264',     # H.264视频编码'-c:a', 'aac',         # AAC音频编码'-strict', 'experimental','-y',                  # 覆盖输出文件output_path]subprocess.run(command)# 示例
avi_to_mp4_ffmpeg("input.avi", "output.mp4")

优点

  • 转换速度最快,支持所有主流编码。
  • 可自定义参数(如分辨率、比特率等)。

安装FFmpeg

  • Windows:从 FFmpeg官网 下载并添加至系统环境变量。
  • macOS:brew install ffmpeg
  • Linux:sudo apt install ffmpeg

方法4:使用 PyAV(高级控制)

PyAV 是FFmpeg的Python绑定,适合需要精细控制编码参数的场景。

import avdef avi_to_mp4_pyav(input_path, output_path):input_container = av.open(input_path)output_container = av.open(output_path, mode='w')# 配置输出流(复制输入流的参数)in_stream = input_container.streams.video[0]out_stream = output_container.add_stream('h264', rate=in_stream.average_rate)out_stream.width = in_stream.widthout_stream.height = in_stream.height# 逐帧转码for frame in input_container.decode(video=0):packet = out_stream.encode(frame)output_container.mux(packet)# 关闭容器output_container.close()input_container.close()# 示例
avi_to_mp4_pyav("input.avi", "output.mp4")

优点

  • 支持底层编码参数调整。
  • 性能接近原生FFmpeg。

安装依赖

pip install av

常见问题解决

  1. 转换后无声音

    • 确保使用支持音频的编码器(如moviepy或FFmpeg的-c:a aac)。
    • 检查输入文件是否包含音频流(可用ffmpeg -i input.avi查看)。
  2. 转换速度慢

    • 使用FFmpeg命令行并添加 -preset fast 参数。
    • 降低输出分辨率(如 -vf scale=1280:720)。
  3. 文件体积过大

    • 调整比特率(如 -b:v 2000k)。
    • 使用CRF控制质量(如 -crf 23,数值越小质量越高)。

总结

方法适用场景是否需要FFmpeg保留音频
moviepy快速简单转换
OpenCV + FFmpeg需要逐帧处理可选
FFmpeg命令行高性能/批量处理
PyAV高级编码控制

推荐选择

  • 普通用户:直接用 moviepy
  • 开发者或需要批量处理:FFmpeg命令行。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.pswp.cn/bicheng/83528.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Apache SeaTunnel部署技术详解:模式选择、技巧与最佳实践

Apache SeaTunnel(原Waterdrop)作为高性能、分布式数据集成平台,支持海量数据的离线与实时同步。其灵活多样的部署模式可适配不同规模的生产环境需求。本文将系统解析SeaTunnel的部署架构、技术要点及最佳实践,帮助用户高效构建稳定可靠的数据管道。 一、部署模式全景概览 …

【机械视觉】Halcon—【六、交集并集差集和仿射变换】

【机械视觉】Halcon—【六、交集并集差集和仿射变换】 目录 【机械视觉】Halcon—【六、交集并集差集和仿射变换】 介绍 交集并集差集介绍: 1. 交集(Intersection) 2. 并集(Union) 3. 差集(Difference&#xff…

实验设计与分析(第6版,Montgomery)第5章析因设计引导5.7节思考题5.6 R语言解题

本文是实验设计与分析&#xff08;第6版&#xff0c;Montgomery著&#xff0c;傅珏生译) 第5章析因设计引导5.7节思考题5.6 R语言解题。主要涉及方差分析&#xff0c;正态假设检验&#xff0c;残差分析&#xff0c;交互作用图&#xff0c;等值线图。 dataframe <-data.frame…

剑指offer15_数值的整数次方

数值的整数次方 实现函数 double Power(double base, int exponent) 题目要求 计算 base exponent \text{base}^{\text{exponent}} baseexponent&#xff1a; 不得使用库函数不需要考虑大数问题&#xff0c;绝对误差不超过 10 − 2 10^{-2} 10−2不会出现底数和指数同为 0…

【Typst】1.Typst概述

概述 Typst是一种用于排版文档的标记语言&#xff0c;可以用于排版各种精美的论文、文章、书籍、报告和作业等。它是LaTex的精神续作&#xff0c;但是运行环境和编译速度都要更简单、更快捷。 它设计了一种脚本结合简单的标记语法实现复杂的排版效果。并且支持模板创建、文件…

[Java恶补day14] 56. 合并区间

以数组 intervals 表示若干个区间的集合&#xff0c;其中单个区间为 intervals[i] [starti, endi] 。请你合并所有重叠的区间&#xff0c;并返回 一个不重叠的区间数组&#xff0c;该数组需恰好覆盖输入中的所有区间 。 示例 1&#xff1a; 输入&#xff1a;intervals [[1,3…

DiskGenius专业版v6.0.1.1645:分区管理、数据恢复、备份还原,一应俱全!

各位小伙伴&#xff0c;大家好&#xff01;今天阿灿给大家带来一款超好用的分区工具&#xff0c;DiskGenius专业版。这款工具堪称电脑管理界的“瑞士军刀”&#xff0c;功能强大&#xff0c;现在出了新版本v6.0.1.1645&#xff0c;简繁中文单文件便携版&#xff0c;使用超方便。…

azure web app创建分步指南系列之二

为注册表授权托管标识 你创建的托管标识尚未获得从容器注册表中提取数据的授权。在此步骤中,你将启用授权。 返回容器注册表的管理页面: 在左侧导航菜单中,选择“访问控制 (IAM)”。选择“添加角色分配”。此屏幕截图显示了如何为容器注册表启用添加角色分配。在角色列表中…

STM32 AD单通道与多通道实战指南

文章目录 AD单通道&#xff08;实验&#xff09;有关配置的库函数AD单通道部分主要代码 AD多通道实现多通道采集实现思路探讨单次转换非扫描模式实现AD多通道AD多通道部分代码 学习建议&#xff1a;推荐搭配 江协科技 AD单通道 AD多通道一起食用&#xff01;&#xff01;&#…

沟通频率不合适,如何找到平衡点

在团队协作中&#xff0c;沟通频率过高、信息干扰、节奏错位常常导致效率下降与成员倦怠。PMI研究指出&#xff0c;沟通不当是75%项目延误的根源&#xff0c;其中沟通频率失衡是关键变量之一。要解决这一问题&#xff0c;关键在于设定节奏、分层沟通、制定协议。其中&#xff0…

EC2 实例详解:AWS 的云服务器怎么玩?☁️

弹性计算、灵活计费、全球可用&#xff0c;AWS EC2 全攻略 在 AWS 生态中&#xff0c;有两个核心服务是非常关键的&#xff0c;一个是 S3&#xff08;对象存储&#xff09;&#xff0c;另一个就是我们今天的主角 —— Amazon EC2&#xff08;Elastic Compute Cloud&#xff09…

lvs-keepalived高可用群集

目录 1.Keepalived 概述及安装 1.1 Keepalived 的热备方式 1.2 keepalived的安装与服务控制 &#xff08;1&#xff09;安装keep alived (2)控制 Keepalived 服务DNF 安装 keepalived 后,执行以下命令将keepalived 服务设置为开机启动。 2.使用 Keepalived 实现双机热备 …

车载诊断架构SOVD --- 车辆发现与建连

我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 钝感力的“钝”,不是木讷、迟钝,而是直面困境的韧劲和耐力,是面对外界噪音的通透淡然。 生活中有两种人,一种人格外在意别人的眼光;另一种人无论…

BUUCTF之[ACTF2020 新生赛]BackupFile

打开环境就一句话 找出源文件! 结合题目名字&#xff1a;BackupFile 先用dirsearct扫描网站文件 发现一个index.php.bak ,拼接url下载 打开发现php代码 <?php include_once "flag.php";if(isset($_GET[key])) {$key $_GET[key];if(!is_numeric($key)) {exit…

Rag技术----项目博客(六)

RAG 定义&#xff1a;检索增强生成&#xff08;Retrieval Augmented Generation&#xff09;&#xff0c;简称 RAG&#xff0c;已经成为当前最火热的LLM应用方案。 目的&#xff1a;通过提供相关领域数据库通过问题检索信息&#xff0c;将相关信息合并到Prompt中&#xff0c;…

设计模式——外观设计模式(结构型)

摘要 本文介绍了外观设计模式&#xff0c;它是一种结构型设计模式&#xff0c;通过引入一个外观类来封装复杂子系统的调用细节&#xff0c;对外提供简单统一的接口。文中通过生活类比、关键角色介绍、使用场景分析以及结构说明等方面对这一模式进行了全面阐述&#xff0c;还涉…

LabVIEW磁悬浮轴承传感器故障识别

针对工业高端装备中主动磁悬浮轴承&#xff08;AMB&#xff09;的位移传感器故障检测需求&#xff0c;基于 LabVIEW 平台构建了一套高精度故障识别系统。通过集成品牌硬件与 LabVIEW 的信号处理能力&#xff0c;实现了传感器探头故障的实时监测与精准定位&#xff0c;解决了传统…

集成学习三种框架

集成学习通过组合多个弱学习器构建强学习器&#xff0c;常见框架包括Bagging&#xff08;装袋&#xff09;、Boosting&#xff08;提升&#xff09; 和Stacking&#xff08;堆叠&#xff09; 一、Bagging&#xff08;自助装袋法&#xff09; 核心思想 从原始数据中通过有放回…

PCI DSS培训记录

22日上午: 整体PCI DSS 结构分享VISA分享全球欺诈风险动态 信用卡被偷枚举攻击依然是最为主要的安全威胁之一(枚举验证码),增加3DS验证防护勒索软件和信息泄漏攻击欺诈分子对AI技术的兴趣日益增加,如换脸软件过验证基于NFC技术利用非接交易进行欺诈成为新的攻击手段,如NF…

数据安全中心是什么?如何做好数据安全管理?

目录 一、数据安全中心是什么 &#xff08;一&#xff09;数据安全中心的定义 &#xff08;二&#xff09;数据安全中心的功能 1. 数据分类分级 2. 访问控制 3. 数据加密 4. 安全审计 5. 威胁检测与响应 二、数据安全管理的重要性 三、如何借助数据安全中心做好数据安…