Fix sound playing
This commit is contained in:
parent
b972169341
commit
1727579f84
@ -1,57 +1,60 @@
|
||||
package com.annimon.turrets;
|
||||
|
||||
import com.annimon.turrets.util.ExceptionHandler;
|
||||
import java.io.IOException;
|
||||
import java.net.URL;
|
||||
import javax.sound.sampled.AudioInputStream;
|
||||
import javax.sound.sampled.AudioSystem;
|
||||
import javax.sound.sampled.Clip;
|
||||
import javax.sound.sampled.LineUnavailableException;
|
||||
import javax.sound.sampled.UnsupportedAudioFileException;
|
||||
|
||||
/**
|
||||
*
|
||||
* @author aNNiMON
|
||||
*/
|
||||
public enum Sound {
|
||||
CLICK("/res/click.wav"),
|
||||
EXPLOSION_1("/res/explosion1.wav"),
|
||||
EXPLOSION_2("/res/explosion2.wav");
|
||||
|
||||
private static boolean enabled;
|
||||
private final Clip soundClip;
|
||||
|
||||
Sound(String resource) {
|
||||
soundClip = loadClip(resource);
|
||||
}
|
||||
|
||||
public static boolean isEnabled() {
|
||||
return enabled;
|
||||
}
|
||||
|
||||
public static void setEnabled(boolean enabled) {
|
||||
Sound.enabled = enabled;
|
||||
}
|
||||
|
||||
public void play() {
|
||||
if (enabled) {
|
||||
soundClip.setFramePosition(0);
|
||||
soundClip.start();
|
||||
}
|
||||
}
|
||||
|
||||
private Clip loadClip(String resource) {
|
||||
Clip clip = null;
|
||||
try {
|
||||
final URL url = getClass().getResource(resource);
|
||||
try (AudioInputStream ais = AudioSystem.getAudioInputStream(url)) {
|
||||
clip = AudioSystem.getClip();
|
||||
clip.open(ais);
|
||||
}
|
||||
} catch (IOException | UnsupportedAudioFileException | LineUnavailableException ex) {
|
||||
ExceptionHandler.handle(ex);
|
||||
}
|
||||
return clip;
|
||||
}
|
||||
|
||||
}
|
||||
package com.annimon.turrets;
|
||||
|
||||
import com.annimon.turrets.util.ExceptionHandler;
|
||||
import java.io.IOException;
|
||||
import java.net.URL;
|
||||
import javax.sound.sampled.AudioInputStream;
|
||||
import javax.sound.sampled.AudioSystem;
|
||||
import javax.sound.sampled.Clip;
|
||||
import javax.sound.sampled.LineUnavailableException;
|
||||
import javax.sound.sampled.UnsupportedAudioFileException;
|
||||
|
||||
/**
|
||||
*
|
||||
* @author aNNiMON
|
||||
*/
|
||||
public enum Sound {
|
||||
CLICK("/res/click.wav"),
|
||||
EXPLOSION_1("/res/explosion1.wav"),
|
||||
EXPLOSION_2("/res/explosion2.wav");
|
||||
|
||||
private static boolean enabled;
|
||||
private final Clip soundClip;
|
||||
|
||||
Sound(String resource) {
|
||||
soundClip = loadClip(resource);
|
||||
}
|
||||
|
||||
public static boolean isEnabled() {
|
||||
return enabled;
|
||||
}
|
||||
|
||||
public static void setEnabled(boolean enabled) {
|
||||
Sound.enabled = enabled;
|
||||
}
|
||||
|
||||
public void play() {
|
||||
if (enabled && (soundClip != null)) {
|
||||
soundClip.setFramePosition(0);
|
||||
soundClip.start();
|
||||
}
|
||||
}
|
||||
|
||||
private Clip loadClip(String resource) {
|
||||
Clip clip = null;
|
||||
try {
|
||||
final URL url = getClass().getResource(resource);
|
||||
try (AudioInputStream ais = AudioSystem.getAudioInputStream(url)) {
|
||||
clip = AudioSystem.getClip();
|
||||
clip.open(ais);
|
||||
}
|
||||
} catch (IllegalArgumentException iae) {
|
||||
Sound.setEnabled(false);
|
||||
ExceptionHandler.handle(iae);
|
||||
} catch (IOException | UnsupportedAudioFileException | LineUnavailableException ex) {
|
||||
ExceptionHandler.handle(ex);
|
||||
}
|
||||
return clip;
|
||||
}
|
||||
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user