feat: debut de gestion de l'activation

This commit is contained in:
Nicolas Hordé 2016-08-25 14:21:41 +02:00
parent 2b5361a559
commit ea59612ae5
3 changed files with 63 additions and 7 deletions

View File

@ -180,14 +180,15 @@ public class TouchMaptiles extends Actor implements GestureListener,InputProcess
if (level.Grid.GetXY(x,y).Fiber_state==0) if (level.Grid.GetXY(x,y).Fiber_state==0)
((TiledMapTileLayer) map.getLayers().get(0)).getCell((int) x,(int) y).setTile(AssetLoader.tileSet.getTile(61)); ((TiledMapTileLayer) map.getLayers().get(0)).getCell((int) x,(int) y).setTile(AssetLoader.tileSet.getTile(61));
else { else {
((TiledMapTileLayer) map.getLayers().get(0)).getCell((int) x,(int) y).setTile(AssetLoader.tileSet.getTile(90+level.Grid.GetXY(x,y).Fiber_state)); ((TiledMapTileLayer) map.getLayers().get(0)).getCell((int) x,(int) y).setTile(AssetLoader.tileSet.getTile(89
+level.Grid.GetXY(x,y).Fiber_state));
} }
} }
else 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(64));
else else
((TiledMapTileLayer) map.getLayers().get(5)).getCell((int) x,(int) y).setTile(null); ((TiledMapTileLayer) map.getLayers().get(5)).getCell((int) x,(int) y).setTile(null);
if (level.Grid.GetXY(x,y).Free) if (level.Grid.GetXY(x,y).Free)

View File

@ -4,18 +4,25 @@ import java.io.Serializable;
import java.util.Iterator; import java.util.Iterator;
import com.badlogic.gdx.Gdx; import com.badlogic.gdx.Gdx;
import com.badlogic.gdx.maps.tiled.TiledMapTileLayer;
import com.badlogic.gdx.math.Vector2; import com.badlogic.gdx.math.Vector2;
import com.badlogic.gdx.utils.Array; import com.badlogic.gdx.utils.Array;
import com.badlogic.gdx.utils.OrderedMap;
import com.badlogic.gdx.utils.ObjectMap.Entries;
import com.badlogic.gdx.utils.ObjectMap.Entry; import com.badlogic.gdx.utils.ObjectMap.Entry;
import fr.evolving.assets.AssetLoader;
import fr.evolving.automata.Particle.Orientation; import fr.evolving.automata.Particle.Orientation;
import fr.evolving.automata.Particle.Type; import fr.evolving.automata.Particle.Type;
import fr.evolving.automata.Transmuter.CaseType;
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;
public transient Array<Particle> particles; private transient Array<Particle> particles;
private transient Array<Transmuter> transmuters;
private transient Array<Vector2> transmuterscoords;
public Grid(Integer X, Integer Y) { public Grid(Integer X, Integer Y) {
Reinit(); Reinit();
@ -32,6 +39,10 @@ public class Grid implements Serializable,Cloneable {
public void Reinit() { public void Reinit() {
if (particles==null) if (particles==null)
particles=new Array<Particle>(); particles=new Array<Particle>();
if (transmuters==null)
transmuters=new Array<Transmuter>();
if (transmuterscoords==null)
transmuterscoords=new Array<Vector2>();
} }
//Réalise un cycle de simulation dans la grille //Réalise un cycle de simulation dans la grille
@ -40,6 +51,20 @@ public class Grid implements Serializable,Cloneable {
Gdx.app.debug("wirechem-Grid", "Grid Cycle -> Particle "+particle.getType()+"/"+particle.getSize()+ " coords:"+particle.getCoordx()+","+particle.getCoordy()+"/"+particle.getOrientation()+" charge:"+particle.getCharge()); 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) { if (particle.getType()==Type.Photon) {
particle.Next(); particle.Next();
for(int i=0;i<transmuters.size;i++) {
OrderedMap<Vector2, Integer> tiles = transmuters.get(i).getTilesidrotated();
Entries<Vector2, Integer> iterator = tiles.iterator();
while (iterator.hasNext()) {
Entry<Vector2, Integer> all = iterator.next();
CaseType thecase=transmuters.get(i).getTilestype(tiles.keys().toArray().indexOf(all.key, false));
Vector2 position=transmuterscoords.get(i);
if (GetXY(position.x+ all.key.x, position.y+ all.key.y).Fiber && position.x==particle.getCoordx() && position.y==particle.getCoordy())
if (thecase==CaseType.Fibre||thecase==CaseType.Tout||thecase==CaseType.Fibre_seul)
Gdx.app.debug("wirechem-Grid", "Grid Cycle -> Activation Photon state :"+GetXY(particle.getCoordx(), particle.getCoordy()).Fiber_state+":"+particle.getCoordx()+","+particle.getCoordy()+"Transmuter:"+transmuters.get(i).getName()+"/"+transmuters.get(i).getActivationLevel());
particle.subLife(transmuters.get(i).getMaxActivationLevel()-transmuters.get(i).getActivationLevel());
transmuters.get(i).Activate();
}
}
if (!particle.isAlive()) { if (!particle.isAlive()) {
Gdx.app.debug("wirechem-Particle", "coords:"+particle.getCoordx()+","+particle.getCoordy()+" killed & removed"); Gdx.app.debug("wirechem-Particle", "coords:"+particle.getCoordx()+","+particle.getCoordy()+" killed & removed");
particles.removeValue(particle, true); particles.removeValue(particle, true);
@ -56,7 +81,7 @@ public class Grid implements Serializable,Cloneable {
GetXY(x, y).Fiber_state = 0; GetXY(x, y).Fiber_state = 0;
for(Particle particle: particles) { for(Particle particle: particles) {
if (particle.getType()==Type.Photon) { if (particle.getType()==Type.Photon) {
GetXY(particle.getCoordx(), particle.getCoordy()).Fiber_state=Math.floorDiv(29-particle.getLife(),3); GetXY(particle.getCoordx(), particle.getCoordy()).Fiber_state=1+Math.floorDiv(Particle.PHOTONLIFE-particle.getLife(),Math.floorDiv(Particle.PHOTONLIFE,10));
Gdx.app.debug("wirechem-Grid", "Grid Tiling -> Photon state :"+GetXY(particle.getCoordx(), particle.getCoordy()).Fiber_state+":"+particle.getCoordx()+","+particle.getCoordy()); Gdx.app.debug("wirechem-Grid", "Grid Tiling -> Photon state :"+GetXY(particle.getCoordx(), particle.getCoordy()).Fiber_state+":"+particle.getCoordx()+","+particle.getCoordy());
} }
} }
@ -71,6 +96,19 @@ public class Grid implements Serializable,Cloneable {
particles.get(0).setCoordx(6); particles.get(0).setCoordx(6);
particles.get(0).setCoordy(3); particles.get(0).setCoordy(3);
particles.get(0).setOrientation(Orientation.E); particles.get(0).setOrientation(Orientation.E);
particles.add(new Particle(this));
particles.get(1).setType(Type.Electron);
particles.get(1).setCoordx(7);
particles.get(1).setCoordy(13);
particles.get(1).setOrientation(Orientation.O);
transmuters.clear();
transmuterscoords.clear();
for (int x = 0; x < this.sizeX; x++)
for (int y = 0; y < this.sizeY; y++)
if (GetXY(x, y).Transmuter!=null) {
transmuters.add(GetXY(x, y).Transmuter);
transmuterscoords.add(new Vector2(x,y));
}
} }
//Genère des tiles qui correspondent aux transmuteurs sur la grille //Genère des tiles qui correspondent aux transmuteurs sur la grille

View File

@ -17,6 +17,8 @@ public class Particle {
Positif, Negatif, Neutre Positif, Negatif, Neutre
}; };
public final static int PHOTONLIFE=200;
private Orientation oldorientation; private Orientation oldorientation;
private Orientation orientation; private Orientation orientation;
private Size size; private Size size;
@ -56,6 +58,14 @@ public class Particle {
this.life=life; this.life=life;
} }
public void subLife(int sub) {
this.life=life-sub;
if (this.life<=0) {
this.life=0;
this.kill();
}
}
public int getCoordx() { public int getCoordx() {
return this.coordX; return this.coordX;
} }
@ -168,7 +178,7 @@ public class Particle {
Vector2 move=null; Vector2 move=null;
Orientation neworientation=this.orientation; Orientation neworientation=this.orientation;
if (type==Type.Photon) { if (type==Type.Photon) {
if (life>=30) this.kill(); if (life>=PHOTONLIFE) this.kill();
Orientation[] orientations=get_orientations(this.orientation); Orientation[] orientations=get_orientations(this.orientation);
Vector2 soluce0=testorientation(orientations[0]); Vector2 soluce0=testorientation(orientations[0]);
Vector2 soluce1=testorientation(orientations[1]); Vector2 soluce1=testorientation(orientations[1]);
@ -178,9 +188,16 @@ public class Particle {
move=soluce0; move=soluce0;
} }
else if (soluce1!=null && soluce2!=null) { else if (soluce1!=null && soluce2!=null) {
if (orientations[1]==oldorientation) {
neworientation=orientations[1]; neworientation=orientations[1];
move=soluce1; move=soluce1;
} }
else
{
neworientation=orientations[2];
move=soluce2;
}
}
else if (soluce1!=null) { else if (soluce1!=null) {
neworientation=orientations[1]; neworientation=orientations[1];
move=soluce1; move=soluce1;