5.3 KiB
MenuGraphr
In-game menu and dialog creation and management for EightBittr.
MenuGraphr automates creating in-game menus containing paragraphs or scrolling lists of text. Each menu has a unique name by which its globally identified as well as a rectangular position relative to its parent. Menus can be positioned as children of the root game's MapScreenr viewport or of each other.
Usage
MenuGraphr instances take in, at the very least, a EightBittr game to create Things within.
The game should have have a "Menu" Thing defined.
Constructor
const eightBitter = new EightBittr({ ... });
const menuGrapher = new MenuGraphr({ eightBitter });
eightBitter
The parent EightBittr managing Things. This is the only mandatory settings field.
aliases
Alternate Thing titles for characters, such as " " for "Space".
Normally, Things used as menu text have titles equal to "Text" plus the name of the character.
These will replace the name of the character in that computation.
// Uses "TextSpace" instead of "Text "
new MenuGraphr({
aliases: {
" ": "Space",
},
eightBitter,
});
sounds
Sounds that should be played for certain menu actions.
So far, this is only onInteraction, which is whenever a menu is interacted with
(usually off the A or B buttons being pressed).
These are played with the EightBittr's AudioPlayr.
new MenuGraphr({
eightBitter,
sounds: {
onInteraction: "Bloop",
}
});
replacements
Programmatic replacements for deliniated words. Allows texts in menus to contain dynamic values using predetermined strings.
These can be hardcoded strings or functions to generate them.
new MenuGraphr({
eightBitter,
replacements: {
"DYNAMIC": () => eightBitter.itemsHolder.get("dynamic-value"),
"STATIC": "My name here!",
},
});
Menu dialogs and lists will directly replace the values of replacements between the menu's replacerKey (see below):
menuGrapher.addMenuDialog("GeneralText", [
// Inserts the value of eightBitter.itemsHolder.get("dynamic-value")
"Dynamic value: %%%%%%%DYNAMIC%%%%%%%",
// Inserts "My name here!"
"Static value: %%%%%%%STATIC%%%%%%%",
]);
replacerKey
Separator for words to replace using replacements.
Defaults to "%%%%%%%".
new MenuGraphr({
eightBitter,
replacements: {
"STATIC": "My name here!",
},
replacerKey: "|",
});
menuGrapher.addMenuDialog("GeneralText", [
// Inserts "My name here!"
"Static value: |STATIC|",
]);
schemas
Known menu schemas, keyed by name.
Those properties are defined on IMenuSchema.
See docs/schemas.md.
new MenuGraphr({
eightBitter,
schemas: {
GeneralText: {
size: {
height: 96,
width: 320,
},
},
},
});
createMenu
Menus are created with createMenu, which takes in the string name of the menu and any additional schema properties.
See docs/schemas.md.
menuGrapher.createMenu("GeneralText", { /* ... */ });
Each menu is identified by a unique string name.
When createMenu creates a menu, any existing menu under that name is disposed of.
setActiveMenu
Sets a menu to appear to have user focus. For dialogs, this allows the user to "A" through them. For lists, this visualizes the selected index with an "Arrow" Thing.
Only one menu may be active at any time. There does not need to be an active menu, and menus are not active by default.
menuGrapher.createMenu("GeneralText");
menuGrapher.addMenuDialog("GeneralText", "Hello world!");
menuGrapher.setActiveMenu("GeneralText");
Development
After forking the repo from GitHub:
git clone https://github.com/<your-name-here>/MenuGraphr
cd MenuGraphr
npm install
npm run setup
npm run verify
npm run setupcreates a few auto-generated setup files locally.npm run verifybuilds, lints, and runs tests.
Building
npm run watch
Source files are written under src/ in TypeScript and compile in-place to JavaScript files.
npm run watch will directly run the TypeScript compiler on source files in watch mode.
Use it in the background while developing to keep the compiled files up-to-date.
Running Tests
npm run test
Tests are written in Mocha and Chai.
Their files are written using alongside source files under src/ and named *.test.ts?.
Whenever you add, remove, or rename a *.test.t* file under src/, watch will re-run npm run test:setup to regenerate the list of static test files in test/index.html.
You can open that file in a browser to debug through the tests.