我一直致力于为我的网站创建弹出式播放器,用户可以在其中播放其他用户上传到网站的音乐播放列表。然而,目前我不得不手动点击每个曲目来播放它,我想知道是否有人设法创建<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,其中列出了用户播放列表中的所有歌曲。通过单击歌曲,它会更新在媒体播放器中播放的曲目。我想知道无论如何,当歌曲结束时可以自动点击下一个链接,并且可能有一种方式,如果已经设置了一个变量来重复播放列表,当它到达最后一个曲目时它会再次回到第一个曲目。
答案 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,但是这段伪代码可以让你到达你需要的位置。
这些是我使用的资源。
<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>