|
|
@ -318,6 +318,7 @@ public class GameScreen extends WizardScreen {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (currentAction == null && pendingSync.getAndSet(false)) {
|
|
|
|
if (currentAction == null && pendingSync.getAndSet(false)) {
|
|
|
|
|
|
|
|
doSetPersistentMessage(null);
|
|
|
|
game.getClient().execute(Game.class, Game::sync);
|
|
|
|
game.getClient().execute(Game.class, Game::sync);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -732,11 +733,15 @@ public class GameScreen extends WizardScreen {
|
|
|
|
execute(new TrumpOverlay(this, players.get(player), trumpCard, trumpSuit));
|
|
|
|
execute(new TrumpOverlay(this, players.get(player), trumpCard, trumpSuit));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public void showColoredCardOverlay(@NotNull Card card, long timeout) {
|
|
|
|
public PlayColoredCardOverlay showColoredCardOverlay(@NotNull Card card, long timeout) {
|
|
|
|
if (card == Card.JUGGLER) {
|
|
|
|
if (card == Card.JUGGLER) {
|
|
|
|
execute(new PlayColoredCardOverlay(this, timeout, card, Card.JUGGLER_RED, Card.JUGGLER_GREEN, Card.JUGGLER_BLUE, Card.JUGGLER_YELLOW));
|
|
|
|
var overlay = new PlayColoredCardOverlay(this, timeout, card, Card.JUGGLER_RED, Card.JUGGLER_GREEN, Card.JUGGLER_BLUE, Card.JUGGLER_YELLOW);
|
|
|
|
|
|
|
|
execute(overlay);
|
|
|
|
|
|
|
|
return overlay;
|
|
|
|
} else if (card == Card.CLOUD) {
|
|
|
|
} else if (card == Card.CLOUD) {
|
|
|
|
execute(new PlayColoredCardOverlay(this, timeout, card, Card.CLOUD_RED, Card.CLOUD_GREEN, Card.CLOUD_BLUE, Card.CLOUD_YELLOW));
|
|
|
|
var overlay = new PlayColoredCardOverlay(this, timeout, card, Card.CLOUD_RED, Card.CLOUD_GREEN, Card.CLOUD_BLUE, Card.CLOUD_YELLOW);
|
|
|
|
|
|
|
|
execute(overlay);
|
|
|
|
|
|
|
|
return overlay;
|
|
|
|
} else {
|
|
|
|
} else {
|
|
|
|
throw new IllegalArgumentException();
|
|
|
|
throw new IllegalArgumentException();
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -808,21 +813,23 @@ public class GameScreen extends WizardScreen {
|
|
|
|
|
|
|
|
|
|
|
|
public void setPersistentMessage(String key, Object...args) {
|
|
|
|
public void setPersistentMessage(String key, Object...args) {
|
|
|
|
var text = key == null ? null : args != null ? messages.format(key, args) : messages.get(key);
|
|
|
|
var text = key == null ? null : args != null ? messages.format(key, args) : messages.get(key);
|
|
|
|
execute(() -> {
|
|
|
|
execute(() -> doSetPersistentMessage(text));
|
|
|
|
if (persistentMessage != null) {
|
|
|
|
}
|
|
|
|
persistentMessage.addAction(sequence(
|
|
|
|
|
|
|
|
delay(AnimationTimings.MESSAGE_HOLD),
|
|
|
|
|
|
|
|
alpha(0, AnimationTimings.MESSAGE_FADE),
|
|
|
|
|
|
|
|
removeActor()
|
|
|
|
|
|
|
|
));
|
|
|
|
|
|
|
|
persistentMessage = null;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (text != null) {
|
|
|
|
private void doSetPersistentMessage(String message) {
|
|
|
|
persistentMessage = new Label(text, skin);
|
|
|
|
if (persistentMessage != null) {
|
|
|
|
messageStack.addActor(persistentMessage);
|
|
|
|
persistentMessage.addAction(sequence(
|
|
|
|
}
|
|
|
|
delay(AnimationTimings.MESSAGE_HOLD),
|
|
|
|
});
|
|
|
|
alpha(0, AnimationTimings.MESSAGE_FADE),
|
|
|
|
|
|
|
|
removeActor()
|
|
|
|
|
|
|
|
));
|
|
|
|
|
|
|
|
persistentMessage = null;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (message != null) {
|
|
|
|
|
|
|
|
persistentMessage = new Label(message, skin);
|
|
|
|
|
|
|
|
messageStack.addActor(persistentMessage);
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
//</editor-fold>
|
|
|
|
//</editor-fold>
|
|
|
|
|
|
|
|
|
|
|
@ -838,6 +845,11 @@ public class GameScreen extends WizardScreen {
|
|
|
|
|
|
|
|
|
|
|
|
public void sync() {
|
|
|
|
public void sync() {
|
|
|
|
pendingSync.set(true);
|
|
|
|
pendingSync.set(true);
|
|
|
|
|
|
|
|
execute(() -> {
|
|
|
|
|
|
|
|
if (pendingSync.get()) {
|
|
|
|
|
|
|
|
doSetPersistentMessage(messages.get("game.message.sync"));
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public void closeInteractionOverlay() {
|
|
|
|
public void closeInteractionOverlay() {
|
|
|
|