foul-magics/Mage/src/main/java/mage/game/draft/RichManCubeBoosterDraft.java

108 lines
3.5 KiB
Java

package mage.game.draft;
import java.util.*;
import mage.cards.Card;
import mage.cards.ExpansionSet;
import mage.game.draft.DraftCube.CardIdentity;
/**
*
* @author spjspj
*/
public class RichManCubeBoosterDraft extends DraftImpl {
//protected int[] richManTimes = {75, 70, 65, 60, 55, 50, 45, 40, 35, 35, 35, 35, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25};
protected int[] richManTimes = {70, 70, 70, 70, 70, 70, 70, 70, 70, 70, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 40, 40, 40, 40, 40, 40, 40, 40, 40, 40, 40};
protected final Map<String, CardIdentity> cardsInCube = new LinkedHashMap<>();
public RichManCubeBoosterDraft(DraftOptions options, List<ExpansionSet> sets) {
super(options, sets);
}
@Override
public void start() {
cardNum = 0;
while (!isAbort() && cardNum < 36) {
openBooster();
cardNum = 0;
while (!isAbort() && pickCards()) {
passLeft();
fireUpdatePlayersEvent();
}
}
resetBufferedCards();
this.fireEndDraftEvent();
}
@Override
protected void passLeft() {
synchronized (players) {
UUID startId = table.get(0);
UUID currentId = startId;
UUID nextId = table.getNext();
DraftPlayer next = players.get(nextId);
draftCube.leftCubeCards.clear();
draftCube.leftCubeCards.addAll(draftCube.getCubeCards());
cardsInCube.clear();
for (CardIdentity card : draftCube.leftCubeCards) {
cardsInCube.put(card.getName(), card);
}
while (true) {
for (DraftPlayer player : players.values()) {
if (player != null && player.getDeck() != null) {
for (Card card : player.getDeck().getSideboard()) {
if (cardsInCube.get(card.getName()) != null) {
draftCube.removeFromLeftCards(cardsInCube.get(card.getName()));
}
}
}
}
List<Card> nextBooster = draftCube.createBooster();
next.setBooster(nextBooster);
if (Objects.equals(nextId, startId)) {
break;
}
nextId = table.getNext();
next = players.get(nextId);
}
}
}
@Override
protected boolean pickCards() {
cardNum++;
for (DraftPlayer player : players.values()) {
if (cardNum > 36) {
return false;
}
player.setPicking();
player.getPlayer().pickCard(player.getBooster(), player.getDeck(), this);
}
synchronized (this) {
while (!donePicking()) {
try {
this.wait();
} catch (InterruptedException ex) {
}
}
}
return true;
}
@Override
public void firePickCardEvent(UUID playerId) {
DraftPlayer player = players.get(playerId);
if (cardNum > 36) {
cardNum = 36;
}
if (cardNum <= 0) {
cardNum = 1;
}
int time = richManTimes[cardNum - 1] * timing.getFactor();
playerQueryEventSource.pickCard(playerId, "Pick card", player.getBooster(), time);
}
}