extended mpd control to check if track is playing after starting new song
This commit is contained in:
parent
f35fc861c7
commit
d50ee914ef
2 changed files with 87 additions and 51 deletions
|
@ -20,6 +20,7 @@ public class TheGame implements StatemachineListener, GuiEventListener, IRCEvent
|
|||
private Thread discoThread;
|
||||
private boolean shouldStopDisco;
|
||||
private boolean gemActivated = false;
|
||||
private int gemCounter = 0;
|
||||
private boolean startedHurrySound = false;
|
||||
private char lastInput;
|
||||
private boolean sproing;
|
||||
|
@ -239,6 +240,7 @@ public class TheGame implements StatemachineListener, GuiEventListener, IRCEvent
|
|||
*/
|
||||
@Override
|
||||
public void timerTick(int tsecondsLeft) {
|
||||
if(gemCounter>0) gemCounter--;
|
||||
guiControl.setCountDown(tsecondsLeft);
|
||||
if(tsecondsLeft == 0) {
|
||||
ircClient.say("timer expired");
|
||||
|
@ -421,6 +423,9 @@ public class TheGame implements StatemachineListener, GuiEventListener, IRCEvent
|
|||
// Yes, it makes no sense, but I want have it anyway. For more Spass am Geraet!
|
||||
private void handleGemCommand() {
|
||||
if (!gemActivated) {
|
||||
|
||||
if(gemCounter > 1200) return;
|
||||
|
||||
java.util.Random random = new java.util.Random();
|
||||
int scry = random.nextInt(100);
|
||||
if (scry >= 99) {
|
||||
|
@ -430,6 +435,8 @@ public class TheGame implements StatemachineListener, GuiEventListener, IRCEvent
|
|||
} else {
|
||||
ircClient.say("Gem Activated");
|
||||
}
|
||||
|
||||
gemCounter+=100;
|
||||
} else {
|
||||
ircClient.say("Gem Deactivated");
|
||||
}
|
||||
|
|
|
@ -12,6 +12,7 @@ import org.bff.javampd.exception.MPDPlaylistException;
|
|||
import org.bff.javampd.objects.MPDSong;
|
||||
|
||||
import java.net.UnknownHostException;
|
||||
import java.sql.SQLOutput;
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
import java.util.Random;
|
||||
|
@ -43,47 +44,75 @@ public class MPDController implements IMPDController {
|
|||
System.out.println("playSong: " + artist + " - " + title);
|
||||
|
||||
if(mpd != null) {
|
||||
/*Runnable r = new Runnable() {
|
||||
Runnable r = new Runnable() {
|
||||
@Override
|
||||
public void run() {
|
||||
synchronized (mpd) { */
|
||||
synchronized (mpd) {
|
||||
addToPlayListIfNeeded(artist, title);
|
||||
|
||||
try {
|
||||
Thread.sleep(200);
|
||||
|
||||
MPDPlaylist playlist = mpd.getMPDPlaylist();
|
||||
|
||||
for(MPDSong song: playlist.getSongList()) {
|
||||
|
||||
if(song.getArtist() != null && song.getTitle() != null) {
|
||||
if(song.getArtist().getName().toLowerCase().equals(artist.toLowerCase()) &&
|
||||
song.getTitle().toLowerCase().equals(title.toLowerCase())) {
|
||||
|
||||
MPDPlayer player = mpd.getMPDPlayer();
|
||||
player.stop();
|
||||
|
||||
player.playId(song);
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
} catch (MPDConnectionException e) {
|
||||
Logger.sLog("MPD error: " + e.getMessage());
|
||||
} catch (MPDPlayerException e) {
|
||||
Logger.sLog("MPD error: " + e.getMessage());
|
||||
} catch (InterruptedException e) {
|
||||
Logger.sLog("MPD error: " + e.getMessage());
|
||||
}
|
||||
/*}
|
||||
doPlaySong(artist,title);
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
new Thread(r).start(); */
|
||||
//new Thread(r).start();
|
||||
r.run();
|
||||
}
|
||||
}
|
||||
|
||||
private void doPlaySong(final String artist, final String title) {
|
||||
try {
|
||||
MPDPlaylist playlist = mpd.getMPDPlaylist();
|
||||
MPDPlayer player = mpd.getMPDPlayer();
|
||||
|
||||
int tries = 3;
|
||||
|
||||
while(tries>0) {
|
||||
for(MPDSong song: playlist.getSongList()) {
|
||||
if(checkSong(song, artist, title)) {
|
||||
System.out.println("MPD: stopping, playing, go...");
|
||||
player.stop();
|
||||
player.playId(song);
|
||||
break;
|
||||
} else {
|
||||
System.out.println("MPD: track title or artist is null or not correct," + song.toString());
|
||||
}
|
||||
}
|
||||
|
||||
// now check, if it is playing
|
||||
|
||||
MPDSong song = player.getCurrentSong();
|
||||
|
||||
if(checkSong(song, artist, title)) {
|
||||
System.out.println("MPD: song is correctly playing");
|
||||
return;
|
||||
} else {
|
||||
System.out.println("MPD: whilst checking current song: track title or artist is null or not correct " + song.toString());
|
||||
}
|
||||
|
||||
System.out.println("MPD: next try");
|
||||
tries--;
|
||||
}
|
||||
|
||||
Logger.sLog("MPD error: track not in playlist or not found... cannot play");
|
||||
|
||||
} catch (MPDConnectionException e) {
|
||||
Logger.sLog("MPD error: " + e.getMessage());
|
||||
} catch (MPDPlayerException e) {
|
||||
Logger.sLog("MPD error: " + e.getMessage());
|
||||
}
|
||||
}
|
||||
|
||||
private boolean checkSong(final MPDSong song, final String artist, final String title) {
|
||||
if(song.getArtist() != null && song.getTitle() != null) {
|
||||
if(song.getArtist().getName().toLowerCase().contentEquals(artist.toLowerCase()) &&
|
||||
song.getTitle().toLowerCase().contentEquals(title.toLowerCase())) {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
/**
|
||||
* Add a song to current mpd playlist
|
||||
* @param artist Artist of the track to play
|
||||
|
@ -92,10 +121,10 @@ public class MPDController implements IMPDController {
|
|||
@Override
|
||||
public void addToPlayList(final String artist, final String title) {
|
||||
if(mpd != null) {
|
||||
/*Runnable r = new Runnable() {
|
||||
Runnable r = new Runnable() {
|
||||
@Override
|
||||
public void run() {
|
||||
synchronized (mpd) { */
|
||||
synchronized (mpd) {
|
||||
MPDDatabase db = mpd.getMPDDatabase();
|
||||
MPDPlaylist playlist = mpd.getMPDPlaylist();
|
||||
|
||||
|
@ -115,26 +144,25 @@ public class MPDController implements IMPDController {
|
|||
} catch (MPDPlaylistException e) {
|
||||
Logger.sLog("MPD error: " + e.getMessage());
|
||||
}
|
||||
/*}
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
new Thread(r).start(); */
|
||||
//new Thread(r).start();
|
||||
r.run();
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void skipRandomStart() {
|
||||
if(mpd != null) {
|
||||
/*Runnable r = new Runnable() {
|
||||
Runnable r = new Runnable() {
|
||||
@Override
|
||||
public void run() {
|
||||
synchronized (mpd) {*/
|
||||
synchronized (mpd) {
|
||||
MPDPlayer player = mpd.getMPDPlayer();
|
||||
|
||||
try {
|
||||
Thread.sleep(500);
|
||||
|
||||
int length;
|
||||
MPDSong song = player.getCurrentSong();
|
||||
if(song!= null) {
|
||||
|
@ -146,13 +174,13 @@ public class MPDController implements IMPDController {
|
|||
e.printStackTrace();
|
||||
} catch (MPDPlayerException e) {
|
||||
e.printStackTrace();
|
||||
} catch (InterruptedException ignored) {
|
||||
}
|
||||
/*}
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
new Thread(r).start(); */
|
||||
//new Thread(r).start();
|
||||
r.run();
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -163,10 +191,10 @@ public class MPDController implements IMPDController {
|
|||
@Override
|
||||
public void setVolume(final int volume) {
|
||||
if(mpd != null) {
|
||||
/*Runnable r = new Runnable() {
|
||||
Runnable r = new Runnable() {
|
||||
@Override
|
||||
public void run() {
|
||||
synchronized (mpd) {*/
|
||||
synchronized (mpd) {
|
||||
try {
|
||||
mpd.getMPDPlayer().setVolume(volume);
|
||||
} catch (MPDConnectionException e) {
|
||||
|
@ -174,11 +202,11 @@ public class MPDController implements IMPDController {
|
|||
} catch (MPDPlayerException e) {
|
||||
Logger.sLog("MPD error: " + e.getMessage());
|
||||
}
|
||||
/*}
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
new Thread(r).start();*/
|
||||
//new Thread(r).start();
|
||||
r.run();
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -188,10 +216,10 @@ public class MPDController implements IMPDController {
|
|||
@Override
|
||||
public void clearPlaylist() {
|
||||
if(mpd != null) {
|
||||
/*Runnable r = new Runnable() {
|
||||
Runnable r = new Runnable() {
|
||||
@Override
|
||||
public void run() {
|
||||
synchronized (mpd) {*/
|
||||
synchronized (mpd) {
|
||||
try {
|
||||
MPDPlaylist playlist = mpd.getMPDPlaylist();
|
||||
playlist.clearPlaylist();
|
||||
|
@ -204,11 +232,12 @@ public class MPDController implements IMPDController {
|
|||
} catch (MPDPlayerException e) {
|
||||
Logger.sLog("MPD error: " + e.getMessage());
|
||||
}
|
||||
/*}
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
new Thread(r).start(); */
|
||||
//new Thread(r).start();
|
||||
r.run();
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue