mirror of
https://github.com/Card-Forge/forge.git
synced 2025-11-19 12:18:00 +00:00
Support retrying if you lose a game in Planar Conquest
This commit is contained in:
@@ -28,12 +28,12 @@ public class ConquestWinLose extends ControlWinLose {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public final void showRewards() {
|
public final void showRewards() {
|
||||||
FModel.getConquest().showGameRewards(lastGame, getView());
|
FModel.getConquest().showGameOutcome(lastGame, getView());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public final void actionOnQuit() {
|
public final void actionOnQuit() {
|
||||||
|
FModel.getConquest().finishEvent();
|
||||||
super.actionOnQuit();
|
super.actionOnQuit();
|
||||||
FModel.getConquest().onGameFinished(lastGame);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -3,14 +3,11 @@ package forge.screens.planarconquest;
|
|||||||
import forge.Forge;
|
import forge.Forge;
|
||||||
import forge.model.FModel;
|
import forge.model.FModel;
|
||||||
import forge.planarconquest.ConquestEvent;
|
import forge.planarconquest.ConquestEvent;
|
||||||
import forge.planarconquest.ConquestController.GameRunner;
|
|
||||||
import forge.planarconquest.ConquestEvent.IConquestEventLauncher;
|
|
||||||
import forge.screens.LaunchScreen;
|
import forge.screens.LaunchScreen;
|
||||||
import forge.screens.LoadingOverlay;
|
import forge.screens.LoadingOverlay;
|
||||||
import forge.toolbox.FOptionPane;
|
import forge.toolbox.FOptionPane;
|
||||||
import forge.util.ThreadUtil;
|
|
||||||
|
|
||||||
public class ConquestEventScreen extends LaunchScreen implements IConquestEventLauncher {
|
public class ConquestEventScreen extends LaunchScreen {
|
||||||
protected static final float PADDING = FOptionPane.PADDING;
|
protected static final float PADDING = FOptionPane.PADDING;
|
||||||
|
|
||||||
private final ConquestEvent event;
|
private final ConquestEvent event;
|
||||||
@@ -37,22 +34,12 @@ public class ConquestEventScreen extends LaunchScreen implements IConquestEventL
|
|||||||
@Override
|
@Override
|
||||||
protected void startMatch() {
|
protected void startMatch() {
|
||||||
if (launchedEvent) { return; } //avoid launching event more than once
|
if (launchedEvent) { return; } //avoid launching event more than once
|
||||||
|
|
||||||
launchedEvent = true;
|
launchedEvent = true;
|
||||||
ThreadUtil.invokeInGameThread(new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
FModel.getConquest().launchEvent(ConquestEventScreen.this, FModel.getConquest().getModel().getSelectedCommander(), event);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
LoadingOverlay.show("Starting battle...", new Runnable() {
|
||||||
public void startGame(final GameRunner gameRunner) {
|
|
||||||
LoadingOverlay.show("Loading new game...", new Runnable() {
|
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
gameRunner.finishStartingGame();
|
FModel.getConquest().launchEvent(FModel.getConquest().getModel().getSelectedCommander(), event);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -53,6 +53,7 @@ public class ConquestPrefsScreen extends FScreen {
|
|||||||
scroller.add(new PrefsOption("Base Card Value", CQPref.AETHER_BASE_VALUE, PrefsGroup.AETHER));
|
scroller.add(new PrefsOption("Base Card Value", CQPref.AETHER_BASE_VALUE, PrefsGroup.AETHER));
|
||||||
scroller.add(new PrefsOption("Markup Percentage", CQPref.AETHER_MARKUP, PrefsGroup.AETHER));
|
scroller.add(new PrefsOption("Markup Percentage", CQPref.AETHER_MARKUP, PrefsGroup.AETHER));
|
||||||
scroller.add(new PrefsOption("Starting Shards", CQPref.AETHER_START_SHARDS, PrefsGroup.AETHER));
|
scroller.add(new PrefsOption("Starting Shards", CQPref.AETHER_START_SHARDS, PrefsGroup.AETHER));
|
||||||
|
scroller.add(new PrefsOption("Chaos Wheel Shard Value", CQPref.AETHER_WHEEL_SHARDS, PrefsGroup.AETHER));
|
||||||
|
|
||||||
scroller.add(new PrefsHeader("Booster Packs", FSkinImage.PACK, PrefsGroup.BOOSTER));
|
scroller.add(new PrefsHeader("Booster Packs", FSkinImage.PACK, PrefsGroup.BOOSTER));
|
||||||
scroller.add(new PrefsOption("Commons", CQPref.BOOSTER_COMMONS, PrefsGroup.BOOSTER));
|
scroller.add(new PrefsOption("Commons", CQPref.BOOSTER_COMMONS, PrefsGroup.BOOSTER));
|
||||||
|
|||||||
@@ -39,7 +39,6 @@ import forge.interfaces.IWinLoseView;
|
|||||||
import forge.item.PaperCard;
|
import forge.item.PaperCard;
|
||||||
import forge.match.HostedMatch;
|
import forge.match.HostedMatch;
|
||||||
import forge.model.FModel;
|
import forge.model.FModel;
|
||||||
import forge.planarconquest.ConquestEvent.IConquestEventLauncher;
|
|
||||||
import forge.planarconquest.ConquestPlane.AwardPool;
|
import forge.planarconquest.ConquestPlane.AwardPool;
|
||||||
import forge.planarconquest.ConquestPreferences.CQPref;
|
import forge.planarconquest.ConquestPreferences.CQPref;
|
||||||
import forge.player.GamePlayerUtil;
|
import forge.player.GamePlayerUtil;
|
||||||
@@ -56,7 +55,7 @@ import forge.util.storage.StorageImmediatelySerialized;
|
|||||||
public class ConquestController {
|
public class ConquestController {
|
||||||
private ConquestData model;
|
private ConquestData model;
|
||||||
private IStorage<Deck> decks;
|
private IStorage<Deck> decks;
|
||||||
private GameRunner gameRunner;
|
private ConquestEvent activeEvent;
|
||||||
private LobbyPlayerHuman humanPlayer;
|
private LobbyPlayerHuman humanPlayer;
|
||||||
|
|
||||||
public ConquestController() {
|
public ConquestController() {
|
||||||
@@ -82,48 +81,9 @@ public class ConquestController {
|
|||||||
return decks;
|
return decks;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void launchEvent(final IConquestEventLauncher launcher0, final ConquestCommander commander0, final ConquestEvent event0) {
|
public void launchEvent(ConquestCommander commander, ConquestEvent event) {
|
||||||
if (gameRunner != null) { return; } //prevent running multiple games at once
|
if (activeEvent != null) { return; }
|
||||||
|
|
||||||
gameRunner = new GameRunner(launcher0, commander0, event0);
|
|
||||||
gameRunner.invokeAndWait();
|
|
||||||
gameRunner = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
public class GameRunner {
|
|
||||||
private class Lock {
|
|
||||||
}
|
|
||||||
private final Lock lock = new Lock();
|
|
||||||
|
|
||||||
private final IConquestEventLauncher launcher;
|
|
||||||
private final ConquestCommander commander;
|
|
||||||
private final ConquestEvent event;
|
|
||||||
|
|
||||||
private GameRunner(final IConquestEventLauncher launcher0, final ConquestCommander commander0, final ConquestEvent event0) {
|
|
||||||
launcher = launcher0;
|
|
||||||
commander = commander0;
|
|
||||||
event = event0;
|
|
||||||
}
|
|
||||||
|
|
||||||
public final void invokeAndWait() {
|
|
||||||
FThreads.assertExecutedByEdt(false); //not supported if on UI thread
|
|
||||||
FThreads.invokeInEdtLater(new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
launcher.startGame(GameRunner.this);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
try {
|
|
||||||
synchronized(lock) {
|
|
||||||
lock.wait();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
catch (InterruptedException e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void finishStartingGame() {
|
|
||||||
//determine game variants
|
//determine game variants
|
||||||
Set<GameType> variants = new HashSet<GameType>();
|
Set<GameType> variants = new HashSet<GameType>();
|
||||||
event.addVariants(variants);
|
event.addVariants(variants);
|
||||||
@@ -172,12 +132,7 @@ public class ConquestController {
|
|||||||
hostedMatch.startMatch(rules, null, starter, humanStart, GuiBase.getInterface().getNewGuiGame());
|
hostedMatch.startMatch(rules, null, starter, humanStart, GuiBase.getInterface().getNewGuiGame());
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
activeEvent = event;
|
||||||
|
|
||||||
private void finish() {
|
|
||||||
synchronized(lock) { //release game lock once game finished
|
|
||||||
lock.notify();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private List<PaperCard> generatePlanarPool() {
|
private List<PaperCard> generatePlanarPool() {
|
||||||
@@ -213,40 +168,29 @@ public class ConquestController {
|
|||||||
}
|
}
|
||||||
return pool;
|
return pool;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
public void showGameRewards(final GameView game, final IWinLoseView<? extends IButton> view) {
|
public void showGameOutcome(final GameView game, final IWinLoseView<? extends IButton> view) {
|
||||||
if (game.isMatchWonBy(humanPlayer)) {
|
if (game.isMatchWonBy(humanPlayer)) {
|
||||||
|
view.getBtnRestart().setVisible(false);
|
||||||
view.getBtnQuit().setText("Great!");
|
view.getBtnQuit().setText("Great!");
|
||||||
|
model.addWin(activeEvent);
|
||||||
//give controller a chance to run remaining logic on a separate thread
|
|
||||||
view.showRewards(new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
awardBooster(view);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
view.getBtnQuit().setText("OK");
|
view.getBtnRestart().setVisible(true);
|
||||||
}
|
view.getBtnRestart().setText("Retry");
|
||||||
}
|
view.getBtnQuit().setText("Quit");
|
||||||
|
model.addLoss(activeEvent);
|
||||||
public void onGameFinished(final GameView game) {
|
|
||||||
if (game.isMatchWonBy(humanPlayer)) {
|
|
||||||
model.addWin(gameRunner.event);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
model.addLoss(gameRunner.event);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
model.saveData();
|
model.saveData();
|
||||||
FModel.getConquestPreferences().save();
|
FModel.getConquestPreferences().save();
|
||||||
|
|
||||||
gameRunner.finish();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void awardBooster(final IWinLoseView<? extends IButton> view) {
|
public void finishEvent() {
|
||||||
|
activeEvent = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public List<ConquestReward> awardBooster() {
|
||||||
AwardPool pool = FModel.getConquest().getModel().getCurrentPlane().getAwardPool();
|
AwardPool pool = FModel.getConquest().getModel().getCurrentPlane().getAwardPool();
|
||||||
ConquestPreferences prefs = FModel.getConquestPreferences();
|
ConquestPreferences prefs = FModel.getConquestPreferences();
|
||||||
List<PaperCard> rewards = new ArrayList<PaperCard>();
|
List<PaperCard> rewards = new ArrayList<PaperCard>();
|
||||||
@@ -289,14 +233,9 @@ public class ConquestController {
|
|||||||
allRewards.add(new ConquestReward(card, replacementShards));
|
allRewards.add(new ConquestReward(card, replacementShards));
|
||||||
}
|
}
|
||||||
|
|
||||||
FThreads.invokeInEdtNowOrLater(new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
view.showConquestRewards("Booster Awarded", allRewards);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
model.unlockCards(rewards);
|
model.unlockCards(rewards);
|
||||||
model.rewardAEtherShards(shards);
|
model.rewardAEtherShards(shards);
|
||||||
|
return allRewards;
|
||||||
}
|
}
|
||||||
|
|
||||||
public int calculateShardCost(ItemPool<PaperCard> filteredCards, int unfilteredCount) {
|
public int calculateShardCost(ItemPool<PaperCard> filteredCards, int unfilteredCount) {
|
||||||
|
|||||||
@@ -4,7 +4,6 @@ import java.util.Set;
|
|||||||
|
|
||||||
import forge.deck.Deck;
|
import forge.deck.Deck;
|
||||||
import forge.game.GameType;
|
import forge.game.GameType;
|
||||||
import forge.planarconquest.ConquestController.GameRunner;
|
|
||||||
import forge.util.XmlReader;
|
import forge.util.XmlReader;
|
||||||
import forge.util.XmlWriter;
|
import forge.util.XmlWriter;
|
||||||
import forge.util.XmlWriter.IXmlWritable;
|
import forge.util.XmlWriter.IXmlWritable;
|
||||||
@@ -40,10 +39,6 @@ public abstract class ConquestEvent {
|
|||||||
public abstract String getOpponentName();
|
public abstract String getOpponentName();
|
||||||
public abstract String getAvatarImageKey();
|
public abstract String getAvatarImageKey();
|
||||||
|
|
||||||
public static interface IConquestEventLauncher {
|
|
||||||
void startGame(GameRunner gameRunner);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static class ConquestEventRecord implements IXmlWritable {
|
public static class ConquestEventRecord implements IXmlWritable {
|
||||||
private final ConquestRecord[] tiers = new ConquestRecord[4];
|
private final ConquestRecord[] tiers = new ConquestRecord[4];
|
||||||
|
|
||||||
|
|||||||
@@ -31,7 +31,8 @@ public class ConquestPreferences extends PreferencesStore<ConquestPreferences.CQ
|
|||||||
|
|
||||||
AETHER_BASE_VALUE("100"),
|
AETHER_BASE_VALUE("100"),
|
||||||
AETHER_MARKUP("50"),
|
AETHER_MARKUP("50"),
|
||||||
AETHER_START_SHARDS("1000"),
|
AETHER_START_SHARDS("3000"),
|
||||||
|
AETHER_WHEEL_SHARDS("1000"),
|
||||||
|
|
||||||
BOOSTER_COMMONS("11"),
|
BOOSTER_COMMONS("11"),
|
||||||
BOOSTER_UNCOMMONS("3"),
|
BOOSTER_UNCOMMONS("3"),
|
||||||
|
|||||||
Reference in New Issue
Block a user