python實(shí)現(xiàn)錄屏功能(親測(cè)好用)
前言
由與上不了學(xué),教我們Mastercam的老師提前給我們布置了4道習(xí)題。對(duì)我們太好了,謝謝老師
沒(méi)辦法,干就完了。
只是要求附上制作過(guò)程視頻,就想到了能不能用python做個(gè)錄屏的程序,于是在網(wǎng)上看了好多文章,發(fā)現(xiàn)很多都不是很好用,要不就是太麻煩(我就錄個(gè)屏,不用聲音,也不用控件)。最后看到了一個(gè)符合我要求的,可以去看看這里(感謝?。?/p>
不過(guò)呢,俗話說(shuō):適合自己的才是最好的。當(dāng)我們用的時(shí)候,會(huì)發(fā)現(xiàn)錄制的時(shí)間和視頻播放的時(shí)間不一致,有的快了,有的慢了,所以就想出了原因與解決辦法。接下來(lái)先上代碼吧
需要安裝的第三方庫(kù)有pillow、opencv-python、numpy、pynput
上‘馬'
import time,threading from datetime import datetime from PIL import ImageGrab from cv2 import * import numpy as np from pynput import keyboard def video_record(): # 錄入視頻 global name name = datetime.now().strftime('%Y-%m-%d %H-%M-%S') # 當(dāng)前的時(shí)間(當(dāng)文件名) screen = ImageGrab.grab() # 獲取當(dāng)前屏幕 width, high = screen.size # 獲取當(dāng)前屏幕的大小 fourcc = VideoWriter_fourcc('X', 'V', 'I', 'D') # MPEG-4編碼,文件后綴可為.avi .asf .mov等 video = VideoWriter('%s.avi' % name, fourcc, 15, (width, high)) # (文件名,編碼器,幀率,視頻寬高) #print('3秒后開(kāi)始錄制----') # 可選 #time.sleep(3) print('開(kāi)始錄制!') global start_time start_time = time.time() while True: if flag: print("錄制結(jié)束!") global final_time final_time = time.time() video.release() #釋放 break im = ImageGrab.grab() # 圖片為RGB模式 imm = cvtColor(np.array(im), COLOR_RGB2BGR) # 轉(zhuǎn)為opencv的BGR模式 video.write(imm) #寫入 # time.sleep(5) # 等待5秒再次循環(huán) def on_press(key): # 監(jiān)聽(tīng)按鍵 global flag if key == keyboard.Key.home: flag = True # 改變 return False # 返回False,鍵盤監(jiān)聽(tīng)結(jié)束! def video_info(): # 視頻信息 video = VideoCapture('%s.avi' % name) # 記得文件名加格式不要錯(cuò)! fps = video.get(CAP_PROP_FPS) Count = video.get(CAP_PROP_FRAME_COUNT) size = (int(video.get(CAP_PROP_FRAME_WIDTH)), int(video.get(CAP_PROP_FRAME_HEIGHT))) print('幀率=%.1f'%fps) print('幀數(shù)=%.1f'%Count) print('分辨率',size) print('視頻時(shí)間=%.3f秒'%(int(Count)/fps)) print('錄制時(shí)間=%.3f秒'%(final_time-start_time)) print('推薦幀率=%.2f'%(fps*((int(Count)/fps)/(final_time-start_time)))) if __name__ == '__main__': flag = False th = threading.Thread(target=video_record) th.start() with keyboard.Listener(on_press=on_press) as listener: listener.join() time.sleep(1) # 等待視頻釋放過(guò)后 video_info()
解決
觀察代碼可以發(fā)現(xiàn)實(shí)現(xiàn)錄屏的方式就是不斷循環(huán)獲取屏幕然后寫入,可以想到每循環(huán)一次就是一幀,而循環(huán)一次要多長(zhǎng)時(shí)間就取決于運(yùn)行的速度了。所以我們只要讓一秒中寫入的幀數(shù)(也就是1秒中循環(huán)的次數(shù))和video中的參數(shù)幀率相等,就能獲得差不多正常的速度
因此我在代碼中加入了視頻信息,算出了視頻播放的時(shí)間和錄制時(shí)間,再推算出來(lái)正常速度的幀率👉推薦幀率。只要先運(yùn)行試一下,看一下推薦幀率是多少,再把代碼中的參數(shù)改過(guò)來(lái)就行了(要取整數(shù)哦)
要按home鍵來(lái)正常結(jié)束程序,才會(huì)有video_info出現(xiàn)
然后呢!我發(fā)現(xiàn)老師要我們附制造過(guò)程視頻,我TM也不可能發(fā)個(gè)幾個(gè)幾百M(fèi)甚至上G的視頻過(guò)去吧,老師也沒(méi)時(shí)間去看吧
于是乎,我在循環(huán)中加入了‘等待5秒',這樣就差不多每5秒獲取1幀,推薦幀率顯示0.20,當(dāng)然,我不能也不會(huì)按這個(gè)速度播放,給它來(lái)個(gè)25倍(幀率為0.20*25=5,這樣視頻出來(lái)就又小又短了🤣)
多提一下,因?yàn)閮蓚€(gè)線程并不會(huì)同時(shí)結(jié)束,只是通過(guò)flag這個(gè)變量改變來(lái)使得另一個(gè)結(jié)束,所以按home鍵flag改變的時(shí)候,另一個(gè)線程video_record還處于運(yùn)行循環(huán)中,因此我們要等它經(jīng)過(guò)這次循環(huán),進(jìn)入下一次條件判斷,視頻才得以從內(nèi)存釋放…呃嗯,就是我要在代碼倒數(shù)第2行那里等待個(gè)5+1=6秒(這樣比較保險(xiǎn)),否則的話,那個(gè)幀數(shù)會(huì)顯示為0,甚至?xí)霈F(xiàn)運(yùn)行錯(cuò)誤(不能除0)
說(shuō)了那么多,怎么能不給你們看一下效果呢
成果
4題,錄了4個(gè),最小的不到4M,最大也就14M多點(diǎn)👏
因?yàn)檫@里放不了AVI,所以我把最小的那個(gè)轉(zhuǎn)成GIF格式放給你們看看。
不過(guò)模糊了好多,還多了一些莫名的××點(diǎn)點(diǎn)😒
最后
總結(jié)
到此這篇關(guān)于python實(shí)現(xiàn)錄屏功能(親測(cè)好用)的文章就介紹到這了,更多相關(guān)python 實(shí)現(xiàn)錄屏內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
python通過(guò)get,post方式發(fā)送http請(qǐng)求和接收http響應(yīng)的方法
這篇文章主要介紹了python通過(guò)get,post方式發(fā)送http請(qǐng)求和接收http響應(yīng)的方法,涉及Python使用urllib模塊與urllib2模塊實(shí)現(xiàn)get與post發(fā)送數(shù)據(jù)的相關(guān)技巧,需要的朋友可以參考下2015-05-05Python中base64與xml取值結(jié)合問(wèn)題
這篇文章主要介紹了Python中base64與xml取值結(jié)合問(wèn)題,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-12-12Python調(diào)用易語(yǔ)言動(dòng)態(tài)鏈接庫(kù)實(shí)現(xiàn)驗(yàn)證碼功能
今天成功把易語(yǔ)言調(diào)用驗(yàn)證碼通殺的DLL在Python中成功調(diào)用了,心理美滋滋的,接著把我的經(jīng)驗(yàn)及示例代碼分享給大家,希望對(duì)大家有所幫助2021-08-08python常用的時(shí)間模塊之datetime模塊示例詳解
這篇文章主要介紹了python常用的時(shí)間模塊之datetime模塊,本文通過(guò)示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-05-05Python Pytorch深度學(xué)習(xí)之自動(dòng)微分
今天小編就為大家分享一篇關(guān)于Pytorch自動(dòng)微分的文章,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-10-10Python深度學(xué)習(xí)pytorch神經(jīng)網(wǎng)絡(luò)Dropout應(yīng)用詳解解
這篇文章主要為大家介紹了Python深度學(xué)習(xí)中關(guān)于pytorch神經(jīng)網(wǎng)絡(luò)Dropout的應(yīng)用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步2021-10-10使用Python生成200個(gè)激活碼的實(shí)現(xiàn)方法
這篇文章主要介紹了使用Python生成200個(gè)激活碼的實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11