Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Docs
提交
7a6b0d4e
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看板
未验证
提交
7a6b0d4e
编写于
1月 20, 2022
作者:
O
openharmony_ci
提交者:
Gitee
1月 20, 2022
浏览文件
操作
浏览文件
下载
差异文件
!1216 更新js-apis-media.md和audio-playback.md
Merge pull request !1216 from 马靖涛/apis.md
上级
98e9a5ac
d20d29bc
变更
3
展开全部
隐藏空白更改
内联
并排
Showing
3 changed file
with
573 addition
and
235 deletion
+573
-235
zh-cn/application-dev/media/audio-playback.md
zh-cn/application-dev/media/audio-playback.md
+169
-121
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/reference/apis/js-apis-media.md
zh-cn/application-dev/reference/apis/js-apis-media.md
+404
-114
未找到文件。
zh-cn/application-dev/media/audio-playback.md
浏览文件 @
7a6b0d4e
# 音频播放开发指导
# 音频播放开发指导
-
[
场景介绍
](
#场景介绍
)
-
[
接口说明
](
#接口说明
)
## 场景介绍
## 场景介绍
音频播放的主要工作是将音频数据转码为可听见的音频模拟信号并通过输出设备进行播放,同时对播放任务进行管理。
音频播放的主要工作是将音频数据转码为可听见的音频模拟信号并通过输出设备进行播放,同时对播放任务进行管理。
**图1**
音频播放状态机
**图1**
音频播放状态机
![
zh-cn_image_0000001182608857
](
figures/zh-cn_image_0000001182608857.png
)
![
zh-ch_image_20220117
](
figures/zh-ch_image_20220117.jpg
)
## 接口说明
## 音频播放开发步骤
**表1**
media
详细API含义可参考:
[
js-apis-media.md
](
../reference/apis/js-apis-media.md
)
| 接口名 | 描述 |
### 全流程场景
| -------- | -------- |
| media.createAudioPlayer() | 创建AudioPlayer实例。 |
包含流程:创建实例,设置uri,播放音频,跳转播放位置,设置音量,暂停播放,获取轨道信息,停止播放,重置,释放资源等流程。
| AudioPlayer | 提供音频播放相关功能,具体见表
音频播放相关的interface
AudioPlayer。 |
AudioPlayer支持的src媒体源输入类型可参考:
[
src属性说明
](
../reference/apis/js-apis-media.md#audioplayer_属性
)
**表2**
音频播放相关的interface
**AudioPlayer**
```
js
| 接口名 | 描述 |
function
SetCallBack
(
audioPlayer
)
{
| -------- | -------- |
audioPlayer
.
on
(
'
dataLoad
'
,
()
=>
{
//设置'dataLoad'事件回调,src属性设置成功后,触发此回调
| release() | 释放音频资源。 |
console
.
info
(
'
audio set source success
'
);
| play() | 开始播放音频源。 |
//播放界面可切换至已准备好,可点击播放按钮进行播放状态
| pause() | 暂停播放。 |
});
| stop() | 停止播放。 |
audioPlayer
.
on
(
'
play
'
,
()
=>
{
//设置'play'事件回调
| reset()
<sup>
7+
</sup>
| 重置播放音频源。 |
console
.
info
(
'
audio play success
'
);
| setVolume(vol:
number) | 改变音频播放音量 |
//将播放按钮切换至可暂停状态
| seek(timeMs:
number) | 改变播放位置。 |
});
| src:string | 音频播放的媒体URI。 |
audioPlayer
.
on
(
'
pause
'
,
()
=>
{
//设置'pause'事件回调
| state:AudioState | 播放的状态属性。 |
console
.
info
(
'
audio pause success
'
);
| currentTime:number | 音频的当前播放位置。 |
//将播放按钮切换至可播放状态
| duration:number | 音频播放的时长(当数据源不支持改变播放位置时返回-1, 比如实时流媒体场景)。 |
});
| loop:boolean | 音频的循环播放属性。 |
audioPlayer
.
on
(
'
stop
'
,
()
=>
{
//设置'stop'事件回调
| on('play',
function
callback) | 订阅音频播放开始事件。 |
console
.
info
(
'
audio stop success
'
);
| on('pause',
function
callback) | 订阅音频播放暂停事件。 |
//播放停止,播放进度条归零,播放按钮切换至可播放状态
| on('stop',
function
callback) | 订阅音频播放停止事件。 |
});
| on('reset',
function
callback) | 订阅音频播放重置事件。 |
audioPlayer
.
on
(
'
reset
'
,
()
=>
{
//设置'reset'事件回调
| on('finish',function
callback) | 订阅音频播放结束事件。 |
console
.
info
(
'
audio reset success
'
);
| on('error',
function
callback) | 订阅音频播放错误事件。 |
//需重新设置src属性后,可继续播放其他音频
| on('dataload',
function
callback) | 订阅音频播放加载数据事件。 |
});
| on('volumeChange',
function
callback) | 订阅音频播放音量变化事件。 |
audioPlayer
.
on
(
'
timeUpdate
'
,
(
seekDoneTime
)
=>
{
//设置'timeUpdate'事件回调
| on('timeUpdate',
function
callback) | 订阅音频播放进度改变事件。 |
if
(
typeof
(
seekDoneTime
)
==
'
undefined
'
)
{
console
.
info
(
'
audio seek fail
'
);
1.
创建音频播放器。
```
import media from '@ohos.multimedia.media';
var player = media.createAudioPlayer();
```
2.
设置消息订阅事件。
```
player.on('play', (err, action) => {
if (err) {
console.error('Error returned in the play() callback.');
return;
}
console.info('Current player duration: '+ player.duration);
console.info('Current player time: ' + player.currentTime);
console.info('Current player status: '+player.state);
console.info('Pause MP3');
player.pause();
});
player.on('pause', (err, action) => {
if (err) {
console.error('Error returned in the pause() callback.');
return
;
return
;
}
console.info('Current player status: ' + player.state);
console.info('Current player time: ' + player.currentTime);
player.seek(30000); // Seek for 30 seconds.
});
player.on('stop', (err, action) => {
if (err) {
console.error('Error returned in the stop() callback.');
return;
}
console.info('stop callback invoked. State:' + player.state);
player.reset();
});
player.on('dataLoad', (err, action) => {
if (err) {
console.error('Error returned in the dataLoad() callback.');
return;
}
console.info('dataLoad callback invoked. Current time: ' + player.currentTime);
console.info('Duration of the source:' + player.duration);
player.play();
});
player.on('reset', (err, action) => {
if (err) {
console.error('Error returned in the reset() callback.');
return;
}
console.info('reset callback invoked.');
player.release();
});
player.on('finish', (err, action) => {
if (err) {
console.error('Error returned in the finish() callback.');
return;
}
}
console.info('finish callback invoked.');
console
.
info
(
'
audio seek success, and seek time is
'
+
seekDoneTime
);
});
//播放进度条更新到seek对应的位置
player.on('timeUpdate', (seekTime, action) => {
});
console.info('Seek time: ' + seekTime);
audioPlayer
.
on
(
'
volumeChange
'
,
()
=>
{
//设置'volumeChange'事件回调
console.info('Current player time: ' + player.currentTime);
console
.
info
(
'
audio volumeChange success
'
);
var newTime = player.currentTime;
//更新音量显示
if(newTime == 30000) {
});
console.info('Seek succeeded. New time: ' + newTime);
audioPlayer
.
on
(
'
finish
'
,
()
=>
{
//设置'finish'事件回调,播放完成触发
} else {
console
.
info
(
'
audio play finish
'
);
console.error('Seek failed: ', + newTime);
});
audioPlayer
.
on
(
'
error
'
,
(
error
)
=>
{
//设置'error'事件回调
console
.
info
(
`audio error called, errName is
${
error
.
name
}
`
);
console
.
info
(
`audio error called, errCode is
${
error
.
code
}
`
);
console
.
info
(
`audio error called, errMessage is
${
error
.
message
}
`
);
});
}
function
printfDescription
(
obj
)
{
for
(
let
item
in
obj
)
{
let
property
=
obj
[
item
];
console
.
info
(
'
audio key is
'
+
item
);
console
.
info
(
'
audio value is
'
+
property
);
}
}
//1、创建实例
let
audioPlayer
=
media
.
createAudioPlayer
();
SetCallBack
(
audioPlayer
);
//设置事件回调
//2、用户选择音频,设置uri
audioPlayer
.
src
=
'
file:///data/data/ohos.xxx.xxx/files/test.mp3
'
;
//设置src属性,并触发'dataLoad'事件回调
//3、播放音频
audioPlayer
.
play
();
//需等待'dataLoad'事件回调完成后,才可调用play进行播放,触发'play'事件回调
//4、跳转播放位置
audioPlayer
.
seek
(
30000
);
//触发'timeUpdate'事件回调,seek到30000ms处播放
//5、设置音量
audioPlayer
.
setVolume
(
0.5
);
//触发'volumeChange'事件回调
//6、暂停播放
audioPlayer
.
pause
();
//触发'pause'事件回调,暂停播放
//7、获取轨道信息
audioPlayer
.
getTrackDescription
((
error
,
arrlist
)
=>
{
//通过回调方式获取音频轨道信息
if
(
typeof
(
arrlist
)
!=
'
undefined
'
)
{
for
(
let
i
=
0
;
i
<
arrlist
.
length
;
i
++
)
{
printfDescription
(
arrlist
[
i
]);
}
}
player.stop();
}
else
{
});
console
.
log
(
`audio getTrackDescription fail, error:
${
error
.
message
}
`
);
player.on('error', (err) => {
}
console.error('Player error: ${err.message}');
});
});
//8、停止播放
```
audioPlayer
.
stop
();
//触发'stop'事件回调
//9、重置播放资源
3.
启动播放。
audioPlayer
.
reset
();
//触发'reset'事件回调后,重新设置src属性,可完成切歌
```
//10、释放资源
var audioSourceMp3 = 'file://test.mp3';
audioPlayer
.
release
();
//audioPlayer资源被销毁
player.src = audioSourceMp3;
audioPlayer
=
undefined
;
player.loop = true;
```
```
### 正常播放场景
```
js
function
SetCallBack
(
audioPlayer
)
{
audioPlayer
.
on
(
'
dataLoad
'
,
()
=>
{
//设置'dataLoad'事件回调,src属性设置成功后,触发此回调
console
.
info
(
'
audio set source success
'
);
audioPlayer
.
play
();
//调用play方法开始播放,触发'play'事件回调
});
audioPlayer
.
on
(
'
play
'
,
()
=>
{
//设置'play'事件回调
console
.
info
(
'
audio play success
'
);
});
audioPlayer
.
on
(
'
finish
'
,
()
=>
{
//设置'finish'事件回调,播放完成触发
console
.
info
(
'
audio play finish
'
);
audioPlayer
.
release
();
//audioPlayer资源被销毁
audioPlayer
=
undefined
;
});
}
let
audioPlayer
=
media
.
createAudioPlayer
();
//创建一个音频播放实例
SetCallBack
(
audioPlayer
);
//设置事件回调
/* 用户选择音频,设置uri */
audioPlayer
.
src
=
'
file:///data/data/ohos.xxx.xxx/files/test.mp3
'
;
//设置src属性,并触发'dataLoad'事件回调
```
### 切歌场景
```
js
function
SetCallBack
(
audioPlayer
)
{
audioPlayer
.
on
(
'
dataLoad
'
,
()
=>
{
//设置'dataLoad'事件回调,src属性设置成功后,触发此回调
console
.
info
(
'
audio set source success
'
);
audioPlayer
.
play
();
//调用play方法开始播放,触发'play'事件回调
});
audioPlayer
.
on
(
'
play
'
,
()
=>
{
//设置'play'事件回调
console
.
info
(
'
audio play success
'
);
});
audioPlayer
.
on
(
'
finish
'
,
()
=>
{
//设置'finish'事件回调,播放完成触发
console
.
info
(
'
audio play finish
'
);
audioPlayer
.
release
();
//audioPlayer资源被销毁
audioPlayer
=
undefined
;
});
}
let
audioPlayer
=
media
.
createAudioPlayer
();
//创建一个音频播放实例
SetCallBack
(
audioPlayer
);
//设置事件回调
/* 用户选择音频,设置uri */
audioPlayer
.
src
=
'
file:///data/data/ohos.xxx.xxx/files/test.mp3
'
;
//设置src属性,并触发'dataLoad'事件回调
/* 播放一段时间后,下发切歌指令 */
audioPlayer
.
reset
();
audioPlayer
.
src
=
'
file:///data/data/ohos.xxx.xxx/files/next.mp3
'
;
```
### 单曲循环场景
```
js
function
SetCallBack
(
audioPlayer
)
{
audioPlayer
.
on
(
'
dataLoad
'
,
()
=>
{
//设置'dataLoad'事件回调,src属性设置成功后,触发此回调
console
.
info
(
'
audio set source success
'
);
audioPlayer
.
play
();
//调用play方法开始播放,触发'play'事件回调
});
audioPlayer
.
on
(
'
play
'
,
()
=>
{
//设置'play'事件回调
console
.
info
(
'
audio play success
'
);
});
audioPlayer
.
on
(
'
finish
'
,
()
=>
{
//设置'finish'事件回调,播放完成触发
console
.
info
(
'
audio play finish
'
);
audioPlayer
.
release
();
//audioPlayer资源被销毁
audioPlayer
=
undefined
;
});
}
let
audioPlayer
=
media
.
createAudioPlayer
();
//创建一个音频播放实例
SetCallBack
(
audioPlayer
);
//设置事件回调
/* 用户选择音频,设置uri */
audioPlayer
.
src
=
'
file:///data/data/ohos.xxx.xxx/files/test.mp3
'
;
//设置src属性,并触发'dataLoad'事件回调
audioPlayer
.
loop
=
true
;
//设置循环播放属性
```
\ No newline at end of file
zh-cn/application-dev/media/figures/zh-ch_image_20220117.jpg
0 → 100644
浏览文件 @
7a6b0d4e
67.4 KB
zh-cn/application-dev/reference/apis/js-apis-media.md
浏览文件 @
7a6b0d4e
此差异已折叠。
点击以展开。
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录