mirror of
https://github.com/magefree/mage.git
synced 2025-12-20 10:40:06 -08:00
[TDM] Implement Krumar Initiate
This commit is contained in:
parent
a29dbc17eb
commit
04f9ab75ba
3 changed files with 61 additions and 2 deletions
48
Mage.Sets/src/mage/cards/k/KrumarInitiate.java
Normal file
48
Mage.Sets/src/mage/cards/k/KrumarInitiate.java
Normal file
|
|
@ -0,0 +1,48 @@
|
||||||
|
package mage.cards.k;
|
||||||
|
|
||||||
|
import mage.MageInt;
|
||||||
|
import mage.abilities.Ability;
|
||||||
|
import mage.abilities.common.ActivateAsSorceryActivatedAbility;
|
||||||
|
import mage.abilities.costs.common.PayLifeCost;
|
||||||
|
import mage.abilities.costs.common.TapSourceCost;
|
||||||
|
import mage.abilities.costs.mana.ManaCostsImpl;
|
||||||
|
import mage.abilities.dynamicvalue.common.GetXValue;
|
||||||
|
import mage.abilities.effects.keyword.EndureSourceEffect;
|
||||||
|
import mage.cards.CardImpl;
|
||||||
|
import mage.cards.CardSetInfo;
|
||||||
|
import mage.constants.CardType;
|
||||||
|
import mage.constants.SubType;
|
||||||
|
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author TheElk801
|
||||||
|
*/
|
||||||
|
public final class KrumarInitiate extends CardImpl {
|
||||||
|
|
||||||
|
public KrumarInitiate(UUID ownerId, CardSetInfo setInfo) {
|
||||||
|
super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{1}{B}");
|
||||||
|
|
||||||
|
this.subtype.add(SubType.HUMAN);
|
||||||
|
this.subtype.add(SubType.CLERIC);
|
||||||
|
this.power = new MageInt(2);
|
||||||
|
this.toughness = new MageInt(2);
|
||||||
|
|
||||||
|
// {X}{B}, {T}, Pay X life: This creature endures X. Activate only as a sorcery.
|
||||||
|
Ability ability = new ActivateAsSorceryActivatedAbility(
|
||||||
|
new EndureSourceEffect(GetXValue.instance, "{this}"), new ManaCostsImpl<>("{X}{B}")
|
||||||
|
);
|
||||||
|
ability.addCost(new TapSourceCost());
|
||||||
|
ability.addCost(new PayLifeCost(GetXValue.instance, "X life"));
|
||||||
|
this.addAbility(ability);
|
||||||
|
}
|
||||||
|
|
||||||
|
private KrumarInitiate(final KrumarInitiate card) {
|
||||||
|
super(card);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public KrumarInitiate copy() {
|
||||||
|
return new KrumarInitiate(this);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -141,6 +141,7 @@ public final class TarkirDragonstorm extends ExpansionSet {
|
||||||
cards.add(new SetCardInfo("Knockout Maneuver", 147, Rarity.UNCOMMON, mage.cards.k.KnockoutManeuver.class));
|
cards.add(new SetCardInfo("Knockout Maneuver", 147, Rarity.UNCOMMON, mage.cards.k.KnockoutManeuver.class));
|
||||||
cards.add(new SetCardInfo("Kotis, the Fangkeeper", 202, Rarity.RARE, mage.cards.k.KotisTheFangkeeper.class));
|
cards.add(new SetCardInfo("Kotis, the Fangkeeper", 202, Rarity.RARE, mage.cards.k.KotisTheFangkeeper.class));
|
||||||
cards.add(new SetCardInfo("Krotiq Nestguard", 148, Rarity.COMMON, mage.cards.k.KrotiqNestguard.class));
|
cards.add(new SetCardInfo("Krotiq Nestguard", 148, Rarity.COMMON, mage.cards.k.KrotiqNestguard.class));
|
||||||
|
cards.add(new SetCardInfo("Krumar Initiate", 84, Rarity.UNCOMMON, mage.cards.k.KrumarInitiate.class));
|
||||||
cards.add(new SetCardInfo("Lasyd Prowler", 149, Rarity.RARE, mage.cards.l.LasydProwler.class));
|
cards.add(new SetCardInfo("Lasyd Prowler", 149, Rarity.RARE, mage.cards.l.LasydProwler.class));
|
||||||
cards.add(new SetCardInfo("Lie in Wait", 203, Rarity.UNCOMMON, mage.cards.l.LieInWait.class));
|
cards.add(new SetCardInfo("Lie in Wait", 203, Rarity.UNCOMMON, mage.cards.l.LieInWait.class));
|
||||||
cards.add(new SetCardInfo("Lightfoot Technique", 14, Rarity.COMMON, mage.cards.l.LightfootTechnique.class));
|
cards.add(new SetCardInfo("Lightfoot Technique", 14, Rarity.COMMON, mage.cards.l.LightfootTechnique.class));
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,8 @@
|
||||||
package mage.abilities.effects.keyword;
|
package mage.abilities.effects.keyword;
|
||||||
|
|
||||||
import mage.abilities.Ability;
|
import mage.abilities.Ability;
|
||||||
|
import mage.abilities.dynamicvalue.DynamicValue;
|
||||||
|
import mage.abilities.dynamicvalue.common.StaticValue;
|
||||||
import mage.abilities.effects.OneShotEffect;
|
import mage.abilities.effects.OneShotEffect;
|
||||||
import mage.constants.Outcome;
|
import mage.constants.Outcome;
|
||||||
import mage.counters.CounterType;
|
import mage.counters.CounterType;
|
||||||
|
|
@ -15,13 +17,17 @@ import mage.util.CardUtil;
|
||||||
*/
|
*/
|
||||||
public class EndureSourceEffect extends OneShotEffect {
|
public class EndureSourceEffect extends OneShotEffect {
|
||||||
|
|
||||||
private final int amount;
|
private final DynamicValue amount;
|
||||||
|
|
||||||
public EndureSourceEffect(int amount) {
|
public EndureSourceEffect(int amount) {
|
||||||
this(amount, "it");
|
this(amount, "it");
|
||||||
}
|
}
|
||||||
|
|
||||||
public EndureSourceEffect(int amount, String selfText) {
|
public EndureSourceEffect(int amount, String selfText) {
|
||||||
|
this(StaticValue.get(amount), selfText);
|
||||||
|
}
|
||||||
|
|
||||||
|
public EndureSourceEffect(DynamicValue amount, String selfText) {
|
||||||
super(Outcome.Benefit);
|
super(Outcome.Benefit);
|
||||||
staticText = selfText + " endures " + amount;
|
staticText = selfText + " endures " + amount;
|
||||||
this.amount = amount;
|
this.amount = amount;
|
||||||
|
|
@ -39,7 +45,11 @@ public class EndureSourceEffect extends OneShotEffect {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean apply(Game game, Ability source) {
|
public boolean apply(Game game, Ability source) {
|
||||||
return doEndure(source.getSourcePermanentOrLKI(game), 1, game, source);
|
return doEndure(
|
||||||
|
source.getSourcePermanentOrLKI(game),
|
||||||
|
amount.calculate(game, source, this),
|
||||||
|
game, source
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static boolean doEndure(Permanent permanent, int amount, Game game, Ability source) {
|
public static boolean doEndure(Permanent permanent, int amount, Game game, Ability source) {
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue