91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

使用Python怎么實現一個流媒體播放器

發布時間:2021-04-29 16:09:33 來源:億速云 閱讀:521 作者:Leah 欄目:開發技術

今天就跟大家聊聊有關使用Python怎么實現一個流媒體播放器,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。

python有哪些常用庫

python常用的庫:1.requesuts;2.scrapy;3.pillow;4.twisted;5.numpy;6.matplotlib;7.pygama;8.ipyhton等。

環境準備

 VLC 安裝

VLC實際上是比較知名的開源多媒體播放器,要使用這個庫,首先需要在電腦上安裝VLC,我們可以直接在上述的官網中下載并安裝它,有一點需要特別注意,如果本地安裝的Python是32位,則你必須下載32位的VLC,64位則下64位的VLC,必須與Python的版本對應,否則無法使用。

事實上,我并不推薦這樣直接安裝。試想一下,如果我們使用Python開發一個基于VLC的播放器發布出去,卻要求用戶在使用之前,先安裝一個VLC播放器,豈不是很荒謬?那么如何將VLC集成到Python程序中來,才是問題的關鍵。

關于這個問題,沒有找到相關資料,只能通過查看python-vlc綁定的源碼來尋找方法。

安裝python-vlc 綁定

VLC是純C語言開發的框架,Python想要更簡單的調用,需要安裝一個python-vlc 綁定,實際上就是一個vlc.py模塊,它封裝了VLC動態庫的接口,讓我們使用更簡單。

python -m pip install python-vlc

完成安裝后,我們在site-packages中找到vlc.py源碼,查看其對VLC動態庫的加載代碼,可以發現,在Windows系統上,vlc.py是通過查詢Windows注冊表的方式來搜索路徑并加載VLCdll動態庫的。但它其中也提供了一個配置環境變量PYTHON_VLC_MODULE_PATH的加載方式,這樣我們就能在盡可能不修改vlc.py源碼的前提下完成VLC動態庫的集成。

好了,到這里,我們只需要去下載一個VLC的綠色免安裝版本即可。由于我的Python環境是64位,這里給出一個Windows 64位下載地址:點我 選擇vlc-3.0.6-win64.7z即可

下載完成后,解壓目錄,進入其中,刪除無關內容,保留如下文件

使用Python怎么實現一個流媒體播放器

其中plugins中的內容非常多,達到122M,我們可以根據實際情況進行剪裁,例如我們只需要做一個音頻播放器,則可將其中的video相關的文件夾刪除,還包括gui文件夾,因為我們要自己做界面,不需要gui里面的qt相關的dll。

簡單播放示例

創建一個Python工程,將已經剪裁好的vlc-3.0.6文件夾拷貝到工程根目錄。然后創建一個python腳本,我們對vlc.py再次封裝

import os, time

# 設置VLC庫路徑,需在import vlc之前
os.environ['PYTHON_VLC_MODULE_PATH'] = "./vlc-3.0.6"

import vlc


class Player:
    '''
        args:設置 options
    '''
    def __init__(self, *args):
        if args:
            instance = vlc.Instance(*args)
            self.media = instance.media_player_new()
        else:
            self.media = vlc.MediaPlayer()

    # 設置待播放的url地址或本地文件路徑,每次調用都會重新加載資源
    def set_uri(self, uri):
        self.media.set_mrl(uri)

    # 播放 成功返回0,失敗返回-1
    def play(self, path=None):
        if path:
            self.set_uri(path)
            return self.media.play()
        else:
            return self.media.play()

    # 暫停
    def pause(self):
        self.media.pause()

    # 恢復
    def resume(self):
        self.media.set_pause(0)

    # 停止
    def stop(self):
        self.media.stop()

    # 釋放資源
    def release(self):
        return self.media.release()

    # 是否正在播放
    def is_playing(self):
        return self.media.is_playing()

    # 已播放時間,返回毫秒值
    def get_time(self):
        return self.media.get_time()

    # 拖動指定的毫秒值處播放。成功返回0,失敗返回-1 (需要注意,只有當前多媒體格式或流媒體協議支持才會生效)
    def set_time(self, ms):
        return self.media.get_time()

    # 音視頻總長度,返回毫秒值
    def get_length(self):
        return self.media.get_length()

    # 獲取當前音量(0~100)
    def get_volume(self):
        return self.media.audio_get_volume()

    # 設置音量(0~100)
    def set_volume(self, volume):
        return self.media.audio_set_volume(volume)

    # 返回當前狀態:正在播放;暫停中;其他
    def get_state(self):
        state = self.media.get_state()
        if state == vlc.State.Playing:
            return 1
        elif state == vlc.State.Paused:
            return 0
        else:
            return -1

    # 當前播放進度情況。返回0.0~1.0之間的浮點數
    def get_position(self):
        return self.media.get_position()

    # 拖動當前進度,傳入0.0~1.0之間的浮點數(需要注意,只有當前多媒體格式或流媒體協議支持才會生效)
    def set_position(self, float_val):
        return self.media.set_position(float_val)

    # 獲取當前文件播放速率
    def get_rate(self):
        return self.media.get_rate()

    # 設置播放速率(如:1.2,表示加速1.2倍播放)
    def set_rate(self, rate):
        return self.media.set_rate(rate)

    # 設置寬高比率(如"16:9","4:3")
    def set_ratio(self, ratio):
        self.media.video_set_scale(0)  # 必須設置為0,否則無法修改屏幕寬高
        self.media.video_set_aspect_ratio(ratio)

    # 注冊監聽器
    def add_callback(self, event_type, callback):
        self.media.event_manager().event_attach(event_type, callback)

    # 移除監聽器
    def remove_callback(self, event_type, callback):
        self.media.event_manager().event_detach(event_type, callback)

調用代碼

def my_call_back(event):
    print("call:", player.get_time())


if "__main__" == __name__:
    player = Player()
    player.add_callback(vlc.EventType.MediaPlayerTimeChanged, my_call_back)
    # 在線播放流媒體視頻
    player.play("http://hd.yinyuetai.com/uploads/videos/common/"
                                 "22970150925A6BB75E20D95798D129EE.flv?sc\u003d17d6a907580e9892"
                                 "\u0026br\u003d1103\u0026vid\u003d2400382\u0026aid\u003d32"
                                 "\u0026area\u003dML\u0026vst\u003d0")

    # 播放本地mp3
    # player.play("D:/abc.mp3")

    # 防止當前進程退出
    while True:
        pass

VLC 監聽器

上面代碼中,我們注冊了MediaPlayerTimeChanged類型的監聽器,表示已播放時間變化時回調,可以看到my_call_back會不斷回調,因為每播放一點都會回調。

除了上述的監聽器,VLC的監聽器實際上非常多,常見的我們列舉如下:

  1. MediaPlayerNothingSpecial:vlc處于空閑狀態,只是等待發出命令

  2. MediaPlayerOpening:vlc正在打開媒體資源定位器(MRL)

  3. MediaPlayerBuffering(int cache):vlc正在緩沖

  4. MediaPlayerPlaying:vlc正在播放媒體

  5. MediaPlayerPaused:vlc處于暫停狀態

  6. MediaPlayerStopped:vlc處于停止狀態

  7. MediaPlayerForward:vlc通過媒體快進(這永遠不會被調用)

  8. MediaPlayerBackward:vlc正在快退(這永遠不會被調用)

  9. MediaPlayerEncounteredError:vlc遇到錯誤,無法繼續

  10. MediaPlayerEndReached:vlc已到達當前播放列表的末尾

  11. MediaPlayerTimeChanged:時間發生改變

  12. MediaPlayerPositionChanged:進度發生改變

  13. MediaPlayerSeekableChanged:流媒體是否可搜索的狀態發生改變(true表示可搜索,false表示不可搜索)

  14. MediaPlayerPausableChanged:媒體是否可暫停狀態發生改變(true表示可暫停,false表示不可暫停)

  15. MediaPlayerMediaChanged : 媒體發生改變

  16. MediaPlayerTitleChanged: 標題發生改變(DVD/Blu-ray)

  17. MediaPlayerChapterChanged :章節發生改變(DVD/Blu-ray)

  18. MediaPlayerLengthChanged :(在vlc版本<2.2.0僅適用于Mozilla)長度已更改

  19. MediaPlayerVout :視頻輸出的數量發生改變

  20. MediaPlayerMuted :靜音

  21. MediaPlayerUnmuted :取消靜音

  22. MediaPlayerAudioVolume :音量發生改變

要查看全部支持的監聽器,請訪問 官方文檔 并搜索EventType類型查看

視頻加字幕

在我們上述封裝的Player類中添加如下方法

def set_marquee(self):
        self.media.video_set_marquee_int(vlc.VideoMarqueeOption.Enable, 1)
        self.media.video_set_marquee_int(vlc.VideoMarqueeOption.Size, 28)
        self.media.video_set_marquee_int(vlc.VideoMarqueeOption.Color, 0xff0000)
        self.media.video_set_marquee_int(vlc.VideoMarqueeOption.Position, vlc.Position.Bottom)
        self.media.video_set_marquee_int(vlc.VideoMarqueeOption.Timeout, 0)
        self.media.video_set_marquee_int(vlc.VideoMarqueeOption.Refresh, 10000)

    def update_text(self, content):
        self.media.video_set_marquee_string(vlc.VideoMarqueeOption.Text, content)

創建調用代碼


video_set_marquee_string函數不僅支持直接傳入字符串,還支持"%Y-%m-%d %H:%M:%S"這種時間格式,運行上述代碼后,會在屏幕下方顯示當前時間,且每一秒刷新一次。

關于文本的一些屬性設置

  • VideoMarqueeOption.Color :文本顏色,值為16進制數

  • VideoMarqueeOption.Enable:是否開啟文本顯示,1表示開啟

  • VideoMarqueeOption.Opacity:文本透明度,0 透明,255 完全不透明

  • VideoMarqueeOption.Position:文本顯示的位置

  • VideoMarqueeOption.Refresh:字符串刷新的間隔(毫秒)對時間格式字串刷新有用

  • VideoMarqueeOption.Size:文字大小,單位像素

  • VideoMarqueeOption.Text:要顯示的文本內容

  • VideoMarqueeOption.Timeout:文本停留時間。0表示永遠停留(毫秒值)

  • VideoMarqueeOption.marquee_X:設置顯示文本的x坐標值

  • VideoMarqueeOption.marquee_Y:設置顯示文本的y坐標值

上面的示例僅僅顯示了一個固定的時間字符串,下面我們看一下如何顯示連續的字幕

if "__main__" == __name__:
    player = Player("--sub-source=marq")

    player.play("http://hd.yinyuetai.com/uploads/videos/common/"
                                 "22970150925A6BB75E20D95798D129EE.flv?sc\u003d17d6a907580e9892"
                                 "\u0026br\u003d1103\u0026vid\u003d2400382\u0026aid\u003d32"
                                 "\u0026area\u003dML\u0026vst\u003d0")
    player.set_marquee()


    i = 0
    while True:
        # 字幕每2秒刷新一條
        time.sleep(2)
        player.update_text("我是字幕君 "+str(i))
        i += 1

VLC的選項參數設置

'''
        args:設置 options
    '''

    def __init__(self, *args):
        if args:
            instance = vlc.Instance(*args)
            self.media = instance.media_player_new()
        else:
            self.media = vlc.MediaPlayer()

我們在封裝時,特意預留了選項參數的設置,上面添加字幕時,用到了"--sub-source=marq"參數,實際上VLC有非常多的參數,關于各種參數的詳細介紹,可以查看 官方資料
如果看英文太累,這里還有一份 中文版參數詳解

音頻可視化

VLC眾多參數中,有一個非常有用的功能,那就是顯示音頻的可視化。這里我們以頻譜為例

if "__main__" == __name__:
    player = Player("--audio-visual=visual", "--effect-list=spectrum", "--effect-fft-window=flattop")

    player.play("https://api.mlwei.com/music/api/wy/?key=523077333&cache=1&type=url&id=566442496")

    while True:
        pass

使用Python怎么實現一個流媒體播放器

--effect-list=<字符串>

當前可用的效果包括: dummy、scope、spectrum(頻譜)、spectrometer(頻譜儀)與vuMeter

--effect-fft-window=

可選的值{none,hann,flattop,blackmanharris,kaiser}

在Tkinter中嵌入視頻

上面的測試代碼都是在命令行執行的,雖然運行后啟動了一個窗口渲染視頻,但是我們無法進行暫停、快進、退出、設置音量等操作,這是因為我們沒有寫GUI程序,而tkinter作為Python犀利的圖形程序庫,可以幫助我們快速構建一個界面程序。

完整示例代碼如下

import os, platform

# 設置VLC庫路徑,需在import vlc之前
os.environ['PYTHON_VLC_MODULE_PATH'] = "./vlc-3.0.6"

import vlc


class Player:
    '''
        args:設置 options
    '''

    def __init__(self, *args):
        if args:
            instance = vlc.Instance(*args)
            self.media = instance.media_player_new()
        else:
            self.media = vlc.MediaPlayer()

    # 設置待播放的url地址或本地文件路徑,每次調用都會重新加載資源
    def set_uri(self, uri):
        self.media.set_mrl(uri)

    # 播放 成功返回0,失敗返回-1
    def play(self, path=None):
        if path:
            self.set_uri(path)
            return self.media.play()
        else:
            return self.media.play()

    # 暫停
    def pause(self):
        self.media.pause()

    # 恢復
    def resume(self):
        self.media.set_pause(0)

    # 停止
    def stop(self):
        self.media.stop()

    # 釋放資源
    def release(self):
        return self.media.release()

    # 是否正在播放
    def is_playing(self):
        return self.media.is_playing()

    # 已播放時間,返回毫秒值
    def get_time(self):
        return self.media.get_time()

    # 拖動指定的毫秒值處播放。成功返回0,失敗返回-1 (需要注意,只有當前多媒體格式或流媒體協議支持才會生效)
    def set_time(self, ms):
        return self.media.get_time()

    # 音視頻總長度,返回毫秒值
    def get_length(self):
        return self.media.get_length()

    # 獲取當前音量(0~100)
    def get_volume(self):
        return self.media.audio_get_volume()

    # 設置音量(0~100)
    def set_volume(self, volume):
        return self.media.audio_set_volume(volume)

    # 返回當前狀態:正在播放;暫停中;其他
    def get_state(self):
        state = self.media.get_state()
        if state == vlc.State.Playing:
            return 1
        elif state == vlc.State.Paused:
            return 0
        else:
            return -1

    # 當前播放進度情況。返回0.0~1.0之間的浮點數
    def get_position(self):
        return self.media.get_position()

    # 拖動當前進度,傳入0.0~1.0之間的浮點數(需要注意,只有當前多媒體格式或流媒體協議支持才會生效)
    def set_position(self, float_val):
        return self.media.set_position(float_val)

    # 獲取當前文件播放速率
    def get_rate(self):
        return self.media.get_rate()

    # 設置播放速率(如:1.2,表示加速1.2倍播放)
    def set_rate(self, rate):
        return self.media.set_rate(rate)

    # 設置寬高比率(如"16:9","4:3")
    def set_ratio(self, ratio):
        self.media.video_set_scale(0)  # 必須設置為0,否則無法修改屏幕寬高
        self.media.video_set_aspect_ratio(ratio)

    # 設置窗口句柄
    def set_window(self, wm_id):
        if platform.system() == 'Windows':
            self.media.set_hwnd(wm_id)
        else:
            self.media.set_xwindow(wm_id)

    # 注冊監聽器
    def add_callback(self, event_type, callback):
        self.media.event_manager().event_attach(event_type, callback)

    # 移除監聽器
    def remove_callback(self, event_type, callback):
        self.media.event_manager().event_detach(event_type, callback)



import tkinter as tk


class App(tk.Tk):
    def __init__(self):
        super().__init__()
        self.player = Player()
        self.title("流媒體播放器")
        self.create_video_view()
        self.create_control_view()

    def create_video_view(self):
        self._canvas = tk.Canvas(self, bg="black")
        self._canvas.pack()
        self.player.set_window(self._canvas.winfo_id())

    def create_control_view(self):
        frame = tk.Frame(self)
        tk.Button(frame, text="播放", command=lambda: self.click(0)).pack(side=tk.LEFT, padx=5)
        tk.Button(frame, text="暫停", command=lambda: self.click(1)).pack(side=tk.LEFT)
        tk.Button(frame, text="停止", command=lambda: self.click(2)).pack(side=tk.LEFT, padx=5)
        frame.pack()

    def click(self, action):
        if action == 0:
            if self.player.get_state() == 0:
                self.player.resume()
            elif self.player.get_state() == 1:
                pass  # 播放新資源
            else:
                self.player.play("http://hd.yinyuetai.com/uploads/videos/common/"
                                 "22970150925A6BB75E20D95798D129EE.flv?sc\u003d17d6a907580e9892"
                                 "\u0026br\u003d1103\u0026vid\u003d2400382\u0026aid\u003d32"
                                 "\u0026area\u003dML\u0026vst\u003d0")
        elif action == 1:
            if self.player.get_state() == 1:
                self.player.pause()
        else:
            self.player.stop()


if "__main__" == __name__:
    app = App()
    app.mainloop()

使用Python怎么實現一個流媒體播放器

最后說一點,如果我們在創建Player時,指定音頻可視化參數,如下,則當播放音頻時,self._canvas中將顯示音頻可視化頻譜。

player = Player("--audio-visual=visual", 
"--effect-list=spectrum", "--effect-fft-window=flattop")

跨平臺

如果我們想用Python開發跨平臺的播放器,在Linux系統中,不推薦集成VLC二進制文件,我們可以有兩種思路,Ubuntu中,我們可以通過調用命令在線安裝vlc

sudo apt-get install vlc

另一種思路則是集成VLC源碼,調用系統的編譯命令進行編譯。通常Linux平臺都會帶有gcc編譯器和make構建工具。該方案同樣適用于Mac os平臺。


看完上述內容,你們對使用Python怎么實現一個流媒體播放器有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

新平| 北海市| 临江市| 页游| 高清| 岐山县| 汉中市| 集贤县| 克拉玛依市| 宁安市| 布尔津县| 城口县| 兴城市| 裕民县| 德保县| 军事| 龙岩市| 天峻县| 瑞安市| 上林县| 石林| 明溪县| 临沂市| 翁源县| 海兴县| 通榆县| 巴马| 将乐县| 嘉善县| 万年县| 遂宁市| 彭阳县| 南华县| 栖霞市| 平邑县| 阳谷县| 怀安县| 峨眉山市| 澄城县| 胶州市| 志丹县|