diff options
author | Starla Insigna <hatkirby@fourisland.com> | 2009-03-06 09:36:26 -0500 |
---|---|---|
committer | Starla Insigna <hatkirby@fourisland.com> | 2009-03-06 09:36:26 -0500 |
commit | 8e0383a3674f4d9c57b3a1b5667750a3e963a7bd (patch) | |
tree | 848fb37afbf3b2c73a123551dfcc05ba41ee5a7e /src | |
parent | c86c8e440af09e3b1a8b1286f1fb837cba25a302 (diff) | |
download | fourpuzzle-8e0383a3674f4d9c57b3a1b5667750a3e963a7bd.tar.gz fourpuzzle-8e0383a3674f4d9c57b3a1b5667750a3e963a7bd.tar.bz2 fourpuzzle-8e0383a3674f4d9c57b3a1b5667750a3e963a7bd.zip |
Engine: Added configuration to ChoiceWindow
Added ability to force a specific width for MenuEMS so menu looks pREETY OMG IM HYPER Refs #15
Diffstat (limited to 'src')
4 files changed, 98 insertions, 75 deletions
diff --git a/src/com/fourisland/fourpuzzle/gamestate/TitleScreenGameState.java b/src/com/fourisland/fourpuzzle/gamestate/TitleScreenGameState.java index 6f12d02..db6225e 100755 --- a/src/com/fourisland/fourpuzzle/gamestate/TitleScreenGameState.java +++ b/src/com/fourisland/fourpuzzle/gamestate/TitleScreenGameState.java | |||
@@ -32,8 +32,11 @@ public class TitleScreenGameState implements GameState { | |||
32 | { | 32 | { |
33 | Audio.playMusic(Database.getMusic(Music.Title)); | 33 | Audio.playMusic(Database.getMusic(Music.Title)); |
34 | 34 | ||
35 | choices = new ChoiceWindow(Arrays.asList(Database.getVocab(Vocabulary.NewGame), Database.getVocab(Vocabulary.LoadGame), Database.getVocab(Vocabulary.EndGame)), true, ChoiceWindow.ChoiceWindowLocation.BottomLeft); | 35 | choices = new ChoiceWindow.Builder(Arrays.asList(Database.getVocab(Vocabulary.NewGame), Database.getVocab(Vocabulary.LoadGame), Database.getVocab(Vocabulary.EndGame)), ChoiceWindow.ChoiceWindowLocation.BottomLeft) |
36 | .center(true) | ||
37 | .build(); | ||
36 | Display.registerRenderable(choices); | 38 | Display.registerRenderable(choices); |
39 | KeyboardInput.registerInputable(choices); | ||
37 | } | 40 | } |
38 | 41 | ||
39 | public void deinitalize() | 42 | public void deinitalize() |
@@ -41,6 +44,7 @@ public class TitleScreenGameState implements GameState { | |||
41 | Audio.stopMusic(); | 44 | Audio.stopMusic(); |
42 | 45 | ||
43 | Display.unregisterRenderable(choices); | 46 | Display.unregisterRenderable(choices); |
47 | KeyboardInput.unregisterInputable(choices); | ||
44 | } | 48 | } |
45 | 49 | ||
46 | PauseTimer pt = new PauseTimer(0); | 50 | PauseTimer pt = new PauseTimer(0); |
diff --git a/src/com/fourisland/fourpuzzle/gamestate/menu/MenuEMS.java b/src/com/fourisland/fourpuzzle/gamestate/menu/MenuEMS.java index 4fad509..b6fcd3b 100644 --- a/src/com/fourisland/fourpuzzle/gamestate/menu/MenuEMS.java +++ b/src/com/fourisland/fourpuzzle/gamestate/menu/MenuEMS.java | |||
@@ -14,7 +14,6 @@ import com.fourisland.fourpuzzle.database.Transitions; | |||
14 | import com.fourisland.fourpuzzle.database.Vocabulary; | 14 | import com.fourisland.fourpuzzle.database.Vocabulary; |
15 | import com.fourisland.fourpuzzle.gamestate.TitleScreenGameState; | 15 | import com.fourisland.fourpuzzle.gamestate.TitleScreenGameState; |
16 | import com.fourisland.fourpuzzle.window.ChoiceWindow; | 16 | import com.fourisland.fourpuzzle.window.ChoiceWindow; |
17 | import com.fourisland.fourpuzzle.window.InputableChoiceWindow; | ||
18 | import java.awt.Color; | 17 | import java.awt.Color; |
19 | import java.awt.Graphics2D; | 18 | import java.awt.Graphics2D; |
20 | import java.awt.event.KeyEvent; | 19 | import java.awt.event.KeyEvent; |
@@ -27,12 +26,14 @@ import java.util.Arrays; | |||
27 | public class MenuEMS implements EscapeMenuState { | 26 | public class MenuEMS implements EscapeMenuState { |
28 | 27 | ||
29 | MenuGameState parent; | 28 | MenuGameState parent; |
30 | InputableChoiceWindow cw; | 29 | ChoiceWindow cw; |
31 | 30 | ||
32 | public void initalize(MenuGameState mgs) | 31 | public void initalize(MenuGameState mgs) |
33 | { | 32 | { |
34 | parent = mgs; | 33 | parent = mgs; |
35 | cw = new InputableChoiceWindow(Arrays.asList(Database.getVocab(Vocabulary.EscapeMenuItems), Database.getVocab(Vocabulary.EscapeMenuEquipment), Database.getVocab(Vocabulary.EscapeMenuMagic), Database.getVocab(Vocabulary.EscapeMenuSave), Database.getVocab(Vocabulary.EscapeMenuQuit)), false, ChoiceWindow.ChoiceWindowLocation.AbsoluteTopLeft); | 34 | cw = new ChoiceWindow.Builder(Arrays.asList(Database.getVocab(Vocabulary.EscapeMenuItems), Database.getVocab(Vocabulary.EscapeMenuEquipment), Database.getVocab(Vocabulary.EscapeMenuMagic), Database.getVocab(Vocabulary.EscapeMenuSave), Database.getVocab(Vocabulary.EscapeMenuQuit)), ChoiceWindow.ChoiceWindowLocation.AbsoluteTopLeft) |
35 | .width(Game.WIDTH/5) | ||
36 | .build(); | ||
36 | Display.registerRenderable(cw); | 37 | Display.registerRenderable(cw); |
37 | KeyboardInput.registerInputable(cw); | 38 | KeyboardInput.registerInputable(cw); |
38 | } | 39 | } |
diff --git a/src/com/fourisland/fourpuzzle/window/ChoiceWindow.java b/src/com/fourisland/fourpuzzle/window/ChoiceWindow.java index 90f2d96..8dce753 100755 --- a/src/com/fourisland/fourpuzzle/window/ChoiceWindow.java +++ b/src/com/fourisland/fourpuzzle/window/ChoiceWindow.java | |||
@@ -8,12 +8,16 @@ package com.fourisland.fourpuzzle.window; | |||
8 | import com.fourisland.fourpuzzle.Audio; | 8 | import com.fourisland.fourpuzzle.Audio; |
9 | import com.fourisland.fourpuzzle.Display; | 9 | import com.fourisland.fourpuzzle.Display; |
10 | import com.fourisland.fourpuzzle.Game; | 10 | import com.fourisland.fourpuzzle.Game; |
11 | import com.fourisland.fourpuzzle.KeyInput; | ||
11 | import com.fourisland.fourpuzzle.database.Database; | 12 | import com.fourisland.fourpuzzle.database.Database; |
12 | import com.fourisland.fourpuzzle.database.Sound; | 13 | import com.fourisland.fourpuzzle.database.Sound; |
14 | import com.fourisland.fourpuzzle.util.Inputable; | ||
15 | import com.fourisland.fourpuzzle.util.PauseTimer; | ||
13 | import com.fourisland.fourpuzzle.util.Renderable; | 16 | import com.fourisland.fourpuzzle.util.Renderable; |
14 | import java.awt.Graphics2D; | 17 | import java.awt.Graphics2D; |
15 | import java.awt.Rectangle; | 18 | import java.awt.Rectangle; |
16 | import java.awt.TexturePaint; | 19 | import java.awt.TexturePaint; |
20 | import java.awt.event.KeyEvent; | ||
17 | import java.awt.image.BufferedImage; | 21 | import java.awt.image.BufferedImage; |
18 | import java.util.List; | 22 | import java.util.List; |
19 | 23 | ||
@@ -21,9 +25,40 @@ import java.util.List; | |||
21 | * | 25 | * |
22 | * @author hatkirby | 26 | * @author hatkirby |
23 | */ | 27 | */ |
24 | public class ChoiceWindow implements Renderable { | 28 | public class ChoiceWindow implements Renderable, Inputable { |
25 | 29 | ||
26 | private static final int SPACER = 4; | 30 | private static final int SPACER = 4; |
31 | |||
32 | public static class Builder | ||
33 | { | ||
34 | List<String> choices; | ||
35 | ChoiceWindowLocation location; | ||
36 | boolean center = false; | ||
37 | int width = 0; | ||
38 | |||
39 | public Builder(List<String> choices, ChoiceWindowLocation location) | ||
40 | { | ||
41 | this.choices = choices; | ||
42 | this.location = location; | ||
43 | } | ||
44 | |||
45 | public Builder center(boolean center) | ||
46 | { | ||
47 | this.center = center; | ||
48 | return this; | ||
49 | } | ||
50 | |||
51 | public Builder width(int width) | ||
52 | { | ||
53 | this.width = width; | ||
54 | return this; | ||
55 | } | ||
56 | |||
57 | public ChoiceWindow build() | ||
58 | { | ||
59 | return new ChoiceWindow(this); | ||
60 | } | ||
61 | } | ||
27 | 62 | ||
28 | private List<String> choices; | 63 | private List<String> choices; |
29 | int numChoices; | 64 | int numChoices; |
@@ -33,27 +68,36 @@ public class ChoiceWindow implements Renderable { | |||
33 | BufferedImage cacheBase; | 68 | BufferedImage cacheBase; |
34 | int x; | 69 | int x; |
35 | int y; | 70 | int y; |
36 | public ChoiceWindow(List<String> choices, boolean center, ChoiceWindowLocation cwl) | 71 | String clickSound; |
72 | private ChoiceWindow(Builder builder) | ||
37 | { | 73 | { |
38 | this.choices = choices; | 74 | this.choices = builder.choices; |
39 | numChoices = choices.size(); | 75 | numChoices = choices.size(); |
40 | this.center = center; | 76 | this.center = builder.center; |
41 | 77 | ||
42 | for (String choice : choices) | 78 | for (String choice : choices) |
43 | { | 79 | { |
44 | int l = Display.getFontMetrics().stringWidth(choice); | 80 | if (builder.width == 0) |
45 | if (l > getWidth()) | ||
46 | { | 81 | { |
47 | width = l; | 82 | int l = Display.getFontMetrics().stringWidth(choice); |
83 | if (l > getWidth()) | ||
84 | { | ||
85 | width = l; | ||
86 | } | ||
48 | } | 87 | } |
49 | 88 | ||
50 | height += Display.getFontMetrics().getHeight() + SPACER; | 89 | height += Display.getFontMetrics().getHeight() + SPACER; |
51 | } | 90 | } |
52 | 91 | ||
92 | if (builder.width != 0) | ||
93 | { | ||
94 | width = builder.width; | ||
95 | } | ||
96 | |||
53 | cacheBase = Window.Default.getImage(width, height); | 97 | cacheBase = Window.Default.getImage(width, height); |
54 | 98 | ||
55 | x = cwl.getX(width); | 99 | x = builder.location.getX(width); |
56 | y = cwl.getY(height); | 100 | y = builder.location.getY(height); |
57 | } | 101 | } |
58 | 102 | ||
59 | public void render(Graphics2D g2) | 103 | public void render(Graphics2D g2) |
@@ -167,4 +211,39 @@ public class ChoiceWindow implements Renderable { | |||
167 | } | 211 | } |
168 | } | 212 | } |
169 | 213 | ||
214 | Boolean hasInput = false; | ||
215 | PauseTimer pt = new PauseTimer(0); | ||
216 | public void processInput(KeyInput key) | ||
217 | { | ||
218 | if (key.getKey() == KeyEvent.VK_UP) | ||
219 | { | ||
220 | if (pt.isElapsed()) | ||
221 | { | ||
222 | moveUp(); | ||
223 | pt.setTimer(1); | ||
224 | } | ||
225 | } else if (key.getKey() == KeyEvent.VK_DOWN) | ||
226 | { | ||
227 | if (pt.isElapsed()) | ||
228 | { | ||
229 | moveDown(); | ||
230 | pt.setTimer(1); | ||
231 | } | ||
232 | } else if (key.isActionDown()) | ||
233 | { | ||
234 | synchronized (hasInput) | ||
235 | { | ||
236 | hasInput = true; | ||
237 | } | ||
238 | } | ||
239 | } | ||
240 | |||
241 | public boolean hasInput() | ||
242 | { | ||
243 | synchronized (hasInput) | ||
244 | { | ||
245 | return hasInput; | ||
246 | } | ||
247 | } | ||
248 | |||
170 | } \ No newline at end of file | 249 | } \ No newline at end of file |
diff --git a/src/com/fourisland/fourpuzzle/window/InputableChoiceWindow.java b/src/com/fourisland/fourpuzzle/window/InputableChoiceWindow.java deleted file mode 100644 index 02bc737..0000000 --- a/src/com/fourisland/fourpuzzle/window/InputableChoiceWindow.java +++ /dev/null | |||
@@ -1,61 +0,0 @@ | |||
1 | /* | ||
2 | * To change this template, choose Tools | Templates | ||
3 | * and open the template in the editor. | ||
4 | */ | ||
5 | |||
6 | package com.fourisland.fourpuzzle.window; | ||
7 | |||
8 | import com.fourisland.fourpuzzle.KeyInput; | ||
9 | import java.util.List; | ||
10 | import com.fourisland.fourpuzzle.util.Inputable; | ||
11 | import com.fourisland.fourpuzzle.util.PauseTimer; | ||
12 | import java.awt.event.KeyEvent; | ||
13 | |||
14 | /** | ||
15 | * | ||
16 | * @author hatkirby | ||
17 | */ | ||
18 | public class InputableChoiceWindow extends ChoiceWindow implements Inputable { | ||
19 | |||
20 | Boolean hasInput = false; | ||
21 | PauseTimer pt = new PauseTimer(0); | ||
22 | |||
23 | public InputableChoiceWindow(List<String> choices, boolean center, ChoiceWindowLocation cwl) | ||
24 | { | ||
25 | super(choices, center, cwl); | ||
26 | } | ||
27 | |||
28 | public void processInput(KeyInput key) | ||
29 | { | ||
30 | if (key.getKey() == KeyEvent.VK_UP) | ||
31 | { | ||
32 | if (pt.isElapsed()) | ||
33 | { | ||
34 | moveUp(); | ||
35 | pt.setTimer(1); | ||
36 | } | ||
37 | } else if (key.getKey() == KeyEvent.VK_DOWN) | ||
38 | { | ||
39 | if (pt.isElapsed()) | ||
40 | { | ||
41 | moveDown(); | ||
42 | pt.setTimer(1); | ||
43 | } | ||
44 | } else if (key.isActionDown()) | ||
45 | { | ||
46 | synchronized (hasInput) | ||
47 | { | ||
48 | hasInput = true; | ||
49 | } | ||
50 | } | ||
51 | } | ||
52 | |||
53 | public boolean hasInput() | ||
54 | { | ||
55 | synchronized (hasInput) | ||
56 | { | ||
57 | return hasInput; | ||
58 | } | ||
59 | } | ||
60 | |||
61 | } | ||