pokerogue/src/ui/text.ts

92 lines
2.5 KiB
TypeScript
Raw Normal View History

2023-03-28 11:54:52 -07:00
export enum TextStyle {
MESSAGE,
WINDOW,
2023-04-01 17:06:44 -07:00
BATTLE_INFO,
PARTY,
PARTY_RED,
SUMMARY,
SUMMARY_RED,
SUMMARY_GOLD,
2023-10-26 13:33:59 -07:00
MONEY,
SETTINGS_LABEL,
SETTINGS_SELECTED
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
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) {
case TextStyle.SUMMARY:
case TextStyle.SUMMARY_RED:
case TextStyle.SUMMARY_GOLD:
2023-03-28 11:54:52 -07:00
case TextStyle.WINDOW:
case TextStyle.MESSAGE:
2023-10-26 13:33:59 -07:00
case TextStyle.SETTINGS_LABEL:
case TextStyle.SETTINGS_SELECTED:
styleOptions.fontSize = '96px';
2023-03-28 11:54:52 -07:00
break;
2023-04-01 17:06:44 -07:00
case TextStyle.BATTLE_INFO:
case TextStyle.MONEY:
styleOptions.fontSize = '72px';
2023-04-01 17:06:44 -07:00
shadowSize = 4;
break;
2023-03-28 11:54:52 -07:00
case TextStyle.PARTY:
case TextStyle.PARTY_RED:
styleOptions.fontFamily = 'pkmnems';
styleOptions.fontSize = '66px';
break;
2023-03-28 11:54:52 -07:00
}
shadowColor = getTextColor(style, true);
2023-04-26 09:50:21 -07:00
if (extraStyleOptions) {
if (extraStyleOptions.fontSize) {
const sizeRatio = parseInt(extraStyleOptions.fontSize.toString().slice(0, -2)) / parseInt(styleOptions.fontSize.slice(0, -2));
2023-04-26 09:50:21 -07:00
shadowSize *= sizeRatio;
}
2023-03-28 11:54:52 -07:00
styleOptions = Object.assign(styleOptions, extraStyleOptions);
2023-04-26 09:50:21 -07:00
}
2023-03-28 11:54:52 -07:00
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;
}
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.PARTY_RED:
return !shadow ? '#f89890' : '#984038';
case TextStyle.SUMMARY:
return !shadow ? '#ffffff' : '#636363';
case TextStyle.SUMMARY_RED:
return !shadow ? '#f89890' : '#984038';
case TextStyle.SUMMARY_GOLD:
case TextStyle.MONEY:
return !shadow ? '#e8e8a8' : '#a0a060'
2023-10-26 13:33:59 -07:00
case TextStyle.SETTINGS_LABEL:
return !shadow ? '#f8b050' : '#c07800';
case TextStyle.SETTINGS_SELECTED:
return !shadow ? '#f88880' : '#f83018';
}
2023-03-28 11:54:52 -07:00
}