2023-03-28 11:54:52 -07:00
|
|
|
export enum TextStyle {
|
|
|
|
MESSAGE,
|
|
|
|
WINDOW,
|
2023-04-01 17:06:44 -07:00
|
|
|
BATTLE_INFO,
|
2023-04-06 19:24:13 -07:00
|
|
|
PARTY,
|
|
|
|
SUMMARY,
|
2023-04-23 16:41:32 -07:00
|
|
|
SUMMARY_RED,
|
|
|
|
SUMMARY_GOLD
|
2023-03-28 11:54:52 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
export function addTextObject(scene: Phaser.Scene, x: number, y: number, content: string, style: TextStyle, extraStyleOptions?: Phaser.Types.GameObjects.Text.TextStyle) {
|
2023-04-08 17:35:45 -07:00
|
|
|
let shadowColor: string;
|
2023-04-01 17:06:44 -07:00
|
|
|
let shadowSize = 6;
|
2023-03-28 11:54:52 -07:00
|
|
|
|
2023-04-23 16:41:32 -07:00
|
|
|
let styleOptions: Phaser.Types.GameObjects.Text.TextStyle = {
|
|
|
|
fontFamily: 'emerald',
|
|
|
|
fontSize: '96px',
|
|
|
|
color: getTextColor(style, false),
|
|
|
|
padding: {
|
|
|
|
bottom: 6
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2023-03-28 11:54:52 -07:00
|
|
|
switch (style) {
|
2023-04-23 16:41:32 -07:00
|
|
|
case TextStyle.SUMMARY:
|
|
|
|
case TextStyle.SUMMARY_RED:
|
|
|
|
case TextStyle.SUMMARY_GOLD:
|
|
|
|
styleOptions.padding = undefined;
|
2023-03-28 11:54:52 -07:00
|
|
|
case TextStyle.WINDOW:
|
|
|
|
case TextStyle.MESSAGE:
|
2023-04-23 16:41:32 -07:00
|
|
|
styleOptions.fontSize = '96px';
|
2023-03-28 11:54:52 -07:00
|
|
|
break;
|
2023-04-01 17:06:44 -07:00
|
|
|
case TextStyle.BATTLE_INFO:
|
2023-04-23 16:41:32 -07:00
|
|
|
styleOptions.fontSize = '72px';
|
|
|
|
styleOptions.padding = undefined;
|
2023-04-01 17:06:44 -07:00
|
|
|
shadowSize = 4;
|
|
|
|
break;
|
2023-03-28 11:54:52 -07:00
|
|
|
case TextStyle.PARTY:
|
2023-04-23 16:41:32 -07:00
|
|
|
styleOptions.fontFamily = 'pkmnems';
|
|
|
|
styleOptions.fontSize = '66px';
|
2023-04-06 19:24:13 -07:00
|
|
|
break;
|
2023-03-28 11:54:52 -07:00
|
|
|
}
|
|
|
|
|
2023-04-23 16:41:32 -07:00
|
|
|
shadowColor = getTextColor(style, true);
|
|
|
|
|
2023-03-28 11:54:52 -07:00
|
|
|
if (extraStyleOptions)
|
|
|
|
styleOptions = Object.assign(styleOptions, extraStyleOptions);
|
|
|
|
|
|
|
|
const ret = scene.add.text(x, y, content, styleOptions);
|
|
|
|
ret.setScale(0.1666666667);
|
2023-04-01 17:06:44 -07:00
|
|
|
ret.setShadow(shadowSize, shadowSize, shadowColor);
|
2023-03-28 11:54:52 -07:00
|
|
|
ret.setLineSpacing(5);
|
|
|
|
|
|
|
|
return ret;
|
2023-04-23 16:41:32 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
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'
|
|
|
|
}
|
2023-03-28 11:54:52 -07:00
|
|
|
}
|