parent
d7c48b38fa
commit
594ffa9ba9
@ -0,0 +1,140 @@ |
|||||||
|
/* |
||||||
|
* Copyright (C) 2022 jimj316 |
||||||
|
* |
||||||
|
* This program is free software: you can redistribute it and/or modify |
||||||
|
* it under the terms of the GNU General Public License as published by |
||||||
|
* the Free Software Foundation, either version 3 of the License, or |
||||||
|
* (at your option) any later version. |
||||||
|
* |
||||||
|
* This program is distributed in the hope that it will be useful, |
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
||||||
|
* GNU General Public License for more details. |
||||||
|
* |
||||||
|
* You should have received a copy of the GNU General Public License |
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/ |
||||||
|
package moe.nekojimi.chords; |
||||||
|
|
||||||
|
import java.util.LinkedList; |
||||||
|
import java.util.Queue; |
||||||
|
import java.util.function.Consumer; |
||||||
|
|
||||||
|
/** |
||||||
|
* |
||||||
|
* @author jimj316 |
||||||
|
*/ |
||||||
|
public class QueueManager implements Consumer<Song> |
||||||
|
{ |
||||||
|
|
||||||
|
private Mode mode; |
||||||
|
private final Queue<Song> jukeboxQueue; |
||||||
|
private Playlist playlist; |
||||||
|
private MusicHandler handler; |
||||||
|
|
||||||
|
public QueueManager() |
||||||
|
{ |
||||||
|
jukeboxQueue = new LinkedList<>(); |
||||||
|
} |
||||||
|
|
||||||
|
@Override |
||||||
|
public void accept(Song t) |
||||||
|
{ |
||||||
|
jukeboxQueue.add(t); |
||||||
|
|
||||||
|
handler.playNext(); |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* Called by the music handler when the current song has ended, or if |
||||||
|
* playNext is called with nothing playing. |
||||||
|
* |
||||||
|
* @return the next track to play, or null to stop playing. |
||||||
|
*/ |
||||||
|
public Song nextSongNeeded() |
||||||
|
{ |
||||||
|
// if there's anything in the queue, play that first
|
||||||
|
if (!jukeboxQueue.isEmpty()) |
||||||
|
{ |
||||||
|
return jukeboxQueue.poll(); |
||||||
|
} |
||||||
|
// otherwise if there's a playlist, shuffle from that
|
||||||
|
else if (playlist != null) |
||||||
|
{ |
||||||
|
return playlist.getNextSong(); |
||||||
|
} |
||||||
|
// otherwise stop playing
|
||||||
|
else |
||||||
|
return null; |
||||||
|
} |
||||||
|
|
||||||
|
public MusicHandler getHandler() |
||||||
|
{ |
||||||
|
return handler; |
||||||
|
} |
||||||
|
|
||||||
|
public void addSong(Song song) |
||||||
|
{ |
||||||
|
System.out.println("Song added to queue: " + song.getLocation().getAbsolutePath()); |
||||||
|
jukeboxQueue.add(song); |
||||||
|
|
||||||
|
} |
||||||
|
|
||||||
|
public boolean removeSong(int i) |
||||||
|
{ |
||||||
|
try |
||||||
|
{ |
||||||
|
return jukeboxQueue.remove((Song) jukeboxQueue.toArray()[i]); |
||||||
|
} catch (ArrayIndexOutOfBoundsException ex) |
||||||
|
{ |
||||||
|
return false; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
public boolean removeSong(Song song) |
||||||
|
{ |
||||||
|
return jukeboxQueue.remove(song); |
||||||
|
} |
||||||
|
|
||||||
|
public void setHandler(MusicHandler handler) |
||||||
|
{ |
||||||
|
this.handler = handler; |
||||||
|
handler.setQueueManager(this); |
||||||
|
} |
||||||
|
|
||||||
|
public Queue<Song> getJukeboxQueue() |
||||||
|
{ |
||||||
|
return jukeboxQueue; |
||||||
|
} |
||||||
|
|
||||||
|
public Playlist getPlaylist() |
||||||
|
{ |
||||||
|
return playlist; |
||||||
|
} |
||||||
|
|
||||||
|
public void setPlaylist(Playlist playlist) |
||||||
|
{ |
||||||
|
this.playlist = playlist; |
||||||
|
} |
||||||
|
|
||||||
|
public Mode getMode() |
||||||
|
{ |
||||||
|
return mode; |
||||||
|
} |
||||||
|
|
||||||
|
public void setMode(Mode mode) |
||||||
|
{ |
||||||
|
this.mode = mode; |
||||||
|
} |
||||||
|
|
||||||
|
public boolean restartSong() |
||||||
|
{ |
||||||
|
throw new UnsupportedOperationException("Not supported yet."); |
||||||
|
} |
||||||
|
|
||||||
|
public enum Mode |
||||||
|
{ |
||||||
|
JUKEBOX, |
||||||
|
PLAYLIST; |
||||||
|
} |
||||||
|
} |
Loading…
Reference in new issue