2023-04-11 05:24:55 +01:00
|
|
|
import BattleScene, { Button } from "../battle-scene";
|
2023-11-10 20:51:34 +00:00
|
|
|
import { ModifierTypeOption } from "../modifier/modifier-type";
|
2023-04-20 20:46:05 +01:00
|
|
|
import { getPokeballAtlasKey, PokeballType } from "../data/pokeball";
|
2023-11-10 20:51:34 +00:00
|
|
|
import { addTextObject, getModifierTierTextTint, getTextColor, TextStyle } from "./text";
|
2023-03-28 19:54:52 +01:00
|
|
|
import AwaitableUiHandler from "./awaitable-ui-handler";
|
|
|
|
import { Mode } from "./ui";
|
2023-04-21 19:05:16 +01:00
|
|
|
import { PokemonHeldItemModifier } from "../modifier/modifier";
|
2023-03-28 19:54:52 +01:00
|
|
|
|
|
|
|
export default class ModifierSelectUiHandler extends AwaitableUiHandler {
|
|
|
|
private modifierContainer: Phaser.GameObjects.Container;
|
2023-11-10 20:51:34 +00:00
|
|
|
private rerollButtonContainer: Phaser.GameObjects.Container;
|
2023-04-21 19:05:16 +01:00
|
|
|
private transferButtonContainer: Phaser.GameObjects.Container;
|
2023-11-10 20:51:34 +00:00
|
|
|
private rerollCostText: Phaser.GameObjects.Text;
|
2023-04-21 19:05:16 +01:00
|
|
|
|
|
|
|
private lastCursor: integer = 0;
|
2023-10-29 20:05:17 +00:00
|
|
|
private player: boolean;
|
2023-04-21 19:05:16 +01:00
|
|
|
|
2023-03-29 05:31:25 +01:00
|
|
|
public options: ModifierOption[];
|
2023-03-28 19:54:52 +01:00
|
|
|
|
|
|
|
private cursorObj: Phaser.GameObjects.Image;
|
|
|
|
|
|
|
|
constructor(scene: BattleScene) {
|
2023-04-07 03:24:13 +01:00
|
|
|
super(scene, Mode.CONFIRM);
|
2023-03-28 19:54:52 +01:00
|
|
|
|
|
|
|
this.options = [];
|
|
|
|
}
|
|
|
|
|
|
|
|
setup() {
|
|
|
|
const ui = this.getUi();
|
|
|
|
|
|
|
|
this.modifierContainer = this.scene.add.container(0, 0);
|
|
|
|
ui.add(this.modifierContainer);
|
2023-04-21 19:05:16 +01:00
|
|
|
|
|
|
|
this.transferButtonContainer = this.scene.add.container((this.scene.game.canvas.width / 6) - 1, -64);
|
|
|
|
this.transferButtonContainer.setVisible(false);
|
|
|
|
ui.add(this.transferButtonContainer);
|
|
|
|
|
|
|
|
const transferButtonText = addTextObject(this.scene, -4, -2, 'Transfer', TextStyle.PARTY);
|
|
|
|
transferButtonText.setOrigin(1, 0);
|
|
|
|
this.transferButtonContainer.add(transferButtonText);
|
2023-11-10 20:51:34 +00:00
|
|
|
|
|
|
|
this.rerollButtonContainer = this.scene.add.container(16, -64);
|
|
|
|
this.rerollButtonContainer.setVisible(false);
|
|
|
|
ui.add(this.rerollButtonContainer);
|
|
|
|
|
|
|
|
const rerollButtonText = addTextObject(this.scene, -4, -2, 'Reroll', TextStyle.PARTY);
|
|
|
|
rerollButtonText.setOrigin(0, 0);
|
|
|
|
this.rerollButtonContainer.add(rerollButtonText);
|
|
|
|
|
|
|
|
this.rerollCostText = addTextObject(this.scene, 0, 0, '', TextStyle.MONEY);
|
|
|
|
this.rerollCostText.setOrigin(0, 0);
|
|
|
|
this.rerollCostText.setPositionRelative(rerollButtonText, rerollButtonText.displayWidth + 5, 1);
|
|
|
|
this.rerollButtonContainer.add(this.rerollCostText);
|
2023-03-28 19:54:52 +01:00
|
|
|
}
|
|
|
|
|
2023-12-30 23:41:25 +00:00
|
|
|
show(args: any[]): boolean {
|
2023-04-10 00:15:21 +01:00
|
|
|
if (this.active) {
|
2023-11-10 20:51:34 +00:00
|
|
|
if (args.length >= 3) {
|
2023-04-10 00:15:21 +01:00
|
|
|
this.awaitingActionInput = true;
|
2023-10-29 20:05:17 +00:00
|
|
|
this.onActionInput = args[2];
|
2023-04-10 00:15:21 +01:00
|
|
|
}
|
2023-12-30 23:41:25 +00:00
|
|
|
return false;
|
2023-04-10 00:15:21 +01:00
|
|
|
}
|
|
|
|
|
2023-11-10 20:51:34 +00:00
|
|
|
if (args.length !== 4 || !(args[1] instanceof Array) || !args[1].length || !(args[2] instanceof Function))
|
2023-12-30 23:41:25 +00:00
|
|
|
return false;
|
2023-03-28 19:54:52 +01:00
|
|
|
|
|
|
|
super.show(args);
|
|
|
|
|
|
|
|
this.getUi().clearText();
|
|
|
|
|
2023-10-29 20:05:17 +00:00
|
|
|
this.player = args[0];
|
|
|
|
|
|
|
|
const partyHasHeldItem = this.player && !!this.scene.findModifiers(m => m instanceof PokemonHeldItemModifier && (m as PokemonHeldItemModifier).getTransferrable(true)).length;
|
2023-04-21 19:05:16 +01:00
|
|
|
|
|
|
|
this.transferButtonContainer.setVisible(false);
|
|
|
|
this.transferButtonContainer.setAlpha(0);
|
|
|
|
|
2023-11-10 20:51:34 +00:00
|
|
|
this.rerollButtonContainer.setVisible(false);
|
|
|
|
this.rerollButtonContainer.setAlpha(0);
|
|
|
|
|
|
|
|
this.updateRerollCostText(args[3] as integer);
|
|
|
|
|
2023-10-29 20:05:17 +00:00
|
|
|
const typeOptions = args[1] as ModifierTypeOption[];
|
2023-04-12 17:48:02 +01:00
|
|
|
for (let m = 0; m < typeOptions.length; m++) {
|
|
|
|
const sliceWidth = (this.scene.game.canvas.width / 6) / (typeOptions.length + 2);
|
|
|
|
const option = new ModifierOption(this.scene, sliceWidth * (m + 1) + (sliceWidth * 0.5), -this.scene.game.canvas.height / 12 - 24, typeOptions[m]);
|
2023-03-28 19:54:52 +01:00
|
|
|
option.setScale(0.5);
|
|
|
|
this.scene.add.existing(option);
|
|
|
|
this.modifierContainer.add(option);
|
|
|
|
this.options.push(option);
|
|
|
|
}
|
|
|
|
|
2023-04-12 17:48:02 +01:00
|
|
|
const hasUpgrade = typeOptions.filter(to => to.upgraded).length;
|
|
|
|
|
2023-11-10 20:51:34 +00:00
|
|
|
this.scene.showFieldOverlay(750);
|
2023-03-28 19:54:52 +01:00
|
|
|
|
|
|
|
let i = 0;
|
|
|
|
|
|
|
|
this.scene.tweens.addCounter({
|
|
|
|
ease: 'Sine.easeIn',
|
|
|
|
duration: 1250,
|
|
|
|
onUpdate: t => {
|
|
|
|
const value = t.getValue();
|
2023-04-12 17:48:02 +01:00
|
|
|
const index = Math.floor(value * typeOptions.length);
|
|
|
|
if (index > i && index <= typeOptions.length) {
|
2023-03-29 05:31:25 +01:00
|
|
|
const option = this.options[i++];
|
2023-04-12 17:48:02 +01:00
|
|
|
option?.show(Math.floor((1 - value) * 1250) * 0.325 + (hasUpgrade ? 2000 : 0));
|
2023-03-29 05:31:25 +01:00
|
|
|
}
|
2023-03-28 19:54:52 +01:00
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2023-04-12 17:48:02 +01:00
|
|
|
this.scene.time.delayedCall(4000 + (hasUpgrade ? 2000 : 0), () => {
|
2023-04-21 19:05:16 +01:00
|
|
|
if (partyHasHeldItem) {
|
|
|
|
this.transferButtonContainer.setAlpha(0);
|
|
|
|
this.transferButtonContainer.setVisible(true);
|
|
|
|
this.scene.tweens.add({
|
|
|
|
targets: this.transferButtonContainer,
|
|
|
|
alpha: 1,
|
|
|
|
duration: 250
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2023-11-10 20:51:34 +00:00
|
|
|
if (this.scene.currentBattle.waveIndex % 10) {
|
|
|
|
this.rerollButtonContainer.setAlpha(0);
|
|
|
|
this.rerollButtonContainer.setVisible(true);
|
|
|
|
this.scene.tweens.add({
|
|
|
|
targets: this.rerollButtonContainer,
|
|
|
|
alpha: 1,
|
|
|
|
duration: 250
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2023-03-28 19:54:52 +01:00
|
|
|
this.setCursor(0);
|
|
|
|
this.awaitingActionInput = true;
|
2023-10-29 20:05:17 +00:00
|
|
|
this.onActionInput = args[2];
|
2023-03-28 19:54:52 +01:00
|
|
|
});
|
2023-12-30 23:41:25 +00:00
|
|
|
|
|
|
|
return true;
|
2023-03-28 19:54:52 +01:00
|
|
|
}
|
|
|
|
|
2023-11-12 05:31:40 +00:00
|
|
|
processInput(button: Button): boolean {
|
2023-03-28 19:54:52 +01:00
|
|
|
const ui = this.getUi();
|
|
|
|
|
|
|
|
if (!this.awaitingActionInput)
|
2023-11-12 05:31:40 +00:00
|
|
|
return false;
|
2023-03-28 19:54:52 +01:00
|
|
|
|
|
|
|
let success = false;
|
|
|
|
|
2023-04-11 05:24:55 +01:00
|
|
|
if (button === Button.ACTION) {
|
2023-03-28 19:54:52 +01:00
|
|
|
success = true;
|
2023-04-09 05:22:14 +01:00
|
|
|
if (this.onActionInput) {
|
|
|
|
const originalOnActionInput = this.onActionInput;
|
2023-04-10 00:15:21 +01:00
|
|
|
this.awaitingActionInput = false;
|
2023-04-09 05:22:14 +01:00
|
|
|
this.onActionInput = null;
|
2023-11-10 20:51:34 +00:00
|
|
|
if (!originalOnActionInput(this.cursor)) {
|
|
|
|
this.awaitingActionInput = true;
|
|
|
|
this.onActionInput = originalOnActionInput;
|
|
|
|
}
|
2023-04-09 05:22:14 +01:00
|
|
|
}
|
2023-04-11 05:24:55 +01:00
|
|
|
} else if (button === Button.CANCEL) {
|
2023-10-29 20:05:17 +00:00
|
|
|
if (this.player) {
|
|
|
|
success = true;
|
|
|
|
if (this.onActionInput) {
|
|
|
|
const originalOnActionInput = this.onActionInput;
|
|
|
|
this.awaitingActionInput = false;
|
|
|
|
this.onActionInput = null;
|
|
|
|
originalOnActionInput(-1);
|
|
|
|
}
|
2023-04-09 05:22:14 +01:00
|
|
|
}
|
2023-03-28 19:54:52 +01:00
|
|
|
} else {
|
2023-04-11 05:24:55 +01:00
|
|
|
switch (button) {
|
2023-04-21 19:05:16 +01:00
|
|
|
case Button.UP:
|
2023-11-10 20:51:34 +00:00
|
|
|
if (this.cursor >= this.options.length)
|
|
|
|
success = this.setCursor(this.lastCursor < this.options.length ? this.lastCursor : this.cursor - this.options.length ? this.options.length - 1 : 0);
|
2023-04-21 19:05:16 +01:00
|
|
|
break;
|
|
|
|
case Button.DOWN:
|
2023-11-10 20:51:34 +00:00
|
|
|
if (this.cursor < this.options.length && (this.rerollButtonContainer.visible || this.transferButtonContainer.visible)) {
|
|
|
|
const isLeftOption = this.cursor <= Math.floor(this.options.length / 2);
|
|
|
|
success = this.setCursor(this.options.length + (this.rerollButtonContainer.visible && (isLeftOption || !this.transferButtonContainer.visible) ? 0 : 1));
|
|
|
|
}
|
2023-04-21 19:05:16 +01:00
|
|
|
break;
|
2023-04-11 05:24:55 +01:00
|
|
|
case Button.LEFT:
|
2023-11-10 20:51:34 +00:00
|
|
|
if ((this.cursor || this.rerollButtonContainer.visible) && this.cursor !== this.options.length)
|
|
|
|
success = this.setCursor(this.cursor ? this.cursor - 1 : this.options.length);
|
2023-03-28 19:54:52 +01:00
|
|
|
break;
|
2023-04-11 05:24:55 +01:00
|
|
|
case Button.RIGHT:
|
2023-11-10 20:51:34 +00:00
|
|
|
if (this.cursor < this.options.length - 1)
|
2023-03-28 19:54:52 +01:00
|
|
|
success = this.setCursor(this.cursor + 1);
|
2023-11-10 20:51:34 +00:00
|
|
|
else if (this.cursor === this.options.length && this.transferButtonContainer.visible)
|
|
|
|
success = this.setCursor(this.options.length + 1);
|
2023-03-28 19:54:52 +01:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (success)
|
|
|
|
ui.playSelect();
|
2023-11-12 05:31:40 +00:00
|
|
|
|
|
|
|
return success;
|
2023-03-28 19:54:52 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
setCursor(cursor: integer): boolean {
|
2023-04-21 19:05:16 +01:00
|
|
|
const lastCursor = this.cursor;
|
|
|
|
|
2023-03-28 19:54:52 +01:00
|
|
|
const ui = this.getUi();
|
|
|
|
const ret = super.setCursor(cursor);
|
|
|
|
|
2023-04-21 19:05:16 +01:00
|
|
|
if (ret)
|
|
|
|
this.lastCursor = lastCursor;
|
|
|
|
|
2023-03-28 19:54:52 +01:00
|
|
|
if (!this.cursorObj) {
|
|
|
|
this.cursorObj = this.scene.add.image(0, 0, 'cursor');
|
|
|
|
this.modifierContainer.add(this.cursorObj);
|
|
|
|
}
|
|
|
|
|
2023-04-21 19:05:16 +01:00
|
|
|
this.cursorObj.setScale(cursor < this.options.length ? 2 : 1);
|
|
|
|
|
|
|
|
if (cursor < this.options.length) {
|
|
|
|
const sliceWidth = (this.scene.game.canvas.width / 6) / (this.options.length + 2);
|
|
|
|
this.cursorObj.setPosition(sliceWidth * (cursor + 1) + (sliceWidth * 0.5) - 20, -this.scene.game.canvas.height / 12 - 20);
|
|
|
|
ui.showText(this.options[this.cursor].modifierTypeOption.type.description);
|
2023-11-10 20:51:34 +00:00
|
|
|
} else if (cursor === this.options.length) {
|
|
|
|
this.cursorObj.setPosition(6, -60);
|
|
|
|
ui.showText('Spend money to reroll your item options');
|
2023-04-21 19:05:16 +01:00
|
|
|
} else {
|
|
|
|
this.cursorObj.setPosition((this.scene.game.canvas.width / 6) - 50, -60);
|
2023-10-18 23:01:15 +01:00
|
|
|
ui.showText('Transfer a held item from one Pokémon to another instead of selecting an item');
|
2023-04-21 19:05:16 +01:00
|
|
|
}
|
2023-03-28 19:54:52 +01:00
|
|
|
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
2023-11-10 20:51:34 +00:00
|
|
|
updateRerollCostText(rerollCost: integer): void {
|
|
|
|
const canReroll = this.scene.money >= rerollCost;
|
|
|
|
|
|
|
|
this.rerollCostText.setText(`₽${rerollCost.toLocaleString('en-US')}`);
|
|
|
|
this.rerollCostText.setColor(getTextColor(canReroll ? TextStyle.MONEY : TextStyle.PARTY_RED));
|
|
|
|
this.rerollCostText.setShadowColor(getTextColor(canReroll ? TextStyle.MONEY : TextStyle.PARTY_RED, true));
|
|
|
|
}
|
|
|
|
|
2023-03-28 19:54:52 +01:00
|
|
|
clear() {
|
|
|
|
super.clear();
|
|
|
|
|
|
|
|
this.awaitingActionInput = false;
|
|
|
|
this.onActionInput = null;
|
|
|
|
this.getUi().clearText();
|
|
|
|
this.eraseCursor();
|
|
|
|
|
2023-11-10 20:51:34 +00:00
|
|
|
this.scene.hideFieldOverlay(250);
|
|
|
|
|
|
|
|
const options = this.options.slice(0);
|
|
|
|
this.options.splice(0, this.options.length);
|
|
|
|
|
2023-03-28 19:54:52 +01:00
|
|
|
this.scene.tweens.add({
|
2023-11-10 20:51:34 +00:00
|
|
|
targets: options,
|
2023-03-28 19:54:52 +01:00
|
|
|
scale: 0.01,
|
|
|
|
duration: 250,
|
2023-04-22 16:46:52 +01:00
|
|
|
ease: 'Cubic.easeIn',
|
2023-11-10 20:51:34 +00:00
|
|
|
onComplete: () => options.forEach(o => o.destroy())
|
2023-03-28 19:54:52 +01:00
|
|
|
});
|
2023-11-10 20:51:34 +00:00
|
|
|
|
2023-11-10 21:41:02 +00:00
|
|
|
[ this.rerollButtonContainer, this.transferButtonContainer ].forEach(container => {
|
|
|
|
if (container.visible) {
|
|
|
|
this.scene.tweens.add({
|
|
|
|
targets: container,
|
|
|
|
alpha: 0,
|
|
|
|
duration: 250,
|
|
|
|
ease: 'Cubic.easeIn',
|
|
|
|
onComplete: () => {
|
|
|
|
if (!this.options.length)
|
|
|
|
container.setVisible(false);
|
|
|
|
else
|
|
|
|
container.setAlpha(1);
|
2023-11-10 20:51:34 +00:00
|
|
|
}
|
2023-11-10 21:41:02 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
2023-03-28 19:54:52 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
eraseCursor() {
|
|
|
|
if (this.cursorObj)
|
|
|
|
this.cursorObj.destroy();
|
|
|
|
this.cursorObj = null;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
class ModifierOption extends Phaser.GameObjects.Container {
|
2023-04-12 17:48:02 +01:00
|
|
|
public modifierTypeOption: ModifierTypeOption;
|
2023-03-28 19:54:52 +01:00
|
|
|
private pb: Phaser.GameObjects.Sprite;
|
2023-04-12 17:48:02 +01:00
|
|
|
private pbTint: Phaser.GameObjects.Sprite;
|
2023-03-28 19:54:52 +01:00
|
|
|
private itemContainer: Phaser.GameObjects.Container;
|
|
|
|
private item: Phaser.GameObjects.Sprite;
|
|
|
|
private itemTint: Phaser.GameObjects.Sprite;
|
|
|
|
private itemText: Phaser.GameObjects.Text;
|
|
|
|
|
2023-04-12 17:48:02 +01:00
|
|
|
constructor(scene: BattleScene, x: number, y: number, modifierTypeOption: ModifierTypeOption) {
|
2023-03-28 19:54:52 +01:00
|
|
|
super(scene, x, y);
|
|
|
|
|
2023-04-12 17:48:02 +01:00
|
|
|
this.modifierTypeOption = modifierTypeOption;
|
2023-03-28 19:54:52 +01:00
|
|
|
|
|
|
|
this.setup();
|
|
|
|
}
|
|
|
|
|
|
|
|
setup() {
|
2023-04-12 17:48:02 +01:00
|
|
|
const getPb = (): Phaser.GameObjects.Sprite => {
|
|
|
|
const pb = this.scene.add.sprite(0, -150, 'pb', this.getPbAtlasKey(true));
|
|
|
|
pb.setScale(2);
|
|
|
|
return pb;
|
|
|
|
};
|
|
|
|
|
|
|
|
this.pb = getPb();
|
2023-03-28 19:54:52 +01:00
|
|
|
this.add(this.pb);
|
|
|
|
|
2023-04-12 17:48:02 +01:00
|
|
|
this.pbTint = getPb();
|
|
|
|
this.pbTint.setVisible(false);
|
|
|
|
this.add(this.pbTint);
|
|
|
|
|
2023-03-28 19:54:52 +01:00
|
|
|
this.itemContainer = this.scene.add.container(0, 0);
|
|
|
|
this.itemContainer.setScale(0.5);
|
|
|
|
this.itemContainer.setAlpha(0);
|
|
|
|
this.add(this.itemContainer);
|
|
|
|
|
|
|
|
const getItem = () => {
|
2023-04-12 17:48:02 +01:00
|
|
|
const item = this.scene.add.sprite(0, 0, 'items', this.modifierTypeOption.type.iconImage);
|
2023-03-28 19:54:52 +01:00
|
|
|
return item;
|
|
|
|
};
|
|
|
|
|
|
|
|
this.item = getItem();
|
|
|
|
this.itemContainer.add(this.item);
|
|
|
|
|
|
|
|
this.itemTint = getItem();
|
|
|
|
this.itemTint.setTintFill(Phaser.Display.Color.GetColor(255, 192, 255));
|
|
|
|
this.itemContainer.add(this.itemTint);
|
|
|
|
|
2023-04-12 17:48:02 +01:00
|
|
|
this.itemText = addTextObject(this.scene, 0, 35, this.modifierTypeOption.type.name, TextStyle.PARTY, { align: 'center' });
|
2023-03-28 19:54:52 +01:00
|
|
|
this.itemText.setOrigin(0.5, 0);
|
|
|
|
this.itemText.setAlpha(0);
|
2023-11-02 04:55:20 +00:00
|
|
|
this.itemText.setTint(getModifierTierTextTint(this.modifierTypeOption.type.tier));
|
2023-03-28 19:54:52 +01:00
|
|
|
this.add(this.itemText);
|
|
|
|
}
|
|
|
|
|
|
|
|
show(remainingDuration: integer) {
|
|
|
|
this.scene.tweens.add({
|
|
|
|
targets: this.pb,
|
|
|
|
y: 0,
|
|
|
|
duration: 1250,
|
|
|
|
ease: 'Bounce.Out'
|
|
|
|
});
|
|
|
|
|
|
|
|
let lastValue = 1;
|
|
|
|
let bounceCount = 0;
|
|
|
|
let bounce = false;
|
|
|
|
|
|
|
|
this.scene.tweens.addCounter({
|
|
|
|
from: 1,
|
|
|
|
to: 0,
|
|
|
|
duration: 1250,
|
|
|
|
ease: 'Bounce.Out',
|
|
|
|
onUpdate: t => {
|
2023-03-29 05:31:25 +01:00
|
|
|
if (!this.scene)
|
|
|
|
return;
|
2023-03-28 19:54:52 +01:00
|
|
|
const value = t.getValue();
|
|
|
|
if (!bounce && value > lastValue) {
|
2023-10-21 13:58:39 +01:00
|
|
|
(this.scene as BattleScene).playSound('pb_bounce_1', { volume: 1 / ++bounceCount });
|
2023-03-28 19:54:52 +01:00
|
|
|
bounce = true;
|
|
|
|
} else if (bounce && value < lastValue)
|
|
|
|
bounce = false;
|
|
|
|
lastValue = value;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2023-04-12 17:48:02 +01:00
|
|
|
if (this.modifierTypeOption.upgraded) {
|
|
|
|
this.scene.time.delayedCall(remainingDuration, () => {
|
2023-10-21 13:58:39 +01:00
|
|
|
(this.scene as BattleScene).playSound('upgrade');
|
2023-04-12 17:48:02 +01:00
|
|
|
this.pbTint.setPosition(this.pb.x, this.pb.y);
|
|
|
|
this.pbTint.setTintFill(0xFFFFFF);
|
|
|
|
this.pbTint.setAlpha(0);
|
|
|
|
this.pbTint.setVisible(true);
|
|
|
|
this.scene.tweens.add({
|
|
|
|
targets: this.pbTint,
|
|
|
|
alpha: 1,
|
|
|
|
duration: 1000,
|
|
|
|
ease: 'Sine.easeIn',
|
|
|
|
onComplete: () => {
|
|
|
|
this.pb.setTexture('pb', this.getPbAtlasKey(false));
|
|
|
|
this.scene.tweens.add({
|
|
|
|
targets: this.pbTint,
|
|
|
|
alpha: 0,
|
|
|
|
duration: 1000,
|
|
|
|
ease: 'Sine.easeOut',
|
|
|
|
onComplete: () => {
|
|
|
|
this.pbTint.setVisible(false);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2023-03-28 19:54:52 +01:00
|
|
|
this.scene.time.delayedCall(remainingDuration + 2000, () => {
|
2023-03-29 05:31:25 +01:00
|
|
|
if (!this.scene)
|
|
|
|
return;
|
|
|
|
|
2023-04-12 17:48:02 +01:00
|
|
|
this.pb.setTexture('pb', `${this.getPbAtlasKey(false)}_open`);
|
2023-10-21 13:58:39 +01:00
|
|
|
(this.scene as BattleScene).playSound('pb_rel');
|
2023-03-28 19:54:52 +01:00
|
|
|
|
|
|
|
this.scene.tweens.add({
|
|
|
|
targets: this.pb,
|
|
|
|
duration: 500,
|
|
|
|
delay: 250,
|
|
|
|
ease: 'Sine.easeIn',
|
|
|
|
alpha: 0,
|
|
|
|
onComplete: () => this.pb.destroy()
|
|
|
|
})
|
|
|
|
this.scene.tweens.add({
|
|
|
|
targets: this.itemContainer,
|
|
|
|
duration: 500,
|
|
|
|
ease: 'Elastic.Out',
|
|
|
|
scale: 2,
|
|
|
|
alpha: 1
|
|
|
|
});
|
|
|
|
this.scene.tweens.add({
|
|
|
|
targets: this.itemTint,
|
|
|
|
alpha: 0,
|
|
|
|
duration: 500,
|
|
|
|
ease: 'Sine.easeIn',
|
|
|
|
onComplete: () => this.itemTint.destroy()
|
|
|
|
});
|
|
|
|
this.scene.tweens.add({
|
|
|
|
targets: this.itemText,
|
|
|
|
duration: 500,
|
|
|
|
alpha: 1,
|
|
|
|
y: 25,
|
|
|
|
ease: 'Cubic.easeInOut'
|
|
|
|
});
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2023-04-12 17:48:02 +01:00
|
|
|
getPbAtlasKey(beforeUpgrade: boolean) {
|
|
|
|
return getPokeballAtlasKey((this.modifierTypeOption.type.tier - (beforeUpgrade && this.modifierTypeOption.upgraded ? 1 : 0)) as integer as PokeballType);
|
2023-03-28 19:54:52 +01:00
|
|
|
}
|
|
|
|
}
|