Added support for multiple GameImage file extensions.

Specifically, the main menu background and pause/fail backgrounds now accept JPGs as well as PNGs.

Other changes:
- Don't draw the default pause/fail background if the buttons are skinned and the background is unskinned.
- Preload logo and main menu background.

Signed-off-by: Jeffrey Han <itdelatrisu@gmail.com>
This commit is contained in:
Jeffrey Han 2015-01-15 18:16:46 -05:00
parent 516e6280c7
commit f8dad2889f
4 changed files with 224 additions and 146 deletions

View File

@ -21,6 +21,8 @@ package itdelatrisu.opsu;
import itdelatrisu.opsu.states.Options; import itdelatrisu.opsu.states.Options;
import java.io.File; import java.io.File;
import java.util.ArrayList;
import java.util.List;
import org.newdawn.slick.Image; import org.newdawn.slick.Image;
import org.newdawn.slick.SlickException; import org.newdawn.slick.SlickException;
@ -31,60 +33,60 @@ import org.newdawn.slick.util.Log;
*/ */
public enum GameImage { public enum GameImage {
// Game // Game
SECTION_PASS ("section-pass.png"), SECTION_PASS ("section-pass", "png"),
SECTION_FAIL ("section-fail.png"), SECTION_FAIL ("section-fail", "png"),
WARNINGARROW ("play-warningarrow.png"), WARNINGARROW ("play-warningarrow", "png"),
SKIP ("play-skip.png") { SKIP ("play-skip", "png") {
@Override @Override
protected Image process_sub(Image img, int w, int h) { protected Image process_sub(Image img, int w, int h) {
return img.getScaledCopy((h * 0.1f) / img.getHeight()); return img.getScaledCopy((h * 0.1f) / img.getHeight());
} }
}, },
COUNTDOWN_READY ("ready.png") { COUNTDOWN_READY ("ready", "png") {
@Override @Override
protected Image process_sub(Image img, int w, int h) { protected Image process_sub(Image img, int w, int h) {
return img.getScaledCopy((h / 3f) / img.getHeight()); return img.getScaledCopy((h / 3f) / img.getHeight());
} }
}, },
COUNTDOWN_3 ("count3.png") { COUNTDOWN_3 ("count3", "png") {
@Override @Override
protected Image process_sub(Image img, int w, int h) { protected Image process_sub(Image img, int w, int h) {
return img.getScaledCopy((h / 3f) / img.getHeight()); return img.getScaledCopy((h / 3f) / img.getHeight());
} }
}, },
COUNTDOWN_2 ("count2.png") { COUNTDOWN_2 ("count2", "png") {
@Override @Override
protected Image process_sub(Image img, int w, int h) { protected Image process_sub(Image img, int w, int h) {
return img.getScaledCopy((h / 3f) / img.getHeight()); return img.getScaledCopy((h / 3f) / img.getHeight());
} }
}, },
COUNTDOWN_1 ("count1.png") { COUNTDOWN_1 ("count1", "png") {
@Override @Override
protected Image process_sub(Image img, int w, int h) { protected Image process_sub(Image img, int w, int h) {
return img.getScaledCopy((h / 3f) / img.getHeight()); return img.getScaledCopy((h / 3f) / img.getHeight());
} }
}, },
COUNTDOWN_GO ("go.png") { COUNTDOWN_GO ("go", "png") {
@Override @Override
protected Image process_sub(Image img, int w, int h) { protected Image process_sub(Image img, int w, int h) {
return img.getScaledCopy((h / 3f) / img.getHeight()); return img.getScaledCopy((h / 3f) / img.getHeight());
} }
}, },
HITCIRCLE_SELECT ("hitcircleselect.png"), HITCIRCLE_SELECT ("hitcircleselect", "png"),
UNRANKED ("play-unranked.png"), UNRANKED ("play-unranked", "png"),
// Game Pause/Fail // Game Pause/Fail
PAUSE_CONTINUE ("pause-continue.png"), PAUSE_CONTINUE ("pause-continue", "png"),
PAUSE_RETRY ("pause-retry.png"), PAUSE_RETRY ("pause-retry", "png"),
PAUSE_BACK ("pause-back.png"), PAUSE_BACK ("pause-back", "png"),
PAUSE_OVERLAY ("pause-overlay.png") { PAUSE_OVERLAY ("pause-overlay", "png|jpg") {
@Override @Override
protected Image process_sub(Image img, int w, int h) { protected Image process_sub(Image img, int w, int h) {
img.setAlpha(0.7f); img.setAlpha(0.7f);
return img.getScaledCopy(w, h); return img.getScaledCopy(w, h);
} }
}, },
FAIL_BACKGROUND ("fail-background.png") { FAIL_BACKGROUND ("fail-background", "png|jpg") {
@Override @Override
protected Image process_sub(Image img, int w, int h) { protected Image process_sub(Image img, int w, int h) {
img.setAlpha(0.7f); img.setAlpha(0.7f);
@ -93,214 +95,233 @@ public enum GameImage {
}, },
// Circle // Circle
HITCIRCLE ("hitcircle.png"), HITCIRCLE ("hitcircle", "png"),
HITCIRCLE_OVERLAY ("hitcircleoverlay.png"), HITCIRCLE_OVERLAY ("hitcircleoverlay", "png"),
APPROACHCIRCLE ("approachcircle.png"), APPROACHCIRCLE ("approachcircle", "png"),
// Slider // Slider
SLIDER_FOLLOWCIRCLE ("sliderfollowcircle.png"), SLIDER_FOLLOWCIRCLE ("sliderfollowcircle", "png"),
REVERSEARROW ("reversearrow.png"), REVERSEARROW ("reversearrow", "png"),
SLIDER_TICK ("sliderscorepoint.png"), SLIDER_TICK ("sliderscorepoint", "png"),
// Spinner // Spinner
SPINNER_CIRCLE ("spinner-circle.png"), SPINNER_CIRCLE ("spinner-circle", "png"),
SPINNER_APPROACHCIRCLE ("spinner-approachcircle.png"), SPINNER_APPROACHCIRCLE ("spinner-approachcircle", "png"),
SPINNER_METRE ("spinner-metre.png"), SPINNER_METRE ("spinner-metre", "png"),
SPINNER_SPIN ("spinner-spin.png"), SPINNER_SPIN ("spinner-spin", "png"),
SPINNER_CLEAR ("spinner-clear.png"), SPINNER_CLEAR ("spinner-clear", "png"),
SPINNER_OSU ("spinner-osu.png"), SPINNER_OSU ("spinner-osu", "png"),
// Game Score // Game Score
SCOREBAR_BG ("scorebar-bg.png") { SCOREBAR_BG ("scorebar-bg", "png") {
@Override @Override
protected Image process_sub(Image img, int w, int h) { protected Image process_sub(Image img, int w, int h) {
return img.getScaledCopy(w / 2, img.getHeight()); return img.getScaledCopy(w / 2, img.getHeight());
} }
}, },
SCOREBAR_COLOUR ("scorebar-colour.png") { SCOREBAR_COLOUR ("scorebar-colour", "png") {
@Override @Override
protected Image process_sub(Image img, int w, int h) { protected Image process_sub(Image img, int w, int h) {
return img.getScaledCopy(w / 2, img.getHeight()); return img.getScaledCopy(w / 2, img.getHeight());
} }
}, },
SCOREBAR_KI ("scorebar-ki.png"), SCOREBAR_KI ("scorebar-ki", "png"),
SCOREBAR_KI_DANGER ("scorebar-kidanger.png"), SCOREBAR_KI_DANGER ("scorebar-kidanger", "png"),
SCOREBAR_KI_DANGER2 ("scorebar-kidanger2.png"), SCOREBAR_KI_DANGER2 ("scorebar-kidanger2", "png"),
HIT_MISS ("hit0.png"), HIT_MISS ("hit0", "png"),
HIT_50 ("hit50.png"), HIT_50 ("hit50", "png"),
HIT_100 ("hit100.png"), HIT_100 ("hit100", "png"),
HIT_300 ("hit300.png"), HIT_300 ("hit300", "png"),
HIT_100K ("hit100k.png"), HIT_100K ("hit100k", "png"),
HIT_300K ("hit300k.png"), HIT_300K ("hit300k", "png"),
HIT_300G ("hit300g.png"), HIT_300G ("hit300g", "png"),
HIT_SLIDER10 ("sliderpoint10.png"), HIT_SLIDER10 ("sliderpoint10", "png"),
HIT_SLIDER30 ("sliderpoint30.png"), HIT_SLIDER30 ("sliderpoint30", "png"),
RANKING_SS ("ranking-X.png"), RANKING_SS ("ranking-X", "png"),
RANKING_SS_SMALL ("ranking-X-small.png"), RANKING_SS_SMALL ("ranking-X-small", "png"),
RANKING_SSH ("ranking-XH.png"), RANKING_SSH ("ranking-XH", "png"),
RANKING_SSH_SMALL ("ranking-XH-small.png"), RANKING_SSH_SMALL ("ranking-XH-small", "png"),
RANKING_S ("ranking-S.png"), RANKING_S ("ranking-S", "png"),
RANKING_S_SMALL ("ranking-S-small.png"), RANKING_S_SMALL ("ranking-S-small", "png"),
RANKING_SH ("ranking-SH.png"), RANKING_SH ("ranking-SH", "png"),
RANKING_SH_SMALL ("ranking-SH-small.png"), RANKING_SH_SMALL ("ranking-SH-small", "png"),
RANKING_A ("ranking-A.png"), RANKING_A ("ranking-A", "png"),
RANKING_A_SMALL ("ranking-A-small.png"), RANKING_A_SMALL ("ranking-A-small", "png"),
RANKING_B ("ranking-B.png"), RANKING_B ("ranking-B", "png"),
RANKING_B_SMALL ("ranking-B-small.png"), RANKING_B_SMALL ("ranking-B-small", "png"),
RANKING_C ("ranking-C.png"), RANKING_C ("ranking-C", "png"),
RANKING_C_SMALL ("ranking-C-small.png"), RANKING_C_SMALL ("ranking-C-small", "png"),
RANKING_D ("ranking-D.png"), RANKING_D ("ranking-D", "png"),
RANKING_D_SMALL ("ranking-D-small.png"), RANKING_D_SMALL ("ranking-D-small", "png"),
RANKING_PANEL ("ranking-panel.png") { RANKING_PANEL ("ranking-panel", "png") {
@Override @Override
protected Image process_sub(Image img, int w, int h) { protected Image process_sub(Image img, int w, int h) {
return img.getScaledCopy((h * 0.63f) / img.getHeight()); return img.getScaledCopy((h * 0.63f) / img.getHeight());
} }
}, },
RANKING_PERFECT ("ranking-perfect.png") { RANKING_PERFECT ("ranking-perfect", "png") {
@Override @Override
protected Image process_sub(Image img, int w, int h) { protected Image process_sub(Image img, int w, int h) {
return img.getScaledCopy((h * 0.16f) / img.getHeight()); return img.getScaledCopy((h * 0.16f) / img.getHeight());
} }
}, },
RANKING_TITLE ("ranking-title.png") { RANKING_TITLE ("ranking-title", "png") {
@Override @Override
protected Image process_sub(Image img, int w, int h) { protected Image process_sub(Image img, int w, int h) {
return img.getScaledCopy((h * 0.15f) / img.getHeight()); return img.getScaledCopy((h * 0.15f) / img.getHeight());
} }
}, },
RANKING_MAXCOMBO ("ranking-maxcombo.png") { RANKING_MAXCOMBO ("ranking-maxcombo", "png") {
@Override @Override
protected Image process_sub(Image img, int w, int h) { protected Image process_sub(Image img, int w, int h) {
return img.getScaledCopy((h * 0.05f) / img.getHeight()); return img.getScaledCopy((h * 0.05f) / img.getHeight());
} }
}, },
RANKING_ACCURACY ("ranking-accuracy.png") { RANKING_ACCURACY ("ranking-accuracy", "png") {
@Override @Override
protected Image process_sub(Image img, int w, int h) { protected Image process_sub(Image img, int w, int h) {
return img.getScaledCopy((h * 0.05f) / img.getHeight()); return img.getScaledCopy((h * 0.05f) / img.getHeight());
} }
}, },
DEFAULT_0 ("default-0.png"), DEFAULT_0 ("default-0", "png"),
DEFAULT_1 ("default-1.png"), DEFAULT_1 ("default-1", "png"),
DEFAULT_2 ("default-2.png"), DEFAULT_2 ("default-2", "png"),
DEFAULT_3 ("default-3.png"), DEFAULT_3 ("default-3", "png"),
DEFAULT_4 ("default-4.png"), DEFAULT_4 ("default-4", "png"),
DEFAULT_5 ("default-5.png"), DEFAULT_5 ("default-5", "png"),
DEFAULT_6 ("default-6.png"), DEFAULT_6 ("default-6", "png"),
DEFAULT_7 ("default-7.png"), DEFAULT_7 ("default-7", "png"),
DEFAULT_8 ("default-8.png"), DEFAULT_8 ("default-8", "png"),
DEFAULT_9 ("default-9.png"), DEFAULT_9 ("default-9", "png"),
SCORE_0 ("score-0.png"), SCORE_0 ("score-0", "png"),
SCORE_1 ("score-1.png"), SCORE_1 ("score-1", "png"),
SCORE_2 ("score-2.png"), SCORE_2 ("score-2", "png"),
SCORE_3 ("score-3.png"), SCORE_3 ("score-3", "png"),
SCORE_4 ("score-4.png"), SCORE_4 ("score-4", "png"),
SCORE_5 ("score-5.png"), SCORE_5 ("score-5", "png"),
SCORE_6 ("score-6.png"), SCORE_6 ("score-6", "png"),
SCORE_7 ("score-7.png"), SCORE_7 ("score-7", "png"),
SCORE_8 ("score-8.png"), SCORE_8 ("score-8", "png"),
SCORE_9 ("score-9.png"), SCORE_9 ("score-9", "png"),
SCORE_COMMA ("score-comma.png"), SCORE_COMMA ("score-comma", "png"),
SCORE_DOT ("score-dot.png"), SCORE_DOT ("score-dot", "png"),
SCORE_PERCENT ("score-percent.png"), SCORE_PERCENT ("score-percent", "png"),
SCORE_X ("score-x.png"), SCORE_X ("score-x", "png"),
// Non-Game Components // Non-Game Components
MENU_BACK ("menu-back.png", false) { MENU_BACK ("menu-back", "png", false) {
@Override @Override
protected Image process_sub(Image img, int w, int h) { protected Image process_sub(Image img, int w, int h) {
return img.getScaledCopy((h * 0.1f) / img.getHeight()); return img.getScaledCopy((h * 0.1f) / img.getHeight());
} }
}, },
MENU_BUTTON_BG ("menu-button-background.png", false) { MENU_BUTTON_BG ("menu-button-background", "png", false) {
@Override @Override
protected Image process_sub(Image img, int w, int h) { protected Image process_sub(Image img, int w, int h) {
return img.getScaledCopy(w / 2, h / 6); return img.getScaledCopy(w / 2, h / 6);
} }
}, },
MENU_TAB ("selection-tab.png", false) { MENU_TAB ("selection-tab", "png", false) {
@Override @Override
protected Image process_sub(Image img, int w, int h) { protected Image process_sub(Image img, int w, int h) {
return img.getScaledCopy((h * 0.033f) / img.getHeight()); return img.getScaledCopy((h * 0.033f) / img.getHeight());
} }
}, },
MENU_SEARCH ("search.png", false) { MENU_SEARCH ("search", "png", false) {
@Override @Override
protected Image process_sub(Image img, int w, int h) { protected Image process_sub(Image img, int w, int h) {
return img.getScaledCopy(Utils.FONT_BOLD.getLineHeight() * 2f / img.getHeight()); return img.getScaledCopy(Utils.FONT_BOLD.getLineHeight() * 2f / img.getHeight());
} }
}, },
MENU_OPTIONS ("options.png", false) { MENU_OPTIONS ("options", "png", false) {
@Override @Override
protected Image process_sub(Image img, int w, int h) { protected Image process_sub(Image img, int w, int h) {
return img.getScaledCopy(Utils.FONT_BOLD.getLineHeight() * 2f / img.getHeight()); return img.getScaledCopy(Utils.FONT_BOLD.getLineHeight() * 2f / img.getHeight());
} }
}, },
MENU_MUSICNOTE ("music-note.png", false) { MENU_MUSICNOTE ("music-note", "png", false) {
@Override @Override
protected Image process_sub(Image img, int w, int h) { protected Image process_sub(Image img, int w, int h) {
int r = (int) (Utils.FONT_LARGE.getLineHeight() * 0.75f + Utils.FONT_DEFAULT.getLineHeight()); int r = (int) (Utils.FONT_LARGE.getLineHeight() * 0.75f + Utils.FONT_DEFAULT.getLineHeight());
return img.getScaledCopy(r, r); return img.getScaledCopy(r, r);
} }
}, },
MENU_LOADER ("loader.png", false) { MENU_LOADER ("loader", "png", false) {
@Override @Override
protected Image process_sub(Image img, int w, int h) { protected Image process_sub(Image img, int w, int h) {
int r = (int) (Utils.FONT_LARGE.getLineHeight() * 0.75f + Utils.FONT_DEFAULT.getLineHeight()); int r = (int) (Utils.FONT_LARGE.getLineHeight() * 0.75f + Utils.FONT_DEFAULT.getLineHeight());
return img.getScaledCopy(r / 48f); return img.getScaledCopy(r / 48f);
} }
}, },
MENU_LOGO ("logo.png", false) { MENU_BG ("menu-background", "png|jpg", false) {
@Override
protected Image process_sub(Image img, int w, int h) {
img.setAlpha(0.9f);
return img.getScaledCopy(w, h);
}
},
MENU_LOGO ("logo", "png", false) {
@Override @Override
protected Image process_sub(Image img, int w, int h) { protected Image process_sub(Image img, int w, int h) {
return img.getScaledCopy((h / 1.2f) / img.getHeight()); return img.getScaledCopy((h / 1.2f) / img.getHeight());
} }
}, },
MENU_PlAY ("menu-play.png", false) { MENU_PlAY ("menu-play", "png", false) {
@Override @Override
protected Image process_sub(Image img, int w, int h) { protected Image process_sub(Image img, int w, int h) {
return img.getScaledCopy(MENU_LOGO.getImage().getWidth() * 0.83f / img.getWidth()); return img.getScaledCopy(MENU_LOGO.getImage().getWidth() * 0.83f / img.getWidth());
} }
}, },
MENU_EXIT ("menu-exit.png", false) { MENU_EXIT ("menu-exit", "png", false) {
@Override @Override
protected Image process_sub(Image img, int w, int h) { protected Image process_sub(Image img, int w, int h) {
return img.getScaledCopy(MENU_LOGO.getImage().getWidth() * 0.66f / img.getWidth()); return img.getScaledCopy(MENU_LOGO.getImage().getWidth() * 0.66f / img.getWidth());
} }
}, },
MENU_BUTTON_MID ("button-middle.png", false) { MENU_BUTTON_MID ("button-middle", "png", false) {
@Override @Override
protected Image process_sub(Image img, int w, int h) { protected Image process_sub(Image img, int w, int h) {
return img.getScaledCopy(w / 2, img.getHeight()); return img.getScaledCopy(w / 2, img.getHeight());
} }
}, },
MENU_BUTTON_LEFT ("button-left.png", false), MENU_BUTTON_LEFT ("button-left", "png", false),
MENU_BUTTON_RIGHT ("button-right.png", false), MENU_BUTTON_RIGHT ("button-right", "png", false),
MUSIC_PLAY ("music-play.png", false), MUSIC_PLAY ("music-play", "png", false),
MUSIC_PAUSE ("music-pause.png", false), MUSIC_PAUSE ("music-pause", "png", false),
MUSIC_NEXT ("music-next.png", false), MUSIC_NEXT ("music-next", "png", false),
MUSIC_PREVIOUS ("music-previous.png", false), MUSIC_PREVIOUS ("music-previous", "png", false),
RANKING_RETRY ("ranking-retry.png", false) { RANKING_RETRY ("ranking-retry", "png", false) {
@Override @Override
protected Image process_sub(Image img, int w, int h) { protected Image process_sub(Image img, int w, int h) {
return img.getScaledCopy((h * 0.15f) / img.getHeight()); return img.getScaledCopy((h * 0.15f) / img.getHeight());
} }
}, },
RANKING_EXIT ("ranking-back.png", false) { RANKING_EXIT ("ranking-back", "png", false) {
@Override @Override
protected Image process_sub(Image img, int w, int h) { protected Image process_sub(Image img, int w, int h) {
return img.getScaledCopy((h * 0.15f) / img.getHeight()); return img.getScaledCopy((h * 0.15f) / img.getHeight());
} }
}; };
/**
* Image file types.
*/
private static final byte
IMG_PNG = 1,
IMG_JPG = 2;
/** /**
* The file name. * The file name.
*/ */
private String filename; private String filename;
/**
* Image file type.
*/
private byte type;
/** /**
* Whether or not the image is related to gameplay. * Whether or not the image is related to gameplay.
* Game images are skinnable per beatmap, while other images are not. * Game images are skinnable per beatmap, while other images are not.
@ -350,22 +371,43 @@ public enum GameImage {
} }
} }
/**
* Returns the bitmask image type from a type string.
* @param type the type string
* @return the byte bitmask
*/
private static byte getType(String type) {
byte b = 0;
String[] s = type.split("\\|");
for (int i = 0; i < s.length; i++) {
if (s[i].equals("png"))
b |= IMG_PNG;
else if (s[i].equals("jpg"))
b |= IMG_JPG;
}
return b;
}
/** /**
* Constructor. * Constructor.
* @param filename the image file name * @param filename the image file name
* @param type the file types (separated by '|')
*/ */
GameImage(String filename) { GameImage(String filename, String type) {
this.filename = filename; this.filename = filename;
this.type = getType(type);
this.gameImage = true; this.gameImage = true;
} }
/** /**
* Constructor. * Constructor.
* @param filename the image file name * @param filename the image file name
* @param type the file types (separated by '|')
* @param gameImage whether or not the image is related to gameplay * @param gameImage whether or not the image is related to gameplay
*/ */
GameImage(String filename, boolean gameImage) { GameImage(String filename, String type, boolean gameImage) {
this.filename = filename; this.filename = filename;
this.type = getType(type);
this.gameImage = gameImage; this.gameImage = gameImage;
} }
@ -396,6 +438,19 @@ public enum GameImage {
this.defaultImage = img; this.defaultImage = img;
} }
/**
* Returns a list of possible filenames (with extensions).
* @return filename list
*/
private List<String> getFileNames() {
List<String> list = new ArrayList<String>(2);
if ((type & IMG_PNG) != 0)
list.add(String.format("%s.png", filename));
if ((type & IMG_JPG) != 0)
list.add(String.format("%s.jpg", filename));
return list;
}
/** /**
* Sets the default image for this resource. * Sets the default image for this resource.
* If the default image has already been loaded, this will do nothing. * If the default image has already been loaded, this will do nothing.
@ -403,12 +458,20 @@ public enum GameImage {
public void setDefaultImage() { public void setDefaultImage() {
if (defaultImage != null) if (defaultImage != null)
return; return;
try { for (String name : getFileNames()) {
defaultImage = new Image(filename); try {
process(); // try loading the image
} catch (SlickException e) { Image img = new Image(name);
Log.error(String.format("Failed to set default image '%s'.", filename), e);
// image successfully loaded
this.defaultImage = img;
process();
return;
} catch (SlickException | RuntimeException e) {
continue;
}
} }
Log.error(String.format("Failed to set default image '%s'.", filename));
} }
/** /**
@ -423,24 +486,42 @@ public enum GameImage {
// destroy the existing image, if any // destroy the existing image, if any
destroySkinImage(); destroySkinImage();
try { // beatmap skins disabled
// set a new image if (Options.isBeatmapSkinIgnored())
File file = new File(dir, filename); return false;
if (file.isFile() && !Options.isBeatmapSkinIgnored()) {
skinImage = new Image(file.getAbsolutePath()); // look for a skin image
String errorFile = null;
for (String name : getFileNames()) {
File file = new File(dir, name);
if (!file.isFile())
continue;
try {
// try loading the image
Image img = new Image(file.getAbsolutePath());
// image successfully loaded
this.skinImage = img;
process(); process();
skinImageLoaded = true; skinImageLoaded = true;
return true; return true;
} else { } catch (SlickException | RuntimeException e) {
skinImage = null; errorFile = file.getAbsolutePath();
return false; continue;
} }
} catch (SlickException e) {
Log.error(String.format("Failed to set skin image '%s'.", filename), e);
return false;
} }
skinImage = null;
if (errorFile != null)
Log.error(String.format("Failed to set skin image '%s'.", errorFile));
return false;
} }
/**
* Returns whether a skin image is currently loaded.
* @return true if skin image exists
*/
public boolean hasSkinImage() { return (skinImage != null && !skinImage.isDestroyed()); }
/** /**
* Destroys the associated skin image, if any. * Destroys the associated skin image, if any.
*/ */

View File

@ -186,6 +186,8 @@ public class Utils {
// initialize game images // initialize game images
GameImage.init(width, height); GameImage.init(width, height);
GameImage.MENU_LOGO.setDefaultImage();
GameImage.MENU_BG.setDefaultImage();
// initialize game mods // initialize game mods
for (GameMod mod : GameMod.values()) for (GameMod mod : GameMod.values())

View File

@ -84,11 +84,19 @@ public class GamePauseMenu extends BasicGameState {
@Override @Override
public void render(GameContainer container, StateBasedGame game, Graphics g) public void render(GameContainer container, StateBasedGame game, Graphics g)
throws SlickException { throws SlickException {
// background // get background image
if (gameState.getRestart() != Game.Restart.LOSE) GameImage bg = (gameState.getRestart() == Game.Restart.LOSE) ?
GameImage.PAUSE_OVERLAY.getImage().draw(); GameImage.FAIL_BACKGROUND : GameImage.PAUSE_OVERLAY;
// don't draw default background if button skinned and background unskinned
boolean buttonsSkinned =
GameImage.PAUSE_CONTINUE.hasSkinImage() ||
GameImage.PAUSE_RETRY.hasSkinImage() ||
GameImage.PAUSE_BACK.hasSkinImage();
if (!buttonsSkinned || bg.hasSkinImage())
bg.getImage().draw();
else else
GameImage.FAIL_BACKGROUND.getImage().draw(); g.setBackground(Color.black);
// draw buttons // draw buttons
if (gameState.getRestart() != Game.Restart.LOSE) if (gameState.getRestart() != Game.Restart.LOSE)

View File

@ -93,11 +93,6 @@ public class MainMenu extends BasicGameState {
*/ */
private Stack<Integer> previous; private Stack<Integer> previous;
/**
* Main menu background image (optional).
*/
private Image backgroundImage;
/** /**
* Background alpha level (for fade-in effect). * Background alpha level (for fade-in effect).
*/ */
@ -160,14 +155,6 @@ public class MainMenu extends BasicGameState {
musicPrevious.setHoverScale(1.5f); musicPrevious.setHoverScale(1.5f);
reset(); reset();
// menu background
try {
backgroundImage = new Image("menu-background.jpg").getScaledCopy(width, height);
backgroundImage.setAlpha(0.9f);
} catch (Exception e) {
// optional
}
} }
@Override @Override
@ -181,11 +168,11 @@ public class MainMenu extends BasicGameState {
if (Options.isDynamicBackgroundEnabled() && if (Options.isDynamicBackgroundEnabled() &&
osu != null && osu.drawBG(width, height, bgAlpha)) osu != null && osu.drawBG(width, height, bgAlpha))
; ;
else if (backgroundImage != null) { else {
backgroundImage.setAlpha(bgAlpha); Image bg = GameImage.MENU_BG.getImage();
backgroundImage.draw(); bg.setAlpha(bgAlpha);
} else bg.draw();
g.setBackground(Utils.COLOR_BLUE_BACKGROUND); }
// draw buttons // draw buttons
if (logoTimer > 0) { if (logoTimer > 0) {