Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Docs
提交
f1c196f2
D
Docs
项目概览
OpenHarmony
/
Docs
1 年多 前同步成功
通知
159
Star
292
Fork
28
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
Docs
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
f1c196f2
编写于
2月 22, 2022
作者:
O
openharmony_ci
提交者:
Gitee
2月 22, 2022
浏览文件
操作
浏览文件
下载
差异文件
!1588 视频资料
Merge pull request !1588 from hwgaizw/docsVideoPlayer
上级
47f636c0
2b707caf
变更
9
展开全部
隐藏空白更改
内联
并排
Showing
9 changed file
with
1237 addition
and
5 deletion
+1237
-5
zh-cn/application-dev/media/Readme-CN.md
zh-cn/application-dev/media/Readme-CN.md
+2
-1
zh-cn/application-dev/media/audio-playback.md
zh-cn/application-dev/media/audio-playback.md
+7
-1
zh-cn/application-dev/media/figures/zh-ch_image_20220117.jpg
zh-cn/application-dev/media/figures/zh-ch_image_20220117.jpg
+0
-0
zh-cn/application-dev/media/figures/zh-ch_image_audio_player.png
...pplication-dev/media/figures/zh-ch_image_audio_player.png
+0
-0
zh-cn/application-dev/media/figures/zh-ch_image_audio_state_machine.png
...ion-dev/media/figures/zh-ch_image_audio_state_machine.png
+0
-0
zh-cn/application-dev/media/figures/zh-ch_image_video_player.png
...pplication-dev/media/figures/zh-ch_image_video_player.png
+0
-0
zh-cn/application-dev/media/figures/zh-ch_image_video_state_machine.png
...ion-dev/media/figures/zh-ch_image_video_state_machine.png
+0
-0
zh-cn/application-dev/media/video-playback.md
zh-cn/application-dev/media/video-playback.md
+375
-0
zh-cn/application-dev/reference/apis/js-apis-media.md
zh-cn/application-dev/reference/apis/js-apis-media.md
+853
-3
未找到文件。
zh-cn/application-dev/media/Readme-CN.md
浏览文件 @
f1c196f2
...
...
@@ -5,7 +5,8 @@
-
[
音频播放开发指导
](
audio-playback.md
)
-
[
音频管理开发指导
](
audio-management.md
)
-
[
音频录制开发指导
](
audio-recorder.md
)
-
视频
-
[
视频开发概述
](
video-overview.md
)
-
[
视频播放开发指导
](
video-playback.md
)
-
[
视频录制开发指导
](
video-recorder.md
)
zh-cn/application-dev/media/audio-playback.md
浏览文件 @
f1c196f2
...
...
@@ -6,7 +6,13 @@
**图1**
音频播放状态机
![
zh-ch_image_20220117
](
figures/zh-ch_image_20220117.jpg
)
![
zh-ch_image_audio_state_machine
](
figures/zh-ch_image_audio_state_machine.png
)
## 视频播放零层图
**图2**
视频播放零层图
![
zh-ch_image_audio_player
](
figures/zh-ch_image_audio_player.png
)
## 音频播放开发步骤
...
...
zh-cn/application-dev/media/figures/zh-ch_image_20220117.jpg
已删除
100644 → 0
浏览文件 @
47f636c0
67.3 KB
zh-cn/application-dev/media/figures/zh-ch_image_audio_player.png
0 → 100644
浏览文件 @
f1c196f2
19.3 KB
zh-cn/application-dev/media/figures/zh-ch_image_audio_state_machine.png
0 → 100644
浏览文件 @
f1c196f2
28.8 KB
zh-cn/application-dev/media/figures/zh-ch_image_video_player.png
0 → 100644
浏览文件 @
f1c196f2
22.3 KB
zh-cn/application-dev/media/figures/zh-ch_image_video_state_machine.png
0 → 100644
浏览文件 @
f1c196f2
37.6 KB
zh-cn/application-dev/media/video-playback.md
0 → 100644
浏览文件 @
f1c196f2
# 视频播放开发指导
## 场景介绍
视频播放的主要工作是将视频数据转码并输出到设备进行播放,同时管理播放任务。本文将对视频播放全流程、视频切换、视频循环播放等场景开发进行介绍说明。
**图1**
视频播放状态机
![
zh-ch_image_video_state_machine
](
figures/zh-ch_image_video_state_machine.png
)
## 视频播放零层图
**图2**
视频播放零层图
![
zh-ch_image_video_player
](
figures/zh-ch_image_video_player.png
)
*
注意:视频播放需要显示、音频、编解码等硬件能力。
1.
三方应用从Xcomponent组件获取surfaceID。
2.
三方应用把surfaceID传递给VideoPlayer JS。
3.
媒体服务把帧数据flush给surface buffer。
## 视频播放开发步骤
详细API含义可参考:
[
js-apis-media.md
](
../reference/apis/js-apis-media.md
)
### 全流程场景
包含流程:创建实例,设置url,设置SurfaceId,准备播放视频,播放视频,暂停播放,获取轨道信息,跳转播放位置,设置音量,设置倍速,结束播放,重置,释放资源等流程。
VideoPlayer支持的url媒体源输入类型可参考:
[
url属性说明
](
../reference/apis/js-apis-media.md#videoplayer_属性
)
```
js
let
videoPlayer
=
undefined
;
// 用于保存createVideoPlayer创建的对象
let
surfaceID
=
undefined
;
// 用于保存Xcomponent接口返回的surfaceID
// 函数调用发生错误时用于上报错误信息
function
failureCallback
(
error
)
{
console
.
info
(
`error happened,error Name is
${
error
.
name
}
`
);
console
.
info
(
`error happened,error Code is
${
error
.
code
}
`
);
console
.
info
(
`error happened,error Message is
${
error
.
message
}
`
);
}
// 当函数调用发生异常时用于上报错误信息
function
catchCallback
(
error
)
{
console
.
info
(
`catch error happened,error Name is
${
error
.
name
}
`
);
console
.
info
(
`catch error happened,error Code is
${
error
.
code
}
`
);
console
.
info
(
`catch error happened,error Message is
${
error
.
message
}
`
);
}
// 用于打印视频轨道信息
function
printfDescription
(
obj
)
{
for
(
let
item
in
obj
)
{
let
property
=
obj
[
item
];
console
.
info
(
'
key is
'
+
item
);
console
.
info
(
'
value is
'
+
property
);
}
}
// 调用createVideoPlayer接口返回videoPlayer实例对象
await
media
.
createVideoPlayer
().
then
((
video
)
=>
{
if
(
typeof
(
video
)
!=
'
undefined
'
)
{
console
.
info
(
'
createVideoPlayer success!
'
);
videoPlayer
=
video
;
}
else
{
console
.
info
(
'
createVideoPlayer fail!
'
);
}
},
failureCallback
).
catch
(
catchCallback
);
// 用户选择视频设置url
videoPlayer
.
url
=
'
file:///data/data/ohos.xxx.xxx/files/test.mp4
'
;
// 该处需要调用Xcomponent的接口用于获取surfaceID,并保存在surfaceID变量中
// 设置surfaceID用于显示视频画面
await
videoPlayer
.
setDisplaySurface
(
surfaceID
).
then
(()
=>
{
console
.
info
(
'
setDisplaySurface success
'
);
},
failureCallback
).
catch
(
catchCallback
);
// 调用prepare完成播放前准备工作
await
videoPlayer
.
prepare
().
then
(()
=>
{
console
.
info
(
'
prepare success
'
);
},
failureCallback
).
catch
(
catchCallback
);
// 调用play接口正式开始播放
await
videoPlayer
.
play
().
then
(()
=>
{
console
.
info
(
'
play success
'
);
},
failureCallback
).
catch
(
catchCallback
);
// 暂停播放
await
videoPlayer
.
pause
().
then
(()
=>
{
console
.
info
(
'
pause success
'
);
},
failureCallback
).
catch
(
catchCallback
);
// 通过promise回调方式获取视频轨道信息
let
arrayDescription
;
await
videoPlayer
.
getTrackDescription
().
then
((
arrlist
)
=>
{
if
(
typeof
(
arrlist
)
!=
'
undefined
'
)
{
arrayDescription
=
arrlist
;
}
else
{
console
.
log
(
'
video getTrackDescription fail
'
);
}
},
failureCallback
).
catch
(
catchCallback
);
for
(
let
i
=
0
;
i
<
arrayDescription
.
length
;
i
++
)
{
printfDescription
(
arrayDescription
[
i
]);
}
// 跳转播放时间到50s位置,具体入参意义请参考接口文档
let
seekTime
=
50000
;
await
videoPlayer
.
seek
(
seekTime
,
media
.
SeekMode
.
_NEXT_SYNC
).
then
((
seekDoneTime
)
=>
{
console
.
info
(
'
seek success
'
);
},
failureCallback
).
catch
(
catchCallback
);
// 音量设置接口,具体入参意义请参考接口文档
let
volume
=
0.5
;
await
videoPlayer
.
setVolume
(
volume
).
then
(()
=>
{
console
.
info
(
'
setVolume success
'
);
},
failureCallback
).
catch
(
catchCallback
);
// 倍速设置接口,具体入参意义请参考接口文档
let
speed
=
media
.
PlaybackRateMode
.
SPEED_FORWARD_2_00_X
;
await
videoPlayer
.
setSpeed
(
speed
).
then
(()
=>
{
console
.
info
(
'
setSpeed success
'
);
},
failureCallback
).
catch
(
catchCallback
);
// 结束播放
await
videoPlayer
.
stop
().
then
(()
=>
{
console
.
info
(
'
stop success
'
);
},
failureCallback
).
catch
(
catchCallback
);
// 重置播放配置
await
videoPlayer
.
reset
().
then
(()
=>
{
console
.
info
(
'
reset success
'
);
},
failureCallback
).
catch
(
catchCallback
);
// 释放播放资源
await
videoPlayer
.
release
().
then
(()
=>
{
console
.
info
(
'
release success
'
);
},
failureCallback
).
catch
(
catchCallback
);
// 相关对象置undefined
videoPlayer
=
undefined
;
surfaceID
=
undefined
;
```
### 正常播放场景
```
js
let
videoPlayer
=
undefined
;
// 用于保存createVideoPlayer创建的对象
let
surfaceID
=
undefined
;
// 用于保存Xcomponent接口返回的surfaceID
// 函数调用发生错误时用于上报错误信息
function
failureCallback
(
error
)
{
console
.
info
(
`error happened,error Name is
${
error
.
name
}
`
);
console
.
info
(
`error happened,error Code is
${
error
.
code
}
`
);
console
.
info
(
`error happened,error Message is
${
error
.
message
}
`
);
}
// 当函数调用发生异常时用于上报错误信息
function
catchCallback
(
error
)
{
console
.
info
(
`catch error happened,error Name is
${
error
.
name
}
`
);
console
.
info
(
`catch error happened,error Code is
${
error
.
code
}
`
);
console
.
info
(
`catch error happened,error Message is
${
error
.
message
}
`
);
}
// 设置'playbackCompleted'事件回调,播放完成触发
function
SetCallBack
(
videoPlayer
)
{
videoPlayer
.
on
(
'
playbackCompleted
'
,
()
=>
{
console
.
info
(
'
video play finish
'
);
await
videoPlayer
.
release
().
then
(()
=>
{
console
.
info
(
'
release success
'
);
},
failureCallback
).
catch
(
catchCallback
);
videoPlayer
=
undefined
;
surfaceID
=
undefined
;
});
}
// 调用createVideoPlayer接口返回videoPlayer实例对象
await
media
.
createVideoPlayer
().
then
((
video
)
=>
{
if
(
typeof
(
video
)
!=
'
undefined
'
)
{
console
.
info
(
'
createVideoPlayer success!
'
);
videoPlayer
=
video
;
}
else
{
console
.
info
(
'
createVideoPlayer fail!
'
);
}
},
failureCallback
).
catch
(
catchCallback
);
// 设置事件回调
SetCallBack
(
videoPlayer
);
// 用户选择视频设置url
videoPlayer
.
url
=
'
file:///data/data/ohos.xxx.xxx/files/test.mp4
'
;
// 该处需要调用Xcomponent的接口用于获取surfaceID,并保存在surfaceID变量中
// 设置surfaceID用于显示视频画面
await
videoPlayer
.
setDisplaySurface
(
surfaceID
).
then
(()
=>
{
console
.
info
(
'
setDisplaySurface success
'
);
},
failureCallback
).
catch
(
catchCallback
);
// 调用prepare完成播放前准备工作
await
videoPlayer
.
prepare
().
then
(()
=>
{
console
.
info
(
'
prepare success
'
);
},
failureCallback
).
catch
(
catchCallback
);
// 调用play接口正式开始播放
await
videoPlayer
.
play
().
then
(()
=>
{
console
.
info
(
'
play success
'
);
},
failureCallback
).
catch
(
catchCallback
);
```
### 切视频场景
```
js
let
videoPlayer
=
undefined
;
// 用于保存createVideoPlayer创建的对象
let
surfaceID
=
undefined
;
// 用于保存Xcomponent接口返回的surfaceID
// 函数调用发生错误时用于上报错误信息
function
failureCallback
(
error
)
{
console
.
info
(
`error happened,error Name is
${
error
.
name
}
`
);
console
.
info
(
`error happened,error Code is
${
error
.
code
}
`
);
console
.
info
(
`error happened,error Message is
${
error
.
message
}
`
);
}
// 当函数调用发生异常时用于上报错误信息
function
catchCallback
(
error
)
{
console
.
info
(
`catch error happened,error Name is
${
error
.
name
}
`
);
console
.
info
(
`catch error happened,error Code is
${
error
.
code
}
`
);
console
.
info
(
`catch error happened,error Message is
${
error
.
message
}
`
);
}
// 设置'playbackCompleted'事件回调,播放完成触发
function
SetCallBack
(
videoPlayer
)
{
videoPlayer
.
on
(
'
playbackCompleted
'
,
()
=>
{
console
.
info
(
'
video play finish
'
);
await
videoPlayer
.
release
().
then
(()
=>
{
console
.
info
(
'
release success
'
);
},
failureCallback
).
catch
(
catchCallback
);
videoPlayer
=
undefined
;
surfaceID
=
undefined
;
});
}
// 调用createVideoPlayer接口返回videoPlayer实例对象
await
media
.
createVideoPlayer
().
then
((
video
)
=>
{
if
(
typeof
(
video
)
!=
'
undefined
'
)
{
console
.
info
(
'
createVideoPlayer success!
'
);
videoPlayer
=
video
;
}
else
{
console
.
info
(
'
createVideoPlayer fail!
'
);
}
},
failureCallback
).
catch
(
catchCallback
);
// 设置事件回调
SetCallBack
(
videoPlayer
);
// 用户选择视频设置url
videoPlayer
.
url
=
'
file:///data/data/ohos.xxx.xxx/files/test.mp4
'
;
// 该处需要调用Xcomponent的接口用于获取surfaceID,并保存在surfaceID变量中
// 设置surfaceID用于显示视频画面
await
videoPlayer
.
setDisplaySurface
(
surfaceID
).
then
(()
=>
{
console
.
info
(
'
setDisplaySurface success
'
);
},
failureCallback
).
catch
(
catchCallback
);
// 调用prepare完成播放前准备工作
await
videoPlayer
.
prepare
().
then
(()
=>
{
console
.
info
(
'
prepare success
'
);
},
failureCallback
).
catch
(
catchCallback
);
// 调用play接口正式开始播放
await
videoPlayer
.
play
().
then
(()
=>
{
console
.
info
(
'
play success
'
);
},
failureCallback
).
catch
(
catchCallback
);
// 播放一段时间后,下发切视频指令
// 重置播放配置
await
videoPlayer
.
reset
().
then
(()
=>
{
console
.
info
(
'
reset success
'
);
},
failureCallback
).
catch
(
catchCallback
);
videoPlayer
.
url
=
'
file:///data/data/ohos.xxx.xxx/files/next.mp4
'
;
// 设置surfaceID用于显示视频画面
await
videoPlayer
.
setDisplaySurface
(
surfaceID
).
then
(()
=>
{
console
.
info
(
'
setDisplaySurface success
'
);
},
failureCallback
).
catch
(
catchCallback
);
// 调用prepare完成播放前准备工作
await
videoPlayer
.
prepare
().
then
(()
=>
{
console
.
info
(
'
prepare success
'
);
},
failureCallback
).
catch
(
catchCallback
);
// 调用play接口正式开始播放
await
videoPlayer
.
play
().
then
(()
=>
{
console
.
info
(
'
play success
'
);
},
failureCallback
).
catch
(
catchCallback
);
```
### 单个视频循环场景
```
js
let
videoPlayer
=
undefined
;
// 用于保存createVideoPlayer创建的对象
let
surfaceID
=
undefined
;
// 用于保存Xcomponent接口返回的surfaceID
// 函数调用发生错误时用于上报错误信息
function
failureCallback
(
error
)
{
console
.
info
(
`error happened,error Name is
${
error
.
name
}
`
);
console
.
info
(
`error happened,error Code is
${
error
.
code
}
`
);
console
.
info
(
`error happened,error Message is
${
error
.
message
}
`
);
}
// 当函数调用发生异常时用于上报错误信息
function
catchCallback
(
error
)
{
console
.
info
(
`catch error happened,error Name is
${
error
.
name
}
`
);
console
.
info
(
`catch error happened,error Code is
${
error
.
code
}
`
);
console
.
info
(
`catch error happened,error Message is
${
error
.
message
}
`
);
}
// 设置'playbackCompleted'事件回调,播放完成触发
function
SetCallBack
(
videoPlayer
)
{
videoPlayer
.
on
(
'
playbackCompleted
'
,
()
=>
{
console
.
info
(
'
video play finish
'
);
await
videoPlayer
.
release
().
then
(()
=>
{
console
.
info
(
'
release success
'
);
},
failureCallback
).
catch
(
catchCallback
);
videoPlayer
=
undefined
;
surfaceID
=
undefined
;
});
}
// 调用createVideoPlayer接口返回videoPlayer实例对象
await
media
.
createVideoPlayer
().
then
((
video
)
=>
{
if
(
typeof
(
video
)
!=
'
undefined
'
)
{
console
.
info
(
'
createVideoPlayer success!
'
);
videoPlayer
=
video
;
}
else
{
console
.
info
(
'
createVideoPlayer fail!
'
);
}
},
failureCallback
).
catch
(
catchCallback
);
// 设置事件回调
SetCallBack
(
videoPlayer
);
// 用户选择视频设置url
videoPlayer
.
url
=
'
file:///data/data/ohos.xxx.xxx/files/test.mp4
'
;
// 该处需要调用Xcomponent的接口用于获取surfaceID,并保存在surfaceID变量中
// 设置surfaceID用于显示视频画面
await
videoPlayer
.
setDisplaySurface
(
surfaceID
).
then
(()
=>
{
console
.
info
(
'
setDisplaySurface success
'
);
},
failureCallback
).
catch
(
catchCallback
);
// 调用prepare完成播放前准备工作
await
videoPlayer
.
prepare
().
then
(()
=>
{
console
.
info
(
'
prepare success
'
);
},
failureCallback
).
catch
(
catchCallback
);
// 设置循环播放属性
videoPlayer
.
loop
=
true
;
// 调用play接口正式开始播放
await
videoPlayer
.
play
().
then
(()
=>
{
console
.
info
(
'
play success
'
);
},
failureCallback
).
catch
(
catchCallback
);
```
\ No newline at end of file
zh-cn/application-dev/reference/apis/js-apis-media.md
浏览文件 @
f1c196f2
此差异已折叠。
点击以展开。
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录