mirror of
https://github.com/Cockatrice/Cockatrice.git
synced 2026-06-15 19:47:46 -07:00
Add actions for shuffle top/bottom X cards (#5695)
* Add actions for shuffle top/bottom X cards * fix typo * move shuffle actions into existing menus
This commit is contained in:
parent
1d11bb19b8
commit
0ecf6298a3
3 changed files with 90 additions and 6 deletions
|
|
@ -246,8 +246,10 @@ Player::Player(const ServerInfo_User &info, int _id, bool _local, bool _judge, T
|
||||||
connect(aDrawCards, &QAction::triggered, this, &Player::actDrawCards);
|
connect(aDrawCards, &QAction::triggered, this, &Player::actDrawCards);
|
||||||
aUndoDraw = new QAction(this);
|
aUndoDraw = new QAction(this);
|
||||||
connect(aUndoDraw, &QAction::triggered, this, &Player::actUndoDraw);
|
connect(aUndoDraw, &QAction::triggered, this, &Player::actUndoDraw);
|
||||||
|
|
||||||
aShuffle = new QAction(this);
|
aShuffle = new QAction(this);
|
||||||
connect(aShuffle, &QAction::triggered, this, &Player::actShuffle);
|
connect(aShuffle, &QAction::triggered, this, &Player::actShuffle);
|
||||||
|
|
||||||
aMulligan = new QAction(this);
|
aMulligan = new QAction(this);
|
||||||
connect(aMulligan, &QAction::triggered, this, &Player::actMulligan);
|
connect(aMulligan, &QAction::triggered, this, &Player::actMulligan);
|
||||||
|
|
||||||
|
|
@ -268,6 +270,9 @@ Player::Player(const ServerInfo_User &info, int _id, bool _local, bool _judge, T
|
||||||
aMoveTopCardToBottom = new QAction(this);
|
aMoveTopCardToBottom = new QAction(this);
|
||||||
connect(aMoveTopCardToBottom, &QAction::triggered, this, &Player::actMoveTopCardToBottom);
|
connect(aMoveTopCardToBottom, &QAction::triggered, this, &Player::actMoveTopCardToBottom);
|
||||||
|
|
||||||
|
aShuffleTopCards = new QAction(this);
|
||||||
|
connect(aShuffleTopCards, &QAction::triggered, this, &Player::actShuffleTop);
|
||||||
|
|
||||||
aDrawBottomCard = new QAction(this);
|
aDrawBottomCard = new QAction(this);
|
||||||
connect(aDrawBottomCard, &QAction::triggered, this, &Player::actDrawBottomCard);
|
connect(aDrawBottomCard, &QAction::triggered, this, &Player::actDrawBottomCard);
|
||||||
aDrawBottomCards = new QAction(this);
|
aDrawBottomCards = new QAction(this);
|
||||||
|
|
@ -286,6 +291,9 @@ Player::Player(const ServerInfo_User &info, int _id, bool _local, bool _judge, T
|
||||||
connect(aMoveBottomCardsToExile, &QAction::triggered, this, &Player::actMoveBottomCardsToExile);
|
connect(aMoveBottomCardsToExile, &QAction::triggered, this, &Player::actMoveBottomCardsToExile);
|
||||||
aMoveBottomCardToTop = new QAction(this);
|
aMoveBottomCardToTop = new QAction(this);
|
||||||
connect(aMoveBottomCardToTop, &QAction::triggered, this, &Player::actMoveBottomCardToTop);
|
connect(aMoveBottomCardToTop, &QAction::triggered, this, &Player::actMoveBottomCardToTop);
|
||||||
|
|
||||||
|
aShuffleBottomCards = new QAction(this);
|
||||||
|
connect(aShuffleBottomCards, &QAction::triggered, this, &Player::actShuffleBottom);
|
||||||
}
|
}
|
||||||
|
|
||||||
playerMenu = new TearOffMenu();
|
playerMenu = new TearOffMenu();
|
||||||
|
|
@ -330,7 +338,6 @@ Player::Player(const ServerInfo_User &info, int _id, bool _local, bool _judge, T
|
||||||
libraryMenu->addSeparator();
|
libraryMenu->addSeparator();
|
||||||
libraryMenu->addAction(aOpenDeckInDeckEditor);
|
libraryMenu->addAction(aOpenDeckInDeckEditor);
|
||||||
_deck->setMenu(libraryMenu, aDrawCard);
|
_deck->setMenu(libraryMenu, aDrawCard);
|
||||||
|
|
||||||
topLibraryMenu->addAction(aMoveTopToPlay);
|
topLibraryMenu->addAction(aMoveTopToPlay);
|
||||||
topLibraryMenu->addAction(aMoveTopToPlayFaceDown);
|
topLibraryMenu->addAction(aMoveTopToPlayFaceDown);
|
||||||
topLibraryMenu->addAction(aMoveTopCardToBottom);
|
topLibraryMenu->addAction(aMoveTopCardToBottom);
|
||||||
|
|
@ -340,6 +347,8 @@ Player::Player(const ServerInfo_User &info, int _id, bool _local, bool _judge, T
|
||||||
topLibraryMenu->addAction(aMoveTopCardToExile);
|
topLibraryMenu->addAction(aMoveTopCardToExile);
|
||||||
topLibraryMenu->addAction(aMoveTopCardsToExile);
|
topLibraryMenu->addAction(aMoveTopCardsToExile);
|
||||||
topLibraryMenu->addAction(aMoveTopCardsUntil);
|
topLibraryMenu->addAction(aMoveTopCardsUntil);
|
||||||
|
topLibraryMenu->addSeparator();
|
||||||
|
topLibraryMenu->addAction(aShuffleTopCards);
|
||||||
|
|
||||||
bottomLibraryMenu->addAction(aDrawBottomCard);
|
bottomLibraryMenu->addAction(aDrawBottomCard);
|
||||||
bottomLibraryMenu->addAction(aDrawBottomCards);
|
bottomLibraryMenu->addAction(aDrawBottomCards);
|
||||||
|
|
@ -352,6 +361,8 @@ Player::Player(const ServerInfo_User &info, int _id, bool _local, bool _judge, T
|
||||||
bottomLibraryMenu->addAction(aMoveBottomCardsToGraveyard);
|
bottomLibraryMenu->addAction(aMoveBottomCardsToGraveyard);
|
||||||
bottomLibraryMenu->addAction(aMoveBottomCardToExile);
|
bottomLibraryMenu->addAction(aMoveBottomCardToExile);
|
||||||
bottomLibraryMenu->addAction(aMoveBottomCardsToExile);
|
bottomLibraryMenu->addAction(aMoveBottomCardsToExile);
|
||||||
|
bottomLibraryMenu->addSeparator();
|
||||||
|
bottomLibraryMenu->addAction(aShuffleBottomCards);
|
||||||
}
|
}
|
||||||
|
|
||||||
graveMenu = playerMenu->addTearOffMenu(QString());
|
graveMenu = playerMenu->addTearOffMenu(QString());
|
||||||
|
|
@ -792,7 +803,8 @@ void Player::retranslateUi()
|
||||||
aDrawCards->setText(tr("D&raw cards..."));
|
aDrawCards->setText(tr("D&raw cards..."));
|
||||||
aUndoDraw->setText(tr("&Undo last draw"));
|
aUndoDraw->setText(tr("&Undo last draw"));
|
||||||
aMulligan->setText(tr("Take &mulligan"));
|
aMulligan->setText(tr("Take &mulligan"));
|
||||||
aShuffle->setText(tr("&Shuffle"));
|
|
||||||
|
aShuffle->setText(tr("Shuffle"));
|
||||||
|
|
||||||
aMoveTopToPlay->setText(tr("&Play top card"));
|
aMoveTopToPlay->setText(tr("&Play top card"));
|
||||||
aMoveTopToPlayFaceDown->setText(tr("Play top card &face down"));
|
aMoveTopToPlayFaceDown->setText(tr("Play top card &face down"));
|
||||||
|
|
@ -802,6 +814,7 @@ void Player::retranslateUi()
|
||||||
aMoveTopCardsToGraveyard->setText(tr("Move top cards to &graveyard..."));
|
aMoveTopCardsToGraveyard->setText(tr("Move top cards to &graveyard..."));
|
||||||
aMoveTopCardsToExile->setText(tr("Move top cards to &exile..."));
|
aMoveTopCardsToExile->setText(tr("Move top cards to &exile..."));
|
||||||
aMoveTopCardsUntil->setText(tr("Put top cards on stack &until..."));
|
aMoveTopCardsUntil->setText(tr("Put top cards on stack &until..."));
|
||||||
|
aShuffleTopCards->setText(tr("Shuffle top cards..."));
|
||||||
|
|
||||||
aDrawBottomCard->setText(tr("&Draw bottom card"));
|
aDrawBottomCard->setText(tr("&Draw bottom card"));
|
||||||
aDrawBottomCards->setText(tr("D&raw bottom cards..."));
|
aDrawBottomCards->setText(tr("D&raw bottom cards..."));
|
||||||
|
|
@ -812,6 +825,7 @@ void Player::retranslateUi()
|
||||||
aMoveBottomCardsToGraveyard->setText(tr("Move bottom cards to &graveyard..."));
|
aMoveBottomCardsToGraveyard->setText(tr("Move bottom cards to &graveyard..."));
|
||||||
aMoveBottomCardsToExile->setText(tr("Move bottom cards to &exile..."));
|
aMoveBottomCardsToExile->setText(tr("Move bottom cards to &exile..."));
|
||||||
aMoveBottomCardToTop->setText(tr("Put bottom card on &top"));
|
aMoveBottomCardToTop->setText(tr("Put bottom card on &top"));
|
||||||
|
aShuffleBottomCards->setText(tr("Shuffle bottom cards..."));
|
||||||
|
|
||||||
handMenu->setTitle(tr("&Hand"));
|
handMenu->setTitle(tr("&Hand"));
|
||||||
mRevealHand->setTitle(tr("&Reveal hand to..."));
|
mRevealHand->setTitle(tr("&Reveal hand to..."));
|
||||||
|
|
@ -979,6 +993,8 @@ void Player::setShortcutsActive()
|
||||||
aUndoDraw->setShortcut(shortcuts.getSingleShortcut("Player/aUndoDraw"));
|
aUndoDraw->setShortcut(shortcuts.getSingleShortcut("Player/aUndoDraw"));
|
||||||
aMulligan->setShortcut(shortcuts.getSingleShortcut("Player/aMulligan"));
|
aMulligan->setShortcut(shortcuts.getSingleShortcut("Player/aMulligan"));
|
||||||
aShuffle->setShortcut(shortcuts.getSingleShortcut("Player/aShuffle"));
|
aShuffle->setShortcut(shortcuts.getSingleShortcut("Player/aShuffle"));
|
||||||
|
aShuffleTopCards->setShortcut(shortcuts.getSingleShortcut("Player/aShuffleTopCards"));
|
||||||
|
aShuffleBottomCards->setShortcut(shortcuts.getSingleShortcut("Player/aShuffleBottomCards"));
|
||||||
aUntapAll->setShortcut(shortcuts.getSingleShortcut("Player/aUntapAll"));
|
aUntapAll->setShortcut(shortcuts.getSingleShortcut("Player/aUntapAll"));
|
||||||
aRollDie->setShortcut(shortcuts.getSingleShortcut("Player/aRollDie"));
|
aRollDie->setShortcut(shortcuts.getSingleShortcut("Player/aRollDie"));
|
||||||
aCreateToken->setShortcut(shortcuts.getSingleShortcut("Player/aCreateToken"));
|
aCreateToken->setShortcut(shortcuts.getSingleShortcut("Player/aCreateToken"));
|
||||||
|
|
@ -1029,6 +1045,8 @@ void Player::setShortcutsInactive()
|
||||||
aUndoDraw->setShortcut(QKeySequence());
|
aUndoDraw->setShortcut(QKeySequence());
|
||||||
aMulligan->setShortcut(QKeySequence());
|
aMulligan->setShortcut(QKeySequence());
|
||||||
aShuffle->setShortcut(QKeySequence());
|
aShuffle->setShortcut(QKeySequence());
|
||||||
|
aShuffleTopCards->setShortcut(QKeySequence());
|
||||||
|
aShuffleBottomCards->setShortcut(QKeySequence());
|
||||||
aUntapAll->setShortcut(QKeySequence());
|
aUntapAll->setShortcut(QKeySequence());
|
||||||
aRollDie->setShortcut(QKeySequence());
|
aRollDie->setShortcut(QKeySequence());
|
||||||
aCreateToken->setShortcut(QKeySequence());
|
aCreateToken->setShortcut(QKeySequence());
|
||||||
|
|
@ -1202,6 +1220,64 @@ void Player::actShuffle()
|
||||||
sendGameCommand(Command_Shuffle());
|
sendGameCommand(Command_Shuffle());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Player::actShuffleTop()
|
||||||
|
{
|
||||||
|
const int maxCards = zones.value("deck")->getCards().size();
|
||||||
|
if (maxCards == 0) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool ok;
|
||||||
|
int number =
|
||||||
|
QInputDialog::getInt(game, tr("Shuffle top cards of library"), tr("Number of cards: (max. %1)").arg(maxCards),
|
||||||
|
defaultNumberTopCards, 1, maxCards, 1, &ok);
|
||||||
|
if (!ok) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (number > maxCards) {
|
||||||
|
number = maxCards;
|
||||||
|
}
|
||||||
|
|
||||||
|
defaultNumberTopCards = number;
|
||||||
|
|
||||||
|
Command_Shuffle cmd;
|
||||||
|
cmd.set_zone_name("deck");
|
||||||
|
cmd.set_start(0);
|
||||||
|
cmd.set_end(number - 1); // inclusive, the indexed card at end will be shuffled
|
||||||
|
|
||||||
|
sendGameCommand(cmd);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Player::actShuffleBottom()
|
||||||
|
{
|
||||||
|
const int maxCards = zones.value("deck")->getCards().size();
|
||||||
|
if (maxCards == 0) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool ok;
|
||||||
|
int number = QInputDialog::getInt(game, tr("Shuffle bottom cards of library"),
|
||||||
|
tr("Number of cards: (max. %1)").arg(maxCards), defaultNumberBottomCards, 1,
|
||||||
|
maxCards, 1, &ok);
|
||||||
|
if (!ok) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (number > maxCards) {
|
||||||
|
number = maxCards;
|
||||||
|
}
|
||||||
|
|
||||||
|
defaultNumberBottomCards = number;
|
||||||
|
|
||||||
|
Command_Shuffle cmd;
|
||||||
|
cmd.set_zone_name("deck");
|
||||||
|
cmd.set_start(-number);
|
||||||
|
cmd.set_end(-1);
|
||||||
|
|
||||||
|
sendGameCommand(cmd);
|
||||||
|
}
|
||||||
|
|
||||||
void Player::actDrawCard()
|
void Player::actDrawCard()
|
||||||
{
|
{
|
||||||
Command_DrawCards cmd;
|
Command_DrawCards cmd;
|
||||||
|
|
|
||||||
|
|
@ -161,6 +161,8 @@ public slots:
|
||||||
void actCreateToken();
|
void actCreateToken();
|
||||||
void actCreateAnotherToken();
|
void actCreateAnotherToken();
|
||||||
void actShuffle();
|
void actShuffle();
|
||||||
|
void actShuffleTop();
|
||||||
|
void actShuffleBottom();
|
||||||
void actDrawCard();
|
void actDrawCard();
|
||||||
void actDrawCards();
|
void actDrawCards();
|
||||||
void actUndoDraw();
|
void actUndoDraw();
|
||||||
|
|
@ -263,10 +265,10 @@ private:
|
||||||
*aViewBottomCards, *aAlwaysRevealTopCard, *aAlwaysLookAtTopCard, *aOpenDeckInDeckEditor,
|
*aViewBottomCards, *aAlwaysRevealTopCard, *aAlwaysLookAtTopCard, *aOpenDeckInDeckEditor,
|
||||||
*aMoveTopCardToGraveyard, *aMoveTopCardToExile, *aMoveTopCardsToGraveyard, *aMoveTopCardsToExile,
|
*aMoveTopCardToGraveyard, *aMoveTopCardToExile, *aMoveTopCardsToGraveyard, *aMoveTopCardsToExile,
|
||||||
*aMoveTopCardsUntil, *aMoveTopCardToBottom, *aViewGraveyard, *aViewRfg, *aViewSideboard, *aDrawCard,
|
*aMoveTopCardsUntil, *aMoveTopCardToBottom, *aViewGraveyard, *aViewRfg, *aViewSideboard, *aDrawCard,
|
||||||
*aDrawCards, *aUndoDraw, *aMulligan, *aShuffle, *aMoveTopToPlay, *aMoveTopToPlayFaceDown, *aUntapAll, *aRollDie,
|
*aDrawCards, *aUndoDraw, *aMulligan, *aShuffle, *aShuffleTopCards, *aShuffleBottomCards, *aMoveTopToPlay,
|
||||||
*aCreateToken, *aCreateAnotherToken, *aMoveBottomToPlay, *aMoveBottomToPlayFaceDown, *aMoveBottomCardToTop,
|
*aMoveTopToPlayFaceDown, *aUntapAll, *aRollDie, *aCreateToken, *aCreateAnotherToken, *aMoveBottomToPlay,
|
||||||
*aMoveBottomCardToGraveyard, *aMoveBottomCardToExile, *aMoveBottomCardsToGraveyard, *aMoveBottomCardsToExile,
|
*aMoveBottomToPlayFaceDown, *aMoveBottomCardToTop, *aMoveBottomCardToGraveyard, *aMoveBottomCardToExile,
|
||||||
*aDrawBottomCard, *aDrawBottomCards;
|
*aMoveBottomCardsToGraveyard, *aMoveBottomCardsToExile, *aDrawBottomCard, *aDrawBottomCards;
|
||||||
|
|
||||||
QAction *aCardMenu;
|
QAction *aCardMenu;
|
||||||
QList<QAction *> aAddCounter, aSetCounter, aRemoveCounter;
|
QList<QAction *> aAddCounter, aSetCounter, aRemoveCounter;
|
||||||
|
|
|
||||||
|
|
@ -578,6 +578,12 @@ private:
|
||||||
{"Player/aShuffle", ShortcutKey(QT_TRANSLATE_NOOP("shortcutsTab", "Shuffle Library"),
|
{"Player/aShuffle", ShortcutKey(QT_TRANSLATE_NOOP("shortcutsTab", "Shuffle Library"),
|
||||||
parseSequenceString("Ctrl+S"),
|
parseSequenceString("Ctrl+S"),
|
||||||
ShortcutGroup::Gameplay)},
|
ShortcutGroup::Gameplay)},
|
||||||
|
{"Player/aShuffleTopCards", ShortcutKey(QT_TRANSLATE_NOOP("shortcutsTab", "Shuffle Top Cards of Library"),
|
||||||
|
parseSequenceString(""),
|
||||||
|
ShortcutGroup::Gameplay)},
|
||||||
|
{"Player/aShuffleBottomCards", ShortcutKey(QT_TRANSLATE_NOOP("shortcutsTab", "Shuffle Bottom Cards of Library"),
|
||||||
|
parseSequenceString(""),
|
||||||
|
ShortcutGroup::Gameplay)},
|
||||||
{"Player/aMulligan", ShortcutKey(QT_TRANSLATE_NOOP("shortcutsTab", "Mulligan"),
|
{"Player/aMulligan", ShortcutKey(QT_TRANSLATE_NOOP("shortcutsTab", "Mulligan"),
|
||||||
parseSequenceString("Ctrl+M"),
|
parseSequenceString("Ctrl+M"),
|
||||||
ShortcutGroup::Drawing)},
|
ShortcutGroup::Drawing)},
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue