Drawer.getImage() added. AbstractDrawer.java added to contain image for

XXXDrawers. ImagePanel.java removed.
This commit is contained in:
ericnerdo 2016-05-09 16:52:04 +02:00
parent 8cc0136ee9
commit d513d5f9fa
9 changed files with 25 additions and 50 deletions

View File

@ -1,29 +1,25 @@
package cicaprojekt;
import java.awt.Graphics;
import java.awt.image.BufferedImage;
import java.io.File;
import java.io.IOException;
import javax.imageio.ImageIO;
import javax.swing.JPanel;
public class ImagePanel extends JPanel{
public abstract class AbstractDrawer implements Drawer {
private BufferedImage image;
public ImagePanel(String path) throws IOException {
public AbstractDrawer(String path) throws IOException {
image = ImageIO.read(new File(path));
}
@Override
protected void paintComponent(Graphics g) {
super.paintComponent(g);
g.drawImage(image, 0, 0, null); // see javadoc for more info on the parameters
}
public void changeImage(String path) throws IOException {
image = ImageIO.read(new File(path));
repaint();
}
@Override
public BufferedImage getImage() {
return image;
}
}

View File

@ -1,5 +1,6 @@
package cicaprojekt;
import java.awt.image.BufferedImage;
import java.io.IOException;
public interface Drawer {
@ -7,4 +8,5 @@ public interface Drawer {
public void draw() throws IOException;
public int getTileX();
public int getTileY();
public BufferedImage getImage();
}

View File

@ -2,14 +2,12 @@ package cicaprojekt;
import java.io.IOException;
public class FieldDrawer extends ImagePanel implements Drawer {
public class FieldDrawer extends AbstractDrawer {
Field field;
public FieldDrawer(Field f) throws IOException {
super("Field.png");
field = f;
setVisible(false);
}
@Override
@ -20,8 +18,6 @@ public class FieldDrawer extends ImagePanel implements Drawer {
changeImage("ZPM.png");
else
changeImage("Field.png");
setVisible(true);
}
@Override
@ -34,4 +30,5 @@ public class FieldDrawer extends ImagePanel implements Drawer {
return field.getY();
}
}

View File

@ -2,19 +2,17 @@ package cicaprojekt;
import java.io.IOException;
public class GapDrawer extends ImagePanel implements Drawer{
public class GapDrawer extends AbstractDrawer {
private Gap gap;
public GapDrawer(Gap g) throws IOException {
super("Gap.png");
gap = g;
setVisible(false);
}
@Override
public void draw() {
setVisible(true);
//TODO ezzel csinálni kéne valamit.
}
@Override

View File

@ -2,14 +2,12 @@ package cicaprojekt;
import java.io.IOException;
public class GateDrawer extends ImagePanel implements Drawer{
public class GateDrawer extends AbstractDrawer {
Gate gate;
public GateDrawer(Gate g) throws IOException {
super("ClosedGate.png");
gate = g;
setVisible(false);
}
@Override
@ -18,8 +16,6 @@ public class GateDrawer extends ImagePanel implements Drawer{
changeImage("Field.png"); //TODO picture for open gate.
else
changeImage("ClosedGate.png");
setVisible(true);
}
@Override

View File

@ -2,13 +2,12 @@ package cicaprojekt;
import java.io.IOException;
public class PlayerBaseDrawer extends ImagePanel implements Drawer {
public class PlayerBaseDrawer extends AbstractDrawer implements Drawer {
PlayerBase playerbase;
public PlayerBaseDrawer(PlayerBase pb) throws IOException {
super("Replicator.png");
playerbase = pb;
setVisible(false);
}
@Override
@ -32,8 +31,6 @@ public class PlayerBaseDrawer extends ImagePanel implements Drawer {
break;
}
}
setVisible(true);
}
@Override

View File

@ -2,13 +2,12 @@ package cicaprojekt;
import java.io.IOException;
public class PlayerDrawer extends ImagePanel implements Drawer {
public class PlayerDrawer extends AbstractDrawer implements Drawer {
Player player;
public PlayerDrawer(Player p) throws IOException {
super("ONeill.png");
player = p;
setVisible(false);
}
@Override
@ -50,8 +49,6 @@ public class PlayerDrawer extends ImagePanel implements Drawer {
}
break;
}
setVisible(true);
}
@Override

View File

@ -2,14 +2,12 @@ package cicaprojekt;
import java.io.IOException;
public class ScaleDrawer extends ImagePanel implements Drawer {
public class ScaleDrawer extends AbstractDrawer implements Drawer {
Scale scale;
public ScaleDrawer(Scale s) throws IOException {
super("Scale.png");
scale = s;
setVisible(false);
}
@Override
@ -18,8 +16,6 @@ public class ScaleDrawer extends ImagePanel implements Drawer {
changeImage("Box.png"); //TODO Picture for Scale with box.
else
changeImage("Scale.png");
setVisible(true);
}
@Override

View File

@ -2,14 +2,12 @@ package cicaprojekt;
import java.io.IOException;
public class WallDrawer extends ImagePanel implements Drawer {
public class WallDrawer extends AbstractDrawer implements Drawer {
Wall wall;
public WallDrawer(Wall w) throws IOException {
super("Wall.png");
wall = w;
setVisible(false);
}
@Override
@ -35,8 +33,6 @@ public class WallDrawer extends ImagePanel implements Drawer {
break;
}
}
setVisible(true);
}
@Override