<cfmediaplayer>如何自动播放下一首曲目</cfmediaplayer>

时间:2013-04-12 11:26:33

标签: javascript jquery coldfusion

我一直致力于为我的网站创建弹出式播放器,用户可以在其中播放其他用户上传到网站的音乐播放列表。然而,目前我不得不手动点击每个曲目来播放它,我想知道是否有人设法创建<cfmediaplayer>自动播放播放列表中的下一首歌曲。它知道当前播放哪首歌的方式是在url变量中定义的,该变量发送用户点击的曲目名称,然后调用数据库以查看它是否可以找到匹配,然后我使用源输出该位置跟踪我存储。生病的邮政编码让我更清楚地了解我正在做的事情:

<cfquery datasource="#mydatabase#" name="getsongs">
    Select *
    From artists, songs
    Where artist_id = song_artistid
</cfquery>

<cfif IsDefined("URL.song")>
    <cfquery datasource="#mydatabase#" name="playsong">
        Select *
        From songs
        Where artist_id = song_artistid
        And song_name = '#URL.song#'
    </cfquery>
</cfif>

<div style="margin: 0 auto; width: 800px;>
    <div style="width: 300px; float: left; overflow: scroll;">
        <cfoutput query="getartists">
            <a href="popup_player.cfm?song=#song_name#>#artist_name# - #song_name#</a>
        </cfoutput>
    </div>

    <cfif IsDefined("URL.song")>
        <div style="width: 500px; float: right;">
            <cfoutput>
                <cfmediaplayer name="song" source="artists/songs/#playsong.song_location#" autoplay="yes" height="500" width="500"></cfmediaplayer>
            </cfoutput>
        </div>
    </cfif>
</div>

正如您所看到的,我有一个滚动div,其中列出了用户播放列表中的所有歌曲。通过单击歌曲,它会更新在媒体播放器中播放的曲目。我想知道无论如何,当歌曲结束时可以自动点击下一个链接,并且可能有一种方式,如果已经设置了一个变量来重复播放列表,当它到达最后一个曲目时它会再次回到第一个曲目。

3 个答案:

答案 0 :(得分:1)

请参阅CFMEDIAPLAYER(http://help.adobe.com/en_US/ColdFusion/10.0/CFMLRef/WSE66DB0CD-E16D-49e7-AAEE-F51F9580554E.html)的参考指南。它支持在曲目结束时运行JavaScript。您可以使用它自动调用下一首曲目。

答案 1 :(得分:0)

您可以在歌曲结束时运行javascript。 添加到您当前的代码:

 <cfmediaplayer onComplete=" YOUR_PLAY_NEXT_FUNCTION"  name="song"
 source="artists/songs/#playsong.song_location#" autoplay="yes"
 height="500" width="500"></cfmediaplayer>

从评论中添加

我没试过,但这对你有用吗?

var i = 0; // This should be the current song_no 
$("#button").on('click', function(){ 
    // Adds +1 to the current song number
    i++  
    // Create a variable using the standard url + the added song-number
    var curr_song = "artists/songs/#playsong.song_location#"+i;  
    // Changes the attribute to the new song-url 
    $('cfmediaplayer').attr("name",curr_song); 
});

答案 2 :(得分:0)

好的,我之前从未使用过cfmediaplayer,但是这段伪代码可以让你到达你需要的位置。

这些是我使用的资源。

  1. Dynamically starting and stopping a video using JavaScript and the CFMEDIAPLAYER tag in ColdFusion
  2. ColdFusion.Mediaplayer.setSource
  3. cfmediaplayer

  4. <cfquery ...>
    Select
       songUrl
    from
       songs
    </cfquery>
    <!--- build your coldFusion array of song URLs --->
    <cfset urlList = valueList(query.songURL)>
    <cfset urlArray = listToArray(urlList)>
    
    <script>
        <cfoutput>
        #toScript(urlArray)#
        var songIndex = #query.currentRow-1#; <!--- or url.currentRow, whatever you're using --->
        </cfoutput>
        startNext(){
            songIndex++;
            if(songIndex <= urlArray.length){                
                ColdFusion.Mediaplayer.setSource('mediaPlayerName', urlArray[songIndex]);
                ColdFusion.Mediaplayer.startPlay('mediaPlayerName');
            }
        }
    </script>