& lt; cfmediaplayer>如何自动播放下一个曲目

<cfmediaplayer> how to automatically play next track

本文关键字:自动播放 曲目 下一个 lt cfmediaplayer      更新时间:2023-09-26

我一直在为我的网站创建一个弹出式播放器,用户可以在其中播放其他用户上传到网站的音乐播放列表。然而,目前我不得不手动点击每个轨道来播放它,我想知道是否有人设法创建一个<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,其中列出了用户播放列表中所有的歌曲。通过点击歌曲,它会更新媒体播放器中播放的曲目。我想知道是否有无论如何下一个链接可以自动点击当歌曲完成,也许有一种方式,如果一个变量已被设置为重复播放列表,当它到达最后一个轨道它回到第一个再次。

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

可以在歌曲结束时运行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); 
});

好吧,我从来没有使用过cfmediaplayer,但这段伪代码应该可以让你在你需要的地方。

这些是我使用的资源。

  1. 在ColdFusion中使用JavaScript和CFMEDIAPLAYER标签动态启动和停止视频
  2. ColdFusion.Mediaplayer.setSource
  3. cfmediaplayer

<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>