注意

这是最新开发分支配套的文档,可能包含已发布版本中尚未提供的功能。如果您要查看特定版本的文档,请使用左侧的下拉菜单并选择所需要的版本。

播放器模块 API 手册#

概述#

本文件详细介绍 K230_CanMV 播放器模块 API,旨在支持 MP4 格式文件的播放。该模块能够同时播放音频与视频,音频格式支持 G.711A/U,视频格式支持 H.264/H.265 编码。

API 介绍#

该模块提供了 Player 类,包含以下方法:

构造函数#

描述

根据指定的 display_type 构造 Player 对象。用户需先创建 Player 对象以进行后续操作。

语法

player = Player(display_type = Display.VIRT,display_to_ide = True)

参数

参数名称

描述

输入/输出

说明

display_type

显示设备类型

输入

display_to_ide

是否同时输出到 IDE 虚拟屏

输入

返回值

返回值

描述

Player 对象

创建的 Player 实例

示例

player = Player(Display.VIRT)
player = Player(Display.ST7701)
player = Player(Display.LT9611)

Player.load#

描述

加载指定文件,目前版本仅支持 MP4 格式文件。

语法

player = Player()
Player.load(filename = "test.mp4")

参数

参数名称

描述

输入/输出

filename

文件名称

输入

返回值

返回值

描述

注意事项

当前版本仅支持播放 MP4 格式文件。

Player.start#

描述

开始播放音视频内容。

语法

player = Player()
player.start()

参数

返回值

返回值

描述

Player.pause#

描述

暂停当前播放。

语法

player = Player()
player.pause()

参数

返回值

返回值

描述

Player.resume#

描述

恢复播放。

语法

player = Player()
player.resume()

参数

返回值

返回值

描述

Player.stop#

描述

停止播放。

语法

player = Player()
player.stop()

参数

返回值

返回值

描述

Player.destroy_mp4#

描述

销毁 mp4 播放器

语法

Player.destroy_mp4()

参数

返回值

返回值

描述

Player.set_event_callback#

描述

设置播放事件的回调函数。

语法

def player_event(event, data):
    pass

player = Player()
player.set_event_callback(callback=player_event)

参数

参数名称

描述

输入/输出

callback

回调函数名称

输入

返回值

返回值

描述

数据结构描述#

play_event_type#

描述

定义了播放事件的类型。

成员

成员名称

描述

K_PLAYER_EVENT_EOF

播放结束

K_PLAYER_EVENT_PROGRESS

播放进度

示例程序#

例程 1#

from media.player import *
import os
import time

start_play = False

def player_event(event, data):
    global start_play
    if event == K_PLAYER_EVENT_EOF:
        start_play = False

def play_mp4_test(filename):
    global start_play
    # 使用 IDE 作为输出显示,支持任意分辨率;适用于 BPI 开发板
    player = Player(Display.VIRT)
    # 使用 ST7701 LCD 屏幕作为输出显示,最大分辨率为 800x480
    # player = Player(Display.ST7701)
    # 使用 HDMI 作为输出显示
    # player = Player(Display.LT9611)
    
    player.load(filename)
    player.set_event_callback(player_event)
    player.start()
    start_play = True

    while start_play:
        time.sleep(0.1)

    player.stop()
    print("播放结束")

play_mp4_test("/sdcard/examples/test.mp4")
评论列表
条评论
登录