Changed GameCharacter to include sprites and draw method.
Added ScifiCritters testspirtes.
This commit is contained in:
BIN
core/assets/ScifiCritters4.PNG
Normal file
BIN
core/assets/ScifiCritters4.PNG
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 12 KiB |
Binary file not shown.
|
Before Width: | Height: | Size: 2.0 KiB |
@@ -1,12 +1,10 @@
|
|||||||
package netwerkprog.game.client.game.characters;
|
package netwerkprog.game.client.game.characters;
|
||||||
|
|
||||||
import com.badlogic.gdx.Gdx;
|
import netwerkprog.game.util.game.GameCharacter;
|
||||||
import com.badlogic.gdx.graphics.Texture;
|
|
||||||
import netwerkprog.game.util.game.Character;
|
|
||||||
import netwerkprog.game.util.game.Faction;
|
import netwerkprog.game.util.game.Faction;
|
||||||
|
|
||||||
public class DevTest1 extends Character {
|
public class DevTest1 extends GameCharacter {
|
||||||
public DevTest1() {
|
public DevTest1() {
|
||||||
super("DevTest1", Faction.HACKER, new Texture(Gdx.files.internal("core/assets/george.png")));
|
super("DevTest1", Faction.HACKER, "core/assets/ScifiCritters4.PNG");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,9 +1,9 @@
|
|||||||
package netwerkprog.game.client.game.characters;
|
package netwerkprog.game.client.game.characters;
|
||||||
|
|
||||||
import netwerkprog.game.util.game.Character;
|
import netwerkprog.game.util.game.GameCharacter;
|
||||||
import netwerkprog.game.util.game.Faction;
|
import netwerkprog.game.util.game.Faction;
|
||||||
|
|
||||||
public class DevTest2 extends Character {
|
public class DevTest2 extends GameCharacter {
|
||||||
public DevTest2() {
|
public DevTest2() {
|
||||||
super("DevTest2", Faction.MEGACORPORATION, null);
|
super("DevTest2", Faction.MEGACORPORATION, null);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,9 +1,9 @@
|
|||||||
package netwerkprog.game.client.game.characters;
|
package netwerkprog.game.client.game.characters;
|
||||||
|
|
||||||
import netwerkprog.game.util.game.Character;
|
import netwerkprog.game.util.game.GameCharacter;
|
||||||
import netwerkprog.game.util.game.Faction;
|
import netwerkprog.game.util.game.Faction;
|
||||||
|
|
||||||
public class DevTest3 extends Character {
|
public class DevTest3 extends GameCharacter {
|
||||||
public DevTest3() {
|
public DevTest3() {
|
||||||
super("DevTest3", Faction.AI, null);
|
super("DevTest3", Faction.AI, null);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,30 +1,28 @@
|
|||||||
package netwerkprog.game.util.game;
|
package netwerkprog.game.util.game;
|
||||||
|
|
||||||
import com.badlogic.gdx.graphics.Texture;
|
import com.badlogic.gdx.graphics.Texture;
|
||||||
|
import com.badlogic.gdx.graphics.g2d.SpriteBatch;
|
||||||
import com.badlogic.gdx.graphics.g2d.TextureRegion;
|
import com.badlogic.gdx.graphics.g2d.TextureRegion;
|
||||||
import com.badlogic.gdx.scenes.scene2d.Actor;
|
import com.badlogic.gdx.scenes.scene2d.Actor;
|
||||||
|
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
|
|
||||||
public abstract class Character extends Actor {
|
public abstract class GameCharacter extends Actor {
|
||||||
protected String name;
|
protected String name;
|
||||||
protected Faction faction;
|
protected Faction faction;
|
||||||
protected HashSet<Ability> abilities;
|
protected HashSet<Ability> abilities;
|
||||||
protected TextureRegion[] sprites;
|
protected TextureRegion[][] sprites;
|
||||||
protected boolean override;
|
protected boolean override;
|
||||||
protected int x;
|
|
||||||
protected int y;
|
|
||||||
private final int maxSize = 1;
|
|
||||||
|
|
||||||
|
public GameCharacter(String name, Faction faction, String spriteSheet, Ability... abilities) {
|
||||||
public Character(String name, Faction faction, Texture spriteSheet, Ability... abilities) {
|
|
||||||
this.name = name;
|
this.name = name;
|
||||||
this.faction = faction;
|
this.faction = faction;
|
||||||
this.sprites = new TextureRegion[this.maxSize];
|
|
||||||
this.abilities = new HashSet<>(Arrays.asList(abilities));
|
this.abilities = new HashSet<>(Arrays.asList(abilities));
|
||||||
this.override = false;
|
this.override = false;
|
||||||
loadSprites(spriteSheet);
|
this.sprites = TextureRegion.split(new Texture(spriteSheet),32,32);
|
||||||
|
super.setX(0);
|
||||||
|
super.setY(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void addAbilities(Ability ability) {
|
public void addAbilities(Ability ability) {
|
||||||
@@ -39,17 +37,10 @@ public abstract class Character extends Actor {
|
|||||||
this.override = !this.override;
|
this.override = !this.override;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void loadSprites(Texture spriteSheet) {
|
public void draw(SpriteBatch batch) {
|
||||||
int counter = 0;
|
batch.begin();
|
||||||
TextureRegion[][] temp = TextureRegion.split(spriteSheet,32,32);
|
batch.draw(this.sprites[0][0],super.getX(),super.getY());
|
||||||
for (TextureRegion[] array : temp) {
|
batch.end();
|
||||||
for (TextureRegion sprite : array) {
|
|
||||||
this.sprites[counter] = sprite;
|
|
||||||
counter++;
|
|
||||||
if (counter >= this.maxSize) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -1,15 +0,0 @@
|
|||||||
import com.badlogic.gdx.Gdx;
|
|
||||||
import com.badlogic.gdx.graphics.Texture;
|
|
||||||
import netwerkprog.game.client.game.characters.DevTest1;
|
|
||||||
import netwerkprog.game.util.game.Character;
|
|
||||||
import org.junit.Test;
|
|
||||||
|
|
||||||
public class CharacterLoadingTest {
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void george() {
|
|
||||||
String path = "core/assets/george.png";
|
|
||||||
Texture texture = new Texture(Gdx.files.internal(path));
|
|
||||||
Character george = new DevTest1();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Reference in New Issue
Block a user