12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697 |
- package pathgame.rendering;
- import me.hammerle.snuviengine.api.Renderer;
- import me.hammerle.snuviengine.api.Texture;
- import pathgame.gameplay.Player;
- import pathgame.gameplay.PlayerAbilities;
- import pathgame.tilemap.TileMap;
- import pathgame.tilemap.TileRenderType;
- public class PlayerRenderer {
- private static final Texture CHARACTER = new Texture("resources/character.png");
- private static final Texture CHARACTER_HIKER = new Texture("resources/hiker.png");
- private static final Texture CHARACTER_HUNTER = new Texture("resources/hunter.png");
- private static final Texture CHARACTER_SAILOR = new Texture("resources/sailor.png");
- private static final Texture CHARACTER_SWIMMER = new Texture("resources/swimmer.png");
- public void renderTick(TileMap map, TileMapRenderer mapR, Renderer r, Player p, float lag, float offX, float offY) {
- boolean inWater = p.getCurrTile().getRenderType() == TileRenderType.WATER;
- float playerSize = mapR.getScale() * TileRenderer.TILE_SIZE;
- r.setMixColorEnabled(false);
- r.setColorEnabled(false);
- r.setTextureEnabled(true);
- r.translateTo(0.0f, 0.0f);
- r.updateMatrix();
- float yIndex;
- float baseX = (p.getLastX() + (p.getX() - p.getLastX()) * lag);
- float ix = baseX * mapR.getScale() * TileRenderer.TILE_SIZE + offX;
- float baseY = (p.getLastY() + (p.getY() - p.getLastY()) * lag);
- float iy = baseY * mapR.getScale() * TileRenderer.TILE_SIZE + offY;
- baseX = baseX - (int) baseX;
- baseY = baseY - (int) baseY;
- int tIndex = 0;
- float xTexOff = 0;
- float yTexOff = 0;
- bindTexture(p, inWater);
- if(p.getVelX() > 0) {
- yIndex = 2;
- tIndex = checkForAnimationIndex(baseX);
- } else if(p.getVelX() < 0) {
- yIndex = 1;
- tIndex = checkForAnimationIndex(baseX);
- } else if(p.getVelY() > 0) {
- yIndex = 0;
- tIndex = checkForAnimationIndex(baseY);
- } else if(p.getVelY() < 0) {
- yIndex = 3;
- tIndex = checkForAnimationIndex(baseY);
- } else {
- yIndex = p.getFacing().getIndex();
- if(inWater && (p.getTicksLived() % 20) < 10) {
- tIndex = 1;
- }
- }
- if(p.isSailing()) {
- yTexOff = 0.5f;
- } else if(inWater) {
- xTexOff = 0.5f;
- }
- float viewScale = r.getViewScale();
- ix = (int) (ix * viewScale) / viewScale;
- iy = (int) (iy * viewScale) / viewScale;
- r.getTextureRenderer().drawRectangle(ix, iy, ix + playerSize, iy + playerSize,
- tIndex * 0.125f + xTexOff, yIndex * 0.125f + yTexOff,
- (tIndex + 1) * 0.125f + xTexOff, yIndex * 0.125f + 0.125f + yTexOff);
- }
- private int checkForAnimationIndex(float base) {
- return ((int) (base * 4 * 2)) % 4;
- }
- private void bindTexture(Player p, boolean inWater) {
- if(p.isSailing() || inWater || p.getAbilities() == PlayerAbilities.NORMAL) {
- CHARACTER.bind();
- } else if(p.getAbilities() == PlayerAbilities.HIKER) {
- CHARACTER_HIKER.bind();
- } else if(p.getAbilities() == PlayerAbilities.HUNTER) {
- CHARACTER_HUNTER.bind();
- } else if(p.getAbilities() == PlayerAbilities.SAILOR) {
- CHARACTER_SAILOR.bind();
- } else if(p.getAbilities() == PlayerAbilities.SWIMMER) {
- CHARACTER_SWIMMER.bind();
- } else {
- CHARACTER.bind();
- }
- }
- }
|