プレイリストの曲を終了するまで継続的に再生する JavaScript の簡単な実装があります。AngularJS で実装する適切な方法を見つけることができませんでした。この演習では、目的の機能に対処する必要があります。
- プレーヤーをサービスとしてカプセル化する
- コントロールにアクセスするには、ディレクティブを使用する必要がありますか?
- 「終了」イベントをキャッチして、新しい曲を開始します
HTMLファイルの抜粋です。
...
<div class="span4">
<button class="btn btn-large btn-primary" type="button" ng-click="startPlaying();">Start Playing</button>
</div>
...
<div class="span6">
<h4 id="NowPlayingID">Now Playing: </h4>
<audio id="AudioPlayerID" controls="controls">
</audio>
</div>
...
<!-- OLD JavaScript code -->
<script type="text/javascript">
function playNextSong(player) {
if (playlist.currentSongIX >= playlist.songs.length)
return;
$('#NowPlayingID').text('Now Playing: ' + playlist.songs[playlist.currentSongIX].name);
player.src = playlist.songs[playlist.currentSongIX].path;
player.play();
playlist.currentSongIX++;
}
function startPlaying() {
var player = document.getElementById("AudioPlayerID");
player.addEventListener('ended', function() {
playNextSong(player);
}, false);
playNextSong(player);
};
</script>
次のコードは進行中の作業であり、不完全です。
app.controller('PlayCtrl', function($scope, $routeParams, Playlist, $log, $document) {
$scope.playlist = Playlist.get({playlistID:$routeParams.playlistID});
var player = ????? ("AudioPlayerID");
$scope.startPlaying = function () {
angular.forEach($scope.playlist.songs, function(song) {
$log.log("Playing: " + song.name);
player.src = song.path;
player.play();
});
};
});
...
私の質問は次のとおりです。
- オーディオ プレーヤーにアクセスする正しい方法はどれですか?
- ディレクティブを使用する必要がありますか?
- 「終了」イベントをキャッチするにはどうすればよいですか?