Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
DCloud
uni-app
提交
bd7d9cd3
U
uni-app
项目概览
DCloud
/
uni-app
2 个月 前同步成功
通知
718
Star
38705
Fork
3642
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
7
列表
看板
标记
里程碑
合并请求
1
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
U
uni-app
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
7
Issue
7
列表
看板
标记
里程碑
合并请求
1
合并请求
1
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
bd7d9cd3
编写于
4月 07, 2020
作者:
Q
qiang
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix: 修复App端无法获取音频暂停状态的问题
上级
26516432
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
28 addition
and
28 deletion
+28
-28
src/platforms/app-plus/service/api/context/audio.js
src/platforms/app-plus/service/api/context/audio.js
+2
-2
src/platforms/app-plus/service/api/context/background-audio.js
...latforms/app-plus/service/api/context/background-audio.js
+26
-26
未找到文件。
src/platforms/app-plus/service/api/context/audio.js
浏览文件 @
bd7d9cd3
...
...
@@ -122,7 +122,7 @@ export function getAudioState ({
errMsg
:
'
getAudioState:ok
'
,
duration
:
1
e3
*
(
audio
.
getDuration
()
||
0
),
currentTime
:
audio
.
isStopped
?
0
:
1
e3
*
audio
.
getPosition
(),
paused
:
audio
.
isPaused
,
paused
:
audio
.
isPaused
()
,
src
,
volume
,
startTime
:
1
e3
*
startTime
,
...
...
@@ -138,7 +138,7 @@ export function operateAudio ({
const
audio
=
audios
[
audioId
]
const
operationTypes
=
[
'
play
'
,
'
pause
'
,
'
stop
'
]
if
(
operationTypes
.
indexOf
(
operationType
)
>=
0
)
{
audio
[
operationType
===
operationTypes
[
0
]
&&
audio
.
isPaused
?
'
resume
'
:
operationType
]()
audio
[
operationType
===
operationTypes
[
0
]
&&
audio
.
isPaused
()
?
'
resume
'
:
operationType
]()
}
else
if
(
operationType
===
'
seek
'
)
{
audio
.
seekTo
(
currentTime
/
1
e3
)
}
...
...
src/platforms/app-plus/service/api/context/background-audio.js
浏览文件 @
bd7d9cd3
...
...
@@ -6,9 +6,9 @@ import {
publish
}
from
'
../../bridge
'
let
audio
let
timeUpdateTimer
=
null
let
audio
let
timeUpdateTimer
=
null
const
TIME_UPDATE
=
250
const
publishBackgroundAudioStateChange
=
(
state
,
res
=
{})
=>
publish
(
'
onBackgroundAudioStateChange
'
,
Object
.
assign
({
...
...
@@ -31,15 +31,15 @@ function initMusic () {
audio
.
addEventListener
(
event
,
()
=>
{
// 添加 isStopped 属性是为了解决 安卓设备停止播放后获取播放进度不正确的问题
if
(
event
===
'
play
'
)
{
audio
.
isStopped
=
false
audio
.
isStopped
=
false
startTimeUpdateTimer
()
}
else
if
(
event
===
'
stop
'
)
{
audio
.
isStopped
=
true
}
if
(
event
===
'
pause
'
||
event
===
'
ended
'
||
event
===
'
stop
'
)
{
stopTimeUpdateTimer
()
}
}
if
(
event
===
'
pause
'
||
event
===
'
ended
'
||
event
===
'
stop
'
)
{
stopTimeUpdateTimer
()
}
const
eventName
=
`onMusic
${
event
[
0
].
toUpperCase
()
+
event
.
substr
(
1
)}
`
publish
(
eventName
,
{
...
...
@@ -51,13 +51,13 @@ function initMusic () {
})
})
})
audio
.
addEventListener
(
'
waiting
'
,
()
=>
{
audio
.
addEventListener
(
'
waiting
'
,
()
=>
{
stopTimeUpdateTimer
()
publishBackgroundAudioStateChange
(
'
waiting
'
,
{
dataUrl
:
audio
.
src
})
})
audio
.
addEventListener
(
'
error
'
,
err
=>
{
audio
.
addEventListener
(
'
error
'
,
err
=>
{
stopTimeUpdateTimer
()
publish
(
'
onMusicError
'
,
{
dataUrl
:
audio
.
src
,
...
...
@@ -71,20 +71,20 @@ function initMusic () {
})
audio
.
addEventListener
(
'
prev
'
,
()
=>
publish
(
'
onBackgroundAudioPrev
'
))
audio
.
addEventListener
(
'
next
'
,
()
=>
publish
(
'
onBackgroundAudioNext
'
))
}
function
startTimeUpdateTimer
()
{
stopTimeUpdateTimer
()
timeUpdateTimer
=
setInterval
(()
=>
{
publishBackgroundAudioStateChange
(
'
timeUpdate
'
,
{})
},
TIME_UPDATE
)
}
}
function
stopTimeUpdateTimer
()
{
if
(
timeUpdateTimer
!==
null
)
{
clearInterval
(
timeUpdateTimer
)
}
}
function
startTimeUpdateTimer
()
{
stopTimeUpdateTimer
()
timeUpdateTimer
=
setInterval
(()
=>
{
publishBackgroundAudioStateChange
(
'
timeUpdate
'
,
{})
},
TIME_UPDATE
)
}
function
stopTimeUpdateTimer
()
{
if
(
timeUpdateTimer
!==
null
)
{
clearInterval
(
timeUpdateTimer
)
}
}
function
setMusicState
(
args
)
{
initMusic
()
...
...
@@ -113,7 +113,7 @@ export function getMusicPlayerState () {
dataUrl
:
audio
.
src
,
duration
:
audio
.
getDuration
()
||
0
,
currentPosition
:
audio
.
getPosition
(),
status
:
audio
.
isPaused
?
0
:
1
,
status
:
audio
.
isPaused
()
?
0
:
1
,
downloadPercent
:
Math
.
round
(
100
*
audio
.
getBuffered
()
/
audio
.
getDuration
()),
errMsg
:
`getMusicPlayerState:ok`
}
...
...
@@ -189,7 +189,7 @@ export function getBackgroundAudioState () {
let
newData
=
{
duration
:
audio
.
getDuration
()
||
0
,
currentTime
:
audio
.
isStopped
?
0
:
audio
.
getPosition
(),
paused
:
audio
.
isPaused
,
paused
:
audio
.
isPaused
()
,
src
:
audio
.
src
,
buffered
:
audio
.
getBuffered
(),
title
:
audio
.
title
,
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录