diff options
author | Nao Pross <naopross@thearcway.org> | 2018-02-10 13:41:19 +0100 |
---|---|---|
committer | Nao Pross <naopross@thearcway.org> | 2018-02-10 13:41:19 +0100 |
commit | 3165434c5aa8081b7c7b0a59c668d6135f882629 (patch) | |
tree | bf07ac9f4e5cec22346836da4aa190aa19549c14 | |
parent | First commit (diff) | |
download | Subconscious-old-3165434c5aa8081b7c7b0a59c668d6135f882629.tar.gz Subconscious-old-3165434c5aa8081b7c7b0a59c668d6135f882629.zip |
Implement barebone game engine
-rw-r--r-- | .gitignore | 6 | ||||
-rw-r--r-- | src/Actor.java | 3 | ||||
-rw-r--r-- | src/EntityType.java | 3 | ||||
-rw-r--r-- | src/MainPanel.java | 265 | ||||
-rw-r--r-- | src/Map.java | 28 | ||||
-rw-r--r-- | src/Scene.java | 5 | ||||
-rw-r--r-- | src/Subconscious.java | 87 | ||||
-rw-r--r-- | src/Tile.java | 27 | ||||
-rw-r--r-- | src/TileType.java | 3 | ||||
-rw-r--r-- | src/WorldScene.java | 32 |
10 files changed, 155 insertions, 304 deletions
diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..2acf61b --- /dev/null +++ b/.gitignore @@ -0,0 +1,6 @@ +# build files +**/*.class + +# build directories +build +jar diff --git a/src/Actor.java b/src/Actor.java new file mode 100644 index 0000000..207d6e6 --- /dev/null +++ b/src/Actor.java @@ -0,0 +1,3 @@ +public class Actor { + +} diff --git a/src/EntityType.java b/src/EntityType.java deleted file mode 100644 index a4ccf30..0000000 --- a/src/EntityType.java +++ /dev/null @@ -1,3 +0,0 @@ -public enum EntityType { - NULL, PLAYER, ENEMY, TREE -} diff --git a/src/MainPanel.java b/src/MainPanel.java deleted file mode 100644 index 8af12ee..0000000 --- a/src/MainPanel.java +++ /dev/null @@ -1,265 +0,0 @@ -import javax.swing.*; -import java.awt.*; -import java.awt.event.*; -import java.util.Random; - -public class MainPanel extends JPanel implements MouseListener, MouseMotionListener { - - public int width = 20; - public Tile[][] tileArray = new Tile[width][width]; - public int size; - public boolean selectionMode = false; - public boolean attackMode = false; - public boolean action = false; - public boolean miss = false; - public int[] selection = {0, 0}; - public int[] attaction = {0, 0}; - public int[] location = {0, 0}; - private int len; - private Color RED = new Color(165, 66, 66); - private Color YELLOW = new Color(250, 198, 116); - private Color GREEN = new Color(181, 189, 104); - private Color BLACK = new Color(29, 31, 33); - private Color WHITE = new Color(197, 200, 198); - private Color BLUE = new Color(95, 129, 157); - private Color ORANGE = new Color(222, 147, 95); - private Color DARKGREEN = new Color(140, 148, 64); - private Color BROWN = new Color(51, 41, 33); - private Random rand = new Random(); - - public MainPanel () { - for (int row = 0; row < width; row++) { - for (int col = 0; col < width; col++) { - tileArray[row][col] = new Tile(row, col, this.size, this.width); - } - } - - tileArray[0][0].entityType = EntityType.PLAYER; - for (int i = 0; i < 35; i++) { - int row = rand.nextInt(width); - int col = rand.nextInt(width); - int type = rand.nextInt(4); - if (tileArray[row][col].entityType == EntityType.NULL) { - if (type == 0) { - tileArray[row][col].entityType = EntityType.ENEMY; - } else { - tileArray[row][col].entityType = EntityType.TREE; - } - } - } - - this.addMouseListener(this); - this.addMouseMotionListener(this); - } - - public void paintComponent(Graphics g) { - if (this.getWidth() > this.getHeight()) { - this.size = this.getHeight(); - } else { - this.size = this.getWidth(); - } - - super.paintComponent(g); - - Graphics2D g2d = (Graphics2D) g.create(); - g2d.setRenderingHint(RenderingHints.KEY_ANTIALIASING, - RenderingHints.VALUE_ANTIALIAS_ON); - - int bar = this.size/20; - - g2d.setColor(WHITE); - g2d.fillRect(0, 0, this.getWidth(), this.getHeight()); - g2d.setColor(BLACK); - g2d.fillRect(0, this.size-bar, this.size-bar, bar); - g2d.setColor(WHITE); - g2d.setFont(new Font("Arial", Font.BOLD, bar-bar/10)); - if (this.miss) { - g2d.drawString("MISS", this.size-bar-(bar-bar/10)*3, this.size-bar/10); - } - - if (action) { - g2d.drawString("PAS", 0, this.size-bar/10); - g2d.drawString("ATK", (bar-bar/10)*3, this.size-bar/10); - } - - for (int row = 0; row < width; row++) { - for (int col = 0; col < width; col++) { - this.tileArray[row][col].calc(row, col, this.size-bar); - int x = this.tileArray[row][col].x; - int y = this.tileArray[row][col].y; - this.len = this.tileArray[row][col].len; - - int border = len/100; - - if (this.tileArray[row][col].tileType == TileType.GRASS) { - g2d.setColor(GREEN); - g2d.fillRect(x, y, len, len); - g2d.setColor(BLACK); - g2d.setStroke(new BasicStroke(len/50)); - g2d.drawRect(x, y, len, len); - } else if ( - this.tileArray[row][col].tileType == TileType.WATER) { - g2d.setColor(Color.BLUE); - g2d.fillRect(x, y, len, len); - g2d.setColor(BLACK); - g2d.setStroke(new BasicStroke(len/50)); - g2d.drawRect(x, y, len, len); - } - - int spacing = len/12; - - - if (this.tileArray[row][col].entityType == EntityType.PLAYER) { - g2d.setColor(BLUE); - g2d.fillRect( - x+spacing, y+spacing, len-spacing*2, len-spacing*2); - this.location[0] = x; - this.location[1] = y; - this.selection[0] = row; - this.selection[1] = col; - } - - if (this.tileArray[row][col].entityType == EntityType.ENEMY) { - g2d.setColor(RED); - g2d.fillRect( - x+spacing, y+spacing, len-spacing*2, len-spacing*2); - } - - if (this.tileArray[row][col].entityType == EntityType.TREE) { - g2d.setColor(DARKGREEN); - g2d.fillRect( - x+spacing, y+spacing, len-spacing*2, len-spacing*2); - g2d.setColor(BROWN); - g2d.fillRect(x+len/3, y+len/3, len/3, len/3); - } - - if (this.tileArray[row][col].selected) { - if (this.tileArray[row][col].entityType == EntityType.NULL) { - g2d.setColor(YELLOW); - g2d.fillRect(x+len/3, y+len/3, len/3, len/3); - } - } - - if (this.tileArray[row][col].attack) { - g2d.setColor(ORANGE); - g2d.setStroke(new BasicStroke(this.len/6)); - g2d.drawRect(x+len/4, y+len/4, len*2/4, len*2/4); - } - } - } - - } - - public void mousePressed(MouseEvent e) {} - public void mouseReleased(MouseEvent e) {} - public void mouseEntered(MouseEvent e) {} - public void mouseMoved(MouseEvent e) { - int x = e.getX(); - int y = e.getY(); - - if (attackMode) { - for (int row = 0; row < width; row++) { - for (int col = 0; col < width; col++) { - this.tileArray[row][col].attack = false; - if ( - x > this.tileArray[row][col].x - && x < this.tileArray[row][col].x - + this.tileArray[row][col].len - && y > this.tileArray[row][col].y - && y < this.tileArray[row][col].y - + this.tileArray[row][col].len - ) { - this.tileArray[row][col].attack = true; - } - } - } - } - this.repaint(); - } - public void mouseExited(MouseEvent e) {} - public void mouseDragged(MouseEvent e) {} - - public void mouseClicked(MouseEvent e) { - int x = e.getX(); - int y = e.getY(); - int bar = this.size/20; - boolean stop = false; - this.miss = false; - - if ( - x > 0 - && x < (bar-bar/10)*3 - && y > this.size-bar - && y < this.size - ) { - this.action = false; - } else if ( - x > (bar-bar/10)*3 - && x < (bar-bar/10)*6 - && y > this.size-bar - && y < this.size - ) { - this.attackMode = true; - this.action = false; - } else { - for (int row = 0; row < width; row++) { - for (int col = 0; col < width; col++) { - if ( - x > this.tileArray[row][col].x - && x < this.tileArray[row][col].x - + this.tileArray[row][col].len - && y > this.tileArray[row][col].y - && y < this.tileArray[row][col].y - + this.tileArray[row][col].len - ) { - if (this.selectionMode) { - if (this.tileArray[row][col].selected) { - this.tileArray[this.selection[0]][this.selection[1]].entityType = EntityType.NULL; - this.tileArray[row][col].entityType = EntityType.PLAYER; - this.selectionMode = false; - this.action = true; - } - } else if (this.attackMode) { - int dist = (int) Math.sqrt(Math.pow(row - this.selection[0], 2) - + Math.pow(col - this.selection[1], 2)); - if (rand.nextInt(13) > dist) { - if (this.tileArray[row][col].entityType == EntityType.ENEMY) { - this.tileArray[row][col].entityType = EntityType.NULL; - } else if (this.tileArray[row][col].entityType == EntityType.TREE) { - this.tileArray[row][col].entityType = EntityType.NULL; - } - } else { - this.miss = true; - } - this.tileArray[row][col].attack = false; - this.attackMode = false; - } else if (this.tileArray[row][col].entityType == EntityType.PLAYER) { - this.selectionMode = true; - this.selection[0] = row; - this.selection[1] = col; - for (int srow = -4; srow <= 4; srow++) { - for (int scol = -4; scol <= 4; scol++) { - if (Math.abs(srow) + Math.abs(scol) <= 4) { - try { - if (this.tileArray[row+srow][col+scol].entityType == EntityType.NULL) { - this.tileArray[row+srow][col+scol].selected = true; - } - } catch (ArrayIndexOutOfBoundsException ex) {} - } - } - } - } - } - } - } - if (!selectionMode) { - for (int row = 0; row < width; row++) { - for (int col = 0; col < width; col++) { - this.tileArray[row][col].selected = false; - } - } - } - } - this.repaint(); - } -} diff --git a/src/Map.java b/src/Map.java new file mode 100644 index 0000000..031e922 --- /dev/null +++ b/src/Map.java @@ -0,0 +1,28 @@ +import java.awt.Dimension; + +public class Map { + + public final Dimension size; + public final Tile grid[]; + + // TODO load map from file + // public Map(File filename) { + public Map(Dimension size) { + this.size = size; + + // populate grid + this.grid = new Tile[this.size.width * this.size.height]; + for (int y = 0; y < this.size.width; y++) { + for (int x = 0; x < this.size.height; x++) { + this.grid[y * this.size.width + x] = new Tile(Tile.Type.GRASS, x, y); + } + } + } + + // public void load() {} + + /* accessors */ + public Tile getTile(int x, int y) { + return this.grid[y * this.size.width + y]; + } +} diff --git a/src/Scene.java b/src/Scene.java new file mode 100644 index 0000000..a2949fd --- /dev/null +++ b/src/Scene.java @@ -0,0 +1,5 @@ +import java.awt.Graphics; + +public abstract class Scene { + abstract void render(Graphics g); +} diff --git a/src/Subconscious.java b/src/Subconscious.java index dc15964..b63eb23 100644 --- a/src/Subconscious.java +++ b/src/Subconscious.java @@ -1,24 +1,79 @@ -import javax.swing.*; -import java.awt.*; +import javax.swing.JFrame; +import javax.swing.JPanel; -public class Subconscious { +import java.awt.Graphics; +import java.awt.Image; +import java.awt.Dimension; - public static final Dimension WINDOW_SIZE = new Dimension(400, 400); - public Subconscious() { - JFrame frame = new JFrame("Subconscious"); +public class Subconscious extends JPanel { - frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); - frame.setSize(WINDOW_SIZE); - frame.setLocationRelativeTo(null); + public static final String TITLE = "Subconscious"; - MainPanel mainPanel= new MainPanel(); - frame.add(mainPanel); + /* graphics */ + public JFrame window; + // public Graphics dbGraphics; // double buffered graphics + // public Image dbImage = null; // double buffered image + + public Scene currentScene; - frame.setVisible(true); - } + /* game */ + public boolean gameOver = false; + public boolean running = false; - public static void main(String[] args) { - Subconscious subconscious = new Subconscious(); - } + public Subconscious() { + createWindow(); + + // TODO remove demo + currentScene = new WorldScene(new Dimension(200, 200), 50); + } + + public void createWindow() { + window = new JFrame(TITLE); + window.setSize(new Dimension(800, 600)); + window.setLocationRelativeTo(null); + window.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); + window.add(this); + } + + /* game logic */ + public void gameLoop() { + + } + + public void gameRender() { + + } + + public void start() { + running = true; + gameOver = false; + + window.setVisible(true); + + while (running) { + gameLoop(); + gameRender(); + repaint(); + + try { + // TODO replace with correct timing + Thread.sleep(20); + } catch (InterruptedException ex) { + // + } + } + } + + /* graphics */ + @Override + public void paintComponent(Graphics g) { + currentScene.render(g); + } + + /* main */ + public static void main(String args[]) { + Subconscious game = new Subconscious(); + game.start(); + } } diff --git a/src/Tile.java b/src/Tile.java index 8624f08..cbdeda4 100644 --- a/src/Tile.java +++ b/src/Tile.java @@ -1,22 +1,15 @@ public class Tile { - public int x; - public int y; - public int len; - public TileType tileType = TileType.GRASS; - public EntityType entityType = EntityType.NULL; - public boolean selected = false; - public boolean attack = false; - public int width; + public enum Type { + GRASS, + }; - public Tile (int row, int col, int window, int width) { - this.width = width; - this.calc(row, col, window); - } + public final int x, y; + public final Type type; - public void calc (int row, int col, int window) { - this.len = (int) (window/(double)this.width); - this.x = col*len; - this.y = row*len; - } + public Tile(Type type, int x, int y) { + this.type = type; + this.x = x; + this.y = y; + } } diff --git a/src/TileType.java b/src/TileType.java deleted file mode 100644 index 82a5b5b..0000000 --- a/src/TileType.java +++ /dev/null @@ -1,3 +0,0 @@ -public enum TileType { - GRASS, ROAD, HOUSE, WATER -} diff --git a/src/WorldScene.java b/src/WorldScene.java new file mode 100644 index 0000000..6dff04a --- /dev/null +++ b/src/WorldScene.java @@ -0,0 +1,32 @@ +import java.awt.Color; +import java.awt.Dimension; +import java.awt.Graphics; +import java.awt.Graphics2D; + + +public class WorldScene extends Scene { + + private Actor actors[]; + private Map map; + + private int tileSize; + + public WorldScene(Dimension gridSize, int tileSize) { + this.tileSize = tileSize; + map = new Map(gridSize); + } + + @Override + public void render(Graphics g) { + Graphics2D g2d = (Graphics2D) g; + + for (Tile tile : this.map.grid) { + g2d.setColor(Color.GREEN); + g2d.fillRect( + this.tileSize * tile.x, + this.tileSize * tile.y, + this.tileSize, this.tileSize + ); + } + } +} |