feat: avancement du mode édition, création de liens...etc

This commit is contained in:
Nicolas Hordé 2016-07-01 14:38:23 +02:00
parent 62d9a26d20
commit ae83f6448e
4 changed files with 154 additions and 50 deletions

View File

@ -418,16 +418,47 @@ public class Worlds extends Actor {
return -1; return -1;
} }
public boolean getLockLevel() {
return getLockLevel(usedlevel.aLevel);
}
public boolean getLockLevel(int levelid) {
Level level=findLevel(levelid);
if (level!=null)
return AssetLoader.Datahandler.user().getLevellock(0, level.id);
else
return false;
}
public void LockLevel() {
if (usedlevel!=null) {
AssetLoader.Datahandler.user().setLevelunlock(0, usedlevel.id, true);
usedlevel.Locked=true;
}
}
public void LockLevel(int levelid) {
Level level=findLevel(levelid);
if (level!=null) {
AssetLoader.Datahandler.user().setLevelunlock(0, level.id, true);
findLevel(levelid).Locked=true;
}
}
public void unLockLevel() { public void unLockLevel() {
AssetLoader.Datahandler.user().setLevelunlock(0, usedlevel.id); if (usedlevel!=null) {
AssetLoader.Datahandler.user().setLevelunlock(0, usedlevel.id, false);
usedlevel.Locked=false; usedlevel.Locked=false;
} }
}
public void unLockLevel(int levelid) { public void unLockLevel(int levelid) {
Level level=findLevel(levelid); Level level=findLevel(levelid);
AssetLoader.Datahandler.user().setLevelunlock(0, level.id); if (level!=null) {
AssetLoader.Datahandler.user().setLevelunlock(0, level.id, false);
findLevel(levelid).Locked=false; findLevel(levelid).Locked=false;
} }
}
public void set(String campaign) { public void set(String campaign) {
Gdx.app.log("wirechem-Worlds", "***** Définition de la compagne "+campaign); Gdx.app.log("wirechem-Worlds", "***** Définition de la compagne "+campaign);

View File

@ -44,7 +44,7 @@ public abstract class Base {
return false; return false;
} }
public boolean setLevelunlock(int user, int level) { public boolean setLevelunlock(int user, int level, boolean state) {
return false; return false;
} }

View File

@ -183,10 +183,11 @@ public class LocalBase extends Base {
return true; return true;
} }
public boolean setLevelunlock(int user, int level) { public boolean setLevelunlock(int user, int level, boolean state) {
String request="insert into locks (user,level) values (" + user + "," + level + ");";
if (state) request="delete from locks where user="+user+" and level="+level+";";
try { try {
dbHandler.execSQL("insert into locks (user,level) values (" + user dbHandler.execSQL(request);
+ "," + level + ");");
} catch (SQLiteGdxException e) { } catch (SQLiteGdxException e) {
return false; return false;
} }

View File

@ -12,7 +12,9 @@ import com.badlogic.gdx.scenes.scene2d.Actor;
import com.badlogic.gdx.scenes.scene2d.Group; import com.badlogic.gdx.scenes.scene2d.Group;
import com.badlogic.gdx.scenes.scene2d.InputEvent; import com.badlogic.gdx.scenes.scene2d.InputEvent;
import com.badlogic.gdx.scenes.scene2d.Stage; import com.badlogic.gdx.scenes.scene2d.Stage;
import com.badlogic.gdx.scenes.scene2d.Touchable;
import com.badlogic.gdx.scenes.scene2d.actions.Actions; import com.badlogic.gdx.scenes.scene2d.actions.Actions;
import com.badlogic.gdx.scenes.scene2d.ui.Button;
import com.badlogic.gdx.scenes.scene2d.ui.ButtonGroup; import com.badlogic.gdx.scenes.scene2d.ui.ButtonGroup;
import com.badlogic.gdx.scenes.scene2d.ui.Image; import com.badlogic.gdx.scenes.scene2d.ui.Image;
import com.badlogic.gdx.scenes.scene2d.ui.ImageButton; import com.badlogic.gdx.scenes.scene2d.ui.ImageButton;
@ -61,7 +63,7 @@ public class LevelScreen implements Screen {
private Stage stage; private Stage stage;
private Table table; private Table table;
private WarningDialog dialog; private WarningDialog dialog;
private ImageButton Previous, Next, Exit, logosmall, databaseSave, adder, signer, finisher, deletelinker, deletebutton, addbutton, unlocked, duplicate, moveit; private ImageButton Previous, Next, Exit, logosmall, databaseSave, adder, signer, finisher, deletelinker, deletebutton, addbutton, unlocked, duplicate, moveit,modify, link;
public Image MenuSolo, MenuMulti, MenuScenario; public Image MenuSolo, MenuMulti, MenuScenario;
private ImageTextButton cout, tech, cycle, temp, rayon, nrj, up_cycle, up_temp, up_rayon, up_nrj, research, up; private ImageTextButton cout, tech, cycle, temp, rayon, nrj, up_cycle, up_temp, up_rayon, up_nrj, research, up;
private TextButton buttonConnect, buttonPlay, buttonStat, buttonSave, buttonApply, buttonPlaythis; private TextButton buttonConnect, buttonPlay, buttonStat, buttonSave, buttonApply, buttonPlaythis;
@ -71,10 +73,10 @@ public class LevelScreen implements Screen {
private TextArea TextDescriptive; private TextArea TextDescriptive;
public Worlds worlds; public Worlds worlds;
private Objectives Victory; private Objectives Victory;
private VerticalGroup vertibar; private VerticalGroup vertibar,vertibarmod;
public ButtonLevel selected; public ButtonLevel selected;
public int addervalue; public int addervalue;
public ButtonGroup chooser; public ButtonGroup<Button> chooser, modifbar;
public Group group_init, group_stat, group_level, group_base, group_debug, group_choose, group_other; public Group group_init, group_stat, group_level, group_base, group_debug, group_choose, group_other;
public ClickListener buttonLevelslistener; public ClickListener buttonLevelslistener;
public DragAndDrop dragAndDrop; public DragAndDrop dragAndDrop;
@ -223,14 +225,14 @@ public class LevelScreen implements Screen {
public void enter(InputEvent event, float x, float y, int pointer, Actor fromActor) { public void enter(InputEvent event, float x, float y, int pointer, Actor fromActor) {
ButtonLevel abutton = (ButtonLevel) event.getListenerActor(); ButtonLevel abutton = (ButtonLevel) event.getListenerActor();
Gdx.app.debug("wirechem-LevelScreen","Enter button "); Gdx.app.debug("wirechem-LevelScreen","Enter button ");
if (!abutton.isChecked() && (!abutton.level.Locked || worlds.isDebug())) if ((!worlds.isDebug() || modify.isChecked()) && !abutton.isChecked() && (!abutton.level.Locked || worlds.isDebug()))
showlevel(abutton); showlevel(abutton);
} }
public void exit(InputEvent event, float x, float y,int pointer, Actor fromActor) { public void exit(InputEvent event, float x, float y,int pointer, Actor fromActor) {
ButtonLevel abutton = (ButtonLevel) event.getListenerActor(); ButtonLevel abutton = (ButtonLevel) event.getListenerActor();
Gdx.app.debug("wirechem-LevelScreen","Enter button "); Gdx.app.debug("wirechem-LevelScreen","Enter button ");
if (!abutton.isChecked() && (!abutton.level.Locked || worlds.isDebug())) if ((!worlds.isDebug() || modify.isChecked()) && !abutton.isChecked() && (!abutton.level.Locked || worlds.isDebug()))
showlevel(abutton); showlevel(abutton);
} }
@ -240,6 +242,10 @@ public class LevelScreen implements Screen {
abutton.setPosition(event.getStageX() - 56, event.getStageY() - 20); abutton.setPosition(event.getStageX() - 56, event.getStageY() - 20);
} }
} }
public void clicked(InputEvent event, float x, float y) {
ButtonLevel abutton = (ButtonLevel) event.getListenerActor();
abutton.setChecked(false);
}
}; };
} }
@ -288,10 +294,14 @@ public class LevelScreen implements Screen {
return; return;
} }
ButtonLevel button=new ButtonLevel(changed, AssetLoader.ratio, true); ButtonLevel button=new ButtonLevel(changed, AssetLoader.ratio, true);
if (worlds.isDebug()) {
button.setDisabled(false);
button.setTouchable(Touchable.enabled);
}
buttonLevels.add(button); buttonLevels.add(button);
stage.addActor(button); stage.addActor(button);
button.addListener(buttonLevelslistener()); button.addListener(buttonLevelslistener());
showlevel(button); //showlevel(button);
return; return;
} }
LevelScreen.this.loadWorld(); LevelScreen.this.loadWorld();
@ -835,7 +845,9 @@ public class LevelScreen implements Screen {
group_choose.setVisible(false); group_choose.setVisible(false);
group_stat.setVisible(false); group_stat.setVisible(false);
group_base.setVisible(false); group_base.setVisible(false);
showlevel(selected); selectnoone();
vertibarmod.setVisible(false);
moveit.setChecked(true);
} }
else { else {
if (buttonLevels != null) if (buttonLevels != null)
@ -846,6 +858,8 @@ public class LevelScreen implements Screen {
worlds.setMaxWorldLevel(); worlds.setMaxWorldLevel();
group_debug.setVisible(false); group_debug.setVisible(false);
group_choose.setVisible(true); group_choose.setVisible(true);
selectoneunlock();
showlevel(selected);
SetButtonStat(); SetButtonStat();
} }
else else
@ -866,10 +880,46 @@ public class LevelScreen implements Screen {
moveit.addListener(new ClickListener() { moveit.addListener(new ClickListener() {
@Override @Override
public void clicked(InputEvent event, float x, float y) { public void clicked(InputEvent event, float x, float y) {
if (moveit.isChecked()) vertibarmod.setVisible(false);
dragAndDrop.clear(); dragAndDrop.clear();
else selectnoone();
}
});
modify = new ImageButton(AssetLoader.Skin_level, "modify");
modify.setPosition(1460, 140);
modify.addListener(new ClickListener() {
@Override
public void clicked(InputEvent event, float x, float y) {
vertibarmod.setVisible(true);
dragAndDrop.clear();
selectone();
}
});
link = new ImageButton(AssetLoader.Skin_level, "link");
link.setPosition(1460, 140);
link.addListener(new ClickListener() {
@Override
public void clicked(InputEvent event, float x, float y) {
vertibarmod.setVisible(false);
initDragDrop(); initDragDrop();
selectnoone();
}
});
addbutton = new ImageButton(AssetLoader.Skin_level, "level");
addbutton.setPosition(1760, 540);
addbutton.addListener(new ClickListener() {
@Override
public void clicked(InputEvent event, float x, float y) {
Level level=new Level(
worlds.getWorld(),
worlds.getFreeLevel(),
"Xenoxanax",
"Xenoxanax",
"Xx", new int[] { 0, 0, 0, 0, 0, 0 },
new int[] { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }, (float)Math.random() * 1000f,
(float)Math.random() * 750f, 0, 0, new Grid(3, 3), 0, 0, 0, 0, 99999, 99999,
99999, 99999, "", false, new int[][] {{}});
worlds.addLevel(level);
} }
}); });
unlocked = new ImageButton(AssetLoader.Skin_level, "unlocked"); unlocked = new ImageButton(AssetLoader.Skin_level, "unlocked");
@ -877,7 +927,10 @@ public class LevelScreen implements Screen {
unlocked.addListener(new ClickListener() { unlocked.addListener(new ClickListener() {
@Override @Override
public void clicked(InputEvent event, float x, float y) { public void clicked(InputEvent event, float x, float y) {
if (selected.level.Locked)
worlds.unLockLevel(selected.level.aLevel); worlds.unLockLevel(selected.level.aLevel);
else
worlds.LockLevel(selected.level.aLevel);
} }
}); });
duplicate = new ImageButton(AssetLoader.Skin_level, "duplicate"); duplicate = new ImageButton(AssetLoader.Skin_level, "duplicate");
@ -912,23 +965,6 @@ public class LevelScreen implements Screen {
} }
} }
}); });
addbutton = new ImageButton(AssetLoader.Skin_level, "level");
addbutton.setPosition(1760, 540);
addbutton.addListener(new ClickListener() {
@Override
public void clicked(InputEvent event, float x, float y) {
Level level=new Level(
worlds.getWorld(),
worlds.getFreeLevel(),
"Xenoxanax",
"Xenoxanax",
"Xx", new int[] { 0, 0, 0, 0, 0, 0 },
new int[] { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }, (float)Math.random() * 1000f,
(float)Math.random() * 750f, 0, 0, new Grid(3, 3), 0, 0, 0, 0, 99999, 99999,
99999, 99999, "", false, new int[][] {{}});
worlds.addLevel(level);
}
});
finisher = new ImageButton(AssetLoader.Skin_level, "finish"); finisher = new ImageButton(AssetLoader.Skin_level, "finish");
finisher.setSize(64, 64); finisher.setSize(64, 64);
finisher.setPosition(1560, 40); finisher.setPosition(1560, 40);
@ -991,24 +1027,40 @@ public class LevelScreen implements Screen {
worlds.save(worlds.getName()); worlds.save(worlds.getName());
} }
}); });
vertibarmod=new VerticalGroup();
vertibarmod.setPosition(1780, AssetLoader.height-100);
vertibarmod.center();
vertibarmod.space(20f);
vertibarmod.addActor(unlocked);
vertibarmod.addActor(finisher);
vertibarmod.addActor(deletebutton);
vertibarmod.addActor(duplicate);
vertibarmod.addActor(deletelinker);
vertibarmod.setVisible(false);
vertibar=new VerticalGroup(); vertibar=new VerticalGroup();
vertibar.setPosition(1600, AssetLoader.height-100); vertibar.setPosition(1600, AssetLoader.height-100);
vertibar.center(); vertibar.center();
vertibar.space(20f); vertibar.space(20f);
vertibar.addActor(moveit); vertibar.addActor(moveit);
vertibar.addActor(deletebutton); vertibar.addActor(link);
vertibar.addActor(modify);
vertibar.addActor(addbutton); vertibar.addActor(addbutton);
vertibar.addActor(duplicate); modifbar=new ButtonGroup<Button>();
vertibar.addActor(deletelinker); modifbar.setMaxCheckCount(1);
vertibar.addActor(unlocked); modifbar.setMinCheckCount(1);
vertibar.addActor(finisher); modifbar.add(moveit);
vertibar.addActor(databaseSave); modifbar.add(link);
modifbar.add(modify);
modifbar.add(addbutton);
group_debug=new Group(); group_debug=new Group();
group_debug.addActor(vertibar);
group_debug.addActor(vertibarmod);
group_debug.addActor(adder); group_debug.addActor(adder);
group_debug.addActor(signer); group_debug.addActor(signer);
group_debug.addActor(vertibar); group_debug.addActor(databaseSave);
//********************************************************** //**********************************************************
Gdx.app.debug("wirechem-LevelScreen", "Affichage du menu."); Gdx.app.debug("wirechem-LevelScreen", "Affichage du menu.");
@ -1067,6 +1119,7 @@ public class LevelScreen implements Screen {
} }
public void selectone() { public void selectone() {
if (selected==null)
for(ButtonLevel button: buttonLevels) for(ButtonLevel button: buttonLevels)
if (button!=null) { if (button!=null) {
selected=button; selected=button;
@ -1076,6 +1129,27 @@ public class LevelScreen implements Screen {
return; return;
} }
public void selectoneunlock() {
if (selected==null)
for(ButtonLevel button: buttonLevels)
if (button!=null && button.level.Locked==false) {
selected=button;
selected.setChecked(true);
return;
}
return;
}
public void selectnoone() {
for(ButtonLevel button: buttonLevels)
if (button!=null) {
selected=button;
selected.setChecked(false);
}
selected=null;
return;
}
public void showlevel(ButtonLevel button) { public void showlevel(ButtonLevel button) {
if (button==null) if (button==null)
return; return;
@ -1144,10 +1218,8 @@ public class LevelScreen implements Screen {
Victory.setVisible(button.level.Cout_orig > 0 || worlds.isDebug()); Victory.setVisible(button.level.Cout_orig > 0 || worlds.isDebug());
Victory.setVictory(button.level.Victory_orig); Victory.setVictory(button.level.Victory_orig);
if (worlds.isDebug()) { if (worlds.isDebug()) {
if (button.level.Special) unlocked.setChecked(!button.level.Locked);
finisher.setColor(AssetLoader.Skin_level.getColor("red")); finisher.setChecked(button.level.Special);
else
finisher.setColor(AssetLoader.Skin_level.getColor("black"));
} }
if (selected != null) if (selected != null)
selected.setChecked(false); selected.setChecked(false);