Soundcloud API Stream不同的歌曲

时间:2017-04-06 22:28:15

标签: javascript api soundcloud

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

这是我的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编辑的。

1 个答案:

答案 0 :(得分:0)

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

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