对于录屏的程序,小编想实现的目的就是实现屏幕的录制,并记录自己的声音。而我们的程序也是基于此进行实现的,程序的框架如下图所示:
主程序启动后,我们利用两个线程来分别实现音频的录制和视频的录制,再将两个线程录制的音频和视频通过主程序进行合成,最终形成我们的录屏结果。
这里需要注意的是,我们的音频和视频的录制必须是同时启动和结束。下面我们一起来看看程序吧~~
首先是音频的录制,我们利用pyaudio库来启用我们的麦克风,然后收录我们的声音,并将录音保存到本地的mp3文件当中,程序如下图所示:上述的程序中,我们首先创建一个音频的输入流对象stream,不断的获取音频数据,然后我们利用wave库,不断的读取输入流中的音频数据,写入到本地的音频当中。这里的self.recording是一个关键的参数,其控制着音频是否持续的记录。
接下来是对于视频的记录,对于视频的记录,我们采用的是不断的获取当前屏幕的图片截屏,然后利用opencv写入到视频文件当中去。程序如下图所示: 上述的程序中,我们通过不断的捕获当前屏幕的内容,然后通过opencv的视频写入对象,将图片不断的写入到视频文件当中去。注意这里用到了与音频录制相同的self.recording参数,来控制视频是否继续进行记录。 上述的程序中,我们开启了两个线程来分别录制视频和音频,同时让主程序保持循环等待,当我们输入“quit”时,让两个子线程同时结束。注意,这里会有几毫秒的时间差,但是不影响,然后我们把两个子线程采集到的音频和视频进行合并,便完成了我们的录频程序。
而且34秒的视频,只要 1.26M空间,非常小巧方便!
以上就是今天的分享,希望对你们有所帮助!目前wx搜索Python 【菜鸟学Python】排第二,汇聚了30万Python爱好者,累计原创近400篇趣味干货(爬虫,数据分析,算法,面试指南,原创趣味实战,Python游戏,机器学习),欢迎一起学Python,交流指正。
网友评论