mirror of
https://github.com/correl/mage.git
synced 2025-01-12 19:25:44 +00:00
[KHM] improved Cosima, God of the Voyage - "to the voyage" exile window, user friendly choose dialog, visible counters in exile, AI support (#7248);
This commit is contained in:
parent
4b9de96a6b
commit
c381ea7716
2 changed files with 34 additions and 7 deletions
|
@ -102,8 +102,13 @@ class CosimaGodOfTheVoyageEffect extends OneShotEffect {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
Card card = game.getCard(permanent.getId());
|
Card card = game.getCard(permanent.getId());
|
||||||
player.moveCards(permanent, Zone.EXILED, source, game);
|
if (card == null) {
|
||||||
if (card == null || game.getState().getZone(card.getId()) != Zone.EXILED) {
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
String exileName = "Exiled to the voyage";
|
||||||
|
player.moveCardsToExile(permanent, source, game, true, source.getSourceId(), exileName);
|
||||||
|
if (game.getState().getZone(card.getId()) != Zone.EXILED) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
game.addEffect(new CosimaGodOfTheVoyageGainAbilityEffect(new MageObjectReference(card, game)), source);
|
game.addEffect(new CosimaGodOfTheVoyageGainAbilityEffect(new MageObjectReference(card, game)), source);
|
||||||
|
@ -206,19 +211,29 @@ class CosimaGodOfTheVoyageReturnEffect extends OneShotEffect {
|
||||||
if (player == null || card == null) {
|
if (player == null || card == null) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (player.chooseUse(outcome, "Add a voyage counter?", source, game)
|
|
||||||
|
// AI hint to return card on 2+ counters
|
||||||
|
int currentCount = card.getCounters(game).getCount(CounterType.VOYAGE);
|
||||||
|
Outcome aiOutcome = (currentCount >= 2) ? Outcome.Benefit : Outcome.Detriment;
|
||||||
|
|
||||||
|
if (player.chooseUse(aiOutcome, "Add a voyage counter (current: " + currentCount + ")?", null,
|
||||||
|
"Yes, add counter", "No, return to battlefield", source, game)
|
||||||
&& card.addCounters(CounterType.VOYAGE.createInstance(), player.getId(), source, game)) {
|
&& card.addCounters(CounterType.VOYAGE.createInstance(), player.getId(), source, game)) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
int counterCount = card.getCounters(game).getCount(CounterType.VOYAGE);
|
|
||||||
|
// return to battle
|
||||||
|
int newCount = card.getCounters(game).getCount(CounterType.VOYAGE);
|
||||||
player.moveCards(card, Zone.BATTLEFIELD, source, game);
|
player.moveCards(card, Zone.BATTLEFIELD, source, game);
|
||||||
if (counterCount < 1) {
|
if (newCount < 1) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
player.drawCards(counterCount, source, game);
|
|
||||||
|
// draw and boost
|
||||||
|
player.drawCards(newCount, source, game);
|
||||||
Permanent permanent = game.getPermanent(card.getId());
|
Permanent permanent = game.getPermanent(card.getId());
|
||||||
if (permanent != null) {
|
if (permanent != null) {
|
||||||
permanent.addCounters(CounterType.P1P1.createInstance(counterCount), player.getId(), source, game);
|
permanent.addCounters(CounterType.P1P1.createInstance(newCount), player.getId(), source, game);
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,7 +7,9 @@ import mage.abilities.*;
|
||||||
import mage.abilities.costs.mana.ManaCost;
|
import mage.abilities.costs.mana.ManaCost;
|
||||||
import mage.abilities.costs.mana.ManaCosts;
|
import mage.abilities.costs.mana.ManaCosts;
|
||||||
import mage.constants.*;
|
import mage.constants.*;
|
||||||
|
import mage.counters.Counters;
|
||||||
import mage.game.Game;
|
import mage.game.Game;
|
||||||
|
import mage.game.GameState;
|
||||||
import mage.game.events.ZoneChangeEvent;
|
import mage.game.events.ZoneChangeEvent;
|
||||||
import mage.util.CardUtil;
|
import mage.util.CardUtil;
|
||||||
import mage.util.SubTypes;
|
import mage.util.SubTypes;
|
||||||
|
@ -111,6 +113,16 @@ public abstract class ModalDoubleFacesCard extends CardImpl {
|
||||||
rightHalfCard.updateZoneChangeCounter(game, event);
|
rightHalfCard.updateZoneChangeCounter(game, event);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Counters getCounters(Game game) {
|
||||||
|
return leftHalfCard.getCounters(game.getState());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Counters getCounters(GameState state) {
|
||||||
|
return state.getCardState(leftHalfCard.getId()).getCounters();
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean cast(Game game, Zone fromZone, SpellAbility ability, UUID controllerId) {
|
public boolean cast(Game game, Zone fromZone, SpellAbility ability, UUID controllerId) {
|
||||||
switch (ability.getSpellAbilityType()) {
|
switch (ability.getSpellAbilityType()) {
|
||||||
|
|
Loading…
Reference in a new issue