mirror of
https://github.com/Klagarge/PokeHES.git
synced 2024-11-30 04:33:27 +00:00
commit
5573b545e0
2
.gitignore
vendored
2
.gitignore
vendored
@ -6,3 +6,5 @@ build
|
|||||||
|
|
||||||
# Ignore bin
|
# Ignore bin
|
||||||
bin/
|
bin/
|
||||||
|
*.tiled-session
|
||||||
|
resources/map/Maps.tiled-session
|
||||||
|
BIN
resources/Base.png
Normal file
BIN
resources/Base.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 1.0 KiB |
BIN
resources/Character.png
Normal file
BIN
resources/Character.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 1.5 KiB |
@ -12,6 +12,8 @@ public class Enemy extends Character{
|
|||||||
|
|
||||||
public Enemy(String name, int x, int y, String img) {
|
public Enemy(String name, int x, int y, String img) {
|
||||||
super(name, x, y, img);
|
super(name, x, y, img);
|
||||||
|
|
||||||
|
turn(Character.Direction.DOWN);
|
||||||
//generate the vector of fight
|
//generate the vector of fight
|
||||||
fightData = new FightData(name);
|
fightData = new FightData(name);
|
||||||
//TODO Auto-generated constructor stub
|
//TODO Auto-generated constructor stub
|
||||||
@ -32,10 +34,4 @@ public class Enemy extends Character{
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public void draw(GdxGraphics arg0) {
|
|
||||||
// TODO Auto-generated method stub
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -36,7 +36,6 @@ public abstract class Entity implements DrawableObject {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void init(){
|
public void init(){
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void graphicRender(GdxGraphics g){
|
public void graphicRender(GdxGraphics g){
|
||||||
|
@ -14,7 +14,7 @@ public class Player extends Character{
|
|||||||
private int xp;
|
private int xp;
|
||||||
|
|
||||||
public Player(int x, int y) {
|
public Player(int x, int y) {
|
||||||
super("Player", x, y, "lumberjack_sheet32");
|
super("Player", x, y, "Character");
|
||||||
}
|
}
|
||||||
|
|
||||||
public void addXp(int xp){
|
public void addXp(int xp){
|
||||||
@ -46,10 +46,14 @@ public class Player extends Character{
|
|||||||
|
|
||||||
// Is the move valid ?
|
// Is the move valid ?
|
||||||
if (sm.isWalkable(nextCell)) {
|
if (sm.isWalkable(nextCell)) {
|
||||||
|
if(!enemy()){
|
||||||
// Go
|
// Go
|
||||||
setSpeed(sm.getSpeed(nextCell));
|
setSpeed(sm.getSpeed(nextCell));
|
||||||
go(goalDirection);
|
go(goalDirection);
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
|
}
|
||||||
|
} else {
|
||||||
// Face the wall
|
// Face the wall
|
||||||
turn(goalDirection);
|
turn(goalDirection);
|
||||||
}
|
}
|
||||||
@ -73,6 +77,16 @@ public class Player extends Character{
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private boolean enemy() {
|
||||||
|
/*
|
||||||
|
Vector<Entity> entities = testHER.getEntities;
|
||||||
|
for (Entity entity : entities) {
|
||||||
|
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
public void move(int x, int y){
|
public void move(int x, int y){
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1,189 +0,0 @@
|
|||||||
package Screen;
|
|
||||||
|
|
||||||
import ch.hevs.gdx2d.components.bitmaps.Spritesheet;
|
|
||||||
import ch.hevs.gdx2d.lib.GdxGraphics;
|
|
||||||
import ch.hevs.gdx2d.lib.interfaces.DrawableObject;
|
|
||||||
import com.badlogic.gdx.math.Interpolation;
|
|
||||||
import com.badlogic.gdx.math.Vector2;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Character for the demo.
|
|
||||||
*
|
|
||||||
* @author Alain Woeffray (woa)
|
|
||||||
* @author Pierre-André Mudry (mui)
|
|
||||||
*/
|
|
||||||
public class Hero implements DrawableObject {
|
|
||||||
|
|
||||||
public enum Direction{
|
|
||||||
UP,
|
|
||||||
DOWN,
|
|
||||||
RIGHT,
|
|
||||||
LEFT,
|
|
||||||
NULL
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The currently selected sprite for animation
|
|
||||||
*/
|
|
||||||
int textureX = 0;
|
|
||||||
int textureY = 1;
|
|
||||||
float speed = 1;
|
|
||||||
|
|
||||||
float dt = 0;
|
|
||||||
int currentFrame = 0;
|
|
||||||
int nFrames = 4;
|
|
||||||
private final static int SPRITE_WIDTH = 32;
|
|
||||||
private final static int SPRITE_HEIGHT = 32;
|
|
||||||
final float FRAME_TIME = 0.1f; // Duration of each frime
|
|
||||||
Spritesheet ss;
|
|
||||||
|
|
||||||
Vector2 lastPosition;
|
|
||||||
Vector2 newPosition;
|
|
||||||
Vector2 position;
|
|
||||||
|
|
||||||
|
|
||||||
private boolean move = false;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Create the hero at the start position (0,0)
|
|
||||||
*/
|
|
||||||
public Hero(){
|
|
||||||
this(new Vector2(0,0));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Create the hero at the given start tile.
|
|
||||||
* @param x Column
|
|
||||||
* @param y Line
|
|
||||||
*/
|
|
||||||
public Hero(int x, int y){
|
|
||||||
this(new Vector2(SPRITE_WIDTH * x, SPRITE_HEIGHT * y));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Create the hero at the start position
|
|
||||||
* @param initialPosition Start position [px] on the map.
|
|
||||||
*/
|
|
||||||
public Hero(Vector2 initialPosition) {
|
|
||||||
|
|
||||||
lastPosition = new Vector2(initialPosition);
|
|
||||||
newPosition = new Vector2(initialPosition);
|
|
||||||
position = new Vector2(initialPosition);
|
|
||||||
|
|
||||||
ss = new Spritesheet("./resources/lumberjack_sheet32.png", SPRITE_WIDTH, SPRITE_HEIGHT);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @return the current position of the hero on the map.
|
|
||||||
*/
|
|
||||||
public Vector2 getPosition(){
|
|
||||||
return this.position;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setPosition(int x, int y){
|
|
||||||
lastPosition.set(x, y);
|
|
||||||
newPosition.set(x, y);
|
|
||||||
position.set(x, y);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Update the position and the texture of the hero.
|
|
||||||
* @param elapsedTime The time [s] elapsed since the last time which this method was called.
|
|
||||||
*/
|
|
||||||
public void animate(double elapsedTime) {
|
|
||||||
float frameTime = FRAME_TIME / speed;
|
|
||||||
|
|
||||||
position = new Vector2(lastPosition);
|
|
||||||
if(isMoving()) {
|
|
||||||
dt += elapsedTime;
|
|
||||||
float alpha = (dt+frameTime*currentFrame)/(frameTime*nFrames);
|
|
||||||
|
|
||||||
position.interpolate(newPosition, alpha,Interpolation.linear);
|
|
||||||
}else{
|
|
||||||
dt = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (dt > frameTime) {
|
|
||||||
dt -= frameTime;
|
|
||||||
currentFrame = (currentFrame + 1) % nFrames;
|
|
||||||
|
|
||||||
if(currentFrame == 0){
|
|
||||||
move = false;
|
|
||||||
lastPosition = new Vector2(newPosition);
|
|
||||||
position = new Vector2(newPosition);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @return True if the hero is actually doing a step.
|
|
||||||
*/
|
|
||||||
public boolean isMoving(){
|
|
||||||
return move;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param speed The new speed of the hero.
|
|
||||||
*/
|
|
||||||
public void setSpeed(float speed){
|
|
||||||
this.speed = speed;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Do a step on the given direction
|
|
||||||
* @param direction The direction to go.
|
|
||||||
*/
|
|
||||||
public void go(Direction direction){
|
|
||||||
move = true;
|
|
||||||
switch(direction){
|
|
||||||
case RIGHT:
|
|
||||||
newPosition.add(SPRITE_WIDTH, 0);
|
|
||||||
break;
|
|
||||||
case LEFT:
|
|
||||||
newPosition.add(-SPRITE_WIDTH, 0);
|
|
||||||
break;
|
|
||||||
case UP:
|
|
||||||
newPosition.add(0, SPRITE_HEIGHT);
|
|
||||||
break;
|
|
||||||
case DOWN:
|
|
||||||
newPosition.add(0, -SPRITE_HEIGHT);
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
turn(direction);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Turn the hero on the given direction without do any step.
|
|
||||||
* @param direction The direction to turn.
|
|
||||||
*/
|
|
||||||
public void turn(Direction direction){
|
|
||||||
switch(direction){
|
|
||||||
case RIGHT:
|
|
||||||
textureY = 2;
|
|
||||||
break;
|
|
||||||
case LEFT:
|
|
||||||
textureY = 1;
|
|
||||||
break;
|
|
||||||
case UP:
|
|
||||||
textureY = 3;
|
|
||||||
break;
|
|
||||||
case DOWN:
|
|
||||||
textureY = 0;
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Draw the character on the graphic object.
|
|
||||||
* @param g Graphic object.
|
|
||||||
*/
|
|
||||||
public void draw(GdxGraphics g) {
|
|
||||||
g.draw(ss.sprites[textureY][currentFrame], position.x, position.y);
|
|
||||||
}
|
|
||||||
}
|
|
@ -35,6 +35,7 @@ public class ScreenMap extends RenderingScreen{
|
|||||||
public int tileHeight;
|
public int tileHeight;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
private void createMap(String name){
|
private void createMap(String name){
|
||||||
TiledMap tm =new TmxMapLoader().load("./resources/map/"+ name + ".tmx");
|
TiledMap tm =new TmxMapLoader().load("./resources/map/"+ name + ".tmx");
|
||||||
tMap.put(name,tm);
|
tMap.put(name,tm);
|
||||||
|
@ -1,6 +1,9 @@
|
|||||||
|
import java.util.Vector;
|
||||||
|
|
||||||
import com.badlogic.gdx.Input;
|
import com.badlogic.gdx.Input;
|
||||||
|
|
||||||
import Control.Controller;
|
import Control.Controller;
|
||||||
|
import Entity.Enemy;
|
||||||
import Entity.Entity;
|
import Entity.Entity;
|
||||||
import Entity.Player;
|
import Entity.Player;
|
||||||
import Screen.ScreenMap;
|
import Screen.ScreenMap;
|
||||||
@ -13,15 +16,19 @@ public class testHER extends PortableApplication{
|
|||||||
private Controller controller;
|
private Controller controller;
|
||||||
private ScreenMap sm;
|
private ScreenMap sm;
|
||||||
private Player p1;
|
private Player p1;
|
||||||
private static Entity[] entities;
|
private static Vector<Entity> entities = new Vector<>();
|
||||||
|
private static Vector<Player> players = new Vector<>();
|
||||||
|
|
||||||
|
|
||||||
public testHER(){
|
public testHER(){
|
||||||
controller = new Controller();
|
controller = new Controller();
|
||||||
p1 = new Player(8, 15);
|
|
||||||
sm = new ScreenMap();
|
sm = new ScreenMap();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static Vector<Entity> getEntities() {
|
||||||
|
return entities;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
public static void main(String[] args) {
|
public static void main(String[] args) {
|
||||||
@ -32,15 +39,25 @@ public class testHER extends PortableApplication{
|
|||||||
public void onInit() {
|
public void onInit() {
|
||||||
controller.init();
|
controller.init();
|
||||||
sm.init();
|
sm.init();
|
||||||
p1.init();
|
p1 = new Player(8, 15);
|
||||||
|
entities.add((Entity) p1);
|
||||||
|
entities.add(new Enemy("Mudry", 10, 15, "lumberjack_sheet32"));
|
||||||
|
entities.add(new Enemy("Pignat", 12, 15, "lumberjack_sheet32"));
|
||||||
|
|
||||||
|
for (Entity entity : entities) {
|
||||||
|
entity.init();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onGraphicRender(GdxGraphics g) {
|
public void onGraphicRender(GdxGraphics g) {
|
||||||
g.clear();
|
g.clear();
|
||||||
p1.manageEntity(sm, controller);
|
p1.manageEntity(sm, controller);
|
||||||
sm.graphicRender(g, p1); // load p1 by Entity[]
|
sm.graphicRender(g, p1);
|
||||||
p1.graphicRender(g);
|
|
||||||
|
for (Entity entity : entities) {
|
||||||
|
entity.graphicRender(g);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
Loading…
Reference in New Issue
Block a user