gpt4 book ai didi

javascript - Soundcloud API 流式传输不同的歌曲

转载 作者:行者123 更新时间:2023-11-28 04:47:08 25 4
gpt4 key购买 nike

我正在尝试根据通过 onclick 函数传递的 trackid 创建一个简单的 javascript soundcloud 播放器。

这是我的 html:

<div id="gs-play" onclick="play(309689093, this.id)" class="fa fa-3x fa-play">play/pause</div>
<div id="gs-play2" onclick="play(316017522, this.id)" class="fa fa-3x fa-play">play/pause</div>
<div id="gs-play3" onclick="play(315363199, this.id)" class="fa fa-3x fa-play">play/pause</div>

这是我的 JavaScript:

SC.initialize({
client_id: 'CLIENT_ID'
});
var is_playing = false,
sound;
function play(trackid, id){
var id = id;
var url = '/tracks/' + trackid;

if( sound ) {
if(is_playing) {
sound.pause();
document.getElementById(id).classList.toggle('fa-pause');
is_playing = false;
} else {
sound.play();
document.getElementById(id).classList.toggle('fa-pause');
is_playing = true;
}
} else {
SC.stream(url).then(function(obj) {
if (obj.options.protocols[0] === 'rtmp') {
obj.options.protocols.splice(0, 1); }
obj.play();
document.getElementById(id).classList.toggle('fa-pause');
sound = obj;
is_playing = true;
});
}
}

这工作得很好,但我在播放/暂停功能方面遇到了问题,因为当然,在歌曲未完成之前sound===false它总是会播放/停止即使我单击另一个 div,也会显示当前轨道。这是JSfiddle更好地理解行为。

另外,我看到了 SC API 的文档,但我不明白如何访问流媒体轨道的信息(标题、时长、艺术作品...)

编辑:

我想出了一个解决方案,通过以下方式检索当前的流媒体轨道:

SC.get(url).then(function(data){
oldid = data.id;
});

如果旧 id 等于新 id,则暂停。我的切换功能仍然存在一些问题(仅切换正在播放的功能),我尝试不使用框架。这是script已编辑。

最佳答案

对于任何对代码感兴趣的人,我已经修复了添加

SC.get(url).then(function(data){
oldid = data.id;
});

然后检查oldid === trackid是否像这样:

SC.initialize({
client_id: 'CLIENT_ID'
});
var oldid;
var is_playing = false,
sound;
function play(trackid, id){
var id = id;
var url = '/tracks/' + trackid;

if( oldid === trackid) {
if(is_playing) {
sound.pause();
document.getElementById(id).classList.toggle('fa-pause');
is_playing = false;
} else {
sound.play();
document.getElementById(id).classList.toggle('fa-pause');
is_playing = true;
}
} else {
SC.stream(url).then(function(obj) {
if (obj.options.protocols[0] === 'rtmp') {
obj.options.protocols.splice(0, 1); }
obj.play();
document.getElementById(id).classList.toggle('fa-pause');
sound = obj;
SC.get(url).then(function(data){
oldid = data.id;
});
console.log(sound.id);
is_playing = true;
});

}
}

这是JSFIddle

关于javascript - Soundcloud API 流式传输不同的歌曲,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43266745/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com