0

0

Python如何实现录屏功能

WBOY

WBOY

发布时间:2023-05-02 21:46:05

|

2198人浏览过

|

来源于亿速云

转载

    一、界面开发

        #设置主界面
    def set_init_window(self):
        # 去掉tkinter默认的标题
        self.tk.title('')
        # 隐藏默认图标
        self.tk.iconbitmap(self.icon_path())
        #获取屏幕的宽度
        screeWidth = self.tk.winfo_screenwidth()
        #获取屏幕高度
        screeHeight = self.tk.winfo_screenheight()
        
        width = int((screeWidth - 500) / 2)
        height = int((screeHeight - 300) / 2)
        # 设置主界面的大小和默认位置
        self.tk.geometry(f'500x100+{width}+{height}')
        
        #添加开始录制按钮,点击之后开启两个线程:一个录屏、一个监听键盘
        btn1 = tkinter.Button(self.tk, width=5, height=1, text='开始',
        command=lambda:[threading.Thread(target=self.video_record).start(),threading.Thread(target=self.start_listen).start()])
        btn1.pack()
        # 设置按钮位置
        btn1.place(x=110, y=50, anchor='n')
        
        #开启新线程设置录屏范围
        btn2 = tkinter.Button(self.tk, width=15, height=1, text='设置录制区域', command=lambda:threading.Thread(target=self.set_range).start())
        btn2.pack()
        btn2.place(x=230, y=50, anchor='n')
    
    
    #生成透明的icon图标
    def icon_path(self):
        ICON = (b'\x00\x00\x01\x00\x01\x00\x10\x10\x00\x00\x01\x00\x08\x00h\x05\x00\x00'
                b'\x16\x00\x00\x00(\x00\x00\x00\x10\x00\x00\x00 \x00\x00\x00\x01\x00'
                b'\x08\x00\x00\x00\x00\x00@\x05\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00'
                b'\x00\x01\x00\x00\x00\x01') + b'\x00' * 1282 + b'\xff' * 64
        _, ICON_PATH = tempfile.mkstemp()
        with open(ICON_PATH, 'wb') as icon_file:
            icon_file.write(ICON)
        return ICON_PATH

    二、录屏参数设置

    1.设置录屏范围

    #设置录屏范围
    def set_range(self):
        #self.init_window.withdraw() #隐藏窗口
        self.tk.state('icon')#窗口最小化
        screeWidth = self.tk.winfo_screenwidth()
        screeHeight = self.tk.winfo_screenheight()
    
        self.newFrame = tkinter.Toplevel(self.tk,width=screeWidth,height=screeHeight,bg='white')#开启新窗口
        self.newFrame.attributes('-transparentcolor', 'white')  # 使白色为透明色
        self.newFrame.overrideredirect(True)  # 隐藏导航栏
    
        self.canvas = tkinter.Canvas(self.newFrame,bg='white',bd=0,width=screeWidth,height=screeHeight)
        self.canvas.bind('<Button-1>', self.onLeftButtonDown)#按下左键
        self.canvas.bind('<B1-Motion>', self.onLeftButtonMove)#移动鼠标
        self.canvas.bind('<ButtonRelease-1>', self.onLeftButtonUp)#抬起左键
        self.canvas.pack(fill=tkinter.BOTH, expand=tkinter.YES)
    
        time.sleep(0.3)
        im = ImageGrab.grab()
        # 暂存全屏截图
        im.save('temp.png')
        im.close()
        self.image = tkinter.PhotoImage(file='temp.png')
        os.remove('temp.png')
        self.canvas.create_image(screeWidth//2, screeHeight//2, image=self.image)

    2.鼠标事件监听

    #按下鼠标
    def onLeftButtonDown(self,event):
        try:
            self.canvas.delete(self.lastDraw)
            self.canvas.delete(self.dot1)
            self.canvas.delete(self.dot2)
            self.btn3.destroy()
        except Exception as e:
            pass
    
        self.X = event.x
        self.Y = event.y
        self.X2 = 0
        self.Y2 = 0
    
    #移动鼠标
    def onLeftButtonMove(self,event):
        try:  # 删除刚画完的图形,不然所有画的框都会出现
            self.canvas.delete(self.lastDraw)
            self.canvas.delete(self.dot1)
            self.canvas.delete(self.dot2)
            self.btn3.destroy()
        except Exception as e:
            pass
    
        self.X2 = event.x
        self.Y2 = event.y
        self.lastDraw = self.canvas.create_rectangle(self.X, self.Y, event.x, event.y,width=2, outline='pink')
    
    #松开鼠标
    def onLeftButtonUp(self,event):
        print("起点", self.X, self.Y)
        print("终点", self.X2, self.Y2)
    
        if self.X2==0 and self.X2==0:
            return
    
        self.width, self.high = self.X2-self.X,self.Y2-self.Y
        self.region = (self.X, self.Y, self.X2, self.Y2)
    
        self.dot1=self.canvas.create_text(self.X, self.Y - 10, text=f'({self.X},{self.Y})', font=("Purisa", 12), fill="pink")
        self.dot2=self.canvas.create_text(self.X2, self.Y2 + 10, text=f'({self.X2},{self.Y2})', font=("Purisa", 12), fill="pink")
    
        # self.newFrame.destroy()#销毁窗口
        # self.init_window.deiconify()#显示窗口
        # self.tk.state('normal')  # 取消窗口最小化
    
        self.btn3 = tkinter.Button(self.canvas, width=15, height=1, text='确定录制区域',bg='pink',fg='#64854c',command=lambda:[self.newFrame.destroy(),self.tk.state('normal')])
        self.btn3.pack()
        self.btn3.place(x=self.X2-20, y=self.Y2+20, anchor='n')

    3.键盘事件监听

    # 开始监听
    def start_listen(self):
        with keyboard.Listener(on_press=self.on_press) as listener:
            listener.join()
        # 监听按键
    def on_press(self,key):
        if key == keyboard.Key.esc:
            self.flag = True  # 改变
            return False  # 返回False,键盘监听结束!

    三、录屏操作

    def video_record(self):
         fourcc = cv2.VideoWriter_fourcc('X', 'V', 'I', 'D')
         out = cv2.VideoWriter('output.mp4', fourcc, 14, (self.width, self.high))  # 参数分别为 输出文件名,解码方式,帧数,录像范围
         self.count = 1
         while (True):
             img = ImageGrab.grab(self.region) #指定截取坐标(左边X,上边Y,右边X,下边Y)
             img_np = numpy.array(img)
             frame = cv2.cvtColor(img_np, cv2.COLOR_BGR2RGB)  # ImageGrab获取的颜色为BGR排序,需转换为RGB
             out.write(frame)
             self.count += 1
             label = tkinter.Label(self.tk, text=f"{int(self.count / 14)}秒")
             label.pack()
             label.place(x=320, y=55, anchor='n')
             # 点击ESC退出
             if self.flag == True:
                 tkinter.messagebox.showinfo('提示', '录屏结束')
                 self.flag = False  # 改变录屏状态
                 break
         out.release()
         cv2.destroyAllWindows()

    相关文章

    python速学教程(入门到精通)
    python速学教程(入门到精通)

    python怎么学习?python怎么入门?python在哪学?python怎么学才快?不用担心,这里为大家提供了python速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

    下载

    相关标签:

    本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

    热门AI工具

    更多
    DeepSeek
    DeepSeek

    幻方量化公司旗下的开源大模型平台

    豆包大模型
    豆包大模型

    字节跳动自主研发的一系列大型语言模型

    WorkBuddy
    WorkBuddy

    腾讯云推出的AI原生桌面智能体工作台

    腾讯元宝
    腾讯元宝

    腾讯混元平台推出的AI助手

    文心一言
    文心一言

    文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

    讯飞写作
    讯飞写作

    基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

    即梦AI
    即梦AI

    一站式AI创作平台,免费AI图片和视频生成。

    ChatGPT
    ChatGPT

    最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

    相关专题

    更多
    TypeScript类型系统进阶与大型前端项目实践
    TypeScript类型系统进阶与大型前端项目实践

    本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

    26

    2026.03.13

    Python异步编程与Asyncio高并发应用实践
    Python异步编程与Asyncio高并发应用实践

    本专题围绕 Python 异步编程模型展开,深入讲解 Asyncio 框架的核心原理与应用实践。内容包括事件循环机制、协程任务调度、异步 IO 处理以及并发任务管理策略。通过构建高并发网络请求与异步数据处理案例,帮助开发者掌握 Python 在高并发场景中的高效开发方法,并提升系统资源利用率与整体运行性能。

    46

    2026.03.12

    C# ASP.NET Core微服务架构与API网关实践
    C# ASP.NET Core微服务架构与API网关实践

    本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

    178

    2026.03.11

    Go高并发任务调度与Goroutine池化实践
    Go高并发任务调度与Goroutine池化实践

    本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

    51

    2026.03.10

    Kotlin Android模块化架构与组件化开发实践
    Kotlin Android模块化架构与组件化开发实践

    本专题围绕 Kotlin 在 Android 应用开发中的架构实践展开,重点讲解模块化设计与组件化开发的实现思路。内容包括项目模块拆分策略、公共组件封装、依赖管理优化、路由通信机制以及大型项目的工程化管理方法。通过真实项目案例分析,帮助开发者构建结构清晰、易扩展且维护成本低的 Android 应用架构体系,提升团队协作效率与项目迭代速度。

    92

    2026.03.09

    JavaScript浏览器渲染机制与前端性能优化实践
    JavaScript浏览器渲染机制与前端性能优化实践

    本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

    102

    2026.03.06

    Rust内存安全机制与所有权模型深度实践
    Rust内存安全机制与所有权模型深度实践

    本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

    227

    2026.03.05

    PHP高性能API设计与Laravel服务架构实践
    PHP高性能API设计与Laravel服务架构实践

    本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

    532

    2026.03.04

    AI安装教程大全
    AI安装教程大全

    2026最全AI工具安装教程专题:包含各版本AI绘图、AI视频、智能办公软件的本地化部署手册。全篇零基础友好,附带最新模型下载地址、一键安装脚本及常见报错修复方案。每日更新,收藏这一篇就够了,让AI安装不再报错!

    171

    2026.03.04

    热门下载

    更多
    网站特效
    /
    网站源码
    /
    网站素材
    /
    前端模板

    精品课程

    更多
    相关推荐
    /
    热门推荐
    /
    最新课程
    最新Python教程 从入门到精通
    最新Python教程 从入门到精通

    共4课时 | 22.5万人学习

    Django 教程
    Django 教程

    共28课时 | 5万人学习

    SciPy 教程
    SciPy 教程

    共10课时 | 1.9万人学习

    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送

    Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号