feat: mise en place du mode "play" ou simulation pour les photons

This commit is contained in:
Nicolas Hordé 2016-08-24 23:23:09 +02:00
parent 321ee560b2
commit 2b430d4bbf
6 changed files with 322 additions and 65 deletions

View File

@ -6,6 +6,7 @@ import java.util.Arrays;
import com.badlogic.gdx.Game; import com.badlogic.gdx.Game;
import com.badlogic.gdx.Gdx; import com.badlogic.gdx.Gdx;
import com.badlogic.gdx.InputProcessor; import com.badlogic.gdx.InputProcessor;
import com.badlogic.gdx.graphics.Color;
import com.badlogic.gdx.graphics.OrthographicCamera; import com.badlogic.gdx.graphics.OrthographicCamera;
import com.badlogic.gdx.graphics.g2d.Batch; import com.badlogic.gdx.graphics.g2d.Batch;
import com.badlogic.gdx.input.GestureDetector.GestureListener; import com.badlogic.gdx.input.GestureDetector.GestureListener;
@ -27,6 +28,7 @@ import com.badlogic.gdx.scenes.scene2d.utils.ActorGestureListener;
import fr.evolving.assets.AssetLoader; import fr.evolving.assets.AssetLoader;
import fr.evolving.automata.Level; import fr.evolving.automata.Level;
import fr.evolving.automata.Worlds; import fr.evolving.automata.Worlds;
import fr.evolving.automata.Worlds.State;
import fr.evolving.screens.GameScreen.calling; import fr.evolving.screens.GameScreen.calling;
public class TouchMaptiles extends Actor implements GestureListener,InputProcessor { public class TouchMaptiles extends Actor implements GestureListener,InputProcessor {
@ -169,9 +171,20 @@ public class TouchMaptiles extends Actor implements GestureListener,InputProcess
// 4 Surtile Fond du transmuteur | Effets // 4 Surtile Fond du transmuteur | Effets
// 5 Verrouillage | Jauge activation // 5 Verrouillage | Jauge activation
// 6 Gratuité // 6 Gratuité
// 7 Direction du centre
public void redraw() { public void redraw() {
for (int x = 0; x < level.Grid.sizeX; x++) for (int x = 0; x < level.Grid.sizeX; x++)
for (int y = 0; y < level.Grid.sizeY; y++) { for (int y = 0; y < level.Grid.sizeY; y++) {
if (worlds.getState()==State.simulating) {
if (level.Grid.GetXY(x,y).Fiber)
if (level.Grid.GetXY(x,y).Fiber_state==0)
((TiledMapTileLayer) map.getLayers().get(0)).getCell((int) x,(int) y).setTile(AssetLoader.tileSet.getTile(61));
else {
((TiledMapTileLayer) map.getLayers().get(0)).getCell((int) x,(int) y).setTile(AssetLoader.tileSet.getTile(90+level.Grid.GetXY(x,y).Fiber_state));
}
}
else
{
if (worlds.isDebug()) { if (worlds.isDebug()) {
if (level.Grid.GetXY(x,y).Locked) if (level.Grid.GetXY(x,y).Locked)
((TiledMapTileLayer) map.getLayers().get(5)).getCell((int) x,(int) y).setTile(AssetLoader.tileSet.getTile(90)); ((TiledMapTileLayer) map.getLayers().get(5)).getCell((int) x,(int) y).setTile(AssetLoader.tileSet.getTile(90));
@ -198,12 +211,12 @@ public class TouchMaptiles extends Actor implements GestureListener,InputProcess
} }
else else
((TiledMapTileLayer) map.getLayers().get(2)).getCell((int) x,(int) y).setTile(null); ((TiledMapTileLayer) map.getLayers().get(2)).getCell((int) x,(int) y).setTile(null);
;
}
((TiledMapTileLayer) map.getLayers().get(0)).getCell((int) 0, (int) 0).setTile(AssetLoader.tileSet.getTile(1010)); ((TiledMapTileLayer) map.getLayers().get(0)).getCell((int) 0, (int) 0).setTile(AssetLoader.tileSet.getTile(1010));
((TiledMapTileLayer) map.getLayers().get(0)).getCell((int) 1, (int) 0).setTile(AssetLoader.tileSet.getTile(1010)); ((TiledMapTileLayer) map.getLayers().get(0)).getCell((int) 1, (int) 0).setTile(AssetLoader.tileSet.getTile(1010));
((TiledMapTileLayer) map.getLayers().get(0)).getCell((int) 2, (int) 0).setTile(AssetLoader.tileSet.getTile(1010)); ((TiledMapTileLayer) map.getLayers().get(0)).getCell((int) 2, (int) 0).setTile(AssetLoader.tileSet.getTile(1010));
} }
}
}
public void initzoom() { public void initzoom() {
if ((level.Grid.sizeX / (float) level.Grid.sizeY) > (this.getWidth() / this.getHeight())) { if ((level.Grid.sizeX / (float) level.Grid.sizeY) > (this.getWidth() / this.getHeight())) {

View File

@ -3,19 +3,20 @@ package fr.evolving.automata;
import java.io.Serializable; import java.io.Serializable;
public class Cell implements Serializable,Cloneable { public class Cell implements Serializable,Cloneable {
public int Fiber; public boolean Fiber;
public boolean Copper; public boolean Copper;
public Transmuter Transmuter; public Transmuter Transmuter;
public boolean Locked; public boolean Locked;
public boolean Free; public boolean Free;
public transient int Fiber_state;
public transient int Copper_calc; public transient int Copper_calc;
public transient int Transmuter_calc; public transient int Transmuter_calc;
public transient int Transmuter_movex; public transient int Transmuter_movex;
public transient int Transmuter_movey; public transient int Transmuter_movey;
public Cell() { public Cell() {
this.Fiber = 0; this.Fiber = false;
this.Copper = false; this.Copper = false;
this.Locked = false; this.Locked = false;
this.Free = false; this.Free = false;

View File

@ -8,6 +8,9 @@ import com.badlogic.gdx.math.Vector2;
import com.badlogic.gdx.utils.Array; import com.badlogic.gdx.utils.Array;
import com.badlogic.gdx.utils.ObjectMap.Entry; import com.badlogic.gdx.utils.ObjectMap.Entry;
import fr.evolving.automata.Particle.Orientation;
import fr.evolving.automata.Particle.Type;
public class Grid implements Serializable,Cloneable { public class Grid implements Serializable,Cloneable {
protected Cell[][] Cells; protected Cell[][] Cells;
public Integer sizeX, sizeY; public Integer sizeX, sizeY;
@ -15,7 +18,7 @@ public class Grid implements Serializable,Cloneable {
public transient Array<Particle> particles; public transient Array<Particle> particles;
public Grid(Integer X, Integer Y) { public Grid(Integer X, Integer Y) {
particles=new Array<Particle>(); Reinit();
this.sizeX = X; this.sizeX = X;
this.sizeY = Y; this.sizeY = Y;
this.Cells = new Cell[this.sizeX][this.sizeY]; this.Cells = new Cell[this.sizeX][this.sizeY];
@ -26,21 +29,48 @@ public class Grid implements Serializable,Cloneable {
} }
} }
public void Reinit() {
if (particles==null)
particles=new Array<Particle>();
}
//Réalise un cycle de simulation dans la grille //Réalise un cycle de simulation dans la grille
public void Cycle() { public void Cycle() {
for(Particle particle: particles) {
Gdx.app.debug("wirechem-Grid", "Grid Cycle -> Particle "+particle.getType()+"/"+particle.getSize()+ " coords:"+particle.getCoordx()+","+particle.getCoordy()+"/"+particle.getOrientation()+" charge:"+particle.getCharge());
if (particle.getType()==Type.Photon) {
particle.Next();
if (!particle.isAlive()) {
Gdx.app.debug("wirechem-Particle", "coords:"+particle.getCoordx()+","+particle.getCoordy()+" killed & removed");
particles.removeValue(particle, true);
}
}
}
} }
//Affiche le cycle en cours à l'écran //Affiche le cycle en cours à l'écran
public void tiling_particle() { public void tiling_particle() {
for (int x = 0; x < this.sizeX; x++)
for (int y = 0; y < this.sizeY; y++)
if (GetXY(x, y).Fiber)
GetXY(x, y).Fiber_state = 0;
for(Particle particle: particles) { for(Particle particle: particles) {
if (particle.getType()==Type.Photon) {
GetXY(particle.getCoordx(), particle.getCoordy()).Fiber_state=Math.floorDiv(29-particle.getLife(),3);
Gdx.app.debug("wirechem-Grid", "Grid Tiling -> Photon state :"+GetXY(particle.getCoordx(), particle.getCoordy()).Fiber_state+":"+particle.getCoordx()+","+particle.getCoordy());
}
} }
} }
//Initialise la simulation pour permettre ensuite de faire des cycles //Initialise la simulation pour permettre ensuite de faire des cycles
public void Initialize() { public void Initialize() {
particles.clear();
this.tiling_particle();
particles.add(new Particle(this));
particles.get(0).setType(Type.Photon);
particles.get(0).setCoordx(6);
particles.get(0).setCoordy(3);
particles.get(0).setOrientation(Orientation.E);
} }
//Genère des tiles qui correspondent aux transmuteurs sur la grille //Genère des tiles qui correspondent aux transmuteurs sur la grille
@ -300,7 +330,7 @@ public class Grid implements Serializable,Cloneable {
if (cell == null) if (cell == null)
return false; return false;
else else
return cell.Fiber > 0; return cell.Fiber;
} }
public int getCoppercalc(float X, float Y) { public int getCoppercalc(float X, float Y) {

View File

@ -1,11 +1,13 @@
package fr.evolving.automata; package fr.evolving.automata;
import com.badlogic.gdx.Gdx;
public class Particle { public class Particle {
public enum Type { public enum Type {
Electron, Photon, Proton, Neutron Electron, Photon, Proton, Neutron
} }
public enum Orientation { public enum Orientation {
Nord, Sud, Est, Ouest N, S, E, O, NE, SE, NO, SO
}; };
public enum Size { public enum Size {
Gros, Petit Gros, Petit
@ -14,16 +16,21 @@ public class Particle {
Positif, Negatif, Neutre Positif, Negatif, Neutre
}; };
protected Orientation orientation; private Orientation orientation;
protected Size size; private Size size;
protected Charge charge; private Charge charge;
protected int coordX; private int coordX;
protected int coordY; private int coordY;
private Type type;
private int life;
private boolean Alive;
static protected Grid grid; static private Grid grid;
public Particle(Grid grid) { public Particle(Grid grid) {
this.orientation=Orientation.Est; this.Alive=true;
this.type=Type.Electron;
this.orientation=Orientation.E;
this.size=Size.Petit; this.size=Size.Petit;
this.charge=Charge.Neutre; this.charge=Charge.Neutre;
this.coordX=0; this.coordX=0;
@ -31,6 +38,38 @@ public class Particle {
Particle.grid=grid; Particle.grid=grid;
} }
public void kill() {
this.Alive=false;
}
public boolean isAlive() {
return this.Alive;
}
public int getLife() {
return this.life;
}
public void setLife(int life) {
this.life=life;
}
public int getCoordx() {
return this.coordX;
}
public int getCoordy() {
return this.coordY;
}
public void setCoordx(int coordX) {
this.coordX=coordX;
}
public void setCoordy(int coordY) {
this.coordY=coordY;
}
public Orientation getOrientation() { public Orientation getOrientation() {
return this.orientation; return this.orientation;
} }
@ -43,6 +82,14 @@ public class Particle {
return this.charge; return this.charge;
} }
public Type getType() {
return this.type;
}
public void setType(Type type) {
this.type=type;
}
public void setOrientation(Orientation orientation) { public void setOrientation(Orientation orientation) {
this.orientation=orientation; this.orientation=orientation;
} }
@ -83,8 +130,158 @@ public class Particle {
} }
public void Next() { public void Next() {
this.life++;
int movex = 0,movey = 0;
Orientation neworientation=this.orientation;
if (type==Type.Photon) {
if (life>=30) this.kill();
if (this.orientation==Orientation.E)
{
if (this.grid.GetXY(this.coordX+1, this.coordY)!=null && this.grid.GetXY(this.coordX+1, this.coordY).Fiber) {
movex=+1;
neworientation=Orientation.E;
}
else if (this.grid.GetXY(this.coordX+1, this.coordY+1)!=null && this.grid.GetXY(this.coordX+1, this.coordY+1).Fiber) {
movex=+1;
movey=+1;
neworientation=Orientation.NE;
}
else if (this.grid.GetXY(this.coordX+1, this.coordY-1)!=null && this.grid.GetXY(this.coordX+1, this.coordY-1).Fiber) {
movex=+1;
movey=-1;
neworientation=Orientation.SE;
}
}
else if (this.orientation==Orientation.NE)
{
if (this.grid.GetXY(this.coordX+1, this.coordY+1)!=null && this.grid.GetXY(this.coordX+1, this.coordY+1).Fiber) {
movex=+1;
movey=+1;
neworientation=Orientation.NE;
}
else if (this.grid.GetXY(this.coordX, this.coordY+1)!=null && this.grid.GetXY(this.coordX, this.coordY+1).Fiber) {
movey=+1;
neworientation=Orientation.N;
}
else if (this.grid.GetXY(this.coordX+1, this.coordY)!=null && this.grid.GetXY(this.coordX+1, this.coordY).Fiber) {
movex=+1;
neworientation=Orientation.E;
}
}
else if (this.orientation==Orientation.N)
{
if (this.grid.GetXY(this.coordX, this.coordY+1)!=null && this.grid.GetXY(this.coordX, this.coordY+1).Fiber) {
movey=+1;
neworientation=Orientation.N;
}
else if (this.grid.GetXY(this.coordX-1, this.coordY+1)!=null && this.grid.GetXY(this.coordX-1, this.coordY+1).Fiber) {
movey=+1;
movex=-1;
neworientation=Orientation.NO;
}
else if (this.grid.GetXY(this.coordX+1, this.coordY+1)!=null && this.grid.GetXY(this.coordX+1, this.coordY+1).Fiber) {
movex=+1;
movey=+1;
neworientation=Orientation.NE;
}
}
else if (this.orientation==Orientation.NO)
{
if (this.grid.GetXY(this.coordX-1, this.coordY+1)!=null && this.grid.GetXY(this.coordX-1, this.coordY+1).Fiber) {
movey=+1;
movex=-1;
neworientation=Orientation.NO;
}
else if (this.grid.GetXY(this.coordX-1, this.coordY+1)!=null && this.grid.GetXY(this.coordX-1, this.coordY+1).Fiber) {
movey=+1;
movex=-1;
neworientation=Orientation.N;
}
else if (this.grid.GetXY(this.coordX+1, this.coordY+1)!=null && this.grid.GetXY(this.coordX+1, this.coordY+1).Fiber) {
movex=+1;
movey=+1;
neworientation=Orientation.O;
}
}
else if (this.orientation==Orientation.O)
{
if (this.grid.GetXY(this.coordX, this.coordY+1)!=null && this.grid.GetXY(this.coordX, this.coordY+1).Fiber) {
movey=+1;
neworientation=Orientation.N;
}
else if (this.grid.GetXY(this.coordX-1, this.coordY+1)!=null && this.grid.GetXY(this.coordX-1, this.coordY+1).Fiber) {
movey=+1;
movex=-1;
neworientation=Orientation.NO;
}
else if (this.grid.GetXY(this.coordX+1, this.coordY+1)!=null && this.grid.GetXY(this.coordX+1, this.coordY+1).Fiber) {
movex=+1;
movey=+1;
neworientation=Orientation.NE;
}
}
else if (this.orientation==Orientation.SO)
{
if (this.grid.GetXY(this.coordX, this.coordY+1)!=null && this.grid.GetXY(this.coordX, this.coordY+1).Fiber) {
movey=+1;
neworientation=Orientation.N;
}
else if (this.grid.GetXY(this.coordX-1, this.coordY+1)!=null && this.grid.GetXY(this.coordX-1, this.coordY+1).Fiber) {
movey=+1;
movex=-1;
neworientation=Orientation.NO;
}
else if (this.grid.GetXY(this.coordX+1, this.coordY+1)!=null && this.grid.GetXY(this.coordX+1, this.coordY+1).Fiber) {
movex=+1;
movey=+1;
neworientation=Orientation.NE;
}
}
else if (this.orientation==Orientation.S)
{
if (this.grid.GetXY(this.coordX, this.coordY+1)!=null && this.grid.GetXY(this.coordX, this.coordY+1).Fiber) {
movey=+1;
neworientation=Orientation.N;
}
else if (this.grid.GetXY(this.coordX-1, this.coordY+1)!=null && this.grid.GetXY(this.coordX-1, this.coordY+1).Fiber) {
movey=+1;
movex=-1;
neworientation=Orientation.NO;
}
else if (this.grid.GetXY(this.coordX+1, this.coordY+1)!=null && this.grid.GetXY(this.coordX+1, this.coordY+1).Fiber) {
movex=+1;
movey=+1;
neworientation=Orientation.NE;
}
}
else if (this.orientation==Orientation.SE)
{
if (this.grid.GetXY(this.coordX, this.coordY+1)!=null && this.grid.GetXY(this.coordX, this.coordY+1).Fiber) {
movey=+1;
neworientation=Orientation.N;
}
else if (this.grid.GetXY(this.coordX-1, this.coordY+1)!=null && this.grid.GetXY(this.coordX-1, this.coordY+1).Fiber) {
movey=+1;
movex=-1;
neworientation=Orientation.NO;
}
else if (this.grid.GetXY(this.coordX+1, this.coordY+1)!=null && this.grid.GetXY(this.coordX+1, this.coordY+1).Fiber) {
movex=+1;
movey=+1;
neworientation=Orientation.NE;
}
}
if (movex==0 && movey==0)
{
Gdx.app.debug("wirechem-Particle", "coords:"+this.coordX+","+this.coordY+" killed no place to go");
this.kill();
}
else {
Gdx.app.debug("wirechem-Particle", "coords:"+this.coordX+","+this.coordY+" move to "+orientation+":"+movex+","+movey+" life:"+this.life);
orientation=neworientation;
this.coordX+=movex;
this.coordY+=movey;
}
}
} }
} }

View File

@ -20,7 +20,7 @@ public class Worlds extends Actor {
private int research; private int research;
private Level lastchange; private Level lastchange;
public enum State {pause,simulating,notloaded,databasefailed}; public enum State {stop,simulating,notloaded,databasefailed};
public enum LinkDelMethod {all,in,out,rebase}; public enum LinkDelMethod {all,in,out,rebase};
public Worlds(String campaign) { public Worlds(String campaign) {
@ -83,7 +83,7 @@ public class Worlds extends Actor {
if (Transmuters==null) if (Transmuters==null)
state=State.notloaded; state=State.notloaded;
else else
state=State.pause; state=State.stop;
} }
public Array<Transmuter> getTransmuters() { public Array<Transmuter> getTransmuters() {
@ -98,8 +98,11 @@ public class Worlds extends Actor {
} }
public void ReadGrid(int number) { public void ReadGrid(int number) {
if (usedlevel!=null) if (usedlevel!=null) {
usedlevel.Grid = AssetLoader.Datahandler.user().getGrid(0, usedlevel.id, number); usedlevel.Grid = AssetLoader.Datahandler.user().getGrid(0, usedlevel.id, number);
if (usedlevel.Grid!=null)
usedlevel.Grid.Reinit();
}
} }
public void SaveGrid() { public void SaveGrid() {
@ -108,8 +111,11 @@ public class Worlds extends Actor {
} }
public void ReadLastGrid() { public void ReadLastGrid() {
if (usedlevel!=null) if (usedlevel!=null) {
usedlevel.Grid = AssetLoader.Datahandler.user().getGrid(0, usedlevel.id, "LAST"); usedlevel.Grid = AssetLoader.Datahandler.user().getGrid(0, usedlevel.id, "LAST");
if (usedlevel.Grid!=null)
usedlevel.Grid.Reinit();
}
} }
public void SaveLastGrid() { public void SaveLastGrid() {
@ -474,7 +480,7 @@ public class Worlds extends Actor {
if (levels==null) if (levels==null)
state=State.notloaded; state=State.notloaded;
else else
state=State.pause; state=State.stop;
} }
public void create(String campaign) { public void create(String campaign) {
@ -485,7 +491,7 @@ public class Worlds extends Actor {
Preference.prefs.flush(); Preference.prefs.flush();
name=campaign; name=campaign;
AssetLoader.Datahandler.game().setCampaign(levels,name); AssetLoader.Datahandler.game().setCampaign(levels,name);
state=State.pause; state=State.stop;
research=0; research=0;
Transmuters=AssetLoader.allTransmuter; Transmuters=AssetLoader.allTransmuter;
SaveTransmuters(); SaveTransmuters();
@ -564,4 +570,14 @@ public class Worlds extends Actor {
return this.name; return this.name;
} }
public void simulate() {
if (this.state==State.stop)
this.state=State.simulating;
}
public void stop() {
if (this.state==State.simulating)
this.state=State.stop;
}
} }

View File

@ -71,6 +71,7 @@ import fr.evolving.automata.Neutraliser_II;
import fr.evolving.automata.Transmuter; import fr.evolving.automata.Transmuter;
import fr.evolving.automata.Transmuter.Angular; import fr.evolving.automata.Transmuter.Angular;
import fr.evolving.automata.Transmuter.CaseType; import fr.evolving.automata.Transmuter.CaseType;
import fr.evolving.automata.Worlds.State;
import fr.evolving.automata.Worlds; import fr.evolving.automata.Worlds;
import fr.evolving.dialogs.PrefWindow; import fr.evolving.dialogs.PrefWindow;
import fr.evolving.dialogs.SavingWindow; import fr.evolving.dialogs.SavingWindow;
@ -82,7 +83,6 @@ public class GameScreen implements Screen {
private Array<InputProcessor> processors; private Array<InputProcessor> processors;
private float[] speed; private float[] speed;
private int speedindex; private int speedindex;
boolean start;
private Stage stage, stage_info, stage_tooltip; private Stage stage, stage_info, stage_tooltip;
private Timer RunTimer; private Timer RunTimer;
private Task RunTask; private Task RunTask;
@ -211,9 +211,10 @@ public class GameScreen implements Screen {
public void run() { public void run() {
Gdx.app.debug("wirechem-GameScreen", "Cycle particule..."); Gdx.app.debug("wirechem-GameScreen", "Cycle particule...");
worlds.getLevelData().Grid.Cycle(); worlds.getLevelData().Grid.Cycle();
worlds.getLevelData().Grid.tiling_particle();
map.redraw();
} }
}; };
start=false;
speed=new float[] {4,2,1,0.5f,0.25f,0.125f,0.0625f}; speed=new float[] {4,2,1,0.5f,0.25f,0.125f,0.0625f};
speedindex=2; speedindex=2;
RunTimer.stop(); RunTimer.stop();
@ -583,7 +584,7 @@ public class GameScreen implements Screen {
Gdx.app.debug("wirechem-GameScreen", "Etat extension:" + unroll); Gdx.app.debug("wirechem-GameScreen", "Etat extension:" + unroll);
if (level.Grid.GetXY(x, y).Copper) if (level.Grid.GetXY(x, y).Copper)
Gdx.app.debug("wirechem-GameScreen", "*** Présence de cuivre"); Gdx.app.debug("wirechem-GameScreen", "*** Présence de cuivre");
if (level.Grid.GetXY(x, y).Fiber > 0) if (level.Grid.GetXY(x, y).Fiber)
Gdx.app.debug("wirechem-GameScreen", "*** Présence de fibre"); Gdx.app.debug("wirechem-GameScreen", "*** Présence de fibre");
if (level.Grid.GetXY(x, y).Transmuter_calc > 0) { if (level.Grid.GetXY(x, y).Transmuter_calc > 0) {
Gdx.app.debug("wirechem-GameScreen", "transmuter deplacement vers origine:" Gdx.app.debug("wirechem-GameScreen", "transmuter deplacement vers origine:"
@ -680,7 +681,7 @@ public class GameScreen implements Screen {
public void map_fiber_eraser(float realx, float realy, int x, int y, public void map_fiber_eraser(float realx, float realy, int x, int y,
boolean alone, int button, calling call) { boolean alone, int button, calling call) {
if (level.Grid.GetXY(x, y).Transmuter_calc == 0 && !level.Grid.GetXY(x, y).Locked) { if (level.Grid.GetXY(x, y).Transmuter_calc == 0 && !level.Grid.GetXY(x, y).Locked) {
level.Grid.GetXY(x, y).Fiber = 0; level.Grid.GetXY(x, y).Fiber = false;
if (alone) { if (alone) {
level.Cout_copperfiber=level.Grid.tiling_copper(); level.Cout_copperfiber=level.Grid.tiling_copper();
map.redraw(); map.redraw();
@ -693,8 +694,7 @@ public class GameScreen implements Screen {
if (!worlds.isDebug() && level.Cout<5) if (!worlds.isDebug() && level.Cout<5)
return; return;
if (level.Grid.GetXY(x, y).Transmuter_calc == 0 && !level.Grid.GetXY(x, y).Locked) if (level.Grid.GetXY(x, y).Transmuter_calc == 0 && !level.Grid.GetXY(x, y).Locked)
level.Grid.GetXY(x, y).Fiber = -1 * level.Grid.GetXY(x, y).Fiber level.Grid.GetXY(x, y).Fiber = !level.Grid.GetXY(x, y).Fiber;
+ 1;
if (alone) { if (alone) {
level.Cout_copperfiber=level.Grid.tiling_copper(); level.Cout_copperfiber=level.Grid.tiling_copper();
map.redraw(); map.redraw();
@ -706,7 +706,7 @@ public class GameScreen implements Screen {
if (!worlds.isDebug() && level.Cout<5) if (!worlds.isDebug() && level.Cout<5)
return; return;
if (level.Grid.GetXY(x, y).Transmuter_calc == 0 && !level.Grid.GetXY(x, y).Locked) if (level.Grid.GetXY(x, y).Transmuter_calc == 0 && !level.Grid.GetXY(x, y).Locked)
level.Grid.GetXY(x, y).Fiber = 1; level.Grid.GetXY(x, y).Fiber = true;
if (alone) { if (alone) {
level.Cout_copperfiber=level.Grid.tiling_copper(); level.Cout_copperfiber=level.Grid.tiling_copper();
map.redraw(); map.redraw();
@ -859,27 +859,27 @@ public class GameScreen implements Screen {
} }
public void run_mode() { public void run_mode() {
if (start==false) { if (worlds.getState()==State.stop) {
worlds.simulate();
Gdx.app.log("wirechem-GameScreen", "***** Mode run."); Gdx.app.log("wirechem-GameScreen", "***** Mode run.");
worlds.getLevelData().Grid.Initialize(); worlds.getLevelData().Grid.Initialize();
worlds.getLevelData().Grid.tiling_particle(); worlds.getLevelData().Grid.tiling_particle();
}
start=true;
RunTimer.start(); RunTimer.start();
} }
}
public void stop_mode() { public void stop_mode() {
Gdx.app.log("wirechem-GameScreen", "***** Mode stop."); Gdx.app.log("wirechem-GameScreen", "***** Mode stop.");
worlds.stop();
worlds.getLevelData().Grid.Initialize(); worlds.getLevelData().Grid.Initialize();
worlds.getLevelData().Grid.tiling_particle(); worlds.getLevelData().Grid.tiling_particle();
RunTimer.stop(); RunTimer.stop();
start=false;
} }
public void pause_mode() { public void pause_mode() {
Gdx.app.log("wirechem-GameScreen", "***** Mode pause" + Gdx.app.log("wirechem-GameScreen", "***** Mode pause" +
"."); ".");
if (start==false) { if (worlds.getState()==State.stop) {
run_mode(); run_mode();
} }
RunTimer.stop(); RunTimer.stop();
@ -1059,7 +1059,7 @@ public class GameScreen implements Screen {
} }
public void hideInfo() { public void hideInfo() {
if (start) { if (worlds.getState()==State.simulating) {
menu.setVisible(false); menu.setVisible(false);
vertibar.setVisible(false); vertibar.setVisible(false);
nextpage.setVisible(false); nextpage.setVisible(false);