diff options
Diffstat (limited to 'src/com/fourisland/fourpuzzle/window/ChoiceWindow.java')
-rwxr-xr-x | src/com/fourisland/fourpuzzle/window/ChoiceWindow.java | 68 |
1 files changed, 35 insertions, 33 deletions
diff --git a/src/com/fourisland/fourpuzzle/window/ChoiceWindow.java b/src/com/fourisland/fourpuzzle/window/ChoiceWindow.java index 40fff30..3b30acc 100755 --- a/src/com/fourisland/fourpuzzle/window/ChoiceWindow.java +++ b/src/com/fourisland/fourpuzzle/window/ChoiceWindow.java | |||
@@ -5,18 +5,13 @@ | |||
5 | 5 | ||
6 | package com.fourisland.fourpuzzle.window; | 6 | package com.fourisland.fourpuzzle.window; |
7 | 7 | ||
8 | import com.fourisland.fourpuzzle.util.TransparentPixelFilter; | 8 | import com.fourisland.fourpuzzle.Audio; |
9 | import java.awt.Font; | 9 | import java.awt.Font; |
10 | import java.awt.Toolkit; | ||
11 | import java.awt.Graphics2D; | 10 | import java.awt.Graphics2D; |
12 | import java.awt.Rectangle; | 11 | import java.awt.Rectangle; |
13 | import java.awt.TexturePaint; | 12 | import java.awt.TexturePaint; |
14 | import java.awt.image.BufferedImage; | 13 | import java.awt.image.BufferedImage; |
15 | import java.awt.image.FilteredImageSource; | ||
16 | import java.util.List; | 14 | import java.util.List; |
17 | import static com.fourisland.fourpuzzle.window.SystemChoiceArea.*; | ||
18 | |||
19 | /* TODO Find a more elegant way to implement window, it looks terrible now */ | ||
20 | 15 | ||
21 | /** | 16 | /** |
22 | * | 17 | * |
@@ -35,7 +30,7 @@ public class ChoiceWindow { | |||
35 | numChoices = choices.size(); | 30 | numChoices = choices.size(); |
36 | this.center = center; | 31 | this.center = center; |
37 | 32 | ||
38 | createGraphic(new BufferedImage(TopLeft.getWidth()+getWidth()+TopRight.getWidth(), TopLeft.getHeight()+getHeight()+BottomLeft.getHeight(), BufferedImage.TYPE_INT_ARGB).createGraphics()); | 33 | createGraphic(new BufferedImage(Window.Default.getFullWidth(width), Window.Default.getFullHeight(height), BufferedImage.TYPE_INT_ARGB).createGraphics()); |
39 | } | 34 | } |
40 | 35 | ||
41 | private int width; | 36 | private int width; |
@@ -57,36 +52,38 @@ public class ChoiceWindow { | |||
57 | width += SPACER*2; | 52 | width += SPACER*2; |
58 | height -= SPACER; | 53 | height -= SPACER; |
59 | 54 | ||
60 | BufferedImage temp = new BufferedImage(TopLeft.getWidth()+getWidth()+TopRight.getWidth(), TopLeft.getHeight()+getHeight()+BottomLeft.getHeight(), BufferedImage.TYPE_INT_ARGB); | 55 | cacheBase = new BufferedImage(Window.Default.getFullWidth(width), Window.Default.getFullHeight(height), BufferedImage.TYPE_INT_ARGB); |
61 | Graphics2D g = temp.createGraphics(); | ||
62 | |||
63 | g.drawImage(SystemGraphic.getChoiceArea(TopLeft), 0, 0, null); | ||
64 | g.drawImage(SystemGraphic.getChoiceArea(Top), TopLeft.getWidth(), 0, getWidth(),Top.getHeight(), null); | ||
65 | g.drawImage(SystemGraphic.getChoiceArea(TopRight), TopLeft.getWidth()+getWidth(), 0, null); | ||
66 | g.drawImage(SystemGraphic.getChoiceArea(Left), 0, TopLeft.getHeight(), Left.getWidth(),getHeight(), null); | ||
67 | g.drawImage(SystemGraphic.getChoiceArea(BottomLeft), 0, TopLeft.getHeight()+getHeight(), null); | ||
68 | g.drawImage(SystemGraphic.getChoiceArea(Bottom), BottomLeft.getWidth(), (getHeight()+TopLeft.getHeight()+BottomLeft.getHeight())-Bottom.getHeight(), getWidth(),Bottom.getHeight(), null); | ||
69 | g.drawImage(SystemGraphic.getChoiceArea(BottomRight), BottomRight.getWidth()+getWidth(), TopRight.getHeight()+getHeight(), null); | ||
70 | g.drawImage(SystemGraphic.getChoiceArea(Right), (getWidth()+TopLeft.getWidth()+TopRight.getWidth())-Right.getWidth(), TopRight.getHeight(), Right.getWidth(),getHeight(), null); | ||
71 | |||
72 | cacheBase = new BufferedImage(TopLeft.getWidth()+getWidth()+TopRight.getWidth(), TopLeft.getHeight()+getHeight()+BottomLeft.getHeight(), BufferedImage.TYPE_INT_ARGB); | ||
73 | Graphics2D g2 = cacheBase.createGraphics(); | 56 | Graphics2D g2 = cacheBase.createGraphics(); |
74 | 57 | ||
75 | g2.drawImage(SystemGraphic.getMessageBackground(), 1, 1, TopLeft.getWidth()+getWidth()+TopRight.getWidth()-2, TopLeft.getHeight()+getHeight()+BottomLeft.getHeight()-2, null); | 58 | g2.drawImage(SystemGraphic.getMessageBackground(), 1, 1, Window.Default.getFullWidth(width)-2, Window.Default.getFullHeight(height)-2, null); |
76 | g2.drawImage(Toolkit.getDefaultToolkit().createImage(new FilteredImageSource(temp.getSource(), new TransparentPixelFilter(SystemGraphic.getTransparentColor().getRGB()))), 0, 0, null); | 59 | g2.drawImage(Window.Default.getImage(width, height), 0, 0, null); |
60 | } | ||
61 | |||
62 | public void render(Graphics2D g2, int x, int y) | ||
63 | { | ||
64 | g2.drawImage(cacheBase, x, y, null); | ||
65 | |||
77 | g2.setFont(g2.getFont().deriveFont(Font.BOLD)); | 66 | g2.setFont(g2.getFont().deriveFont(Font.BOLD)); |
78 | 67 | ||
79 | int ty = TopLeft.getHeight()+g2.getFontMetrics().getHeight()-SPACER; | 68 | int fh = g2.getFontMetrics().getHeight(); |
69 | int ty = Window.Default.getTopY()+fh-SPACER+y; | ||
80 | for (String choice : choices) | 70 | for (String choice : choices) |
81 | { | 71 | { |
82 | int tx = TopLeft.getWidth(); | 72 | int fw = g2.getFontMetrics().stringWidth(choice); |
73 | int tx = Window.Default.getLeftX()+x; | ||
83 | 74 | ||
84 | if (center) | 75 | if (center) |
85 | { | 76 | { |
86 | tx += ((width/2)-(g2.getFontMetrics().stringWidth(choice)/2)); | 77 | tx += ((width/2)-(fw/2)); |
78 | } | ||
79 | |||
80 | if (getSelected().equals(choice)) | ||
81 | { | ||
82 | g2.drawImage(SystemGraphic.getSelectionBackground(), tx, ty-fh, fw+SPACER-2, fh+SPACER-2, null); | ||
83 | g2.drawImage(Window.Selector.getImage(fw-Window.Selector.getLeftX(), fh-Window.Selector.getTopY()), tx-SPACER, ty-fh, null); | ||
87 | } | 84 | } |
88 | 85 | ||
89 | g2.setPaint(new TexturePaint(SystemGraphic.getTextColor(), new Rectangle(tx, ty, g2.getFontMetrics().stringWidth(choice),g2.getFontMetrics().getHeight()))); | 86 | g2.setPaint(new TexturePaint(SystemGraphic.getTextColor(), new Rectangle(tx, ty, fw, fh))); |
90 | g2.drawString(choice, tx, ty); | 87 | g2.drawString(choice, tx, ty); |
91 | 88 | ||
92 | ty+=(SPACER+g2.getFontMetrics().getHeight()); | 89 | ty+=(SPACER+g2.getFontMetrics().getHeight()); |
@@ -95,11 +92,6 @@ public class ChoiceWindow { | |||
95 | g2.setFont(g2.getFont().deriveFont(Font.PLAIN)); | 92 | g2.setFont(g2.getFont().deriveFont(Font.PLAIN)); |
96 | } | 93 | } |
97 | 94 | ||
98 | public void render(Graphics2D g2, int x, int y) | ||
99 | { | ||
100 | g2.drawImage(cacheBase, x, y, null); | ||
101 | } | ||
102 | |||
103 | public int getWidth() | 95 | public int getWidth() |
104 | { | 96 | { |
105 | return width; | 97 | return width; |
@@ -113,12 +105,22 @@ public class ChoiceWindow { | |||
113 | int selected = 0; | 105 | int selected = 0; |
114 | public void moveUp() | 106 | public void moveUp() |
115 | { | 107 | { |
116 | selected--; | 108 | if (selected > 0) |
109 | { | ||
110 | Audio.playSound("Cursor1"); | ||
111 | |||
112 | selected--; | ||
113 | } | ||
117 | } | 114 | } |
118 | 115 | ||
119 | public void moveDown() | 116 | public void moveDown() |
120 | { | 117 | { |
121 | selected++; | 118 | if (selected < (choices.size()-1)) |
119 | { | ||
120 | Audio.playSound("Cursor1"); | ||
121 | |||
122 | selected++; | ||
123 | } | ||
122 | } | 124 | } |
123 | 125 | ||
124 | public String getSelected() | 126 | public String getSelected() |