export enum TextStyle { MESSAGE, WINDOW, BATTLE_INFO, PARTY, SUMMARY, SUMMARY_RED, SUMMARY_GOLD }; export function addTextObject(scene: Phaser.Scene, x: number, y: number, content: string, style: TextStyle, extraStyleOptions?: Phaser.Types.GameObjects.Text.TextStyle) { let shadowColor: string; let shadowSize = 6; let styleOptions: Phaser.Types.GameObjects.Text.TextStyle = { fontFamily: 'emerald', fontSize: '96px', color: getTextColor(style, false), padding: { bottom: 6 } }; switch (style) { case TextStyle.SUMMARY: case TextStyle.SUMMARY_RED: case TextStyle.SUMMARY_GOLD: styleOptions.padding = undefined; case TextStyle.WINDOW: case TextStyle.MESSAGE: styleOptions.fontSize = '96px'; break; case TextStyle.BATTLE_INFO: styleOptions.fontSize = '72px'; styleOptions.padding = undefined; shadowSize = 4; break; case TextStyle.PARTY: styleOptions.fontFamily = 'pkmnems'; styleOptions.fontSize = '66px'; break; } shadowColor = getTextColor(style, true); if (extraStyleOptions) { if (extraStyleOptions.fontSize) { const sizeRatio = parseInt(extraStyleOptions.fontSize.slice(0, -2)) / parseInt(styleOptions.fontSize.slice(0, -2)); shadowSize *= sizeRatio; } styleOptions = Object.assign(styleOptions, extraStyleOptions); } const ret = scene.add.text(x, y, content, styleOptions); ret.setScale(0.1666666667); ret.setShadow(shadowSize, shadowSize, shadowColor); ret.setLineSpacing(5); return ret; } export function getTextColor(textStyle: TextStyle, shadow?: boolean) { switch (textStyle) { case TextStyle.MESSAGE: return !shadow ? '#f8f8f8' : '#6b5a73'; case TextStyle.WINDOW: return !shadow ? '#484848' : '#d0d0c8'; case TextStyle.BATTLE_INFO: return !shadow ? '#404040' : '#ded6b5'; case TextStyle.PARTY: return !shadow ? '#f8f8f8' : '#707070'; case TextStyle.SUMMARY: return !shadow ? '#ffffff' : '#636363'; case TextStyle.SUMMARY_RED: return !shadow ? '#f89890' : '#984038'; case TextStyle.SUMMARY_GOLD: return !shadow ? '#e8e8a8' : '#a0a060' } }