mirror of
https://github.com/Card-Forge/forge.git
synced 2025-11-20 04:38:00 +00:00
add Vengeful Dreams (from Torment)
This commit is contained in:
1
.gitattributes
vendored
1
.gitattributes
vendored
@@ -5316,6 +5316,7 @@ res/cardsfolder/venerable_kumo.txt -text svneol=native#text/plain
|
|||||||
res/cardsfolder/venerable_monk.txt -text svneol=native#text/plain
|
res/cardsfolder/venerable_monk.txt -text svneol=native#text/plain
|
||||||
res/cardsfolder/venerated_teacher.txt -text svneol=native#text/plain
|
res/cardsfolder/venerated_teacher.txt -text svneol=native#text/plain
|
||||||
res/cardsfolder/vengeance.txt -text svneol=native#text/plain
|
res/cardsfolder/vengeance.txt -text svneol=native#text/plain
|
||||||
|
res/cardsfolder/vengeful_dreams.txt -text svneol=native#text/plain
|
||||||
res/cardsfolder/vengeful_firebrand.txt -text svneol=native#text/plain
|
res/cardsfolder/vengeful_firebrand.txt -text svneol=native#text/plain
|
||||||
res/cardsfolder/vengevine.txt -text svneol=native#text/plain
|
res/cardsfolder/vengevine.txt -text svneol=native#text/plain
|
||||||
res/cardsfolder/venomous_dragonfly.txt -text svneol=native#text/plain
|
res/cardsfolder/venomous_dragonfly.txt -text svneol=native#text/plain
|
||||||
|
|||||||
8
res/cardsfolder/vengeful_dreams.txt
Normal file
8
res/cardsfolder/vengeful_dreams.txt
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
Name:Vengeful Dreams
|
||||||
|
ManaCost:W W
|
||||||
|
Types:Instant
|
||||||
|
Text:As an additional cost to cast Vengeful Dreams, discard X cards.\r\n\r\nExile X target attacking creatures.
|
||||||
|
SVar:RemAIDeck:True
|
||||||
|
SVar:Rarity:Rare
|
||||||
|
SVar:Picture:http://www.wizards.com/global/images/magic/general/vengeful_dreams.jpg
|
||||||
|
End
|
||||||
@@ -6093,7 +6093,7 @@ public class CardFactory_Creatures {
|
|||||||
|
|
||||||
//*************** START *********** START **************************
|
//*************** START *********** START **************************
|
||||||
else if(cardName.equals("Memnarch")) {
|
else if(cardName.equals("Memnarch")) {
|
||||||
//has 2 non-tap abilities that effects itself
|
//has 2 non-tap abilities that affect itself
|
||||||
final SpellAbility ability1 = new Ability(card, "1 U U") {
|
final SpellAbility ability1 = new Ability(card, "1 U U") {
|
||||||
@Override
|
@Override
|
||||||
public void resolve() {
|
public void resolve() {
|
||||||
|
|||||||
@@ -3944,6 +3944,86 @@ public class CardFactory_Instants {
|
|||||||
card.addSpellAbility(spell);
|
card.addSpellAbility(spell);
|
||||||
}//*************** END ************ END **************************
|
}//*************** END ************ END **************************
|
||||||
|
|
||||||
|
|
||||||
|
//*************** START *********** START **************************
|
||||||
|
else if(cardName.equals("Vengeful Dreams")) {
|
||||||
|
final CardList targets = new CardList();
|
||||||
|
final SpellAbility spell = new Spell(card) {
|
||||||
|
private static final long serialVersionUID = 1593405082929818055L;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean canPlayAI() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void resolve() {
|
||||||
|
for(Card c:targets) {
|
||||||
|
if(AllZone.GameAction.isCardInPlay(c) && CardFactoryUtil.canTarget(card, c)) {
|
||||||
|
AllZone.GameAction.exile(c);
|
||||||
|
}//if isCardInPlay
|
||||||
|
}
|
||||||
|
targets.clear();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
Input runtime = new Input() {
|
||||||
|
private static final long serialVersionUID = 4656252051002867111L;
|
||||||
|
int max = 0;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void showMessage() {
|
||||||
|
PlayerZone hand = AllZone.getZone(Constant.Zone.Hand, AllZone.HumanPlayer);
|
||||||
|
hand.remove(card);
|
||||||
|
hand.updateObservers();
|
||||||
|
max = AllZoneUtil.getPlayerHand(card.getController()).size();
|
||||||
|
if(max == targets.size()) done();
|
||||||
|
StringBuilder sb = new StringBuilder();
|
||||||
|
sb.append(card.getName()).append(" - Select target attacking creatures. Currently, (");
|
||||||
|
sb.append(targets.size()).append(") selected.");
|
||||||
|
sb.append(" Press OK when done.");
|
||||||
|
AllZone.Display.showMessage(sb.toString());
|
||||||
|
ButtonUtil.enableAll();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void selectButtonCancel() {
|
||||||
|
targets.clear();
|
||||||
|
PlayerZone hand = AllZone.getZone(Constant.Zone.Hand, AllZone.HumanPlayer);
|
||||||
|
hand.add(card);
|
||||||
|
stop();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void selectCard(Card c, PlayerZone zone) {
|
||||||
|
if(zone.is(Constant.Zone.Battlefield) && !targets.contains(c)
|
||||||
|
&& CardFactoryUtil.canTarget(card, c) && c.isAttacking()) {
|
||||||
|
targets.add(c);
|
||||||
|
showMessage();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void selectButtonOK() {
|
||||||
|
done();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void done() {
|
||||||
|
if(targets.size() > AllZoneUtil.getPlayerHand(card.getController()).size()) stop();
|
||||||
|
else {
|
||||||
|
card.getController().discard(targets.size(), spell, false);
|
||||||
|
stopSetNext(new Input_PayManaCost(spell));
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
};
|
||||||
|
spell.setStackDescription(cardName+" - exile X attacking creatures.");
|
||||||
|
spell.setBeforePayMana(runtime);
|
||||||
|
|
||||||
|
card.clearSpellAbility();
|
||||||
|
card.addSpellAbility(spell);
|
||||||
|
}//*************** END ************ END **************************
|
||||||
|
|
||||||
return card;
|
return card;
|
||||||
}//getCard
|
}//getCard
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user