feat: reinplémentation de touchmaptiles avec des inputprocessors et gesturedetector.
This commit is contained in:
parent
26698bd7ca
commit
ad84ac96ed
|
@ -5,8 +5,10 @@ import java.util.Arrays;
|
|||
|
||||
import com.badlogic.gdx.Game;
|
||||
import com.badlogic.gdx.Gdx;
|
||||
import com.badlogic.gdx.InputProcessor;
|
||||
import com.badlogic.gdx.graphics.OrthographicCamera;
|
||||
import com.badlogic.gdx.graphics.g2d.Batch;
|
||||
import com.badlogic.gdx.input.GestureDetector.GestureListener;
|
||||
import com.badlogic.gdx.maps.MapLayers;
|
||||
import com.badlogic.gdx.maps.tiled.TiledMap;
|
||||
import com.badlogic.gdx.maps.tiled.TiledMapTileLayer;
|
||||
|
@ -25,7 +27,7 @@ import fr.evolving.assets.AssetLoader;
|
|||
import fr.evolving.automata.Level;
|
||||
import fr.evolving.screens.GameScreen.calling;
|
||||
|
||||
public class TouchMaptiles extends Actor {
|
||||
public class TouchMaptiles extends Actor implements GestureListener,InputProcessor {
|
||||
|
||||
private TiledMap map;
|
||||
private OrthogonalTiledMapRenderer MapRenderer;
|
||||
|
@ -35,11 +37,13 @@ public class TouchMaptiles extends Actor {
|
|||
private int sizey;
|
||||
private float viewwidth, viewheight, decx, decy;
|
||||
private String selected;
|
||||
private boolean mapexit;
|
||||
|
||||
public TouchMaptiles(Level level, int sizex, int sizey) {
|
||||
this.level = level;
|
||||
this.sizex = sizex;
|
||||
this.sizey = sizey;
|
||||
this.mapexit=false;
|
||||
map = new TiledMap();
|
||||
map.getTileSets().addTileSet(AssetLoader.tileSet);
|
||||
MapLayers layers = map.getLayers();
|
||||
|
@ -60,85 +64,17 @@ public class TouchMaptiles extends Actor {
|
|||
MapRenderer = new OrthogonalTiledMapRenderer(map, 1 / 128.0f);
|
||||
camera = new OrthographicCamera();
|
||||
initzoom();
|
||||
this.addListener(new ActorGestureListener() {
|
||||
@Override
|
||||
public void zoom(InputEvent event, float initialDistance,
|
||||
float distance) {
|
||||
String[] exec = { "zoomp", "zoomm" };
|
||||
int zooming = (int) (distance / initialDistance * 1000f);
|
||||
event_coordination(0, 0, zooming, calling.zoom, exec);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void pinch(InputEvent event, Vector2 initialPointer1,
|
||||
Vector2 initialPointer2, Vector2 pointer1, Vector2 pointer2) {
|
||||
float deltaX = pointer2.x - pointer1.x;
|
||||
float deltaY = pointer2.y - pointer1.y;
|
||||
int angle = (int) ((float) Math.atan2((double) deltaY,
|
||||
(double) deltaX) * MathUtils.radiansToDegrees);
|
||||
angle += 90;
|
||||
if (angle < 0)
|
||||
angle = 360 - (-angle);
|
||||
String[] exec = { "transmuter" };
|
||||
event_coordination(initialPointer1.x, initialPointer1.y, angle,
|
||||
calling.pinch, exec);
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean longPress(Actor actor, float x, float y) {
|
||||
String[] exec = { "transmuter" };
|
||||
return event_coordination(x, y, 0, calling.longpress, exec);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void tap(InputEvent event, float x, float y, int count,
|
||||
int button) {
|
||||
String[] exec = { "transmuter" };
|
||||
if (count == 1)
|
||||
event_coordination(x, y, button, calling.tap, exec);
|
||||
else if (count >= 2)
|
||||
event_coordination(x, y, button, calling.taptap, exec);
|
||||
}
|
||||
});
|
||||
this.addListener(new InputListener() {
|
||||
@Override
|
||||
public boolean mouseMoved(InputEvent event, float x, float y) {
|
||||
String[] exec = { "transmuter" };
|
||||
return event_coordination(x, y, 0, calling.mouseover, exec);
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean touchDown(InputEvent event, float x, float y,
|
||||
int pointer, int button) {
|
||||
//oldx = 0;
|
||||
//oldy = 0;
|
||||
String[] exec = { "cleaner", "infos", "zoomp", "zoomm",
|
||||
"copper_pen", "fiber_pen", "copper_eraser",
|
||||
"fiber_eraser", "transmuter_eraser", "all_eraser",
|
||||
"blank", "transmuter", "copper_brush", "fiber_brush" };
|
||||
return event_coordination(x, y, button, calling.mouseclick,
|
||||
exec);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void touchDragged(InputEvent event, float x, float y,
|
||||
int pointer) {
|
||||
String[] exec = { "transmuter", "move", "copper_brush",
|
||||
"fiber_brush", "copper_eraser", "fiber_eraser",
|
||||
"transmuter_eraser", "all_eraser", "blank" };
|
||||
event_coordination(x, y, 0, calling.mousedrag, exec);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
boolean event_coordination(float x, float y, int button, calling call,
|
||||
String[] exec) {
|
||||
Gdx.app.debug("menu", "xy"+x+","+y);
|
||||
if (selected != null) {
|
||||
if (Arrays.asList(exec).contains(selected)) {
|
||||
Vector2 coords = this.screentoworld(x, y);
|
||||
Vector3 coordsscreen = new Vector3();
|
||||
AssetLoader.Camera.unproject(coordsscreen.set(x, y, 0));
|
||||
Vector2 coords = this.screentoworld(coordsscreen.x, coordsscreen.y);
|
||||
if (level.Grid.GetXY(coords.x, coords.y) != null) {
|
||||
//mapexit = false;
|
||||
mapexit = false;
|
||||
if (call != calling.mouseover)
|
||||
Gdx.app.debug("evenement", "mode:" + call + " outil:"
|
||||
+ selected + " X: " + coords.x
|
||||
|
@ -148,17 +84,17 @@ public class TouchMaptiles extends Actor {
|
|||
Class<?> base = Class.forName("fr.evolving.screens.GameScreen");
|
||||
Class<?>[] params = { float.class, float.class, int.class, int.class, boolean.class, int.class, calling.class };
|
||||
method = base.getDeclaredMethod("map_" + selected, params);
|
||||
method.invoke(((Game) Gdx.app.getApplicationListener()).getScreen(), (float) x, (float) y,(int) coords.x, (int) coords.y, true,(int) button, (calling) call);
|
||||
method.invoke(((Game) Gdx.app.getApplicationListener()).getScreen(), (float) coordsscreen.x, (float) coordsscreen.y,(int) coords.x, (int) coords.y, true,(int) button, (calling) call);
|
||||
} catch (Exception e) {
|
||||
// TODO Auto-generated catch block
|
||||
e.printStackTrace();
|
||||
}
|
||||
} /*else {
|
||||
} else {
|
||||
if (mapexit == false) {
|
||||
mapexit = true;
|
||||
map.tempclear();
|
||||
this.tempclear();
|
||||
}
|
||||
}*/
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
@ -272,8 +208,7 @@ public class TouchMaptiles extends Actor {
|
|||
camera.setToOrtho(false, viewwidth, viewheight);
|
||||
decx = (level.Grid.sizeX - viewwidth) / 2.0f;
|
||||
decy = (level.Grid.sizeY - viewheight) / 2.0f;
|
||||
Gdx.app.debug(getClass().getSimpleName(), "Décalage:" + decx + "x"
|
||||
+ decy);
|
||||
Gdx.app.debug(getClass().getSimpleName(), "Décalage:" + decx + "x" + decy);
|
||||
camera.translate(decx, decy);
|
||||
}
|
||||
|
||||
|
@ -319,12 +254,125 @@ public class TouchMaptiles extends Actor {
|
|||
@Override
|
||||
public void draw(Batch batch, float parentAlpha) {
|
||||
batch.end();
|
||||
// batch.setProjectionMatrix(camera.combined);
|
||||
camera.update();
|
||||
MapRenderer.setView(camera);
|
||||
// MapRenderer.setView(camera.combined,0,0,maxx,maxx);
|
||||
MapRenderer.render();
|
||||
batch.begin();
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean touchDown(float x, float y, int pointer, int button) {
|
||||
String[] exec = { "cleaner", "infos", "zoomp", "zoomm",
|
||||
"copper_pen", "fiber_pen", "copper_eraser",
|
||||
"fiber_eraser", "transmuter_eraser", "all_eraser",
|
||||
"blank", "transmuter", "copper_brush", "fiber_brush" };
|
||||
return event_coordination(x, y, button, calling.mouseclick,
|
||||
exec);
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean tap(float x, float y, int count, int button) {
|
||||
String[] exec = { "transmuter" };
|
||||
if (count == 1)
|
||||
event_coordination(x, y, button, calling.tap, exec);
|
||||
else if (count >= 2)
|
||||
event_coordination(x, y, button, calling.taptap, exec);
|
||||
return false;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean longPress(float x, float y) {
|
||||
String[] exec = { "transmuter" };
|
||||
return event_coordination(x, y, 0, calling.longpress, exec);
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean fling(float velocityX, float velocityY, int button) {
|
||||
// TODO Auto-generated method stub
|
||||
return false;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean pan(float x, float y, float deltaX, float deltaY) {
|
||||
// TODO Auto-generated method stub
|
||||
return false;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean panStop(float x, float y, int pointer, int button) {
|
||||
// TODO Auto-generated method stub
|
||||
return false;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean zoom(float initialDistance, float distance) {
|
||||
String[] exec = { "zoomp", "zoomm" };
|
||||
int zooming = (int) (distance / initialDistance * 1000f);
|
||||
return event_coordination(0, 0, zooming, calling.zoom, exec);
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean pinch(Vector2 initialPointer1, Vector2 initialPointer2,
|
||||
Vector2 pointer1, Vector2 pointer2) {
|
||||
float deltaX = pointer2.x - pointer1.x;
|
||||
float deltaY = pointer2.y - pointer1.y;
|
||||
int angle = (int) ((float) Math.atan2((double) deltaY,
|
||||
(double) deltaX) * MathUtils.radiansToDegrees);
|
||||
angle += 90;
|
||||
if (angle < 0)
|
||||
angle = 360 - (-angle);
|
||||
String[] exec = { "transmuter" };
|
||||
return event_coordination(initialPointer1.x, initialPointer1.y, angle, calling.pinch, exec);
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean keyDown(int keycode) {
|
||||
// TODO Auto-generated method stub
|
||||
return false;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean keyUp(int keycode) {
|
||||
// TODO Auto-generated method stub
|
||||
return false;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean keyTyped(char character) {
|
||||
// TODO Auto-generated method stub
|
||||
return false;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean touchDown(int screenX, int screenY, int pointer, int button) {
|
||||
// TODO Auto-generated method stub
|
||||
return false;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean touchUp(int screenX, int screenY, int pointer, int button) {
|
||||
// TODO Auto-generated method stub
|
||||
return false;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean touchDragged(int screenX, int screenY, int pointer) {
|
||||
String[] exec = { "transmuter", "move", "copper_brush",
|
||||
"fiber_brush", "copper_eraser", "fiber_eraser",
|
||||
"transmuter_eraser", "all_eraser", "blank" };
|
||||
return event_coordination(screenX, screenY, 0, calling.mousedrag, exec);
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean mouseMoved(int screenX, int screenY) {
|
||||
String[] exec = { "transmuter" };
|
||||
return event_coordination(screenX, screenY, 0, calling.mouseover, exec);
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean scrolled(int amount) {
|
||||
// TODO Auto-generated method stub
|
||||
return false;
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -27,6 +27,9 @@ public class GameRenderer {
|
|||
if (layer == 0) {
|
||||
Gdx.gl.glClearColor(0, 0, 0, 1);
|
||||
Gdx.gl.glClear(GL20.GL_COLOR_BUFFER_BIT);
|
||||
batcher.begin();
|
||||
GameScreen.map.draw(batcher, 1f);
|
||||
batcher.end();
|
||||
} else if (layer == 1) {
|
||||
batcher.begin();
|
||||
batcher.setColor(0.25f, 0.25f, 0.25f, 1f);
|
||||
|
|
|
@ -18,6 +18,7 @@ import com.badlogic.gdx.graphics.Color;
|
|||
import com.badlogic.gdx.graphics.Texture.TextureFilter;
|
||||
import com.badlogic.gdx.graphics.g2d.TextureRegion;
|
||||
import com.badlogic.gdx.input.GestureDetector;
|
||||
import com.badlogic.gdx.input.GestureDetector.GestureListener;
|
||||
import com.badlogic.gdx.maps.MapProperties;
|
||||
import com.badlogic.gdx.math.MathUtils;
|
||||
import com.badlogic.gdx.math.Vector2;
|
||||
|
@ -71,7 +72,7 @@ public class GameScreen implements Screen {
|
|||
private InputMultiplexer multiplexer;
|
||||
private Array<InputProcessor> processors;
|
||||
private WarnDialog dialog;
|
||||
private Stage stage, stage_map, stage_info, stage_tooltip;
|
||||
private Stage stage, stage_info, stage_tooltip;
|
||||
private VerticalGroup table2;
|
||||
private GameRenderer Renderer;
|
||||
private float runTime;
|
||||
|
@ -97,7 +98,7 @@ public class GameScreen implements Screen {
|
|||
"separator", "stat" };
|
||||
private ButtonLevel buttonlevel;
|
||||
private Objectives objectives;
|
||||
private TouchMaptiles map;
|
||||
public TouchMaptiles map;
|
||||
private Menu menu;
|
||||
private HorizBarre horizbar;
|
||||
private float oldx, oldy;
|
||||
|
@ -220,6 +221,7 @@ public class GameScreen implements Screen {
|
|||
@Override
|
||||
public void changed(ChangeEvent event, Actor actor) {
|
||||
Gdx.app.debug("Barre", "Element changé");
|
||||
hideInfo();
|
||||
map.tempclear();
|
||||
map.fillempty(60);
|
||||
menu.unSelect();
|
||||
|
@ -238,9 +240,8 @@ public class GameScreen implements Screen {
|
|||
multiplexer = new InputMultiplexer();
|
||||
processors = new Array<InputProcessor>();
|
||||
stage = new Stage(AssetLoader.viewport);
|
||||
stage_map = new Stage(AssetLoader.viewport);
|
||||
stage_info = new Stage(AssetLoader.viewport);
|
||||
stage_tooltip = new Stage(AssetLoader.viewport);
|
||||
//stage_tooltip = new Stage(AssetLoader.viewport);
|
||||
oldx = 0;
|
||||
oldy = 0;
|
||||
unroll = false;
|
||||
|
@ -418,6 +419,7 @@ public class GameScreen implements Screen {
|
|||
@Override
|
||||
public void changed(ChangeEvent event, Actor actor) {
|
||||
Gdx.app.debug("Menu", "Element changé");
|
||||
hideInfo();
|
||||
map.tempclear();
|
||||
map.fillempty(60);
|
||||
if (menu.getTransmuter() != null)
|
||||
|
@ -673,13 +675,12 @@ public class GameScreen implements Screen {
|
|||
if (Preference.prefs.getBoolean("Refresh"))
|
||||
fpsLabel.setText(Gdx.graphics.getFramesPerSecond() + "FPS");
|
||||
Renderer.render(delta, runTime, 0);
|
||||
stage_map.draw();
|
||||
Renderer.render(delta, runTime, 1);
|
||||
stage.draw();
|
||||
if (unroll)
|
||||
stage_info.draw();
|
||||
Renderer.render(delta, runTime, 2);
|
||||
stage_tooltip.draw();
|
||||
//stage_tooltip.draw();
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -713,7 +714,6 @@ public class GameScreen implements Screen {
|
|||
stage_info.addActor(info_cout);
|
||||
stage_info.addActor(info_up);
|
||||
stage_info.addActor(info_desc);
|
||||
stage_map.addActor(map);
|
||||
//stage_tooltip.addActor(tooltip);
|
||||
stage.addActor(horizbar);
|
||||
stage.addActor(nextpage);
|
||||
|
@ -731,12 +731,13 @@ public class GameScreen implements Screen {
|
|||
stage.addActor(cout);
|
||||
stage.addActor(research);
|
||||
stage.addActor(menu);
|
||||
//gesturedetector=new GestureDetector(null);
|
||||
//processors.add(gesturedetector);
|
||||
gesturedetector=new GestureDetector(map);
|
||||
|
||||
//processors.add(stage_tooltip);
|
||||
processors.add(stage_info);
|
||||
processors.add(stage);
|
||||
processors.add(stage_map);
|
||||
processors.add(map);
|
||||
processors.add(gesturedetector);
|
||||
multiplexer.setProcessors(processors);
|
||||
Gdx.input.setInputProcessor(multiplexer);
|
||||
preparemenu(0);
|
||||
|
|
Loading…
Reference in New Issue