From e22055b6974552ea2da71063d46839627df5106b Mon Sep 17 00:00:00 2001 From: theelk801 Date: Mon, 1 Sep 2025 13:11:58 -0400 Subject: [PATCH] [SPM] Implement Radioactive Spider --- .../src/mage/cards/r/RadioactiveSpider.java | 61 +++++++++++++++++++ Mage.Sets/src/mage/sets/MarvelsSpiderMan.java | 2 + 2 files changed, 63 insertions(+) create mode 100644 Mage.Sets/src/mage/cards/r/RadioactiveSpider.java diff --git a/Mage.Sets/src/mage/cards/r/RadioactiveSpider.java b/Mage.Sets/src/mage/cards/r/RadioactiveSpider.java new file mode 100644 index 00000000000..01ca91ace24 --- /dev/null +++ b/Mage.Sets/src/mage/cards/r/RadioactiveSpider.java @@ -0,0 +1,61 @@ +package mage.cards.r; + +import mage.MageInt; +import mage.abilities.Ability; +import mage.abilities.common.ActivateAsSorceryActivatedAbility; +import mage.abilities.costs.common.SacrificeSourceCost; +import mage.abilities.costs.mana.GenericManaCost; +import mage.abilities.effects.common.search.SearchLibraryPutInHandEffect; +import mage.abilities.keyword.DeathtouchAbility; +import mage.abilities.keyword.ReachAbility; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.constants.CardType; +import mage.constants.SubType; +import mage.filter.FilterCard; +import mage.target.common.TargetCardInLibrary; + +import java.util.UUID; + +/** + * @author TheElk801 + */ +public final class RadioactiveSpider extends CardImpl { + + private static final FilterCard filter = new FilterCard("Spider Hero card"); + + static { + filter.add(SubType.SPIDER.getPredicate()); + filter.add(SubType.HERO.getPredicate()); + } + + public RadioactiveSpider(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{G}"); + + this.subtype.add(SubType.SPIDER); + this.power = new MageInt(1); + this.toughness = new MageInt(1); + + // Reach + this.addAbility(ReachAbility.getInstance()); + + // Deathtouch + this.addAbility(DeathtouchAbility.getInstance()); + + // Fateful Bite -- {2}, Sacrifice this creature: Search your library for a Spider Hero card, reveal it, put it into your hand, then shuffle. Activate only as a sorcery. + Ability ability = new ActivateAsSorceryActivatedAbility( + new SearchLibraryPutInHandEffect(new TargetCardInLibrary(filter), true), new GenericManaCost(2) + ); + ability.addCost(new SacrificeSourceCost()); + this.addAbility(ability.withFlavorWord("Fateful Bite")); + } + + private RadioactiveSpider(final RadioactiveSpider card) { + super(card); + } + + @Override + public RadioactiveSpider copy() { + return new RadioactiveSpider(this); + } +} diff --git a/Mage.Sets/src/mage/sets/MarvelsSpiderMan.java b/Mage.Sets/src/mage/sets/MarvelsSpiderMan.java index c7d115b70a3..6ab661dd9c8 100644 --- a/Mage.Sets/src/mage/sets/MarvelsSpiderMan.java +++ b/Mage.Sets/src/mage/sets/MarvelsSpiderMan.java @@ -100,6 +100,8 @@ public final class MarvelsSpiderMan extends ExpansionSet { cards.add(new SetCardInfo("Plains", 189, Rarity.LAND, mage.cards.basiclands.Plains.class, NON_FULL_USE_VARIOUS)); cards.add(new SetCardInfo("Plains", 194, Rarity.LAND, mage.cards.basiclands.Plains.class, NON_FULL_USE_VARIOUS)); cards.add(new SetCardInfo("Prowler, Clawed Thief", 138, Rarity.UNCOMMON, mage.cards.p.ProwlerClawedThief.class)); + cards.add(new SetCardInfo("Radioactive Spider", 213, Rarity.RARE, mage.cards.r.RadioactiveSpider.class, NON_FULL_USE_VARIOUS)); + cards.add(new SetCardInfo("Radioactive Spider", 285, Rarity.RARE, mage.cards.r.RadioactiveSpider.class, NON_FULL_USE_VARIOUS)); cards.add(new SetCardInfo("Raging Goblinoids", 85, Rarity.UNCOMMON, mage.cards.r.RagingGoblinoids.class)); cards.add(new SetCardInfo("Rhino, Barreling Brute", 140, Rarity.UNCOMMON, mage.cards.r.RhinoBarrelingBrute.class)); cards.add(new SetCardInfo("Risky Research", 62, Rarity.COMMON, mage.cards.r.RiskyResearch.class));