added Joraga Warcaller
parent
f86127774a
commit
2006dc5694
|
@ -1092,6 +1092,20 @@ toughness=3
|
||||||
ability=flying
|
ability=flying
|
||||||
timing=fmain
|
timing=fmain
|
||||||
|
|
||||||
|
>Joraga Warcaller
|
||||||
|
image=http://magiccards.info/scans/en/wwk/106.jpg
|
||||||
|
value=2
|
||||||
|
rarity=R
|
||||||
|
type=Creature
|
||||||
|
subtype=Elf,Warrior
|
||||||
|
color=g
|
||||||
|
converted=1
|
||||||
|
cost={G}
|
||||||
|
power=1
|
||||||
|
toughness=1
|
||||||
|
timing=main
|
||||||
|
|
||||||
|
|
||||||
>Judge of Currents
|
>Judge of Currents
|
||||||
image=http://magiccards.info/scans/en/lw/22.jpg
|
image=http://magiccards.info/scans/en/lw/22.jpg
|
||||||
value=2
|
value=2
|
||||||
|
|
|
@ -0,0 +1,97 @@
|
||||||
|
package magic.card;
|
||||||
|
|
||||||
|
import magic.model.MagicCard;
|
||||||
|
import magic.model.MagicCounterType;
|
||||||
|
import magic.model.MagicGame;
|
||||||
|
import magic.model.MagicLayer;
|
||||||
|
import magic.model.MagicManaCost;
|
||||||
|
import magic.model.MagicPayedCost;
|
||||||
|
import magic.model.MagicPermanent;
|
||||||
|
import magic.model.MagicPlayer;
|
||||||
|
import magic.model.MagicPowerToughness;
|
||||||
|
import magic.model.action.MagicChangeCountersAction;
|
||||||
|
import magic.model.action.MagicPlayCardFromStackAction;
|
||||||
|
import magic.model.action.MagicPutItemOnStackAction;
|
||||||
|
import magic.model.choice.MagicKickerChoice;
|
||||||
|
import magic.model.event.MagicEvent;
|
||||||
|
import magic.model.event.MagicEventAction;
|
||||||
|
import magic.model.event.MagicSpellCardEvent;
|
||||||
|
import magic.model.mstatic.MagicStatic;
|
||||||
|
import magic.model.stack.MagicCardOnStack;
|
||||||
|
import magic.model.stack.MagicTriggerOnStack;
|
||||||
|
import magic.model.target.MagicTargetFilter;
|
||||||
|
|
||||||
|
public class Joraga_Warcaller {
|
||||||
|
public static final MagicStatic S = new MagicStatic(
|
||||||
|
MagicLayer.ModPT,
|
||||||
|
MagicTargetFilter.TARGET_ELF_YOU_CONTROL) {
|
||||||
|
|
||||||
|
private int amount = 0;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void getPowerToughness(final MagicGame game,final MagicPermanent permanent,final MagicPowerToughness pt) {
|
||||||
|
pt.add(amount, amount);
|
||||||
|
}
|
||||||
|
@Override
|
||||||
|
public boolean condition(final MagicGame game,final MagicPermanent source,final MagicPermanent target) {
|
||||||
|
if (source.hasCounters()) {
|
||||||
|
amount = source.getCounters(MagicCounterType.PlusOne);
|
||||||
|
}
|
||||||
|
return source != target;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
private static final MagicEventAction KICKED = new MagicEventAction() {
|
||||||
|
@Override
|
||||||
|
public void executeEvent(
|
||||||
|
final MagicGame game,
|
||||||
|
final MagicEvent event,
|
||||||
|
final Object[] data,
|
||||||
|
final Object[] choiceResults) {
|
||||||
|
game.doAction(
|
||||||
|
new MagicChangeCountersAction(
|
||||||
|
(MagicPermanent)data[0],
|
||||||
|
MagicCounterType.PlusOne,
|
||||||
|
(Integer)data[1],
|
||||||
|
true));
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
public static final MagicSpellCardEvent E =new MagicSpellCardEvent() {
|
||||||
|
@Override
|
||||||
|
public MagicEvent getEvent(final MagicCardOnStack cardOnStack,final MagicPayedCost payedCost) {
|
||||||
|
final MagicPlayer player=cardOnStack.getController();
|
||||||
|
final MagicCard card = cardOnStack.getCard();
|
||||||
|
return new MagicEvent(
|
||||||
|
card,
|
||||||
|
player,
|
||||||
|
new MagicKickerChoice(MagicManaCost.ONE_GREEN,true),
|
||||||
|
new Object[]{cardOnStack,player},
|
||||||
|
this,
|
||||||
|
"$Play " + card + ". " + card + " enters the battlefield " +
|
||||||
|
"with a +1/+1 counter on it for each time it was kicked$");
|
||||||
|
}
|
||||||
|
@Override
|
||||||
|
public void executeEvent(
|
||||||
|
final MagicGame game,
|
||||||
|
final MagicEvent event,
|
||||||
|
final Object[] data,
|
||||||
|
final Object[] choiceResults) {
|
||||||
|
final int kickerCount=(Integer)choiceResults[1];
|
||||||
|
final MagicCardOnStack cardOnStack = (MagicCardOnStack)data[0];
|
||||||
|
final MagicPlayCardFromStackAction action = new MagicPlayCardFromStackAction(cardOnStack);
|
||||||
|
game.doAction(action);
|
||||||
|
if (kickerCount>0) {
|
||||||
|
final MagicPermanent permanent = action.getPermanent();
|
||||||
|
final MagicPlayer player = permanent.getController();
|
||||||
|
final MagicEvent triggerEvent = new MagicEvent(
|
||||||
|
permanent,
|
||||||
|
player,
|
||||||
|
new Object[]{permanent,kickerCount},
|
||||||
|
KICKED,
|
||||||
|
"Put " + kickerCount + " +1/+1 counters on " + permanent + ".");
|
||||||
|
game.doAction(new MagicPutItemOnStackAction(new MagicTriggerOnStack(permanent,triggerEvent)));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
|
@ -718,6 +718,17 @@ public interface MagicTargetFilter {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
MagicTargetFilter TARGET_ELF_YOU_CONTROL = new MagicTargetFilter() {
|
||||||
|
public boolean accept(final MagicGame game,final MagicPlayer player,final MagicTarget target) {
|
||||||
|
return target.getController() == player &&
|
||||||
|
((MagicPermanent)target).isCreature() &&
|
||||||
|
((MagicPermanent)target).hasSubType(MagicSubType.Elf);
|
||||||
|
}
|
||||||
|
public boolean acceptType(final MagicTargetType targetType) {
|
||||||
|
return targetType == MagicTargetType.Permanent;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
MagicTargetFilter TARGET_CREATURE_YOUR_OPPONENT_CONTROLS=new MagicTargetFilter() {
|
MagicTargetFilter TARGET_CREATURE_YOUR_OPPONENT_CONTROLS=new MagicTargetFilter() {
|
||||||
|
|
||||||
public boolean accept(final MagicGame game,final MagicPlayer player,final MagicTarget target) {
|
public boolean accept(final MagicGame game,final MagicPlayer player,final MagicTarget target) {
|
||||||
|
|
Loading…
Reference in New Issue