mirror of
https://github.com/britzl/monarch.git
synced 2025-11-26 19:00:53 +01:00
Compare commits
27 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
2eb67bf29d | ||
|
|
fe8341263a | ||
|
|
e0b0a286e3 | ||
|
|
c14e4a8a46 | ||
|
|
482e319285 | ||
|
|
9c7ce61f6f | ||
|
|
f5afbad233 | ||
|
|
6fdde9d2a8 | ||
|
|
d963b583b1 | ||
|
|
6fe59c92c4 | ||
|
|
286a270a1c | ||
|
|
c0d45c3d5c | ||
|
|
bcc6264cd4 | ||
|
|
1dec704047 | ||
|
|
9764c68475 | ||
|
|
d57d550859 | ||
|
|
17df189089 | ||
|
|
387a1805eb | ||
|
|
e26da2c6c5 | ||
|
|
c75b1b0044 | ||
|
|
d3799a93ff | ||
|
|
76d4ca2927 | ||
|
|
9e81b3a327 | ||
|
|
4927d6e766 | ||
|
|
20cf731fdb | ||
|
|
466b558e73 | ||
|
|
398e78670f |
2
.github/workflows/ci-workflow.yml
vendored
2
.github/workflows/ci-workflow.yml
vendored
@@ -16,4 +16,4 @@ jobs:
|
|||||||
DEFOLD_USER: bjorn.ritzl@gmail.com
|
DEFOLD_USER: bjorn.ritzl@gmail.com
|
||||||
DEFOLD_AUTH: foobar
|
DEFOLD_AUTH: foobar
|
||||||
DEFOLD_BOOSTRAP_COLLECTION: /test/test.collectionc
|
DEFOLD_BOOSTRAP_COLLECTION: /test/test.collectionc
|
||||||
run: ./.travis/run.sh
|
run: ./.test/run.sh
|
||||||
|
|||||||
42
.luacheckrc
42
.luacheckrc
@@ -1,42 +0,0 @@
|
|||||||
std = "max"
|
|
||||||
files['.luacheckrc'].global = false
|
|
||||||
unused_args = false
|
|
||||||
|
|
||||||
globals = {
|
|
||||||
"sys",
|
|
||||||
"go",
|
|
||||||
"gui",
|
|
||||||
"label",
|
|
||||||
"render",
|
|
||||||
"crash",
|
|
||||||
"sprite",
|
|
||||||
"sound",
|
|
||||||
"tilemap",
|
|
||||||
"spine",
|
|
||||||
"particlefx",
|
|
||||||
"physics",
|
|
||||||
"factory",
|
|
||||||
"collectionfactory",
|
|
||||||
"iac",
|
|
||||||
"msg",
|
|
||||||
"vmath",
|
|
||||||
"url",
|
|
||||||
"http",
|
|
||||||
"image",
|
|
||||||
"json",
|
|
||||||
"zlib",
|
|
||||||
"iap",
|
|
||||||
"push",
|
|
||||||
"facebook",
|
|
||||||
"hash",
|
|
||||||
"hash_to_hex",
|
|
||||||
"pprint",
|
|
||||||
"init",
|
|
||||||
"final",
|
|
||||||
"update",
|
|
||||||
"on_input",
|
|
||||||
"on_message",
|
|
||||||
"on_reload",
|
|
||||||
"window",
|
|
||||||
"unityads"
|
|
||||||
}
|
|
||||||
@@ -19,12 +19,12 @@ BOB_URL="http://d.defold.com/archive/${SHA1}/bob/bob.jar"
|
|||||||
|
|
||||||
# Download dmengine_headless
|
# Download dmengine_headless
|
||||||
echo "Downloading ${DMENGINE_URL}"
|
echo "Downloading ${DMENGINE_URL}"
|
||||||
curl -o dmengine_headless ${DMENGINE_URL}
|
curl -L -o dmengine_headless ${DMENGINE_URL}
|
||||||
chmod +x dmengine_headless
|
chmod +x dmengine_headless
|
||||||
|
|
||||||
# Download bob.jar
|
# Download bob.jar
|
||||||
echo "Downloading ${BOB_URL}"
|
echo "Downloading ${BOB_URL}"
|
||||||
curl -o bob.jar ${BOB_URL}
|
curl -L -o bob.jar ${BOB_URL}
|
||||||
|
|
||||||
# Fetch libraries
|
# Fetch libraries
|
||||||
echo "Running bob.jar - resolving dependencies"
|
echo "Running bob.jar - resolving dependencies"
|
||||||
30
.travis.yml
30
.travis.yml
@@ -1,30 +0,0 @@
|
|||||||
sudo: required
|
|
||||||
|
|
||||||
dist: bionic
|
|
||||||
|
|
||||||
script:
|
|
||||||
- sudo unlink /usr/bin/gcc && sudo ln -s /usr/bin/gcc-5 /usr/bin/gcc
|
|
||||||
- gcc --version
|
|
||||||
|
|
||||||
addons:
|
|
||||||
apt:
|
|
||||||
sources:
|
|
||||||
- ubuntu-toolchain-r-test
|
|
||||||
packages:
|
|
||||||
- gcc-5
|
|
||||||
- g++-5
|
|
||||||
|
|
||||||
language: java
|
|
||||||
|
|
||||||
jdk:
|
|
||||||
- oraclejdk11
|
|
||||||
|
|
||||||
env:
|
|
||||||
global:
|
|
||||||
- DEFOLD_BOOSTRAP_COLLECTION=/test/test.collectionc
|
|
||||||
|
|
||||||
script:
|
|
||||||
- "./.travis/run.sh"
|
|
||||||
|
|
||||||
after_success:
|
|
||||||
- bash <(curl -s https://codecov.io/bash)
|
|
||||||
60
CHANGELOG.md
60
CHANGELOG.md
@@ -1,60 +0,0 @@
|
|||||||
## Monarch 2.8.0 [britzl released 2018-06-10]
|
|
||||||
NEW: Prevent show/hide operations while busy showing/hiding another screen
|
|
||||||
FIX: Make sure to properly finish active transitions when layout changes
|
|
||||||
|
|
||||||
## Monarch 2.7.0 [britzl released 2018-06-04]
|
|
||||||
NEW: Added monarch.top([offset]) and monarch.bottom([offset]) to get screen id of top and bottom screens (w. optional offset)
|
|
||||||
NEW: Transition messages now contain `next_screen` or `previous_screen`
|
|
||||||
|
|
||||||
## Monarch 2.6.1 [britzl released 2018-06-04]
|
|
||||||
FIX: Check if screen has already been preloaded before trying to preload it again (the callback will still be invoked).
|
|
||||||
|
|
||||||
## Monarch 2.6.0 [britzl released 2018-06-03]
|
|
||||||
NEW: monarch.preload() to load but not show a screen. Useful for content heavy screens that you wish to show without delay.
|
|
||||||
|
|
||||||
## Monarch 2.5.0 [britzl released 2018-06-01]
|
|
||||||
NEW: Transitions will send a `transition_done` message to the creator of the transition to notify that the transition has finished. The `message` will contain which transition that was finished.
|
|
||||||
|
|
||||||
## Monarch 2.4.0 [britzl released 2018-05-26]
|
|
||||||
NEW: Screen transitions are remembered so that they can be replayed when the screen layout changes.
|
|
||||||
|
|
||||||
## Monarch 2.3.0 [britzl released 2018-03-24]
|
|
||||||
CHANGE: The functions in monarch.lua that previously only accepted a hash as screen id now also accepts strings (and does the conversion internally)
|
|
||||||
|
|
||||||
## Monarch 2.2.0 [britzl released 2018-03-19]
|
|
||||||
NEW: Transitions now handle layout changes (via `layout_changed` message)
|
|
||||||
NEW: Transitions can now be notified of changes in window size using transition.window_resize(width, height)
|
|
||||||
|
|
||||||
## Monarch 2.1 [britzl released 2017-12-27]
|
|
||||||
NEW: Added Popup on Popup flag that allows a popup to be shown on top of another popup
|
|
||||||
|
|
||||||
## Monarch 2.0 [britzl released 2017-12-08]
|
|
||||||
BREAKING CHANGE: If you are using custom screen transitions (ie your own transition functions) you need to make a change to the function. The previous function signature was ```(node, to, easing, duration, delay, url)``` where ```url``` was the URL to where the ```transition_done``` message was supposed to be posted. The new function signature for a transition function is: ```(node, to, easing, duration, delay, cb)``` where ```cb``` is a function that should be invoked when the transition is completed.
|
|
||||||
|
|
||||||
FIX: Fixed issues related to screen transitions.
|
|
||||||
FIX: Code cleanup to reduce code duplication.
|
|
||||||
FIX: Improved documentation regarding transitions.
|
|
||||||
|
|
||||||
## Monarch 1.4 [britzl released 2017-12-06]
|
|
||||||
FIX: Several bugfixes for specific corner cases.
|
|
||||||
|
|
||||||
## Monarch 1.3 [britzl released 2017-12-01]
|
|
||||||
FIX: monarch.back(data, cb) set the data on the previous screen not the new current screen.
|
|
||||||
NEW: monarch.is_top(id)
|
|
||||||
NEW: monarch.get_stack()
|
|
||||||
NEW: monarch.in_stack(id)
|
|
||||||
|
|
||||||
## Monarch 1.2 [britzl released 2017-11-28]
|
|
||||||
NEW: Message id constants exposed from the Monarch module
|
|
||||||
NEW: Focus lost/gained contains id of next/previous screen
|
|
||||||
|
|
||||||
## Monarch 1.1 [britzl released 2017-11-22]
|
|
||||||
FIX: Bugfixes for transitions and state under certain circumstances
|
|
||||||
NEW: Added 'reload' option to show() command.
|
|
||||||
|
|
||||||
## Monarch 1.0 [britzl released 2017-09-28]
|
|
||||||
First public stable release
|
|
||||||
|
|
||||||
## Monarch 0.9 [britzl released 2017-09-17]
|
|
||||||
|
|
||||||
|
|
||||||
43
README.md
43
README.md
@@ -37,9 +37,9 @@ For proxies the recommended setup is to create one game object per screen and pe
|
|||||||
* **Timestep below Popup (number)** - Timestep to set on screen proxy when it is below a popup. This is useful when pausing animations and gameplay while a popup is open.
|
* **Timestep below Popup (number)** - Timestep to set on screen proxy when it is below a popup. This is useful when pausing animations and gameplay while a popup is open.
|
||||||
* **Screen Keeps Input Focus When Below Popup (boolean)** - Check this if the screen should keep input focus when it is below a popup.
|
* **Screen Keeps Input Focus When Below Popup (boolean)** - Check this if the screen should keep input focus when it is below a popup.
|
||||||
* **Others Keep Input Focus When Below Screen (boolean)** - Check this if other screens should keep input focus when below this screen.
|
* **Others Keep Input Focus When Below Screen (boolean)** - Check this if other screens should keep input focus when below this screen.
|
||||||
* **Transition Url (url)** - Optional URL to post messages to when the screen is about to be shown/hidden. Use this to trigger a transition (see the section on [transitions](#transitions)).
|
* **Transition Url (url)** - **DEPRECATED** Optional URL to post messages to when the screen is about to be shown/hidden. Use this to trigger a transition (see the section on [transitions](#transitions)).
|
||||||
* **Focus Url (url)** - Optional URL to post messages to when the screen gains or loses focus (see the section on [screen focus](#screen-focus-gainloss)).
|
* **Focus Url (url)** - **DEPRECATED** Optional URL to post messages to when the screen gains or loses focus (see the section on [screen focus](#screen-focus-gainloss)).
|
||||||
* **Receiver Url (url)** - Optional URL to post messages to using `monarch.post()`.
|
* **Receiver Url (url)** - **DEPRECATED** Optional URL to post messages to using `monarch.post()`.
|
||||||
* **Preload (boolean)** - Check this if the screen should be preloaded and kept loaded at all times. For a collection proxy it means that it will be async loaded but not enabled at all times while not visible. This can also temporarily be achieved through the `monarch.preload()` function.
|
* **Preload (boolean)** - Check this if the screen should be preloaded and kept loaded at all times. For a collection proxy it means that it will be async loaded but not enabled at all times while not visible. This can also temporarily be achieved through the `monarch.preload()` function.
|
||||||
|
|
||||||

|

|
||||||
@@ -53,8 +53,8 @@ For factories the recommended setup is to create one game object per screen and
|
|||||||
* **Popup on Popup (boolean)** - Check this if the screen is a [popup](#popups) and it can be shown on top of other popups.
|
* **Popup on Popup (boolean)** - Check this if the screen is a [popup](#popups) and it can be shown on top of other popups.
|
||||||
* **Screen Keeps Input Focus When Below Popup (boolean)** - Check this if the screen should keep input focus when it is below a popup.
|
* **Screen Keeps Input Focus When Below Popup (boolean)** - Check this if the screen should keep input focus when it is below a popup.
|
||||||
* **Others Keep Input Focus When Below Screen (boolean)** - Check this if other screens should keep input focus when below this screen.
|
* **Others Keep Input Focus When Below Screen (boolean)** - Check this if other screens should keep input focus when below this screen.
|
||||||
* **Transition Id (hash)** - Optional id of the game object to send a message to when the screen is about to be shown/hidden. Use this to trigger a transition (see the section on [transitions](#transitions)).
|
* **Transition Id (hash)** - **DEPRECATED** Optional id of the game object to send a message to when the screen is about to be shown/hidden. Use this to trigger a transition (see the section on [transitions](#transitions)).
|
||||||
* **Focus Id (hash)** - Optional id of the game object to send a message to when the screen gains or loses focus (see the section on [screen focus](#screen-focus-gainloss)).
|
* **Focus Id (hash)** - **DEPRECATED** Optional id of the game object to send a message to when the screen gains or loses focus (see the section on [screen focus](#screen-focus-gainloss)).
|
||||||
* **Preload (boolean)** - Check this if the screen should be preloaded and kept loaded at all times. For a collection factory this means that its resources will be dynamically loaded at all times. This can also temporarily be achieved through the `monarch.preload()` function.
|
* **Preload (boolean)** - Check this if the screen should be preloaded and kept loaded at all times. For a collection factory this means that its resources will be dynamically loaded at all times. This can also temporarily be achieved through the `monarch.preload()` function.
|
||||||
|
|
||||||

|

|
||||||
@@ -161,18 +161,30 @@ You can add optional transitions when navigating between screens. This is [descr
|
|||||||
|
|
||||||
|
|
||||||
## Screen focus gain/loss
|
## Screen focus gain/loss
|
||||||
Monarch will send focus gain and focus loss messages if a `Focus Url` (proxy) or `Focus Id` (collectionfactory) was provided when the screen was created. The focus gained message will contain the id of the previous screen and the focus loss message will contain the id of the next screen. Example:
|
Monarch will send focus gain and focus loss messages if a focus change listener has been set using `monarch.on_focus_change(screen_id, fn)`
|
||||||
|
|
||||||
|
DEPRECATED: ~~Monarch will send focus gain and focus loss messages if a `Focus Url` (proxy) or `Focus Id` (collectionfactory) was provided when the screen was created.~~
|
||||||
|
|
||||||
|
The focus gained message will contain the id of the previous screen and the focus loss message will contain the id of the next screen. Example:
|
||||||
|
|
||||||
|
```lua
|
||||||
local monarch = require "monarch.monarch"
|
local monarch = require "monarch.monarch"
|
||||||
|
|
||||||
function on_message(self, message_id, message, sender)
|
function init(self)
|
||||||
if message_id == monarch.FOCUS.GAINED then
|
monarch.on_focus_changed("foobar", function(message_id, message, sender)
|
||||||
print("Focus gained, previous screen: ", message.id)
|
if message_id == monarch.FOCUS.GAINED then
|
||||||
elseif message_id == monarch.FOCUS.LOST then
|
print("Focus gained, previous screen: ", message.id)
|
||||||
print("Focus lost, next screen: ", message.id)
|
elseif message_id == monarch.FOCUS.LOST then
|
||||||
end
|
print("Focus lost, next screen: ", message.id)
|
||||||
|
end
|
||||||
|
end)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
function on_message(self, message_id, message, sender)
|
||||||
|
monarch.on_message(message_id, message, sender)
|
||||||
|
end
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
## Callbacks
|
## Callbacks
|
||||||
Both the `monarch.show()` and `monarch.back()` functions take an optional callback function that will be invoked when the `transition_show_in` (or the `transition_back_in` in the case of a `monarch.back()` call) transition is completed. The transition is considered completed when a `transition_done` message has been received (see section on [transitions](#transitions) above).
|
Both the `monarch.show()` and `monarch.back()` functions take an optional callback function that will be invoked when the `transition_show_in` (or the `transition_back_in` in the case of a `monarch.back()` call) transition is completed. The transition is considered completed when a `transition_done` message has been received (see section on [transitions](#transitions) above).
|
||||||
@@ -180,10 +192,3 @@ Both the `monarch.show()` and `monarch.back()` functions take an optional callba
|
|||||||
|
|
||||||
## Monarch API
|
## Monarch API
|
||||||
The full [Monarch API is documented here](/README_API.md).
|
The full [Monarch API is documented here](/README_API.md).
|
||||||
|
|
||||||
|
|
||||||
## Monarch FAQ
|
|
||||||
|
|
||||||
**Q**: Why am I getting `ERROR GAMEOBJECT: The collection 'default' could not be created since there is already a socket with the same name`?
|
|
||||||
|
|
||||||
**A**: Each collection that you use must be given a unique id. In this case you have more than one collection loaded with the id `default`. Select the root of each collection in the Outline panel and change the Name field in the properties panel from the default value of `default`.
|
|
||||||
|
|||||||
@@ -33,6 +33,13 @@ Hide a screen that has been shown using the `no_stack` option. If used on a scre
|
|||||||
* `success` (boolean) - True if the process of hiding the screen was started successfully.
|
* `success` (boolean) - True if the process of hiding the screen was started successfully.
|
||||||
|
|
||||||
|
|
||||||
|
## monarch.clear([callback])
|
||||||
|
Clear the stack of screens completely. Any visible screen will be hidden by navigating back out from them. This operation will be added to the queue if Monarch is busy.
|
||||||
|
|
||||||
|
**PARAMETERS**
|
||||||
|
* `callback` (function) - Optional function to call when the stack has been cleared.
|
||||||
|
|
||||||
|
|
||||||
## monarch.back([data], [callback])
|
## monarch.back([data], [callback])
|
||||||
Go back to a previous Monarch screen. This operation will be added to the queue if Monarch is busy.
|
Go back to a previous Monarch screen. This operation will be added to the queue if Monarch is busy.
|
||||||
|
|
||||||
@@ -41,13 +48,18 @@ Go back to a previous Monarch screen. This operation will be added to the queue
|
|||||||
* `callback` (function) - Optional function to call when the previous screen is visible.
|
* `callback` (function) - Optional function to call when the previous screen is visible.
|
||||||
|
|
||||||
|
|
||||||
## monarch.preload(screen_id, [callback])
|
## monarch.preload(screen_id, [options], [callback])
|
||||||
Preload a Monarch screen. This will load but not enable the screen. This is useful for content heavy screens that you wish to be able to show without having to wait for it load. This operation will be added to the queue if Monarch is busy.
|
Preload a Monarch screen. This will load but not enable the screen. This is useful for content heavy screens that you wish to be able to show without having to wait for it load. This operation will be added to the queue if Monarch is busy.
|
||||||
|
|
||||||
**PARAMETERS**
|
**PARAMETERS**
|
||||||
* `screen_id` (string|hash) - Id of the screen to preload.
|
* `screen_id` (string|hash) - Id of the screen to preload.
|
||||||
|
* `options` (table)
|
||||||
* `callback` (function) - Optional function to call when the screen is preloaded.
|
* `callback` (function) - Optional function to call when the screen is preloaded.
|
||||||
|
|
||||||
|
The options table can contain the following fields:
|
||||||
|
|
||||||
|
* `keep_loaded` (boolean) - If the `keep_loaded` flag is set Monarch will keep the screen preloaded even after a `hide()` or `back()` navigation event that normally would unload the screen.
|
||||||
|
|
||||||
|
|
||||||
## monarch.is_preloading(screen_id)
|
## monarch.is_preloading(screen_id)
|
||||||
Check if a Monarch screen is preloading (via monarch.preload() or the Preload screen setting).
|
Check if a Monarch screen is preloading (via monarch.preload() or the Preload screen setting).
|
||||||
@@ -142,6 +154,14 @@ Check if a Monarch screen is visible.
|
|||||||
* `exists` (boolean) - True if the screen is visible.
|
* `exists` (boolean) - True if the screen is visible.
|
||||||
|
|
||||||
|
|
||||||
|
## monarch.set_timestep_below_popup(screen_id, timestep)
|
||||||
|
Set the timestep to apply for a screen when below a popup.
|
||||||
|
|
||||||
|
**PARAMETERS**
|
||||||
|
* `screen_id` (string|hash) - Id of the screen to change timestep setting for
|
||||||
|
* `timestep` (number) - Timestep to apply
|
||||||
|
|
||||||
|
|
||||||
## monarch.add_listener([url])
|
## monarch.add_listener([url])
|
||||||
Add a URL that will be notified of navigation events.
|
Add a URL that will be notified of navigation events.
|
||||||
|
|
||||||
@@ -169,6 +189,32 @@ Post a message to a visible screen. If the screen is created through a collectio
|
|||||||
* `error` (string|nil) - Error message if unable to send message
|
* `error` (string|nil) - Error message if unable to send message
|
||||||
|
|
||||||
|
|
||||||
|
## monarch.on_transition(screen_id, fn)
|
||||||
|
Set a function to be called when a screen should transition in our out. The function will receive (message_id, message, sender) with `message_id` being one of the transition constants.
|
||||||
|
IMPORTANT! You must call `monarch.on_message(message_id, message, sender)` from the same script as this function was called.
|
||||||
|
|
||||||
|
**PARAMETERS**
|
||||||
|
* `screen_id` (string|hash) - Id of the screen
|
||||||
|
* `fn` (function) - The function to call when a transition should start
|
||||||
|
|
||||||
|
|
||||||
|
## monarch.on_focus_change(screen_id, fn)
|
||||||
|
Set a function to be called when a screen gains or loses focus. The function will receive (message_id, message, sender) with `message_id` being one of the focus change constants.
|
||||||
|
IMPORTANT! You must call `monarch.on_message(message_id, message, sender)` from the same script as this function was called.
|
||||||
|
|
||||||
|
**PARAMETERS**
|
||||||
|
* `screen_id` (string|hash) - Id of the screen
|
||||||
|
* `fn` (function) - The function to call screen focus changes
|
||||||
|
|
||||||
|
|
||||||
|
## monarch.on_post(screen_id, fn)
|
||||||
|
Set a function to be called when `msg.post()` is called on a specific screen. IMPORTANT! You must call `monarch.on_message(message_id, message, sender)` from the same script as this function was called.
|
||||||
|
|
||||||
|
**PARAMETERS**
|
||||||
|
* `screen_id` (string|hash) - Id of the screen
|
||||||
|
* `fn` (function) - The function to call when the screen receives a message using `msg.post`
|
||||||
|
|
||||||
|
|
||||||
## monarch.debug()
|
## monarch.debug()
|
||||||
Enable verbose logging of the internals of Monarch.
|
Enable verbose logging of the internals of Monarch.
|
||||||
|
|
||||||
|
|||||||
@@ -1,5 +1,7 @@
|
|||||||
# Transitions
|
# Transitions
|
||||||
You can add optional transitions when navigating between screens. The default behavior is that screen navigation is instant but if you have defined a transition for a screen Monarch will wait until the transition is completed before proceeding. The `Transition Url` (proxy) or `Transition Id` (collectionfactory) property described above should be the URL/Id to a script with an `on_message` handlers for the following messages:
|
You can add optional transitions when navigating between screens. The default behavior is that screen navigation is instant but if you have defined a transition for a screen Monarch will wait until the transition is completed before proceeding.
|
||||||
|
|
||||||
|
Transitions are configured through the `monarch.on_transition(screen_id, fn)` function. The function defines for which screen to configure transitions and sets a function to be called when a transition should be started. This function must accept (message_id, message, sender) as arguments, with `message_id` defining which type of transition to start:
|
||||||
|
|
||||||
* `transition_show_in` (constant defined as `monarch.TRANSITION.SHOW_IN`)
|
* `transition_show_in` (constant defined as `monarch.TRANSITION.SHOW_IN`)
|
||||||
* `transition_show_out` (constant defined as `monarch.TRANSITION.SHOW_OUT`)
|
* `transition_show_out` (constant defined as `monarch.TRANSITION.SHOW_OUT`)
|
||||||
@@ -8,6 +10,11 @@ You can add optional transitions when navigating between screens. The default be
|
|||||||
|
|
||||||
When a transition is completed it is up to the developer to send a `transition_done` (constant `monarch.TRANSITION.DONE`) message back to the sender to indicate that the transition is completed and that Monarch can continue the navigation sequence.
|
When a transition is completed it is up to the developer to send a `transition_done` (constant `monarch.TRANSITION.DONE`) message back to the sender to indicate that the transition is completed and that Monarch can continue the navigation sequence.
|
||||||
|
|
||||||
|
## Transition URL
|
||||||
|
This property is deprecated and will be removed in a future version of Monarch.
|
||||||
|
|
||||||
|
~~It is also possible to configure transitions through the `Transition Url` (proxy) or `Transition Id` (collectionfactory) property. This property must be the URL/Id to a script with an `on_message` handlers for the transition messages mentioned above.~~
|
||||||
|
|
||||||
|
|
||||||
## Predefined transitions
|
## Predefined transitions
|
||||||
Monarch comes with a system for setting up transitions easily in a gui_script using the `monarch.transitions.gui` module. Example:
|
Monarch comes with a system for setting up transitions easily in a gui_script using the `monarch.transitions.gui` module. Example:
|
||||||
@@ -20,15 +27,17 @@ function init(self)
|
|||||||
-- create transitions for the node 'root'
|
-- create transitions for the node 'root'
|
||||||
-- the node will slide in/out from left and right with
|
-- the node will slide in/out from left and right with
|
||||||
-- a specific easing, duration and delay
|
-- a specific easing, duration and delay
|
||||||
self.transition = transitions.create(gui.get_node("root"))
|
local transition = transitions.create(gui.get_node("root"))
|
||||||
.show_in(transitions.slide_in_right, gui.EASING_OUTQUAD, 0.6, 0)
|
.show_in(transitions.slide_in_right, gui.EASING_OUTQUAD, 0.6, 0)
|
||||||
.show_out(transitions.slide_out_left, gui.EASING_INQUAD, 0.6, 0)
|
.show_out(transitions.slide_out_left, gui.EASING_INQUAD, 0.6, 0)
|
||||||
.back_in(transitions.slide_in_left, gui.EASING_OUTQUAD, 0.6, 0)
|
.back_in(transitions.slide_in_left, gui.EASING_OUTQUAD, 0.6, 0)
|
||||||
.back_out(transitions.slide_out_right, gui.EASING_INQUAD, 0.6, 0)
|
.back_out(transitions.slide_out_right, gui.EASING_INQUAD, 0.6, 0)
|
||||||
|
|
||||||
|
monarch.on_transition("foobar", transition)
|
||||||
end
|
end
|
||||||
|
|
||||||
function on_message(self, message_id, message, sender)
|
function on_message(self, message_id, message, sender)
|
||||||
self.transition.handle(message_id, message, sender)
|
monarch.on_message(message_id, message, sender)
|
||||||
-- you can also check when a transition has completed:
|
-- you can also check when a transition has completed:
|
||||||
if message_id == monarch.TRANSITION.DONE and message.transition == monarch.TRANSITION.SHOW_IN then
|
if message_id == monarch.TRANSITION.DONE and message.transition == monarch.TRANSITION.SHOW_IN then
|
||||||
print("Show in done!")
|
print("Show in done!")
|
||||||
@@ -40,7 +49,7 @@ It is also possible to assign transitions to multiple nodes:
|
|||||||
|
|
||||||
```lua
|
```lua
|
||||||
function init(self)
|
function init(self)
|
||||||
self.transition = transitions.create() -- note that no node is passed to transition.create()!
|
local transition = transitions.create() -- note that no node is passed to transition.create()!
|
||||||
.show_in(gui.get_node("node1"), transitions.slide_in_right, gui.EASING_OUTQUAD, 0.6, 0)
|
.show_in(gui.get_node("node1"), transitions.slide_in_right, gui.EASING_OUTQUAD, 0.6, 0)
|
||||||
.show_in(gui.get_node("node2"), transitions.slide_in_right, gui.EASING_OUTQUAD, 0.6, 0)
|
.show_in(gui.get_node("node2"), transitions.slide_in_right, gui.EASING_OUTQUAD, 0.6, 0)
|
||||||
end
|
end
|
||||||
@@ -111,7 +120,7 @@ end
|
|||||||
```
|
```
|
||||||
|
|
||||||
## Screen stack info and transitions
|
## Screen stack info and transitions
|
||||||
The transition message sent to the Transition Url specified in the screen configuration contains additional information about the transition. For the `transition_show_in` and `transition_back_out` messages the message contains the previous screen id:
|
The transition message sent transition listener script contains additional information about the transition. For the `transition_show_in` and `transition_back_out` messages the message contains the previous screen id:
|
||||||
|
|
||||||
```lua
|
```lua
|
||||||
function on_message(self, message_id, message, sender)
|
function on_message(self, message_id, message, sender)
|
||||||
|
|||||||
@@ -4,7 +4,7 @@ embedded_instances {
|
|||||||
id: "go"
|
id: "go"
|
||||||
data: "components {\n"
|
data: "components {\n"
|
||||||
" id: \"about\"\n"
|
" id: \"about\"\n"
|
||||||
" component: \"/example/about.gui\"\n"
|
" component: \"/example/advanced/about.gui\"\n"
|
||||||
" position {\n"
|
" position {\n"
|
||||||
" x: 0.0\n"
|
" x: 0.0\n"
|
||||||
" y: 0.0\n"
|
" y: 0.0\n"
|
||||||
@@ -1,4 +1,4 @@
|
|||||||
script: "/example/about.gui_script"
|
script: "/example/advanced/about.gui_script"
|
||||||
fonts {
|
fonts {
|
||||||
name: "example"
|
name: "example"
|
||||||
font: "/assets/example.font"
|
font: "/assets/example.font"
|
||||||
@@ -1,4 +1,4 @@
|
|||||||
name: "example"
|
name: "advanced"
|
||||||
scale_along_z: 0
|
scale_along_z: 0
|
||||||
embedded_instances {
|
embedded_instances {
|
||||||
id: "menu"
|
id: "menu"
|
||||||
@@ -31,12 +31,15 @@ embedded_instances {
|
|||||||
" value: \"/go\"\n"
|
" value: \"/go\"\n"
|
||||||
" type: PROPERTY_TYPE_HASH\n"
|
" type: PROPERTY_TYPE_HASH\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
|
" property_decls {\n"
|
||||||
|
" }\n"
|
||||||
"}\n"
|
"}\n"
|
||||||
"embedded_components {\n"
|
"embedded_components {\n"
|
||||||
" id: \"collectionfactory\"\n"
|
" id: \"collectionfactory\"\n"
|
||||||
" type: \"collectionfactory\"\n"
|
" type: \"collectionfactory\"\n"
|
||||||
" data: \"prototype: \\\"/example/menu.collection\\\"\\n"
|
" data: \"prototype: \\\"/example/advanced/menu.collection\\\"\\n"
|
||||||
"load_dynamically: true\\n"
|
"load_dynamically: true\\n"
|
||||||
|
"dynamic_prototype: false\\n"
|
||||||
"\"\n"
|
"\"\n"
|
||||||
" position {\n"
|
" position {\n"
|
||||||
" x: 0.0\n"
|
" x: 0.0\n"
|
||||||
@@ -72,7 +75,7 @@ embedded_instances {
|
|||||||
id: "main"
|
id: "main"
|
||||||
data: "components {\n"
|
data: "components {\n"
|
||||||
" id: \"main\"\n"
|
" id: \"main\"\n"
|
||||||
" component: \"/example/main.script\"\n"
|
" component: \"/example/advanced/advanced.script\"\n"
|
||||||
" position {\n"
|
" position {\n"
|
||||||
" x: 0.0\n"
|
" x: 0.0\n"
|
||||||
" y: 0.0\n"
|
" y: 0.0\n"
|
||||||
@@ -84,10 +87,12 @@ embedded_instances {
|
|||||||
" z: 0.0\n"
|
" z: 0.0\n"
|
||||||
" w: 1.0\n"
|
" w: 1.0\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
|
" property_decls {\n"
|
||||||
|
" }\n"
|
||||||
"}\n"
|
"}\n"
|
||||||
"components {\n"
|
"components {\n"
|
||||||
" id: \"gui\"\n"
|
" id: \"gui\"\n"
|
||||||
" component: \"/example/debug.gui\"\n"
|
" component: \"/example/advanced/debug.gui\"\n"
|
||||||
" position {\n"
|
" position {\n"
|
||||||
" x: 0.0\n"
|
" x: 0.0\n"
|
||||||
" y: 0.0\n"
|
" y: 0.0\n"
|
||||||
@@ -99,6 +104,8 @@ embedded_instances {
|
|||||||
" z: 0.0\n"
|
" z: 0.0\n"
|
||||||
" w: 1.0\n"
|
" w: 1.0\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
|
" property_decls {\n"
|
||||||
|
" }\n"
|
||||||
"}\n"
|
"}\n"
|
||||||
""
|
""
|
||||||
position {
|
position {
|
||||||
@@ -144,11 +151,13 @@ embedded_instances {
|
|||||||
" value: \"pregame:/go#pregame\"\n"
|
" value: \"pregame:/go#pregame\"\n"
|
||||||
" type: PROPERTY_TYPE_URL\n"
|
" type: PROPERTY_TYPE_URL\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
|
" property_decls {\n"
|
||||||
|
" }\n"
|
||||||
"}\n"
|
"}\n"
|
||||||
"embedded_components {\n"
|
"embedded_components {\n"
|
||||||
" id: \"collectionproxy\"\n"
|
" id: \"collectionproxy\"\n"
|
||||||
" type: \"collectionproxy\"\n"
|
" type: \"collectionproxy\"\n"
|
||||||
" data: \"collection: \\\"/example/pregame.collection\\\"\\n"
|
" data: \"collection: \\\"/example/advanced/pregame.collection\\\"\\n"
|
||||||
"exclude: false\\n"
|
"exclude: false\\n"
|
||||||
"\"\n"
|
"\"\n"
|
||||||
" position {\n"
|
" position {\n"
|
||||||
@@ -207,11 +216,13 @@ embedded_instances {
|
|||||||
" value: \"game:/go#game\"\n"
|
" value: \"game:/go#game\"\n"
|
||||||
" type: PROPERTY_TYPE_URL\n"
|
" type: PROPERTY_TYPE_URL\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
|
" property_decls {\n"
|
||||||
|
" }\n"
|
||||||
"}\n"
|
"}\n"
|
||||||
"embedded_components {\n"
|
"embedded_components {\n"
|
||||||
" id: \"collectionproxy\"\n"
|
" id: \"collectionproxy\"\n"
|
||||||
" type: \"collectionproxy\"\n"
|
" type: \"collectionproxy\"\n"
|
||||||
" data: \"collection: \\\"/example/game.collection\\\"\\n"
|
" data: \"collection: \\\"/example/advanced/game.collection\\\"\\n"
|
||||||
"exclude: false\\n"
|
"exclude: false\\n"
|
||||||
"\"\n"
|
"\"\n"
|
||||||
" position {\n"
|
" position {\n"
|
||||||
@@ -290,11 +301,13 @@ embedded_instances {
|
|||||||
" value: \"true\"\n"
|
" value: \"true\"\n"
|
||||||
" type: PROPERTY_TYPE_BOOLEAN\n"
|
" type: PROPERTY_TYPE_BOOLEAN\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
|
" property_decls {\n"
|
||||||
|
" }\n"
|
||||||
"}\n"
|
"}\n"
|
||||||
"embedded_components {\n"
|
"embedded_components {\n"
|
||||||
" id: \"collectionproxy\"\n"
|
" id: \"collectionproxy\"\n"
|
||||||
" type: \"collectionproxy\"\n"
|
" type: \"collectionproxy\"\n"
|
||||||
" data: \"collection: \\\"/example/about.collection\\\"\\n"
|
" data: \"collection: \\\"/example/advanced/about.collection\\\"\\n"
|
||||||
"exclude: false\\n"
|
"exclude: false\\n"
|
||||||
"\"\n"
|
"\"\n"
|
||||||
" position {\n"
|
" position {\n"
|
||||||
@@ -368,11 +381,13 @@ embedded_instances {
|
|||||||
" value: \"confirm:/go#confirm\"\n"
|
" value: \"confirm:/go#confirm\"\n"
|
||||||
" type: PROPERTY_TYPE_URL\n"
|
" type: PROPERTY_TYPE_URL\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
|
" property_decls {\n"
|
||||||
|
" }\n"
|
||||||
"}\n"
|
"}\n"
|
||||||
"embedded_components {\n"
|
"embedded_components {\n"
|
||||||
" id: \"collectionproxy\"\n"
|
" id: \"collectionproxy\"\n"
|
||||||
" type: \"collectionproxy\"\n"
|
" type: \"collectionproxy\"\n"
|
||||||
" data: \"collection: \\\"/example/confirm.collection\\\"\\n"
|
" data: \"collection: \\\"/example/advanced/confirm.collection\\\"\\n"
|
||||||
"exclude: false\\n"
|
"exclude: false\\n"
|
||||||
"\"\n"
|
"\"\n"
|
||||||
" position {\n"
|
" position {\n"
|
||||||
@@ -426,12 +441,15 @@ embedded_instances {
|
|||||||
" value: \"background\"\n"
|
" value: \"background\"\n"
|
||||||
" type: PROPERTY_TYPE_HASH\n"
|
" type: PROPERTY_TYPE_HASH\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
|
" property_decls {\n"
|
||||||
|
" }\n"
|
||||||
"}\n"
|
"}\n"
|
||||||
"embedded_components {\n"
|
"embedded_components {\n"
|
||||||
" id: \"collectionfactory\"\n"
|
" id: \"collectionfactory\"\n"
|
||||||
" type: \"collectionfactory\"\n"
|
" type: \"collectionfactory\"\n"
|
||||||
" data: \"prototype: \\\"/example/background.collection\\\"\\n"
|
" data: \"prototype: \\\"/example/advanced/background.collection\\\"\\n"
|
||||||
"load_dynamically: false\\n"
|
"load_dynamically: false\\n"
|
||||||
|
"dynamic_prototype: false\\n"
|
||||||
"\"\n"
|
"\"\n"
|
||||||
" position {\n"
|
" position {\n"
|
||||||
" x: 0.0\n"
|
" x: 0.0\n"
|
||||||
@@ -4,7 +4,7 @@ embedded_instances {
|
|||||||
id: "go"
|
id: "go"
|
||||||
data: "components {\n"
|
data: "components {\n"
|
||||||
" id: \"confirm\"\n"
|
" id: \"confirm\"\n"
|
||||||
" component: \"/example/confirm.gui\"\n"
|
" component: \"/example/advanced/confirm.gui\"\n"
|
||||||
" position {\n"
|
" position {\n"
|
||||||
" x: 0.0\n"
|
" x: 0.0\n"
|
||||||
" y: 0.0\n"
|
" y: 0.0\n"
|
||||||
@@ -1,4 +1,4 @@
|
|||||||
script: "/example/confirm.gui_script"
|
script: "/example/advanced/confirm.gui_script"
|
||||||
fonts {
|
fonts {
|
||||||
name: "example"
|
name: "example"
|
||||||
font: "/assets/example.font"
|
font: "/assets/example.font"
|
||||||
@@ -1,4 +1,4 @@
|
|||||||
script: "/example/debug.gui_script"
|
script: "/example/advanced/debug.gui_script"
|
||||||
fonts {
|
fonts {
|
||||||
name: "example"
|
name: "example"
|
||||||
font: "/assets/example.font"
|
font: "/assets/example.font"
|
||||||
@@ -4,7 +4,7 @@ embedded_instances {
|
|||||||
id: "go"
|
id: "go"
|
||||||
data: "components {\n"
|
data: "components {\n"
|
||||||
" id: \"game\"\n"
|
" id: \"game\"\n"
|
||||||
" component: \"/example/game.gui\"\n"
|
" component: \"/example/advanced/game.gui\"\n"
|
||||||
" position {\n"
|
" position {\n"
|
||||||
" x: 0.0\n"
|
" x: 0.0\n"
|
||||||
" y: 0.0\n"
|
" y: 0.0\n"
|
||||||
@@ -1,4 +1,4 @@
|
|||||||
script: "/example/game.gui_script"
|
script: "/example/advanced/game.gui_script"
|
||||||
fonts {
|
fonts {
|
||||||
name: "example"
|
name: "example"
|
||||||
font: "/assets/example.font"
|
font: "/assets/example.font"
|
||||||
@@ -4,7 +4,7 @@ embedded_instances {
|
|||||||
id: "go"
|
id: "go"
|
||||||
data: "components {\n"
|
data: "components {\n"
|
||||||
" id: \"menu\"\n"
|
" id: \"menu\"\n"
|
||||||
" component: \"/example/menu.gui\"\n"
|
" component: \"/example/advanced/menu.gui\"\n"
|
||||||
" position {\n"
|
" position {\n"
|
||||||
" x: 0.0\n"
|
" x: 0.0\n"
|
||||||
" y: 0.0\n"
|
" y: 0.0\n"
|
||||||
@@ -16,6 +16,8 @@ embedded_instances {
|
|||||||
" z: 0.0\n"
|
" z: 0.0\n"
|
||||||
" w: 1.0\n"
|
" w: 1.0\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
|
" property_decls {\n"
|
||||||
|
" }\n"
|
||||||
"}\n"
|
"}\n"
|
||||||
""
|
""
|
||||||
position {
|
position {
|
||||||
@@ -76,12 +78,15 @@ embedded_instances {
|
|||||||
" value: \"/go\"\n"
|
" value: \"/go\"\n"
|
||||||
" type: PROPERTY_TYPE_HASH\n"
|
" type: PROPERTY_TYPE_HASH\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
|
" property_decls {\n"
|
||||||
|
" }\n"
|
||||||
"}\n"
|
"}\n"
|
||||||
"embedded_components {\n"
|
"embedded_components {\n"
|
||||||
" id: \"collectionfactory\"\n"
|
" id: \"collectionfactory\"\n"
|
||||||
" type: \"collectionfactory\"\n"
|
" type: \"collectionfactory\"\n"
|
||||||
" data: \"prototype: \\\"/example/popup.collection\\\"\\n"
|
" data: \"prototype: \\\"/example/advanced/popup.collection\\\"\\n"
|
||||||
"load_dynamically: false\\n"
|
"load_dynamically: false\\n"
|
||||||
|
"dynamic_prototype: false\\n"
|
||||||
"\"\n"
|
"\"\n"
|
||||||
" position {\n"
|
" position {\n"
|
||||||
" x: 0.0\n"
|
" x: 0.0\n"
|
||||||
@@ -1,4 +1,4 @@
|
|||||||
script: "/example/menu.gui_script"
|
script: "/example/advanced/menu.gui_script"
|
||||||
fonts {
|
fonts {
|
||||||
name: "example"
|
name: "example"
|
||||||
font: "/assets/example.font"
|
font: "/assets/example.font"
|
||||||
@@ -4,7 +4,7 @@ embedded_instances {
|
|||||||
id: "go"
|
id: "go"
|
||||||
data: "components {\n"
|
data: "components {\n"
|
||||||
" id: \"popup\"\n"
|
" id: \"popup\"\n"
|
||||||
" component: \"/example/popup.gui\"\n"
|
" component: \"/example/advanced/popup.gui\"\n"
|
||||||
" position {\n"
|
" position {\n"
|
||||||
" x: 0.0\n"
|
" x: 0.0\n"
|
||||||
" y: 0.0\n"
|
" y: 0.0\n"
|
||||||
@@ -1,4 +1,4 @@
|
|||||||
script: "/example/popup.gui_script"
|
script: "/example/advanced/popup.gui_script"
|
||||||
fonts {
|
fonts {
|
||||||
name: "example"
|
name: "example"
|
||||||
font: "/assets/example.font"
|
font: "/assets/example.font"
|
||||||
@@ -4,7 +4,7 @@ embedded_instances {
|
|||||||
id: "go"
|
id: "go"
|
||||||
data: "components {\n"
|
data: "components {\n"
|
||||||
" id: \"pregame\"\n"
|
" id: \"pregame\"\n"
|
||||||
" component: \"/example/pregame.gui\"\n"
|
" component: \"/example/advanced/pregame.gui\"\n"
|
||||||
" position {\n"
|
" position {\n"
|
||||||
" x: 0.0\n"
|
" x: 0.0\n"
|
||||||
" y: 0.0\n"
|
" y: 0.0\n"
|
||||||
@@ -1,4 +1,4 @@
|
|||||||
script: "/example/pregame.gui_script"
|
script: "/example/advanced/pregame.gui_script"
|
||||||
fonts {
|
fonts {
|
||||||
name: "example"
|
name: "example"
|
||||||
font: "/assets/example.font"
|
font: "/assets/example.font"
|
||||||
289
example/basic/basic.collection
Normal file
289
example/basic/basic.collection
Normal file
@@ -0,0 +1,289 @@
|
|||||||
|
name: "basic"
|
||||||
|
scale_along_z: 0
|
||||||
|
embedded_instances {
|
||||||
|
id: "screen1"
|
||||||
|
data: "components {\n"
|
||||||
|
" id: \"screen_proxy\"\n"
|
||||||
|
" component: \"/monarch/screen_proxy.script\"\n"
|
||||||
|
" position {\n"
|
||||||
|
" x: 0.0\n"
|
||||||
|
" y: 0.0\n"
|
||||||
|
" z: 0.0\n"
|
||||||
|
" }\n"
|
||||||
|
" rotation {\n"
|
||||||
|
" x: 0.0\n"
|
||||||
|
" y: 0.0\n"
|
||||||
|
" z: 0.0\n"
|
||||||
|
" w: 1.0\n"
|
||||||
|
" }\n"
|
||||||
|
" properties {\n"
|
||||||
|
" id: \"screen_id\"\n"
|
||||||
|
" value: \"screen1\"\n"
|
||||||
|
" type: PROPERTY_TYPE_HASH\n"
|
||||||
|
" }\n"
|
||||||
|
" property_decls {\n"
|
||||||
|
" }\n"
|
||||||
|
"}\n"
|
||||||
|
"embedded_components {\n"
|
||||||
|
" id: \"collectionproxy\"\n"
|
||||||
|
" type: \"collectionproxy\"\n"
|
||||||
|
" data: \"collection: \\\"/example/basic/screen1.collection\\\"\\n"
|
||||||
|
"exclude: false\\n"
|
||||||
|
"\"\n"
|
||||||
|
" position {\n"
|
||||||
|
" x: 0.0\n"
|
||||||
|
" y: 0.0\n"
|
||||||
|
" z: 0.0\n"
|
||||||
|
" }\n"
|
||||||
|
" rotation {\n"
|
||||||
|
" x: 0.0\n"
|
||||||
|
" y: 0.0\n"
|
||||||
|
" z: 0.0\n"
|
||||||
|
" w: 1.0\n"
|
||||||
|
" }\n"
|
||||||
|
"}\n"
|
||||||
|
""
|
||||||
|
position {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale3 {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
}
|
||||||
|
}
|
||||||
|
embedded_instances {
|
||||||
|
id: "basic"
|
||||||
|
data: "components {\n"
|
||||||
|
" id: \"basic\"\n"
|
||||||
|
" component: \"/example/basic/basic.script\"\n"
|
||||||
|
" position {\n"
|
||||||
|
" x: 0.0\n"
|
||||||
|
" y: 0.0\n"
|
||||||
|
" z: 0.0\n"
|
||||||
|
" }\n"
|
||||||
|
" rotation {\n"
|
||||||
|
" x: 0.0\n"
|
||||||
|
" y: 0.0\n"
|
||||||
|
" z: 0.0\n"
|
||||||
|
" w: 1.0\n"
|
||||||
|
" }\n"
|
||||||
|
" property_decls {\n"
|
||||||
|
" }\n"
|
||||||
|
"}\n"
|
||||||
|
""
|
||||||
|
position {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale3 {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
}
|
||||||
|
}
|
||||||
|
embedded_instances {
|
||||||
|
id: "screen2"
|
||||||
|
data: "components {\n"
|
||||||
|
" id: \"screen_proxy\"\n"
|
||||||
|
" component: \"/monarch/screen_proxy.script\"\n"
|
||||||
|
" position {\n"
|
||||||
|
" x: 0.0\n"
|
||||||
|
" y: 0.0\n"
|
||||||
|
" z: 0.0\n"
|
||||||
|
" }\n"
|
||||||
|
" rotation {\n"
|
||||||
|
" x: 0.0\n"
|
||||||
|
" y: 0.0\n"
|
||||||
|
" z: 0.0\n"
|
||||||
|
" w: 1.0\n"
|
||||||
|
" }\n"
|
||||||
|
" properties {\n"
|
||||||
|
" id: \"screen_id\"\n"
|
||||||
|
" value: \"screen2\"\n"
|
||||||
|
" type: PROPERTY_TYPE_HASH\n"
|
||||||
|
" }\n"
|
||||||
|
" property_decls {\n"
|
||||||
|
" }\n"
|
||||||
|
"}\n"
|
||||||
|
"embedded_components {\n"
|
||||||
|
" id: \"collectionproxy\"\n"
|
||||||
|
" type: \"collectionproxy\"\n"
|
||||||
|
" data: \"collection: \\\"/example/basic/screen2.collection\\\"\\n"
|
||||||
|
"exclude: false\\n"
|
||||||
|
"\"\n"
|
||||||
|
" position {\n"
|
||||||
|
" x: 0.0\n"
|
||||||
|
" y: 0.0\n"
|
||||||
|
" z: 0.0\n"
|
||||||
|
" }\n"
|
||||||
|
" rotation {\n"
|
||||||
|
" x: 0.0\n"
|
||||||
|
" y: 0.0\n"
|
||||||
|
" z: 0.0\n"
|
||||||
|
" w: 1.0\n"
|
||||||
|
" }\n"
|
||||||
|
"}\n"
|
||||||
|
""
|
||||||
|
position {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale3 {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
}
|
||||||
|
}
|
||||||
|
embedded_instances {
|
||||||
|
id: "popup1"
|
||||||
|
data: "components {\n"
|
||||||
|
" id: \"screen_proxy\"\n"
|
||||||
|
" component: \"/monarch/screen_proxy.script\"\n"
|
||||||
|
" position {\n"
|
||||||
|
" x: 0.0\n"
|
||||||
|
" y: 0.0\n"
|
||||||
|
" z: 0.0\n"
|
||||||
|
" }\n"
|
||||||
|
" rotation {\n"
|
||||||
|
" x: 0.0\n"
|
||||||
|
" y: 0.0\n"
|
||||||
|
" z: 0.0\n"
|
||||||
|
" w: 1.0\n"
|
||||||
|
" }\n"
|
||||||
|
" properties {\n"
|
||||||
|
" id: \"screen_id\"\n"
|
||||||
|
" value: \"popup1\"\n"
|
||||||
|
" type: PROPERTY_TYPE_HASH\n"
|
||||||
|
" }\n"
|
||||||
|
" properties {\n"
|
||||||
|
" id: \"popup\"\n"
|
||||||
|
" value: \"true\"\n"
|
||||||
|
" type: PROPERTY_TYPE_BOOLEAN\n"
|
||||||
|
" }\n"
|
||||||
|
" property_decls {\n"
|
||||||
|
" }\n"
|
||||||
|
"}\n"
|
||||||
|
"embedded_components {\n"
|
||||||
|
" id: \"collectionproxy\"\n"
|
||||||
|
" type: \"collectionproxy\"\n"
|
||||||
|
" data: \"collection: \\\"/example/basic/popup1.collection\\\"\\n"
|
||||||
|
"exclude: false\\n"
|
||||||
|
"\"\n"
|
||||||
|
" position {\n"
|
||||||
|
" x: 0.0\n"
|
||||||
|
" y: 0.0\n"
|
||||||
|
" z: 0.0\n"
|
||||||
|
" }\n"
|
||||||
|
" rotation {\n"
|
||||||
|
" x: 0.0\n"
|
||||||
|
" y: 0.0\n"
|
||||||
|
" z: 0.0\n"
|
||||||
|
" w: 1.0\n"
|
||||||
|
" }\n"
|
||||||
|
"}\n"
|
||||||
|
""
|
||||||
|
position {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale3 {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
}
|
||||||
|
}
|
||||||
|
embedded_instances {
|
||||||
|
id: "popup2"
|
||||||
|
data: "components {\n"
|
||||||
|
" id: \"screen_proxy\"\n"
|
||||||
|
" component: \"/monarch/screen_proxy.script\"\n"
|
||||||
|
" position {\n"
|
||||||
|
" x: 0.0\n"
|
||||||
|
" y: 0.0\n"
|
||||||
|
" z: 0.0\n"
|
||||||
|
" }\n"
|
||||||
|
" rotation {\n"
|
||||||
|
" x: 0.0\n"
|
||||||
|
" y: 0.0\n"
|
||||||
|
" z: 0.0\n"
|
||||||
|
" w: 1.0\n"
|
||||||
|
" }\n"
|
||||||
|
" properties {\n"
|
||||||
|
" id: \"screen_id\"\n"
|
||||||
|
" value: \"popup2\"\n"
|
||||||
|
" type: PROPERTY_TYPE_HASH\n"
|
||||||
|
" }\n"
|
||||||
|
" properties {\n"
|
||||||
|
" id: \"popup\"\n"
|
||||||
|
" value: \"true\"\n"
|
||||||
|
" type: PROPERTY_TYPE_BOOLEAN\n"
|
||||||
|
" }\n"
|
||||||
|
" property_decls {\n"
|
||||||
|
" }\n"
|
||||||
|
"}\n"
|
||||||
|
"embedded_components {\n"
|
||||||
|
" id: \"collectionproxy\"\n"
|
||||||
|
" type: \"collectionproxy\"\n"
|
||||||
|
" data: \"collection: \\\"/example/basic/popup2.collection\\\"\\n"
|
||||||
|
"exclude: false\\n"
|
||||||
|
"\"\n"
|
||||||
|
" position {\n"
|
||||||
|
" x: 0.0\n"
|
||||||
|
" y: 0.0\n"
|
||||||
|
" z: 0.0\n"
|
||||||
|
" }\n"
|
||||||
|
" rotation {\n"
|
||||||
|
" x: 0.0\n"
|
||||||
|
" y: 0.0\n"
|
||||||
|
" z: 0.0\n"
|
||||||
|
" w: 1.0\n"
|
||||||
|
" }\n"
|
||||||
|
"}\n"
|
||||||
|
""
|
||||||
|
position {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale3 {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
}
|
||||||
|
}
|
||||||
12
example/basic/basic.script
Normal file
12
example/basic/basic.script
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
local monarch = require "monarch.monarch"
|
||||||
|
|
||||||
|
function init(self)
|
||||||
|
msg.post(".", "acquire_input_focus")
|
||||||
|
msg.post("#", "show_screen1")
|
||||||
|
end
|
||||||
|
|
||||||
|
function on_message(self, message_id, message, sender)
|
||||||
|
if message_id == hash("show_screen1") then
|
||||||
|
monarch.show("screen1")
|
||||||
|
end
|
||||||
|
end
|
||||||
39
example/basic/popup1.collection
Normal file
39
example/basic/popup1.collection
Normal file
@@ -0,0 +1,39 @@
|
|||||||
|
name: "popup1"
|
||||||
|
scale_along_z: 0
|
||||||
|
embedded_instances {
|
||||||
|
id: "go"
|
||||||
|
data: "components {\n"
|
||||||
|
" id: \"popup1\"\n"
|
||||||
|
" component: \"/example/basic/popup1.gui\"\n"
|
||||||
|
" position {\n"
|
||||||
|
" x: 0.0\n"
|
||||||
|
" y: 0.0\n"
|
||||||
|
" z: 0.0\n"
|
||||||
|
" }\n"
|
||||||
|
" rotation {\n"
|
||||||
|
" x: 0.0\n"
|
||||||
|
" y: 0.0\n"
|
||||||
|
" z: 0.0\n"
|
||||||
|
" w: 1.0\n"
|
||||||
|
" }\n"
|
||||||
|
" property_decls {\n"
|
||||||
|
" }\n"
|
||||||
|
"}\n"
|
||||||
|
""
|
||||||
|
position {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale3 {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
}
|
||||||
|
}
|
||||||
385
example/basic/popup1.gui
Normal file
385
example/basic/popup1.gui
Normal file
@@ -0,0 +1,385 @@
|
|||||||
|
script: "/example/basic/popup1.gui_script"
|
||||||
|
fonts {
|
||||||
|
name: "example"
|
||||||
|
font: "/assets/example.font"
|
||||||
|
}
|
||||||
|
background_color {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 0.0
|
||||||
|
}
|
||||||
|
nodes {
|
||||||
|
position {
|
||||||
|
x: 320.0
|
||||||
|
y: 568.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
size {
|
||||||
|
x: 400.0
|
||||||
|
y: 400.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
color {
|
||||||
|
x: 0.5019608
|
||||||
|
y: 0.6
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
type: TYPE_BOX
|
||||||
|
blend_mode: BLEND_MODE_ALPHA
|
||||||
|
texture: ""
|
||||||
|
id: "root"
|
||||||
|
xanchor: XANCHOR_NONE
|
||||||
|
yanchor: YANCHOR_NONE
|
||||||
|
pivot: PIVOT_CENTER
|
||||||
|
adjust_mode: ADJUST_MODE_FIT
|
||||||
|
layer: ""
|
||||||
|
inherit_alpha: true
|
||||||
|
slice9 {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 0.0
|
||||||
|
}
|
||||||
|
clipping_mode: CLIPPING_MODE_NONE
|
||||||
|
clipping_visible: true
|
||||||
|
clipping_inverted: false
|
||||||
|
alpha: 1.0
|
||||||
|
template_node_child: false
|
||||||
|
size_mode: SIZE_MODE_MANUAL
|
||||||
|
custom_type: 0
|
||||||
|
enabled: true
|
||||||
|
visible: true
|
||||||
|
}
|
||||||
|
nodes {
|
||||||
|
position {
|
||||||
|
x: 0.0
|
||||||
|
y: 100.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
size {
|
||||||
|
x: 200.0
|
||||||
|
y: 100.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
color {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
type: TYPE_BOX
|
||||||
|
blend_mode: BLEND_MODE_ALPHA
|
||||||
|
texture: ""
|
||||||
|
id: "showpopup2"
|
||||||
|
xanchor: XANCHOR_NONE
|
||||||
|
yanchor: YANCHOR_NONE
|
||||||
|
pivot: PIVOT_CENTER
|
||||||
|
adjust_mode: ADJUST_MODE_FIT
|
||||||
|
parent: "root"
|
||||||
|
layer: ""
|
||||||
|
inherit_alpha: true
|
||||||
|
slice9 {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 0.0
|
||||||
|
}
|
||||||
|
clipping_mode: CLIPPING_MODE_NONE
|
||||||
|
clipping_visible: true
|
||||||
|
clipping_inverted: false
|
||||||
|
alpha: 1.0
|
||||||
|
template_node_child: false
|
||||||
|
size_mode: SIZE_MODE_AUTO
|
||||||
|
custom_type: 0
|
||||||
|
enabled: true
|
||||||
|
visible: true
|
||||||
|
}
|
||||||
|
nodes {
|
||||||
|
position {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
size {
|
||||||
|
x: 200.0
|
||||||
|
y: 100.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
color {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
type: TYPE_TEXT
|
||||||
|
blend_mode: BLEND_MODE_ALPHA
|
||||||
|
text: "SHOW POPUP 2"
|
||||||
|
font: "example"
|
||||||
|
id: "showtext"
|
||||||
|
xanchor: XANCHOR_NONE
|
||||||
|
yanchor: YANCHOR_NONE
|
||||||
|
pivot: PIVOT_CENTER
|
||||||
|
outline {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
shadow {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
adjust_mode: ADJUST_MODE_FIT
|
||||||
|
line_break: false
|
||||||
|
parent: "showpopup2"
|
||||||
|
layer: ""
|
||||||
|
inherit_alpha: true
|
||||||
|
alpha: 1.0
|
||||||
|
outline_alpha: 1.0
|
||||||
|
shadow_alpha: 1.0
|
||||||
|
template_node_child: false
|
||||||
|
text_leading: 1.0
|
||||||
|
text_tracking: 0.0
|
||||||
|
custom_type: 0
|
||||||
|
enabled: true
|
||||||
|
visible: true
|
||||||
|
}
|
||||||
|
nodes {
|
||||||
|
position {
|
||||||
|
x: 0.0
|
||||||
|
y: -100.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
size {
|
||||||
|
x: 200.0
|
||||||
|
y: 100.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
color {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
type: TYPE_BOX
|
||||||
|
blend_mode: BLEND_MODE_ALPHA
|
||||||
|
texture: ""
|
||||||
|
id: "closepopup"
|
||||||
|
xanchor: XANCHOR_NONE
|
||||||
|
yanchor: YANCHOR_NONE
|
||||||
|
pivot: PIVOT_CENTER
|
||||||
|
adjust_mode: ADJUST_MODE_FIT
|
||||||
|
parent: "root"
|
||||||
|
layer: ""
|
||||||
|
inherit_alpha: true
|
||||||
|
slice9 {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 0.0
|
||||||
|
}
|
||||||
|
clipping_mode: CLIPPING_MODE_NONE
|
||||||
|
clipping_visible: true
|
||||||
|
clipping_inverted: false
|
||||||
|
alpha: 1.0
|
||||||
|
template_node_child: false
|
||||||
|
size_mode: SIZE_MODE_AUTO
|
||||||
|
custom_type: 0
|
||||||
|
enabled: true
|
||||||
|
visible: true
|
||||||
|
}
|
||||||
|
nodes {
|
||||||
|
position {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
size {
|
||||||
|
x: 200.0
|
||||||
|
y: 100.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
color {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
type: TYPE_TEXT
|
||||||
|
blend_mode: BLEND_MODE_ALPHA
|
||||||
|
text: "CLOSE"
|
||||||
|
font: "example"
|
||||||
|
id: "closetext"
|
||||||
|
xanchor: XANCHOR_NONE
|
||||||
|
yanchor: YANCHOR_NONE
|
||||||
|
pivot: PIVOT_CENTER
|
||||||
|
outline {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
shadow {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
adjust_mode: ADJUST_MODE_FIT
|
||||||
|
line_break: false
|
||||||
|
parent: "closepopup"
|
||||||
|
layer: ""
|
||||||
|
inherit_alpha: true
|
||||||
|
alpha: 1.0
|
||||||
|
outline_alpha: 1.0
|
||||||
|
shadow_alpha: 1.0
|
||||||
|
template_node_child: false
|
||||||
|
text_leading: 1.0
|
||||||
|
text_tracking: 0.0
|
||||||
|
custom_type: 0
|
||||||
|
enabled: true
|
||||||
|
visible: true
|
||||||
|
}
|
||||||
|
nodes {
|
||||||
|
position {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
size {
|
||||||
|
x: 200.0
|
||||||
|
y: 40.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
color {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
type: TYPE_TEXT
|
||||||
|
blend_mode: BLEND_MODE_ALPHA
|
||||||
|
text: "THIS IS POPUP 1"
|
||||||
|
font: "example"
|
||||||
|
id: "id"
|
||||||
|
xanchor: XANCHOR_NONE
|
||||||
|
yanchor: YANCHOR_NONE
|
||||||
|
pivot: PIVOT_CENTER
|
||||||
|
outline {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
shadow {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
adjust_mode: ADJUST_MODE_FIT
|
||||||
|
line_break: false
|
||||||
|
parent: "root"
|
||||||
|
layer: ""
|
||||||
|
inherit_alpha: true
|
||||||
|
alpha: 1.0
|
||||||
|
outline_alpha: 1.0
|
||||||
|
shadow_alpha: 1.0
|
||||||
|
template_node_child: false
|
||||||
|
text_leading: 1.0
|
||||||
|
text_tracking: 0.0
|
||||||
|
custom_type: 0
|
||||||
|
enabled: true
|
||||||
|
visible: true
|
||||||
|
}
|
||||||
|
material: "/builtins/materials/gui.material"
|
||||||
|
adjust_reference: ADJUST_REFERENCE_PARENT
|
||||||
|
max_nodes: 512
|
||||||
16
example/basic/popup1.gui_script
Normal file
16
example/basic/popup1.gui_script
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
local monarch = require "monarch.monarch"
|
||||||
|
|
||||||
|
function init(self)
|
||||||
|
msg.post(".", "acquire_input_focus")
|
||||||
|
gui.set_render_order(14)
|
||||||
|
end
|
||||||
|
|
||||||
|
function on_input(self, action_id, action)
|
||||||
|
if action_id == hash("touch") and action.pressed then
|
||||||
|
if gui.pick_node(gui.get_node("showpopup2"), action.x, action.y) then
|
||||||
|
monarch.show("popup2")
|
||||||
|
elseif gui.pick_node(gui.get_node("closepopup"), action.x, action.y) then
|
||||||
|
monarch.back()
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
39
example/basic/popup2.collection
Normal file
39
example/basic/popup2.collection
Normal file
@@ -0,0 +1,39 @@
|
|||||||
|
name: "popup2"
|
||||||
|
scale_along_z: 0
|
||||||
|
embedded_instances {
|
||||||
|
id: "go"
|
||||||
|
data: "components {\n"
|
||||||
|
" id: \"popup2\"\n"
|
||||||
|
" component: \"/example/basic/popup2.gui\"\n"
|
||||||
|
" position {\n"
|
||||||
|
" x: 0.0\n"
|
||||||
|
" y: 0.0\n"
|
||||||
|
" z: 0.0\n"
|
||||||
|
" }\n"
|
||||||
|
" rotation {\n"
|
||||||
|
" x: 0.0\n"
|
||||||
|
" y: 0.0\n"
|
||||||
|
" z: 0.0\n"
|
||||||
|
" w: 1.0\n"
|
||||||
|
" }\n"
|
||||||
|
" property_decls {\n"
|
||||||
|
" }\n"
|
||||||
|
"}\n"
|
||||||
|
""
|
||||||
|
position {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale3 {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
}
|
||||||
|
}
|
||||||
385
example/basic/popup2.gui
Normal file
385
example/basic/popup2.gui
Normal file
@@ -0,0 +1,385 @@
|
|||||||
|
script: "/example/basic/popup2.gui_script"
|
||||||
|
fonts {
|
||||||
|
name: "example"
|
||||||
|
font: "/assets/example.font"
|
||||||
|
}
|
||||||
|
background_color {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 0.0
|
||||||
|
}
|
||||||
|
nodes {
|
||||||
|
position {
|
||||||
|
x: 320.0
|
||||||
|
y: 568.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
size {
|
||||||
|
x: 400.0
|
||||||
|
y: 400.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
color {
|
||||||
|
x: 0.5019608
|
||||||
|
y: 0.7019608
|
||||||
|
z: 0.7019608
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
type: TYPE_BOX
|
||||||
|
blend_mode: BLEND_MODE_ALPHA
|
||||||
|
texture: ""
|
||||||
|
id: "root"
|
||||||
|
xanchor: XANCHOR_NONE
|
||||||
|
yanchor: YANCHOR_NONE
|
||||||
|
pivot: PIVOT_CENTER
|
||||||
|
adjust_mode: ADJUST_MODE_FIT
|
||||||
|
layer: ""
|
||||||
|
inherit_alpha: true
|
||||||
|
slice9 {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 0.0
|
||||||
|
}
|
||||||
|
clipping_mode: CLIPPING_MODE_NONE
|
||||||
|
clipping_visible: true
|
||||||
|
clipping_inverted: false
|
||||||
|
alpha: 1.0
|
||||||
|
template_node_child: false
|
||||||
|
size_mode: SIZE_MODE_MANUAL
|
||||||
|
custom_type: 0
|
||||||
|
enabled: true
|
||||||
|
visible: true
|
||||||
|
}
|
||||||
|
nodes {
|
||||||
|
position {
|
||||||
|
x: 0.0
|
||||||
|
y: 100.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
size {
|
||||||
|
x: 200.0
|
||||||
|
y: 100.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
color {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
type: TYPE_BOX
|
||||||
|
blend_mode: BLEND_MODE_ALPHA
|
||||||
|
texture: ""
|
||||||
|
id: "showpopup2"
|
||||||
|
xanchor: XANCHOR_NONE
|
||||||
|
yanchor: YANCHOR_NONE
|
||||||
|
pivot: PIVOT_CENTER
|
||||||
|
adjust_mode: ADJUST_MODE_FIT
|
||||||
|
parent: "root"
|
||||||
|
layer: ""
|
||||||
|
inherit_alpha: true
|
||||||
|
slice9 {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 0.0
|
||||||
|
}
|
||||||
|
clipping_mode: CLIPPING_MODE_NONE
|
||||||
|
clipping_visible: true
|
||||||
|
clipping_inverted: false
|
||||||
|
alpha: 1.0
|
||||||
|
template_node_child: false
|
||||||
|
size_mode: SIZE_MODE_AUTO
|
||||||
|
custom_type: 0
|
||||||
|
enabled: true
|
||||||
|
visible: true
|
||||||
|
}
|
||||||
|
nodes {
|
||||||
|
position {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
size {
|
||||||
|
x: 200.0
|
||||||
|
y: 100.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
color {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
type: TYPE_TEXT
|
||||||
|
blend_mode: BLEND_MODE_ALPHA
|
||||||
|
text: "SHOW POPUP 2"
|
||||||
|
font: "example"
|
||||||
|
id: "showtext"
|
||||||
|
xanchor: XANCHOR_NONE
|
||||||
|
yanchor: YANCHOR_NONE
|
||||||
|
pivot: PIVOT_CENTER
|
||||||
|
outline {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
shadow {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
adjust_mode: ADJUST_MODE_FIT
|
||||||
|
line_break: false
|
||||||
|
parent: "showpopup2"
|
||||||
|
layer: ""
|
||||||
|
inherit_alpha: true
|
||||||
|
alpha: 1.0
|
||||||
|
outline_alpha: 1.0
|
||||||
|
shadow_alpha: 1.0
|
||||||
|
template_node_child: false
|
||||||
|
text_leading: 1.0
|
||||||
|
text_tracking: 0.0
|
||||||
|
custom_type: 0
|
||||||
|
enabled: true
|
||||||
|
visible: true
|
||||||
|
}
|
||||||
|
nodes {
|
||||||
|
position {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
size {
|
||||||
|
x: 200.0
|
||||||
|
y: 40.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
color {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
type: TYPE_TEXT
|
||||||
|
blend_mode: BLEND_MODE_ALPHA
|
||||||
|
text: "THIS IS POPUP 2"
|
||||||
|
font: "example"
|
||||||
|
id: "id"
|
||||||
|
xanchor: XANCHOR_NONE
|
||||||
|
yanchor: YANCHOR_NONE
|
||||||
|
pivot: PIVOT_CENTER
|
||||||
|
outline {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
shadow {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
adjust_mode: ADJUST_MODE_FIT
|
||||||
|
line_break: false
|
||||||
|
parent: "root"
|
||||||
|
layer: ""
|
||||||
|
inherit_alpha: true
|
||||||
|
alpha: 1.0
|
||||||
|
outline_alpha: 1.0
|
||||||
|
shadow_alpha: 1.0
|
||||||
|
template_node_child: false
|
||||||
|
text_leading: 1.0
|
||||||
|
text_tracking: 0.0
|
||||||
|
custom_type: 0
|
||||||
|
enabled: true
|
||||||
|
visible: true
|
||||||
|
}
|
||||||
|
nodes {
|
||||||
|
position {
|
||||||
|
x: 0.0
|
||||||
|
y: -100.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
size {
|
||||||
|
x: 200.0
|
||||||
|
y: 100.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
color {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
type: TYPE_BOX
|
||||||
|
blend_mode: BLEND_MODE_ALPHA
|
||||||
|
texture: ""
|
||||||
|
id: "closepopup"
|
||||||
|
xanchor: XANCHOR_NONE
|
||||||
|
yanchor: YANCHOR_NONE
|
||||||
|
pivot: PIVOT_CENTER
|
||||||
|
adjust_mode: ADJUST_MODE_FIT
|
||||||
|
parent: "root"
|
||||||
|
layer: ""
|
||||||
|
inherit_alpha: true
|
||||||
|
slice9 {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 0.0
|
||||||
|
}
|
||||||
|
clipping_mode: CLIPPING_MODE_NONE
|
||||||
|
clipping_visible: true
|
||||||
|
clipping_inverted: false
|
||||||
|
alpha: 1.0
|
||||||
|
template_node_child: false
|
||||||
|
size_mode: SIZE_MODE_AUTO
|
||||||
|
custom_type: 0
|
||||||
|
enabled: true
|
||||||
|
visible: true
|
||||||
|
}
|
||||||
|
nodes {
|
||||||
|
position {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
size {
|
||||||
|
x: 200.0
|
||||||
|
y: 100.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
color {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
type: TYPE_TEXT
|
||||||
|
blend_mode: BLEND_MODE_ALPHA
|
||||||
|
text: "CLOSE"
|
||||||
|
font: "example"
|
||||||
|
id: "closetext"
|
||||||
|
xanchor: XANCHOR_NONE
|
||||||
|
yanchor: YANCHOR_NONE
|
||||||
|
pivot: PIVOT_CENTER
|
||||||
|
outline {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
shadow {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
adjust_mode: ADJUST_MODE_FIT
|
||||||
|
line_break: false
|
||||||
|
parent: "closepopup"
|
||||||
|
layer: ""
|
||||||
|
inherit_alpha: true
|
||||||
|
alpha: 1.0
|
||||||
|
outline_alpha: 1.0
|
||||||
|
shadow_alpha: 1.0
|
||||||
|
template_node_child: false
|
||||||
|
text_leading: 1.0
|
||||||
|
text_tracking: 0.0
|
||||||
|
custom_type: 0
|
||||||
|
enabled: true
|
||||||
|
visible: true
|
||||||
|
}
|
||||||
|
material: "/builtins/materials/gui.material"
|
||||||
|
adjust_reference: ADJUST_REFERENCE_PARENT
|
||||||
|
max_nodes: 512
|
||||||
16
example/basic/popup2.gui_script
Normal file
16
example/basic/popup2.gui_script
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
local monarch = require "monarch.monarch"
|
||||||
|
|
||||||
|
function init(self)
|
||||||
|
msg.post(".", "acquire_input_focus")
|
||||||
|
gui.set_render_order(15)
|
||||||
|
end
|
||||||
|
|
||||||
|
function on_input(self, action_id, action)
|
||||||
|
if action_id == hash("touch") and action.pressed then
|
||||||
|
if gui.pick_node(gui.get_node("showpopup2"), action.x, action.y) then
|
||||||
|
monarch.show("popup2")
|
||||||
|
elseif gui.pick_node(gui.get_node("closepopup"), action.x, action.y) then
|
||||||
|
monarch.back()
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
37
example/basic/screen1.collection
Normal file
37
example/basic/screen1.collection
Normal file
@@ -0,0 +1,37 @@
|
|||||||
|
name: "screen1"
|
||||||
|
scale_along_z: 0
|
||||||
|
embedded_instances {
|
||||||
|
id: "go"
|
||||||
|
data: "components {\n"
|
||||||
|
" id: \"screen1\"\n"
|
||||||
|
" component: \"/example/basic/screen1.gui\"\n"
|
||||||
|
" position {\n"
|
||||||
|
" x: 0.0\n"
|
||||||
|
" y: 0.0\n"
|
||||||
|
" z: 0.0\n"
|
||||||
|
" }\n"
|
||||||
|
" rotation {\n"
|
||||||
|
" x: 0.0\n"
|
||||||
|
" y: 0.0\n"
|
||||||
|
" z: 0.0\n"
|
||||||
|
" w: 1.0\n"
|
||||||
|
" }\n"
|
||||||
|
"}\n"
|
||||||
|
""
|
||||||
|
position {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale3 {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
}
|
||||||
|
}
|
||||||
325
example/basic/screen1.gui
Normal file
325
example/basic/screen1.gui
Normal file
@@ -0,0 +1,325 @@
|
|||||||
|
script: "/example/basic/screen1.gui_script"
|
||||||
|
fonts {
|
||||||
|
name: "example"
|
||||||
|
font: "/assets/example.font"
|
||||||
|
}
|
||||||
|
background_color {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 0.0
|
||||||
|
}
|
||||||
|
nodes {
|
||||||
|
position {
|
||||||
|
x: 320.0
|
||||||
|
y: 568.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
size {
|
||||||
|
x: 200.0
|
||||||
|
y: 100.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
color {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
type: TYPE_BOX
|
||||||
|
blend_mode: BLEND_MODE_ALPHA
|
||||||
|
texture: ""
|
||||||
|
id: "showscreen2"
|
||||||
|
xanchor: XANCHOR_NONE
|
||||||
|
yanchor: YANCHOR_NONE
|
||||||
|
pivot: PIVOT_CENTER
|
||||||
|
adjust_mode: ADJUST_MODE_FIT
|
||||||
|
layer: ""
|
||||||
|
inherit_alpha: true
|
||||||
|
slice9 {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 0.0
|
||||||
|
}
|
||||||
|
clipping_mode: CLIPPING_MODE_NONE
|
||||||
|
clipping_visible: true
|
||||||
|
clipping_inverted: false
|
||||||
|
alpha: 1.0
|
||||||
|
template_node_child: false
|
||||||
|
size_mode: SIZE_MODE_AUTO
|
||||||
|
custom_type: 0
|
||||||
|
enabled: true
|
||||||
|
visible: true
|
||||||
|
}
|
||||||
|
nodes {
|
||||||
|
position {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
size {
|
||||||
|
x: 200.0
|
||||||
|
y: 100.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
color {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
type: TYPE_TEXT
|
||||||
|
blend_mode: BLEND_MODE_ALPHA
|
||||||
|
text: "SHOW SCREEN 2"
|
||||||
|
font: "example"
|
||||||
|
id: "showscreen2text"
|
||||||
|
xanchor: XANCHOR_NONE
|
||||||
|
yanchor: YANCHOR_NONE
|
||||||
|
pivot: PIVOT_CENTER
|
||||||
|
outline {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
shadow {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
adjust_mode: ADJUST_MODE_FIT
|
||||||
|
line_break: false
|
||||||
|
parent: "showscreen2"
|
||||||
|
layer: ""
|
||||||
|
inherit_alpha: true
|
||||||
|
alpha: 1.0
|
||||||
|
outline_alpha: 1.0
|
||||||
|
shadow_alpha: 1.0
|
||||||
|
template_node_child: false
|
||||||
|
text_leading: 1.0
|
||||||
|
text_tracking: 0.0
|
||||||
|
custom_type: 0
|
||||||
|
enabled: true
|
||||||
|
visible: true
|
||||||
|
}
|
||||||
|
nodes {
|
||||||
|
position {
|
||||||
|
x: 320.0
|
||||||
|
y: 10.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
size {
|
||||||
|
x: 200.0
|
||||||
|
y: 40.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
color {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
type: TYPE_TEXT
|
||||||
|
blend_mode: BLEND_MODE_ALPHA
|
||||||
|
text: "THIS IS SCREEN 1"
|
||||||
|
font: "example"
|
||||||
|
id: "id"
|
||||||
|
xanchor: XANCHOR_NONE
|
||||||
|
yanchor: YANCHOR_NONE
|
||||||
|
pivot: PIVOT_S
|
||||||
|
outline {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
shadow {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
adjust_mode: ADJUST_MODE_FIT
|
||||||
|
line_break: false
|
||||||
|
layer: ""
|
||||||
|
inherit_alpha: true
|
||||||
|
alpha: 1.0
|
||||||
|
outline_alpha: 1.0
|
||||||
|
shadow_alpha: 1.0
|
||||||
|
template_node_child: false
|
||||||
|
text_leading: 1.0
|
||||||
|
text_tracking: 0.0
|
||||||
|
custom_type: 0
|
||||||
|
enabled: true
|
||||||
|
visible: true
|
||||||
|
}
|
||||||
|
nodes {
|
||||||
|
position {
|
||||||
|
x: 320.0
|
||||||
|
y: 450.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
size {
|
||||||
|
x: 200.0
|
||||||
|
y: 100.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
color {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
type: TYPE_BOX
|
||||||
|
blend_mode: BLEND_MODE_ALPHA
|
||||||
|
texture: ""
|
||||||
|
id: "showpopup1"
|
||||||
|
xanchor: XANCHOR_NONE
|
||||||
|
yanchor: YANCHOR_NONE
|
||||||
|
pivot: PIVOT_CENTER
|
||||||
|
adjust_mode: ADJUST_MODE_FIT
|
||||||
|
layer: ""
|
||||||
|
inherit_alpha: true
|
||||||
|
slice9 {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 0.0
|
||||||
|
}
|
||||||
|
clipping_mode: CLIPPING_MODE_NONE
|
||||||
|
clipping_visible: true
|
||||||
|
clipping_inverted: false
|
||||||
|
alpha: 1.0
|
||||||
|
template_node_child: false
|
||||||
|
size_mode: SIZE_MODE_AUTO
|
||||||
|
custom_type: 0
|
||||||
|
enabled: true
|
||||||
|
visible: true
|
||||||
|
}
|
||||||
|
nodes {
|
||||||
|
position {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
size {
|
||||||
|
x: 200.0
|
||||||
|
y: 100.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
color {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
type: TYPE_TEXT
|
||||||
|
blend_mode: BLEND_MODE_ALPHA
|
||||||
|
text: "SHOW POPUP 1"
|
||||||
|
font: "example"
|
||||||
|
id: "showpopup1text"
|
||||||
|
xanchor: XANCHOR_NONE
|
||||||
|
yanchor: YANCHOR_NONE
|
||||||
|
pivot: PIVOT_CENTER
|
||||||
|
outline {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
shadow {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
adjust_mode: ADJUST_MODE_FIT
|
||||||
|
line_break: false
|
||||||
|
parent: "showpopup1"
|
||||||
|
layer: ""
|
||||||
|
inherit_alpha: true
|
||||||
|
alpha: 1.0
|
||||||
|
outline_alpha: 1.0
|
||||||
|
shadow_alpha: 1.0
|
||||||
|
template_node_child: false
|
||||||
|
text_leading: 1.0
|
||||||
|
text_tracking: 0.0
|
||||||
|
custom_type: 0
|
||||||
|
enabled: true
|
||||||
|
visible: true
|
||||||
|
}
|
||||||
|
material: "/builtins/materials/gui.material"
|
||||||
|
adjust_reference: ADJUST_REFERENCE_PARENT
|
||||||
|
max_nodes: 512
|
||||||
15
example/basic/screen1.gui_script
Normal file
15
example/basic/screen1.gui_script
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
local monarch = require "monarch.monarch"
|
||||||
|
|
||||||
|
function init(self)
|
||||||
|
msg.post(".", "acquire_input_focus")
|
||||||
|
end
|
||||||
|
|
||||||
|
function on_input(self, action_id, action)
|
||||||
|
if action_id == hash("touch") and action.pressed then
|
||||||
|
if gui.pick_node(gui.get_node("showscreen2"), action.x, action.y) then
|
||||||
|
monarch.show("screen2")
|
||||||
|
elseif gui.pick_node(gui.get_node("showpopup1"), action.x, action.y) then
|
||||||
|
monarch.show("popup1")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
37
example/basic/screen2.collection
Normal file
37
example/basic/screen2.collection
Normal file
@@ -0,0 +1,37 @@
|
|||||||
|
name: "screen2"
|
||||||
|
scale_along_z: 0
|
||||||
|
embedded_instances {
|
||||||
|
id: "go"
|
||||||
|
data: "components {\n"
|
||||||
|
" id: \"screen2\"\n"
|
||||||
|
" component: \"/example/basic/screen2.gui\"\n"
|
||||||
|
" position {\n"
|
||||||
|
" x: 0.0\n"
|
||||||
|
" y: 0.0\n"
|
||||||
|
" z: 0.0\n"
|
||||||
|
" }\n"
|
||||||
|
" rotation {\n"
|
||||||
|
" x: 0.0\n"
|
||||||
|
" y: 0.0\n"
|
||||||
|
" z: 0.0\n"
|
||||||
|
" w: 1.0\n"
|
||||||
|
" }\n"
|
||||||
|
"}\n"
|
||||||
|
""
|
||||||
|
position {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale3 {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
}
|
||||||
|
}
|
||||||
325
example/basic/screen2.gui
Normal file
325
example/basic/screen2.gui
Normal file
@@ -0,0 +1,325 @@
|
|||||||
|
script: "/example/basic/screen2.gui_script"
|
||||||
|
fonts {
|
||||||
|
name: "example"
|
||||||
|
font: "/assets/example.font"
|
||||||
|
}
|
||||||
|
background_color {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 0.0
|
||||||
|
}
|
||||||
|
nodes {
|
||||||
|
position {
|
||||||
|
x: 320.0
|
||||||
|
y: 568.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
size {
|
||||||
|
x: 200.0
|
||||||
|
y: 100.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
color {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
type: TYPE_BOX
|
||||||
|
blend_mode: BLEND_MODE_ALPHA
|
||||||
|
texture: ""
|
||||||
|
id: "backbutton"
|
||||||
|
xanchor: XANCHOR_NONE
|
||||||
|
yanchor: YANCHOR_NONE
|
||||||
|
pivot: PIVOT_CENTER
|
||||||
|
adjust_mode: ADJUST_MODE_FIT
|
||||||
|
layer: ""
|
||||||
|
inherit_alpha: true
|
||||||
|
slice9 {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 0.0
|
||||||
|
}
|
||||||
|
clipping_mode: CLIPPING_MODE_NONE
|
||||||
|
clipping_visible: true
|
||||||
|
clipping_inverted: false
|
||||||
|
alpha: 1.0
|
||||||
|
template_node_child: false
|
||||||
|
size_mode: SIZE_MODE_AUTO
|
||||||
|
custom_type: 0
|
||||||
|
enabled: true
|
||||||
|
visible: true
|
||||||
|
}
|
||||||
|
nodes {
|
||||||
|
position {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
size {
|
||||||
|
x: 200.0
|
||||||
|
y: 100.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
color {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
type: TYPE_TEXT
|
||||||
|
blend_mode: BLEND_MODE_ALPHA
|
||||||
|
text: "BACK"
|
||||||
|
font: "example"
|
||||||
|
id: "text"
|
||||||
|
xanchor: XANCHOR_NONE
|
||||||
|
yanchor: YANCHOR_NONE
|
||||||
|
pivot: PIVOT_CENTER
|
||||||
|
outline {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
shadow {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
adjust_mode: ADJUST_MODE_FIT
|
||||||
|
line_break: false
|
||||||
|
parent: "backbutton"
|
||||||
|
layer: ""
|
||||||
|
inherit_alpha: true
|
||||||
|
alpha: 1.0
|
||||||
|
outline_alpha: 1.0
|
||||||
|
shadow_alpha: 1.0
|
||||||
|
template_node_child: false
|
||||||
|
text_leading: 1.0
|
||||||
|
text_tracking: 0.0
|
||||||
|
custom_type: 0
|
||||||
|
enabled: true
|
||||||
|
visible: true
|
||||||
|
}
|
||||||
|
nodes {
|
||||||
|
position {
|
||||||
|
x: 320.0
|
||||||
|
y: 10.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
size {
|
||||||
|
x: 200.0
|
||||||
|
y: 40.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
color {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
type: TYPE_TEXT
|
||||||
|
blend_mode: BLEND_MODE_ALPHA
|
||||||
|
text: "THIS IS SCREEN 2"
|
||||||
|
font: "example"
|
||||||
|
id: "id"
|
||||||
|
xanchor: XANCHOR_NONE
|
||||||
|
yanchor: YANCHOR_NONE
|
||||||
|
pivot: PIVOT_S
|
||||||
|
outline {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
shadow {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
adjust_mode: ADJUST_MODE_FIT
|
||||||
|
line_break: false
|
||||||
|
layer: ""
|
||||||
|
inherit_alpha: true
|
||||||
|
alpha: 1.0
|
||||||
|
outline_alpha: 1.0
|
||||||
|
shadow_alpha: 1.0
|
||||||
|
template_node_child: false
|
||||||
|
text_leading: 1.0
|
||||||
|
text_tracking: 0.0
|
||||||
|
custom_type: 0
|
||||||
|
enabled: true
|
||||||
|
visible: true
|
||||||
|
}
|
||||||
|
nodes {
|
||||||
|
position {
|
||||||
|
x: 320.0
|
||||||
|
y: 450.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
size {
|
||||||
|
x: 200.0
|
||||||
|
y: 100.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
color {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
type: TYPE_BOX
|
||||||
|
blend_mode: BLEND_MODE_ALPHA
|
||||||
|
texture: ""
|
||||||
|
id: "showpopup1"
|
||||||
|
xanchor: XANCHOR_NONE
|
||||||
|
yanchor: YANCHOR_NONE
|
||||||
|
pivot: PIVOT_CENTER
|
||||||
|
adjust_mode: ADJUST_MODE_FIT
|
||||||
|
layer: ""
|
||||||
|
inherit_alpha: true
|
||||||
|
slice9 {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 0.0
|
||||||
|
}
|
||||||
|
clipping_mode: CLIPPING_MODE_NONE
|
||||||
|
clipping_visible: true
|
||||||
|
clipping_inverted: false
|
||||||
|
alpha: 1.0
|
||||||
|
template_node_child: false
|
||||||
|
size_mode: SIZE_MODE_AUTO
|
||||||
|
custom_type: 0
|
||||||
|
enabled: true
|
||||||
|
visible: true
|
||||||
|
}
|
||||||
|
nodes {
|
||||||
|
position {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
size {
|
||||||
|
x: 200.0
|
||||||
|
y: 100.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
color {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
type: TYPE_TEXT
|
||||||
|
blend_mode: BLEND_MODE_ALPHA
|
||||||
|
text: "SHOW POPUP 1"
|
||||||
|
font: "example"
|
||||||
|
id: "showpopup1text"
|
||||||
|
xanchor: XANCHOR_NONE
|
||||||
|
yanchor: YANCHOR_NONE
|
||||||
|
pivot: PIVOT_CENTER
|
||||||
|
outline {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
shadow {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
adjust_mode: ADJUST_MODE_FIT
|
||||||
|
line_break: false
|
||||||
|
parent: "showpopup1"
|
||||||
|
layer: ""
|
||||||
|
inherit_alpha: true
|
||||||
|
alpha: 1.0
|
||||||
|
outline_alpha: 1.0
|
||||||
|
shadow_alpha: 1.0
|
||||||
|
template_node_child: false
|
||||||
|
text_leading: 1.0
|
||||||
|
text_tracking: 0.0
|
||||||
|
custom_type: 0
|
||||||
|
enabled: true
|
||||||
|
visible: true
|
||||||
|
}
|
||||||
|
material: "/builtins/materials/gui.material"
|
||||||
|
adjust_reference: ADJUST_REFERENCE_PARENT
|
||||||
|
max_nodes: 512
|
||||||
15
example/basic/screen2.gui_script
Normal file
15
example/basic/screen2.gui_script
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
local monarch = require "monarch.monarch"
|
||||||
|
|
||||||
|
function init(self)
|
||||||
|
msg.post(".", "acquire_input_focus")
|
||||||
|
end
|
||||||
|
|
||||||
|
function on_input(self, action_id, action)
|
||||||
|
if action_id == hash("touch") and action.pressed then
|
||||||
|
if gui.pick_node(gui.get_node("backbutton"), action.x, action.y) then
|
||||||
|
monarch.back()
|
||||||
|
elseif gui.pick_node(gui.get_node("showpopup1"), action.x, action.y) then
|
||||||
|
monarch.show("popup1")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
159
example/slidingwindow/slidingwindow.collection
Normal file
159
example/slidingwindow/slidingwindow.collection
Normal file
@@ -0,0 +1,159 @@
|
|||||||
|
name: "slidingwindow"
|
||||||
|
scale_along_z: 0
|
||||||
|
embedded_instances {
|
||||||
|
id: "go"
|
||||||
|
data: "components {\n"
|
||||||
|
" id: \"slidingwindow\"\n"
|
||||||
|
" component: \"/example/slidingwindow/slidingwindow.script\"\n"
|
||||||
|
" position {\n"
|
||||||
|
" x: 0.0\n"
|
||||||
|
" y: 0.0\n"
|
||||||
|
" z: 0.0\n"
|
||||||
|
" }\n"
|
||||||
|
" rotation {\n"
|
||||||
|
" x: 0.0\n"
|
||||||
|
" y: 0.0\n"
|
||||||
|
" z: 0.0\n"
|
||||||
|
" w: 1.0\n"
|
||||||
|
" }\n"
|
||||||
|
" property_decls {\n"
|
||||||
|
" }\n"
|
||||||
|
"}\n"
|
||||||
|
""
|
||||||
|
position {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale3 {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
}
|
||||||
|
}
|
||||||
|
embedded_instances {
|
||||||
|
id: "window1"
|
||||||
|
data: "components {\n"
|
||||||
|
" id: \"screen_proxy\"\n"
|
||||||
|
" component: \"/monarch/screen_proxy.script\"\n"
|
||||||
|
" position {\n"
|
||||||
|
" x: 0.0\n"
|
||||||
|
" y: 0.0\n"
|
||||||
|
" z: 0.0\n"
|
||||||
|
" }\n"
|
||||||
|
" rotation {\n"
|
||||||
|
" x: 0.0\n"
|
||||||
|
" y: 0.0\n"
|
||||||
|
" z: 0.0\n"
|
||||||
|
" w: 1.0\n"
|
||||||
|
" }\n"
|
||||||
|
" properties {\n"
|
||||||
|
" id: \"screen_id\"\n"
|
||||||
|
" value: \"window1\"\n"
|
||||||
|
" type: PROPERTY_TYPE_HASH\n"
|
||||||
|
" }\n"
|
||||||
|
" property_decls {\n"
|
||||||
|
" }\n"
|
||||||
|
"}\n"
|
||||||
|
"embedded_components {\n"
|
||||||
|
" id: \"collectionproxy\"\n"
|
||||||
|
" type: \"collectionproxy\"\n"
|
||||||
|
" data: \"collection: \\\"/example/slidingwindow/window1.collection\\\"\\n"
|
||||||
|
"exclude: false\\n"
|
||||||
|
"\"\n"
|
||||||
|
" position {\n"
|
||||||
|
" x: 0.0\n"
|
||||||
|
" y: 0.0\n"
|
||||||
|
" z: 0.0\n"
|
||||||
|
" }\n"
|
||||||
|
" rotation {\n"
|
||||||
|
" x: 0.0\n"
|
||||||
|
" y: 0.0\n"
|
||||||
|
" z: 0.0\n"
|
||||||
|
" w: 1.0\n"
|
||||||
|
" }\n"
|
||||||
|
"}\n"
|
||||||
|
""
|
||||||
|
position {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale3 {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
}
|
||||||
|
}
|
||||||
|
embedded_instances {
|
||||||
|
id: "window2"
|
||||||
|
data: "components {\n"
|
||||||
|
" id: \"screen_proxy\"\n"
|
||||||
|
" component: \"/monarch/screen_proxy.script\"\n"
|
||||||
|
" position {\n"
|
||||||
|
" x: 0.0\n"
|
||||||
|
" y: 0.0\n"
|
||||||
|
" z: 0.0\n"
|
||||||
|
" }\n"
|
||||||
|
" rotation {\n"
|
||||||
|
" x: 0.0\n"
|
||||||
|
" y: 0.0\n"
|
||||||
|
" z: 0.0\n"
|
||||||
|
" w: 1.0\n"
|
||||||
|
" }\n"
|
||||||
|
" properties {\n"
|
||||||
|
" id: \"screen_id\"\n"
|
||||||
|
" value: \"window2\"\n"
|
||||||
|
" type: PROPERTY_TYPE_HASH\n"
|
||||||
|
" }\n"
|
||||||
|
" property_decls {\n"
|
||||||
|
" }\n"
|
||||||
|
"}\n"
|
||||||
|
"embedded_components {\n"
|
||||||
|
" id: \"collectionproxy\"\n"
|
||||||
|
" type: \"collectionproxy\"\n"
|
||||||
|
" data: \"collection: \\\"/example/slidingwindow/window2.collection\\\"\\n"
|
||||||
|
"exclude: false\\n"
|
||||||
|
"\"\n"
|
||||||
|
" position {\n"
|
||||||
|
" x: 0.0\n"
|
||||||
|
" y: 0.0\n"
|
||||||
|
" z: 0.0\n"
|
||||||
|
" }\n"
|
||||||
|
" rotation {\n"
|
||||||
|
" x: 0.0\n"
|
||||||
|
" y: 0.0\n"
|
||||||
|
" z: 0.0\n"
|
||||||
|
" w: 1.0\n"
|
||||||
|
" }\n"
|
||||||
|
"}\n"
|
||||||
|
""
|
||||||
|
position {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale3 {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
}
|
||||||
|
}
|
||||||
13
example/slidingwindow/slidingwindow.script
Normal file
13
example/slidingwindow/slidingwindow.script
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
local monarch = require "monarch.monarch"
|
||||||
|
|
||||||
|
function init(self)
|
||||||
|
monarch.debug()
|
||||||
|
msg.post("@render:/", "clear_color", { color = vmath.vector4(0.4, 0.6, 0.8,1.0) })
|
||||||
|
msg.post("#", "init_monarch") -- wait until init() has been called for all screen.script instances
|
||||||
|
end
|
||||||
|
|
||||||
|
function on_message(self, message_id, message, sender)
|
||||||
|
if message_id == hash("init_monarch") then
|
||||||
|
monarch.show(hash("window1"))
|
||||||
|
end
|
||||||
|
end
|
||||||
39
example/slidingwindow/window1.collection
Normal file
39
example/slidingwindow/window1.collection
Normal file
@@ -0,0 +1,39 @@
|
|||||||
|
name: "window1"
|
||||||
|
scale_along_z: 0
|
||||||
|
embedded_instances {
|
||||||
|
id: "go"
|
||||||
|
data: "components {\n"
|
||||||
|
" id: \"window1\"\n"
|
||||||
|
" component: \"/example/slidingwindow/window1.gui\"\n"
|
||||||
|
" position {\n"
|
||||||
|
" x: 0.0\n"
|
||||||
|
" y: 0.0\n"
|
||||||
|
" z: 0.0\n"
|
||||||
|
" }\n"
|
||||||
|
" rotation {\n"
|
||||||
|
" x: 0.0\n"
|
||||||
|
" y: 0.0\n"
|
||||||
|
" z: 0.0\n"
|
||||||
|
" w: 1.0\n"
|
||||||
|
" }\n"
|
||||||
|
" property_decls {\n"
|
||||||
|
" }\n"
|
||||||
|
"}\n"
|
||||||
|
""
|
||||||
|
position {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale3 {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
}
|
||||||
|
}
|
||||||
261
example/slidingwindow/window1.gui
Normal file
261
example/slidingwindow/window1.gui
Normal file
@@ -0,0 +1,261 @@
|
|||||||
|
script: "/example/slidingwindow/window1.gui_script"
|
||||||
|
fonts {
|
||||||
|
name: "example"
|
||||||
|
font: "/assets/example.font"
|
||||||
|
}
|
||||||
|
background_color {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 0.0
|
||||||
|
}
|
||||||
|
nodes {
|
||||||
|
position {
|
||||||
|
x: 320.0
|
||||||
|
y: 568.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
size {
|
||||||
|
x: 640.0
|
||||||
|
y: 1136.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
color {
|
||||||
|
x: 0.3019608
|
||||||
|
y: 0.3019608
|
||||||
|
z: 0.3019608
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
type: TYPE_BOX
|
||||||
|
blend_mode: BLEND_MODE_ALPHA
|
||||||
|
texture: ""
|
||||||
|
id: "bg"
|
||||||
|
xanchor: XANCHOR_NONE
|
||||||
|
yanchor: YANCHOR_NONE
|
||||||
|
pivot: PIVOT_CENTER
|
||||||
|
adjust_mode: ADJUST_MODE_STRETCH
|
||||||
|
layer: ""
|
||||||
|
inherit_alpha: true
|
||||||
|
slice9 {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 0.0
|
||||||
|
}
|
||||||
|
clipping_mode: CLIPPING_MODE_NONE
|
||||||
|
clipping_visible: true
|
||||||
|
clipping_inverted: false
|
||||||
|
alpha: 1.0
|
||||||
|
template_node_child: false
|
||||||
|
size_mode: SIZE_MODE_MANUAL
|
||||||
|
custom_type: 0
|
||||||
|
enabled: true
|
||||||
|
visible: true
|
||||||
|
}
|
||||||
|
nodes {
|
||||||
|
position {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
size {
|
||||||
|
x: 200.0
|
||||||
|
y: 50.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
color {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
type: TYPE_BOX
|
||||||
|
blend_mode: BLEND_MODE_ALPHA
|
||||||
|
texture: ""
|
||||||
|
id: "button"
|
||||||
|
xanchor: XANCHOR_NONE
|
||||||
|
yanchor: YANCHOR_NONE
|
||||||
|
pivot: PIVOT_CENTER
|
||||||
|
adjust_mode: ADJUST_MODE_FIT
|
||||||
|
parent: "bg"
|
||||||
|
layer: ""
|
||||||
|
inherit_alpha: true
|
||||||
|
slice9 {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 0.0
|
||||||
|
}
|
||||||
|
clipping_mode: CLIPPING_MODE_NONE
|
||||||
|
clipping_visible: true
|
||||||
|
clipping_inverted: false
|
||||||
|
alpha: 1.0
|
||||||
|
template_node_child: false
|
||||||
|
size_mode: SIZE_MODE_MANUAL
|
||||||
|
custom_type: 0
|
||||||
|
enabled: true
|
||||||
|
visible: true
|
||||||
|
}
|
||||||
|
nodes {
|
||||||
|
position {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
size {
|
||||||
|
x: 200.0
|
||||||
|
y: 50.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
color {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
type: TYPE_TEXT
|
||||||
|
blend_mode: BLEND_MODE_ALPHA
|
||||||
|
text: "WINDOW 2"
|
||||||
|
font: "example"
|
||||||
|
id: "text"
|
||||||
|
xanchor: XANCHOR_NONE
|
||||||
|
yanchor: YANCHOR_NONE
|
||||||
|
pivot: PIVOT_CENTER
|
||||||
|
outline {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
shadow {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
adjust_mode: ADJUST_MODE_FIT
|
||||||
|
line_break: false
|
||||||
|
parent: "button"
|
||||||
|
layer: ""
|
||||||
|
inherit_alpha: true
|
||||||
|
alpha: 1.0
|
||||||
|
outline_alpha: 1.0
|
||||||
|
shadow_alpha: 1.0
|
||||||
|
template_node_child: false
|
||||||
|
text_leading: 1.0
|
||||||
|
text_tracking: 0.0
|
||||||
|
custom_type: 0
|
||||||
|
enabled: true
|
||||||
|
visible: true
|
||||||
|
}
|
||||||
|
nodes {
|
||||||
|
position {
|
||||||
|
x: 0.0
|
||||||
|
y: 338.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale {
|
||||||
|
x: 2.0
|
||||||
|
y: 2.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
size {
|
||||||
|
x: 200.0
|
||||||
|
y: 100.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
color {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
type: TYPE_TEXT
|
||||||
|
blend_mode: BLEND_MODE_ALPHA
|
||||||
|
text: "WINDOW 1"
|
||||||
|
font: "example"
|
||||||
|
id: "title"
|
||||||
|
xanchor: XANCHOR_NONE
|
||||||
|
yanchor: YANCHOR_NONE
|
||||||
|
pivot: PIVOT_CENTER
|
||||||
|
outline {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
shadow {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
adjust_mode: ADJUST_MODE_FIT
|
||||||
|
line_break: false
|
||||||
|
parent: "bg"
|
||||||
|
layer: ""
|
||||||
|
inherit_alpha: true
|
||||||
|
alpha: 1.0
|
||||||
|
outline_alpha: 1.0
|
||||||
|
shadow_alpha: 1.0
|
||||||
|
template_node_child: false
|
||||||
|
text_leading: 1.0
|
||||||
|
text_tracking: 0.0
|
||||||
|
custom_type: 0
|
||||||
|
enabled: true
|
||||||
|
visible: true
|
||||||
|
}
|
||||||
|
material: "/builtins/materials/gui.material"
|
||||||
|
adjust_reference: ADJUST_REFERENCE_PARENT
|
||||||
|
max_nodes: 512
|
||||||
35
example/slidingwindow/window1.gui_script
Normal file
35
example/slidingwindow/window1.gui_script
Normal file
@@ -0,0 +1,35 @@
|
|||||||
|
local monarch = require "monarch.monarch"
|
||||||
|
local transitions = require "monarch.transitions.gui"
|
||||||
|
|
||||||
|
function init(self)
|
||||||
|
msg.post(".", "acquire_input_focus")
|
||||||
|
|
||||||
|
local DURATION = 0.3
|
||||||
|
local transition = transitions.create(gui.get_node("bg"))
|
||||||
|
.show_in(transitions.slide_in_right, gui.EASING_LINEAR, DURATION, 0)
|
||||||
|
.show_out(transitions.slide_out_left, gui.EASING_LINEAR, DURATION, 0)
|
||||||
|
.back_in(transitions.slide_in_left, gui.EASING_LINEAR, DURATION, 0)
|
||||||
|
.back_out(transitions.slide_out_right, gui.EASING_LINEAR, DURATION, 0)
|
||||||
|
|
||||||
|
monarch.on_transition("window1", transition)
|
||||||
|
|
||||||
|
monarch.on_focus_changed("window1", function(message_id, message)
|
||||||
|
if message_id == monarch.FOCUS.GAINED then
|
||||||
|
print("window1 gained focus")
|
||||||
|
elseif message_id == monarch.FOCUS.LOST then
|
||||||
|
print("window1 lost focus")
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
end
|
||||||
|
|
||||||
|
function on_input(self, action_id, action)
|
||||||
|
if action_id == hash("touch") and action.released then
|
||||||
|
if gui.pick_node(gui.get_node("button"), action.x, action.y) then
|
||||||
|
monarch.show("window2")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
function on_message(self, message_id, message, sender)
|
||||||
|
monarch.on_message(message_id, message, sender)
|
||||||
|
end
|
||||||
39
example/slidingwindow/window2.collection
Normal file
39
example/slidingwindow/window2.collection
Normal file
@@ -0,0 +1,39 @@
|
|||||||
|
name: "window2"
|
||||||
|
scale_along_z: 0
|
||||||
|
embedded_instances {
|
||||||
|
id: "go"
|
||||||
|
data: "components {\n"
|
||||||
|
" id: \"window2\"\n"
|
||||||
|
" component: \"/example/slidingwindow/window2.gui\"\n"
|
||||||
|
" position {\n"
|
||||||
|
" x: 0.0\n"
|
||||||
|
" y: 0.0\n"
|
||||||
|
" z: 0.0\n"
|
||||||
|
" }\n"
|
||||||
|
" rotation {\n"
|
||||||
|
" x: 0.0\n"
|
||||||
|
" y: 0.0\n"
|
||||||
|
" z: 0.0\n"
|
||||||
|
" w: 1.0\n"
|
||||||
|
" }\n"
|
||||||
|
" property_decls {\n"
|
||||||
|
" }\n"
|
||||||
|
"}\n"
|
||||||
|
""
|
||||||
|
position {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale3 {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
}
|
||||||
|
}
|
||||||
261
example/slidingwindow/window2.gui
Normal file
261
example/slidingwindow/window2.gui
Normal file
@@ -0,0 +1,261 @@
|
|||||||
|
script: "/example/slidingwindow/window2.gui_script"
|
||||||
|
fonts {
|
||||||
|
name: "example"
|
||||||
|
font: "/assets/example.font"
|
||||||
|
}
|
||||||
|
background_color {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 0.0
|
||||||
|
}
|
||||||
|
nodes {
|
||||||
|
position {
|
||||||
|
x: 320.0
|
||||||
|
y: 568.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
size {
|
||||||
|
x: 640.0
|
||||||
|
y: 1136.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
color {
|
||||||
|
x: 0.3019608
|
||||||
|
y: 0.3019608
|
||||||
|
z: 0.3019608
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
type: TYPE_BOX
|
||||||
|
blend_mode: BLEND_MODE_ALPHA
|
||||||
|
texture: ""
|
||||||
|
id: "bg"
|
||||||
|
xanchor: XANCHOR_NONE
|
||||||
|
yanchor: YANCHOR_NONE
|
||||||
|
pivot: PIVOT_CENTER
|
||||||
|
adjust_mode: ADJUST_MODE_STRETCH
|
||||||
|
layer: ""
|
||||||
|
inherit_alpha: true
|
||||||
|
slice9 {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 0.0
|
||||||
|
}
|
||||||
|
clipping_mode: CLIPPING_MODE_NONE
|
||||||
|
clipping_visible: true
|
||||||
|
clipping_inverted: false
|
||||||
|
alpha: 1.0
|
||||||
|
template_node_child: false
|
||||||
|
size_mode: SIZE_MODE_MANUAL
|
||||||
|
custom_type: 0
|
||||||
|
enabled: true
|
||||||
|
visible: true
|
||||||
|
}
|
||||||
|
nodes {
|
||||||
|
position {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
size {
|
||||||
|
x: 200.0
|
||||||
|
y: 50.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
color {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
type: TYPE_BOX
|
||||||
|
blend_mode: BLEND_MODE_ALPHA
|
||||||
|
texture: ""
|
||||||
|
id: "button"
|
||||||
|
xanchor: XANCHOR_NONE
|
||||||
|
yanchor: YANCHOR_NONE
|
||||||
|
pivot: PIVOT_CENTER
|
||||||
|
adjust_mode: ADJUST_MODE_FIT
|
||||||
|
parent: "bg"
|
||||||
|
layer: ""
|
||||||
|
inherit_alpha: true
|
||||||
|
slice9 {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 0.0
|
||||||
|
}
|
||||||
|
clipping_mode: CLIPPING_MODE_NONE
|
||||||
|
clipping_visible: true
|
||||||
|
clipping_inverted: false
|
||||||
|
alpha: 1.0
|
||||||
|
template_node_child: false
|
||||||
|
size_mode: SIZE_MODE_MANUAL
|
||||||
|
custom_type: 0
|
||||||
|
enabled: true
|
||||||
|
visible: true
|
||||||
|
}
|
||||||
|
nodes {
|
||||||
|
position {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
size {
|
||||||
|
x: 200.0
|
||||||
|
y: 50.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
color {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
type: TYPE_TEXT
|
||||||
|
blend_mode: BLEND_MODE_ALPHA
|
||||||
|
text: "BACK"
|
||||||
|
font: "example"
|
||||||
|
id: "text"
|
||||||
|
xanchor: XANCHOR_NONE
|
||||||
|
yanchor: YANCHOR_NONE
|
||||||
|
pivot: PIVOT_CENTER
|
||||||
|
outline {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
shadow {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
adjust_mode: ADJUST_MODE_FIT
|
||||||
|
line_break: false
|
||||||
|
parent: "button"
|
||||||
|
layer: ""
|
||||||
|
inherit_alpha: true
|
||||||
|
alpha: 1.0
|
||||||
|
outline_alpha: 1.0
|
||||||
|
shadow_alpha: 1.0
|
||||||
|
template_node_child: false
|
||||||
|
text_leading: 1.0
|
||||||
|
text_tracking: 0.0
|
||||||
|
custom_type: 0
|
||||||
|
enabled: true
|
||||||
|
visible: true
|
||||||
|
}
|
||||||
|
nodes {
|
||||||
|
position {
|
||||||
|
x: 0.0
|
||||||
|
y: 338.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
rotation {
|
||||||
|
x: 0.0
|
||||||
|
y: 0.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
scale {
|
||||||
|
x: 2.0
|
||||||
|
y: 2.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
size {
|
||||||
|
x: 200.0
|
||||||
|
y: 100.0
|
||||||
|
z: 0.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
color {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
type: TYPE_TEXT
|
||||||
|
blend_mode: BLEND_MODE_ALPHA
|
||||||
|
text: "WINDOW 2"
|
||||||
|
font: "example"
|
||||||
|
id: "title"
|
||||||
|
xanchor: XANCHOR_NONE
|
||||||
|
yanchor: YANCHOR_NONE
|
||||||
|
pivot: PIVOT_CENTER
|
||||||
|
outline {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
shadow {
|
||||||
|
x: 1.0
|
||||||
|
y: 1.0
|
||||||
|
z: 1.0
|
||||||
|
w: 1.0
|
||||||
|
}
|
||||||
|
adjust_mode: ADJUST_MODE_FIT
|
||||||
|
line_break: false
|
||||||
|
parent: "bg"
|
||||||
|
layer: ""
|
||||||
|
inherit_alpha: true
|
||||||
|
alpha: 1.0
|
||||||
|
outline_alpha: 1.0
|
||||||
|
shadow_alpha: 1.0
|
||||||
|
template_node_child: false
|
||||||
|
text_leading: 1.0
|
||||||
|
text_tracking: 0.0
|
||||||
|
custom_type: 0
|
||||||
|
enabled: true
|
||||||
|
visible: true
|
||||||
|
}
|
||||||
|
material: "/builtins/materials/gui.material"
|
||||||
|
adjust_reference: ADJUST_REFERENCE_PARENT
|
||||||
|
max_nodes: 512
|
||||||
28
example/slidingwindow/window2.gui_script
Normal file
28
example/slidingwindow/window2.gui_script
Normal file
@@ -0,0 +1,28 @@
|
|||||||
|
local monarch = require "monarch.monarch"
|
||||||
|
local transitions = require "monarch.transitions.gui"
|
||||||
|
|
||||||
|
function init(self)
|
||||||
|
msg.post(".", "acquire_input_focus")
|
||||||
|
|
||||||
|
local DURATION = 0.3
|
||||||
|
local transition = transitions.create(gui.get_node("bg"))
|
||||||
|
.show_in(transitions.slide_in_right, gui.EASING_LINEAR, DURATION, 0)
|
||||||
|
.show_out(transitions.slide_out_left, gui.EASING_LINEAR, DURATION, 0)
|
||||||
|
.back_in(transitions.slide_in_left, gui.EASING_LINEAR, DURATION, 0)
|
||||||
|
.back_out(transitions.slide_out_right, gui.EASING_LINEAR, DURATION, 0)
|
||||||
|
|
||||||
|
monarch.on_transition("window2", transition)
|
||||||
|
end
|
||||||
|
|
||||||
|
function on_input(self, action_id, action)
|
||||||
|
if action_id == hash("touch") and action.released then
|
||||||
|
if gui.pick_node(gui.get_node("button"), action.x, action.y) then
|
||||||
|
monarch.back()
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
function on_message(self, message_id, message, sender)
|
||||||
|
print("window2", message_id, message, sender)
|
||||||
|
monarch.on_message(message_id, message, sender)
|
||||||
|
end
|
||||||
@@ -1,10 +1,11 @@
|
|||||||
[project]
|
[project]
|
||||||
title = Monarch
|
title = Monarch
|
||||||
version = 0.9
|
version = 0.9
|
||||||
dependencies = https://github.com/britzl/deftest/archive/2.7.0.zip
|
dependencies#0 = https://github.com/britzl/deftest/archive/2.7.0.zip
|
||||||
|
dependencies#1 = https://github.com/defold/lua-language-server/releases/download/v0.0.3/release.zip
|
||||||
|
|
||||||
[bootstrap]
|
[bootstrap]
|
||||||
main_collection = /example/example.collectionc
|
main_collection = /example/slidingwindow/slidingwindow.collectionc
|
||||||
|
|
||||||
[input]
|
[input]
|
||||||
game_binding = /input/game.input_bindingc
|
game_binding = /input/game.input_bindingc
|
||||||
|
|||||||
@@ -1,10 +1,12 @@
|
|||||||
local callback_tracker = require "monarch.utils.callback_tracker"
|
local callback_tracker = require "monarch.utils.callback_tracker"
|
||||||
|
local async = require "monarch.utils.async"
|
||||||
|
|
||||||
local M = {}
|
local M = {}
|
||||||
|
|
||||||
local CONTEXT = hash("monarch_context")
|
local CONTEXT = hash("monarch_context")
|
||||||
local PROXY_LOADED = hash("proxy_loaded")
|
local PROXY_LOADED = hash("proxy_loaded")
|
||||||
local PROXY_UNLOADED = hash("proxy_unloaded")
|
local PROXY_UNLOADED = hash("proxy_unloaded")
|
||||||
|
local LAYOUT_CHANGED = hash("layout_changed")
|
||||||
|
|
||||||
local RELEASE_INPUT_FOCUS = hash("release_input_focus")
|
local RELEASE_INPUT_FOCUS = hash("release_input_focus")
|
||||||
local ACQUIRE_INPUT_FOCUS = hash("acquire_input_focus")
|
local ACQUIRE_INPUT_FOCUS = hash("acquire_input_focus")
|
||||||
@@ -33,6 +35,8 @@ M.SCREEN_TRANSITION_OUT_STARTED = hash("monarch_screen_transition_out_started")
|
|||||||
M.SCREEN_TRANSITION_OUT_FINISHED = hash("monarch_screen_transition_out_finished")
|
M.SCREEN_TRANSITION_OUT_FINISHED = hash("monarch_screen_transition_out_finished")
|
||||||
M.SCREEN_TRANSITION_FAILED = hash("monarch_screen_transition_failed")
|
M.SCREEN_TRANSITION_FAILED = hash("monarch_screen_transition_failed")
|
||||||
|
|
||||||
|
local WAIT_FOR_TRANSITION = true
|
||||||
|
local DO_NOT_WAIT_FOR_TRANSITION = false
|
||||||
|
|
||||||
-- all registered screens
|
-- all registered screens
|
||||||
local screens = {}
|
local screens = {}
|
||||||
@@ -47,7 +51,6 @@ local transition_listeners = {}
|
|||||||
-- monarch is considered busy while there are active transitions
|
-- monarch is considered busy while there are active transitions
|
||||||
local active_transition_count = 0
|
local active_transition_count = 0
|
||||||
|
|
||||||
|
|
||||||
local function log(...) end
|
local function log(...) end
|
||||||
|
|
||||||
function M.debug()
|
function M.debug()
|
||||||
@@ -93,8 +96,8 @@ end
|
|||||||
local queue = {}
|
local queue = {}
|
||||||
|
|
||||||
local function queue_error(message)
|
local function queue_error(message)
|
||||||
print(message)
|
|
||||||
log("queue() error - clearing queue")
|
log("queue() error - clearing queue")
|
||||||
|
print(message)
|
||||||
while next(queue) do
|
while next(queue) do
|
||||||
table.remove(queue)
|
table.remove(queue)
|
||||||
end
|
end
|
||||||
@@ -106,7 +109,7 @@ process_queue = function()
|
|||||||
log("queue() busy")
|
log("queue() busy")
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
action = table.remove(queue, 1)
|
local action = table.remove(queue, 1)
|
||||||
if not action then
|
if not action then
|
||||||
log("queue() empty")
|
log("queue() empty")
|
||||||
return
|
return
|
||||||
@@ -132,23 +135,49 @@ local function notify_transition_listeners(message_id, message)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
local function screen_from_proxy(proxy)
|
local function find_screen(url_to_find)
|
||||||
for _,screen in pairs(screens) do
|
local function find(url)
|
||||||
if screen.proxy == proxy then
|
for _,screen in pairs(screens) do
|
||||||
return screen
|
if screen.script == url or screen.proxy == url then
|
||||||
|
return screen
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
return find(msg.url()) or find(url_to_find)
|
||||||
end
|
end
|
||||||
|
|
||||||
local function screen_from_script()
|
local function find_transition_screen(url_to_find)
|
||||||
local url = msg.url()
|
local function find(url)
|
||||||
for _,screen in pairs(screens) do
|
for _,screen in pairs(screens) do
|
||||||
if screen.script == url then
|
if screen.transition_url == url or screen.script == url or screen.proxy == url then
|
||||||
return screen
|
return screen
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
return find(msg.url()) or find(url_to_find)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local function find_focus_screen(url_to_find)
|
||||||
|
local function find(url)
|
||||||
|
for _,screen in pairs(screens) do
|
||||||
|
if screen.focus_url == url or screen.script == url or screen.proxy == url then
|
||||||
|
return screen
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return find(msg.url()) or find(url_to_find)
|
||||||
|
end
|
||||||
|
|
||||||
|
local function find_post_receiver_screen(url_to_find)
|
||||||
|
local function find(url)
|
||||||
|
for _,screen in pairs(screens) do
|
||||||
|
if screen.receiver_url == url or screen.script == url or screen.proxy == url then
|
||||||
|
return screen
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return find(msg.url()) or find(url_to_find)
|
||||||
|
end
|
||||||
|
|
||||||
--- Check if a screen exists in the current screen stack
|
--- Check if a screen exists in the current screen stack
|
||||||
-- @param id (string|hash)
|
-- @param id (string|hash)
|
||||||
@@ -184,7 +213,7 @@ function M.is_visible(id)
|
|||||||
assert(id, "You must provide a screen id")
|
assert(id, "You must provide a screen id")
|
||||||
id = tohash(id)
|
id = tohash(id)
|
||||||
assert(screens[id], ("There is no screen registered with id %s"):format(tostring(id)))
|
assert(screens[id], ("There is no screen registered with id %s"):format(tostring(id)))
|
||||||
return screens[id].loaded
|
return screens[id].visible
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
@@ -294,8 +323,13 @@ function M.unregister(id)
|
|||||||
id = tohash(id)
|
id = tohash(id)
|
||||||
assert(screens[id], ("There is no screen registered with id %s"):format(tostring(id)))
|
assert(screens[id], ("There is no screen registered with id %s"):format(tostring(id)))
|
||||||
log("unregister()", id)
|
log("unregister()", id)
|
||||||
local screen = screens[id]
|
|
||||||
screens[id] = nil
|
screens[id] = nil
|
||||||
|
-- remove screen from stack
|
||||||
|
for i = #stack, 1, -1 do
|
||||||
|
if stack[i].id == id then
|
||||||
|
table.remove(stack, i)
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
local function acquire_input(screen)
|
local function acquire_input(screen)
|
||||||
@@ -337,7 +371,7 @@ end
|
|||||||
local function change_context(screen)
|
local function change_context(screen)
|
||||||
log("change_context()", screen.id)
|
log("change_context()", screen.id)
|
||||||
screen.wait_for = CONTEXT
|
screen.wait_for = CONTEXT
|
||||||
msg.post(screen.script, CONTEXT)
|
msg.post(screen.script, CONTEXT, { id = screen.id })
|
||||||
coroutine.yield()
|
coroutine.yield()
|
||||||
screen.wait_for = nil
|
screen.wait_for = nil
|
||||||
end
|
end
|
||||||
@@ -346,8 +380,10 @@ local function unload(screen, force)
|
|||||||
if screen.proxy then
|
if screen.proxy then
|
||||||
log("unload() proxy", screen.id)
|
log("unload() proxy", screen.id)
|
||||||
if screen.auto_preload and not force then
|
if screen.auto_preload and not force then
|
||||||
msg.post(screen.proxy, DISABLE)
|
if screen.loaded then
|
||||||
screen.loaded = false
|
msg.post(screen.proxy, DISABLE)
|
||||||
|
screen.loaded = false
|
||||||
|
end
|
||||||
screen.preloaded = true
|
screen.preloaded = true
|
||||||
else
|
else
|
||||||
screen.wait_for = PROXY_UNLOADED
|
screen.wait_for = PROXY_UNLOADED
|
||||||
@@ -451,12 +487,14 @@ local function load(screen)
|
|||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
|
|
||||||
local function transition(screen, message_id, message)
|
local function transition(screen, message_id, message, wait)
|
||||||
log("transition()", screen.id)
|
log("transition()", screen.id)
|
||||||
if screen.transition_url then
|
if screen.transition_url then
|
||||||
screen.wait_for = M.TRANSITION.DONE
|
screen.wait_for = M.TRANSITION.DONE
|
||||||
msg.post(screen.transition_url, message_id, message)
|
msg.post(screen.transition_url, message_id, message)
|
||||||
coroutine.yield()
|
if wait then
|
||||||
|
coroutine.yield()
|
||||||
|
end
|
||||||
screen.wait_for = nil
|
screen.wait_for = nil
|
||||||
else
|
else
|
||||||
log("transition() no transition url - ignoring")
|
log("transition() no transition url - ignoring")
|
||||||
@@ -481,6 +519,7 @@ local function focus_lost(screen, next_screen)
|
|||||||
-- the focus_url
|
-- the focus_url
|
||||||
-- we add a delay to ensure the message queue has time to be processed
|
-- we add a delay to ensure the message queue has time to be processed
|
||||||
cowait(0)
|
cowait(0)
|
||||||
|
cowait(0)
|
||||||
else
|
else
|
||||||
log("focus_lost() no focus url - ignoring")
|
log("focus_lost() no focus url - ignoring")
|
||||||
end
|
end
|
||||||
@@ -538,8 +577,21 @@ local function enable(screen, previous_screen)
|
|||||||
end)
|
end)
|
||||||
end
|
end
|
||||||
|
|
||||||
local function show_out(screen, next_screen, cb)
|
local function show_out(screen, next_screen, wait_for_transition, cb)
|
||||||
log("show_out()", screen.id)
|
log("show_out()", screen.id)
|
||||||
|
assert(wait_for_transition ~= nil)
|
||||||
|
-- make sure the screen is loaded. scenario:
|
||||||
|
-- show A - stack [A]
|
||||||
|
-- - show_in for A
|
||||||
|
-- show B with no_stack = true - stack [A]
|
||||||
|
-- - show_in for B and show_out for A
|
||||||
|
-- show C
|
||||||
|
-- - show_in for C and show_out for A again!
|
||||||
|
if not screen.loaded then
|
||||||
|
log("show_out() screen was not loaded")
|
||||||
|
cb()
|
||||||
|
return
|
||||||
|
end
|
||||||
run_coroutine(screen, cb, function()
|
run_coroutine(screen, cb, function()
|
||||||
active_transition_count = active_transition_count + 1
|
active_transition_count = active_transition_count + 1
|
||||||
notify_transition_listeners(M.SCREEN_TRANSITION_OUT_STARTED, { screen = screen.id, next_screen = next_screen.id })
|
notify_transition_listeners(M.SCREEN_TRANSITION_OUT_STARTED, { screen = screen.id, next_screen = next_screen.id })
|
||||||
@@ -552,7 +604,8 @@ local function show_out(screen, next_screen, cb)
|
|||||||
local next_is_popup = next_screen and next_screen.popup
|
local next_is_popup = next_screen and next_screen.popup
|
||||||
local current_is_popup = screen.popup
|
local current_is_popup = screen.popup
|
||||||
if (not next_is_popup and not current_is_popup) or (current_is_popup) then
|
if (not next_is_popup and not current_is_popup) or (current_is_popup) then
|
||||||
transition(screen, M.TRANSITION.SHOW_OUT, { next_screen = next_screen.id })
|
transition(screen, M.TRANSITION.SHOW_OUT, { next_screen = next_screen.id }, wait_for_transition)
|
||||||
|
screen.visible = false
|
||||||
unload(screen)
|
unload(screen)
|
||||||
elseif next_is_popup then
|
elseif next_is_popup then
|
||||||
change_timestep(screen)
|
change_timestep(screen)
|
||||||
@@ -562,8 +615,9 @@ local function show_out(screen, next_screen, cb)
|
|||||||
end)
|
end)
|
||||||
end
|
end
|
||||||
|
|
||||||
local function show_in(screen, previous_screen, reload, add_to_stack, cb)
|
local function show_in(screen, previous_screen, reload, add_to_stack, wait_for_transition, cb)
|
||||||
log("show_in()", screen.id)
|
log("show_in()", screen.id, wait_for_transition)
|
||||||
|
assert(wait_for_transition ~= nil)
|
||||||
run_coroutine(screen, cb, function()
|
run_coroutine(screen, cb, function()
|
||||||
active_transition_count = active_transition_count + 1
|
active_transition_count = active_transition_count + 1
|
||||||
notify_transition_listeners(M.SCREEN_TRANSITION_IN_STARTED, { screen = screen.id, previous_screen = previous_screen and previous_screen.id })
|
notify_transition_listeners(M.SCREEN_TRANSITION_IN_STARTED, { screen = screen.id, previous_screen = previous_screen and previous_screen.id })
|
||||||
@@ -572,18 +626,24 @@ local function show_in(screen, previous_screen, reload, add_to_stack, cb)
|
|||||||
log("show_in() reloading", screen.id)
|
log("show_in() reloading", screen.id)
|
||||||
unload(screen, reload)
|
unload(screen, reload)
|
||||||
end
|
end
|
||||||
|
if add_to_stack then
|
||||||
|
stack[#stack + 1] = screen
|
||||||
|
end
|
||||||
local ok, err = load(screen)
|
local ok, err = load(screen)
|
||||||
if not ok then
|
if not ok then
|
||||||
log("show_in()", err)
|
log("show_in()", err)
|
||||||
|
if add_to_stack then
|
||||||
|
stack[#stack] = nil
|
||||||
|
end
|
||||||
active_transition_count = active_transition_count - 1
|
active_transition_count = active_transition_count - 1
|
||||||
notify_transition_listeners(M.SCREEN_TRANSITION_FAILED, { screen = screen.id })
|
notify_transition_listeners(M.SCREEN_TRANSITION_FAILED, { screen = screen.id })
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
if add_to_stack then
|
-- wait one frame so that the init() of any script have time to run before starting transitions
|
||||||
stack[#stack + 1] = screen
|
cowait(0)
|
||||||
end
|
|
||||||
reset_timestep(screen)
|
reset_timestep(screen)
|
||||||
transition(screen, M.TRANSITION.SHOW_IN, { previous_screen = previous_screen and previous_screen.id })
|
transition(screen, M.TRANSITION.SHOW_IN, { previous_screen = previous_screen and previous_screen.id }, wait_for_transition)
|
||||||
|
screen.visible = true
|
||||||
acquire_input(screen)
|
acquire_input(screen)
|
||||||
focus_gained(screen, previous_screen)
|
focus_gained(screen, previous_screen)
|
||||||
active_transition_count = active_transition_count - 1
|
active_transition_count = active_transition_count - 1
|
||||||
@@ -591,8 +651,9 @@ local function show_in(screen, previous_screen, reload, add_to_stack, cb)
|
|||||||
end)
|
end)
|
||||||
end
|
end
|
||||||
|
|
||||||
local function back_in(screen, previous_screen, cb)
|
local function back_in(screen, previous_screen, wait_for_transition, cb)
|
||||||
log("back_in()", screen.id)
|
log("back_in()", screen.id)
|
||||||
|
assert(wait_for_transition ~= nil)
|
||||||
run_coroutine(screen, cb, function()
|
run_coroutine(screen, cb, function()
|
||||||
active_transition_count = active_transition_count + 1
|
active_transition_count = active_transition_count + 1
|
||||||
notify_transition_listeners(M.SCREEN_TRANSITION_IN_STARTED, { screen = screen.id, previous_screen = previous_screen and previous_screen.id })
|
notify_transition_listeners(M.SCREEN_TRANSITION_IN_STARTED, { screen = screen.id, previous_screen = previous_screen and previous_screen.id })
|
||||||
@@ -604,10 +665,13 @@ local function back_in(screen, previous_screen, cb)
|
|||||||
notify_transition_listeners(M.SCREEN_TRANSITION_FAILED, { screen = screen.id })
|
notify_transition_listeners(M.SCREEN_TRANSITION_FAILED, { screen = screen.id })
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
-- wait one frame so that the init() of any script have time to run before starting transitions
|
||||||
|
cowait(0)
|
||||||
reset_timestep(screen)
|
reset_timestep(screen)
|
||||||
if previous_screen and not previous_screen.popup then
|
if previous_screen and not previous_screen.popup then
|
||||||
transition(screen, M.TRANSITION.BACK_IN, { previous_screen = previous_screen.id })
|
transition(screen, M.TRANSITION.BACK_IN, { previous_screen = previous_screen.id }, wait_for_transition)
|
||||||
end
|
end
|
||||||
|
screen.visible = true
|
||||||
acquire_input(screen)
|
acquire_input(screen)
|
||||||
focus_gained(screen, previous_screen)
|
focus_gained(screen, previous_screen)
|
||||||
active_transition_count = active_transition_count - 1
|
active_transition_count = active_transition_count - 1
|
||||||
@@ -615,18 +679,20 @@ local function back_in(screen, previous_screen, cb)
|
|||||||
end)
|
end)
|
||||||
end
|
end
|
||||||
|
|
||||||
local function back_out(screen, next_screen, cb)
|
local function back_out(screen, next_screen, wait_for_transition, cb)
|
||||||
log("back_out()", screen.id)
|
log("back_out()", screen.id)
|
||||||
|
assert(wait_for_transition ~= nil)
|
||||||
run_coroutine(screen, cb, function()
|
run_coroutine(screen, cb, function()
|
||||||
notify_transition_listeners(M.SCREEN_TRANSITION_OUT_STARTED, { screen = screen.id, next_screen = next_screen and next_screen.id })
|
notify_transition_listeners(M.SCREEN_TRANSITION_OUT_STARTED, { screen = screen.id, next_screen = next_screen and next_screen.id })
|
||||||
active_transition_count = active_transition_count + 1
|
active_transition_count = active_transition_count + 1
|
||||||
change_context(screen)
|
change_context(screen)
|
||||||
release_input(screen, next_screen)
|
release_input(screen, next_screen)
|
||||||
focus_lost(screen, next_screen)
|
focus_lost(screen, next_screen)
|
||||||
|
transition(screen, M.TRANSITION.BACK_OUT, { next_screen = next_screen and next_screen.id }, wait_for_transition)
|
||||||
if next_screen and screen.popup then
|
if next_screen and screen.popup then
|
||||||
reset_timestep(next_screen)
|
reset_timestep(next_screen)
|
||||||
end
|
end
|
||||||
transition(screen, M.TRANSITION.BACK_OUT, { next_screen = next_screen and next_screen.id })
|
screen.visible = false
|
||||||
unload(screen)
|
unload(screen)
|
||||||
active_transition_count = active_transition_count - 1
|
active_transition_count = active_transition_count - 1
|
||||||
notify_transition_listeners(M.SCREEN_TRANSITION_OUT_FINISHED, { screen = screen.id, next_screen = next_screen and next_screen.id })
|
notify_transition_listeners(M.SCREEN_TRANSITION_OUT_FINISHED, { screen = screen.id, next_screen = next_screen and next_screen.id })
|
||||||
@@ -679,9 +745,7 @@ function M.show(id, options, data, cb)
|
|||||||
id = tohash(id)
|
id = tohash(id)
|
||||||
assert(screens[id], ("There is no screen registered with id %s"):format(tostring(id)))
|
assert(screens[id], ("There is no screen registered with id %s"):format(tostring(id)))
|
||||||
|
|
||||||
log("show() queuing action", id)
|
|
||||||
queue_action(function(action_done, action_error)
|
queue_action(function(action_done, action_error)
|
||||||
log("show()", id)
|
|
||||||
local screen = screens[id]
|
local screen = screens[id]
|
||||||
if not screen then
|
if not screen then
|
||||||
action_error(("show() there is no longer a screen with id %s"):format(tostring(id)))
|
action_error(("show() there is no longer a screen with id %s"):format(tostring(id)))
|
||||||
@@ -719,21 +783,12 @@ function M.show(id, options, data, cb)
|
|||||||
pop = pop - 1
|
pop = pop - 1
|
||||||
end
|
end
|
||||||
stack[#stack] = nil
|
stack[#stack] = nil
|
||||||
show_out(top, screen, callbacks.track())
|
async(function(await, resume)
|
||||||
callbacks.yield_until_done()
|
await(show_out, top, screen, WAIT_FOR_TRANSITION, resume)
|
||||||
|
end)
|
||||||
top = stack[#stack]
|
top = stack[#stack]
|
||||||
end
|
end
|
||||||
|
|
||||||
-- unload the previous screen and transition out from top
|
|
||||||
-- wait until we are done if showing the same screen as is already visible
|
|
||||||
if top and not top.popup then
|
|
||||||
local same_screen = top and top.id == screen.id
|
|
||||||
show_out(top, screen, callbacks.track())
|
|
||||||
if same_screen or (options and options.sequential) then
|
|
||||||
callbacks.yield_until_done()
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
-- if the screen we want to show is in the stack
|
-- if the screen we want to show is in the stack
|
||||||
-- already and the clear flag is set then we need
|
-- already and the clear flag is set then we need
|
||||||
-- to remove every screen on the stack up until and
|
-- to remove every screen on the stack up until and
|
||||||
@@ -755,8 +810,8 @@ function M.show(id, options, data, cb)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
-- show screen, wait until preloaded if it is already preloading
|
-- wait until preloaded if it is already preloading
|
||||||
-- this can typpically happen if you do a show() on app start for a
|
-- this can typically happen if you do a show() on app start for a
|
||||||
-- screen that has Preload set to true
|
-- screen that has Preload set to true
|
||||||
if M.is_preloading(id) then
|
if M.is_preloading(id) then
|
||||||
M.when_preloaded(id, function()
|
M.when_preloaded(id, function()
|
||||||
@@ -764,7 +819,26 @@ function M.show(id, options, data, cb)
|
|||||||
end)
|
end)
|
||||||
coroutine.yield()
|
coroutine.yield()
|
||||||
end
|
end
|
||||||
show_in(screen, top, options and options.reload, add_to_stack, callbacks.track())
|
|
||||||
|
-- showing and hiding the same screen?
|
||||||
|
local same_screen = top and top.id == screen.id
|
||||||
|
if same_screen or (options and options.sequential) then
|
||||||
|
if top then
|
||||||
|
async(function(await, resume)
|
||||||
|
await(show_out, top, screen, WAIT_FOR_TRANSITION, resume)
|
||||||
|
end)
|
||||||
|
end
|
||||||
|
show_in(screen, top, options and options.reload, add_to_stack, WAIT_FOR_TRANSITION, callbacks.track())
|
||||||
|
else
|
||||||
|
-- show screen
|
||||||
|
local cb = callbacks.track()
|
||||||
|
show_in(screen, top, options and options.reload, add_to_stack, DO_NOT_WAIT_FOR_TRANSITION, function()
|
||||||
|
if add_to_stack and top and not top.popup then
|
||||||
|
show_out(top, screen, WAIT_FOR_TRANSITION, callbacks.track())
|
||||||
|
end
|
||||||
|
cb()
|
||||||
|
end)
|
||||||
|
end
|
||||||
|
|
||||||
callbacks.when_done(function()
|
callbacks.when_done(function()
|
||||||
pcallfn(cb)
|
pcallfn(cb)
|
||||||
@@ -793,7 +867,7 @@ end
|
|||||||
|
|
||||||
-- Hide a screen. The screen must either be at the top of the stack or
|
-- Hide a screen. The screen must either be at the top of the stack or
|
||||||
-- visible but not added to the stack (through the no_stack option)
|
-- visible but not added to the stack (through the no_stack option)
|
||||||
-- @param id (string|hash) - Id of the screen to show
|
-- @param id (string|hash) - Id of the screen to .hide
|
||||||
-- @param cb (function) - Optional callback to invoke when the screen is hidden
|
-- @param cb (function) - Optional callback to invoke when the screen is hidden
|
||||||
-- @return true if successfully hiding, false if busy or for some other reason unable to hide the screen
|
-- @return true if successfully hiding, false if busy or for some other reason unable to hide the screen
|
||||||
function M.hide(id, cb)
|
function M.hide(id, cb)
|
||||||
@@ -818,7 +892,7 @@ function M.hide(id, cb)
|
|||||||
action_error(("hide() there is no longer a screen with id %s"):format(tostring(id)))
|
action_error(("hide() there is no longer a screen with id %s"):format(tostring(id)))
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
back_out(screen, nil, callbacks.track())
|
back_out(screen, nil, WAIT_FOR_TRANSITION, callbacks.track())
|
||||||
end
|
end
|
||||||
callbacks.when_done(function()
|
callbacks.when_done(function()
|
||||||
pcallfn(cb)
|
pcallfn(cb)
|
||||||
@@ -830,6 +904,34 @@ function M.hide(id, cb)
|
|||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
-- Clear stack completely. Any visible screens will be hidden by navigating back out
|
||||||
|
-- from them.
|
||||||
|
-- @param cb (function) - Optional callback to invoke when the stack has been cleared
|
||||||
|
function M.clear(cb)
|
||||||
|
log("clear() queuing action")
|
||||||
|
|
||||||
|
queue_action(function(action_done, action_error)
|
||||||
|
async(function(await, resume)
|
||||||
|
local top = stack[#stack]
|
||||||
|
while top and top.visible do
|
||||||
|
stack[#stack] = nil
|
||||||
|
await(back_out, top, stack[#stack - 1], WAIT_FOR_TRANSITION, resume)
|
||||||
|
top = stack[#stack]
|
||||||
|
end
|
||||||
|
|
||||||
|
while stack[#stack] do
|
||||||
|
table.remove(stack)
|
||||||
|
end
|
||||||
|
|
||||||
|
pcallfn(cb)
|
||||||
|
pcallfn(action_done)
|
||||||
|
end)
|
||||||
|
end)
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
-- Go back to the previous screen in the stack.
|
-- Go back to the previous screen in the stack.
|
||||||
-- @param data (*) - Optional data to set for the previous screen
|
-- @param data (*) - Optional data to set for the previous screen
|
||||||
-- @param cb (function) - Optional callback to invoke when the previous screen is visible again
|
-- @param cb (function) - Optional callback to invoke when the previous screen is visible again
|
||||||
@@ -838,6 +940,7 @@ function M.back(data, cb)
|
|||||||
|
|
||||||
queue_action(function(action_done)
|
queue_action(function(action_done)
|
||||||
local callbacks = callback_tracker()
|
local callbacks = callback_tracker()
|
||||||
|
local back_cb = callbacks.track()
|
||||||
local screen = table.remove(stack)
|
local screen = table.remove(stack)
|
||||||
if screen then
|
if screen then
|
||||||
log("back()", screen.id)
|
log("back()", screen.id)
|
||||||
@@ -845,19 +948,33 @@ function M.back(data, cb)
|
|||||||
-- if we go back to the same screen we need to first hide it
|
-- if we go back to the same screen we need to first hide it
|
||||||
-- and wait until it is hidden before we show it again
|
-- and wait until it is hidden before we show it again
|
||||||
if top and screen.id == top.id then
|
if top and screen.id == top.id then
|
||||||
back_out(screen, top, function()
|
back_out(screen, top, WAIT_FOR_TRANSITION, function()
|
||||||
if data then
|
if data then
|
||||||
top.data = data
|
top.data = data
|
||||||
end
|
end
|
||||||
back_in(top, screen, callbacks.track())
|
back_in(top, screen, WAIT_FOR_TRANSITION, back_cb)
|
||||||
end)
|
end)
|
||||||
else
|
else
|
||||||
back_out(screen, top, callbacks.track())
|
|
||||||
if top then
|
if top then
|
||||||
if data then
|
if data then
|
||||||
top.data = data
|
top.data = data
|
||||||
end
|
end
|
||||||
back_in(top, screen, callbacks.track())
|
-- if the screen we are backing out from is a popup and the screen we go
|
||||||
|
-- back to is not a popup we need to let the popup completely hide before
|
||||||
|
-- we start working on the screen we go back to
|
||||||
|
-- we do this to ensure that we do not reset the times step of the screen
|
||||||
|
-- we go back to until it is no longer obscured by the popup
|
||||||
|
if screen.popup and not top.popup then
|
||||||
|
back_out(screen, top, WAIT_FOR_TRANSITION, function()
|
||||||
|
back_in(top, screen, WAIT_FOR_TRANSITION, back_cb)
|
||||||
|
end)
|
||||||
|
else
|
||||||
|
back_in(top, screen, DO_NOT_WAIT_FOR_TRANSITION, function()
|
||||||
|
back_out(screen, top, WAIT_FOR_TRANSITION, back_cb)
|
||||||
|
end)
|
||||||
|
end
|
||||||
|
else
|
||||||
|
back_out(screen, top, WAIT_FOR_TRANSITION, back_cb)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@@ -911,12 +1028,19 @@ end
|
|||||||
--- Preload a screen. This will load but not enable and show a screen. Useful for "heavier" screens
|
--- Preload a screen. This will load but not enable and show a screen. Useful for "heavier" screens
|
||||||
-- that you wish to show without any delay.
|
-- that you wish to show without any delay.
|
||||||
-- @param id (string|hash) - Id of the screen to preload
|
-- @param id (string|hash) - Id of the screen to preload
|
||||||
|
-- @param options (table)
|
||||||
-- @param cb (function) - Optional callback to invoke when screen is loaded
|
-- @param cb (function) - Optional callback to invoke when screen is loaded
|
||||||
function M.preload(id, cb)
|
function M.preload(id, options, cb)
|
||||||
assert(id, "You must provide a screen id")
|
assert(id, "You must provide a screen id")
|
||||||
id = tohash(id)
|
id = tohash(id)
|
||||||
assert(screens[id], ("There is no screen registered with id %s"):format(tostring(id)))
|
assert(screens[id], ("There is no screen registered with id %s"):format(tostring(id)))
|
||||||
|
|
||||||
|
-- support old function signature (id, cb)
|
||||||
|
if type(options) == "function" and not cb then
|
||||||
|
cb = options
|
||||||
|
options = nil
|
||||||
|
end
|
||||||
|
|
||||||
log("preload() queuing action", id)
|
log("preload() queuing action", id)
|
||||||
queue_action(function(action_done, action_error)
|
queue_action(function(action_done, action_error)
|
||||||
log("preload()", id)
|
log("preload()", id)
|
||||||
@@ -927,6 +1051,10 @@ function M.preload(id, cb)
|
|||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
|
-- keep_loaded is an option for monarch.preload()
|
||||||
|
-- use it to get the same behavior as the auto preload checkbox
|
||||||
|
screen.auto_preload = screen.auto_preload or options and options.keep_loaded
|
||||||
|
|
||||||
if screen.preloaded or screen.loaded then
|
if screen.preloaded or screen.loaded then
|
||||||
pcallfn(cb)
|
pcallfn(cb)
|
||||||
pcallfn(action_done)
|
pcallfn(action_done)
|
||||||
@@ -989,7 +1117,7 @@ function M.unload(id, cb)
|
|||||||
end
|
end
|
||||||
run_coroutine(screen, when_unloaded, function()
|
run_coroutine(screen, when_unloaded, function()
|
||||||
change_context(screen)
|
change_context(screen)
|
||||||
unload(screen)
|
unload(screen, true)
|
||||||
end)
|
end)
|
||||||
end)
|
end)
|
||||||
return true -- return true for legacy reasons (before queue existed)
|
return true -- return true for legacy reasons (before queue existed)
|
||||||
@@ -1021,13 +1149,9 @@ function M.post(id, message_id, message)
|
|||||||
return false, "Unable to post message since screen has no receiver url specified"
|
return false, "Unable to post message since screen has no receiver url specified"
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
run_coroutine(screen, nil, function()
|
for id,instance in pairs(screen.factory_ids) do
|
||||||
change_context(screen)
|
msg.post(instance, message_id, message)
|
||||||
log("post() sending message to", screen.receiver_url)
|
end
|
||||||
for id,instance in pairs(screen.factory_ids) do
|
|
||||||
msg.post(instance, message_id, message)
|
|
||||||
end
|
|
||||||
end)
|
|
||||||
end
|
end
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
@@ -1035,29 +1159,57 @@ end
|
|||||||
|
|
||||||
function M.on_message(message_id, message, sender)
|
function M.on_message(message_id, message, sender)
|
||||||
if message_id == PROXY_LOADED then
|
if message_id == PROXY_LOADED then
|
||||||
local screen = screen_from_proxy(sender)
|
local screen = find_screen(sender)
|
||||||
assert(screen, "Unable to find screen for loaded proxy")
|
assert(screen, "Unable to find screen for loaded proxy")
|
||||||
if screen.wait_for == PROXY_LOADED then
|
if screen.wait_for == PROXY_LOADED then
|
||||||
assert(coroutine.resume(screen.co))
|
assert(coroutine.resume(screen.co))
|
||||||
end
|
end
|
||||||
elseif message_id == PROXY_UNLOADED then
|
elseif message_id == PROXY_UNLOADED then
|
||||||
local screen = screen_from_proxy(sender)
|
local screen = find_screen(sender)
|
||||||
assert(screen, "Unable to find screen for unloaded proxy")
|
assert(screen, "Unable to find screen for unloaded proxy")
|
||||||
if screen.wait_for == PROXY_UNLOADED then
|
if screen.wait_for == PROXY_UNLOADED then
|
||||||
assert(coroutine.resume(screen.co))
|
assert(coroutine.resume(screen.co))
|
||||||
end
|
end
|
||||||
elseif message_id == CONTEXT then
|
elseif message_id == CONTEXT then
|
||||||
local screen = screen_from_script()
|
local screen = find_screen(sender)
|
||||||
assert(screen, "Unable to find screen for current script url")
|
assert(screen, "Unable to find screen for current script url")
|
||||||
if screen.wait_for == CONTEXT then
|
if screen.wait_for == CONTEXT then
|
||||||
assert(coroutine.resume(screen.co))
|
assert(coroutine.resume(screen.co))
|
||||||
end
|
end
|
||||||
elseif message_id == M.TRANSITION.DONE then
|
elseif message_id == M.TRANSITION.DONE then
|
||||||
local screen = screen_from_script()
|
local screen = find_transition_screen(sender)
|
||||||
assert(screen, "Unable to find screen for current script url")
|
assert(screen, "Unable to find screen for transition")
|
||||||
if screen.wait_for == M.TRANSITION.DONE then
|
if screen.wait_for == M.TRANSITION.DONE then
|
||||||
assert(coroutine.resume(screen.co))
|
assert(coroutine.resume(screen.co))
|
||||||
end
|
end
|
||||||
|
elseif message_id == M.TRANSITION.SHOW_IN
|
||||||
|
or message_id == M.TRANSITION.SHOW_OUT
|
||||||
|
or message_id == M.TRANSITION.BACK_IN
|
||||||
|
or message_id == M.TRANSITION.BACK_OUT
|
||||||
|
then
|
||||||
|
local screen = find_transition_screen(sender)
|
||||||
|
assert(screen, "Unable to find screen for transition")
|
||||||
|
if screen.transition_fn then
|
||||||
|
screen.transition_fn(message_id, message, sender)
|
||||||
|
end
|
||||||
|
elseif message_id == LAYOUT_CHANGED then
|
||||||
|
local screen = find_screen(sender)
|
||||||
|
if screen and screen.transition_fn then
|
||||||
|
screen.transition_fn(message_id, message, sender)
|
||||||
|
end
|
||||||
|
elseif message_id == M.FOCUS.GAINED
|
||||||
|
or message_id == M.FOCUS.LOST
|
||||||
|
then
|
||||||
|
local screen = find_focus_screen(sender)
|
||||||
|
assert(screen, "Unable to find screen for focus change")
|
||||||
|
if screen.focus_fn then
|
||||||
|
screen.focus_fn(message_id, message, sender)
|
||||||
|
end
|
||||||
|
else
|
||||||
|
local screen = find_post_receiver_screen(sender)
|
||||||
|
if screen and screen.receiver_fn then
|
||||||
|
screen.receiver_fn(message_id, message, sender)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -1091,6 +1243,70 @@ function M.bottom(offset)
|
|||||||
return screen and screen.id
|
return screen and screen.id
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
--- Set the timestep to apply for a screen when below a popup
|
||||||
|
-- @param id (string|hash) Id of the screen to change timestep setting for
|
||||||
|
-- @param timestep (number) Timestep to apply
|
||||||
|
function M.set_timestep_below_popup(id, timestep)
|
||||||
|
assert(id, "You must provide a screen id")
|
||||||
|
assert(timestep, "You must provide a timestep")
|
||||||
|
id = tohash(id)
|
||||||
|
assert(screens[id], ("There is no screen registered with id %s"):format(tostring(id)))
|
||||||
|
screens[id].timestep_below_popup = timestep
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
---
|
||||||
|
-- Set a function to call when a transition should be started
|
||||||
|
-- The function will receive (message_id, message, sender)
|
||||||
|
-- IMPORTANT! You must call monarch.on_message() from the same script as
|
||||||
|
-- this function was called
|
||||||
|
-- @param id Screen id to associate transition with
|
||||||
|
-- @param fn Transition handler function
|
||||||
|
function M.on_transition(id, fn)
|
||||||
|
assert(id, "You must provide a screen id")
|
||||||
|
assert(fn, "You must provide a transition function")
|
||||||
|
id = tohash(id)
|
||||||
|
assert(screens[id], ("There is no screen registered with id %s"):format(tostring(id)))
|
||||||
|
local screen = screens[id]
|
||||||
|
screen.transition_url = msg.url()
|
||||||
|
screen.transition_fn = fn
|
||||||
|
end
|
||||||
|
|
||||||
|
---
|
||||||
|
-- Set a function to call when a screen gains or loses focus
|
||||||
|
-- The function will receive (message_id, message, sender)
|
||||||
|
-- IMPORTANT! You must call monarch.on_message() from the same script as
|
||||||
|
-- this function was called
|
||||||
|
-- @param id Screen id to associate focus listener function with
|
||||||
|
-- @param fn Focus listener function
|
||||||
|
function M.on_focus_changed(id, fn)
|
||||||
|
assert(id, "You must provide a screen id")
|
||||||
|
assert(fn, "You must provide a focus change function")
|
||||||
|
id = tohash(id)
|
||||||
|
assert(screens[id], ("There is no screen registered with id %s"):format(tostring(id)))
|
||||||
|
local screen = screens[id]
|
||||||
|
screen.focus_url = msg.url()
|
||||||
|
screen.focus_fn = fn
|
||||||
|
end
|
||||||
|
|
||||||
|
---
|
||||||
|
-- Set a function to call when a screen is sent a message using monarch.post()
|
||||||
|
-- The function will receive (message_id, message, sender)
|
||||||
|
-- IMPORTANT! You must call monarch.on_message() from the same script as
|
||||||
|
-- this function was called
|
||||||
|
-- @param id Screen id to associate the message listener function with
|
||||||
|
-- @param fn Message listener function
|
||||||
|
function M.on_post(id, fn)
|
||||||
|
assert(id, "You must provide a screen id")
|
||||||
|
assert(fn, "You must provide a post receiver function")
|
||||||
|
id = tohash(id)
|
||||||
|
assert(screens[id], ("There is no screen registered with id %s"):format(tostring(id)))
|
||||||
|
local screen = screens[id]
|
||||||
|
screen.receiver_url = msg.url()
|
||||||
|
screen.receiver_fn = fn
|
||||||
|
end
|
||||||
|
|
||||||
local function url_to_key(url)
|
local function url_to_key(url)
|
||||||
return (url.socket or hash("")) .. (url.path or hash("")) .. (url.fragment or hash(""))
|
return (url.socket or hash("")) .. (url.path or hash("")) .. (url.fragment or hash(""))
|
||||||
end
|
end
|
||||||
@@ -1120,4 +1336,9 @@ function M.dump_stack()
|
|||||||
return s
|
return s
|
||||||
end
|
end
|
||||||
|
|
||||||
|
function M.queue_size()
|
||||||
|
return #queue
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
return M
|
return M
|
||||||
|
|||||||
@@ -20,10 +20,10 @@ local LAYOUT_CHANGED = hash("layout_changed")
|
|||||||
function M.window_resized(width, height)
|
function M.window_resized(width, height)
|
||||||
WIDTH = width
|
WIDTH = width
|
||||||
HEIGHT = height
|
HEIGHT = height
|
||||||
LEFT = vmath.vector3(-WIDTH * 2, 0, 0)
|
LEFT = vmath.vector3(-WIDTH, 0, 0)
|
||||||
RIGHT = vmath.vector3(WIDTH * 2, 0, 0)
|
RIGHT = vmath.vector3(WIDTH, 0, 0)
|
||||||
TOP = vmath.vector3(0, HEIGHT * 2, 0)
|
TOP = vmath.vector3(0, HEIGHT, 0)
|
||||||
BOTTOM = vmath.vector3(0, - HEIGHT * 2, 0)
|
BOTTOM = vmath.vector3(0, - HEIGHT, 0)
|
||||||
end
|
end
|
||||||
|
|
||||||
M.window_resized(tonumber(sys.get_config("display.width")), tonumber(sys.get_config("display.height")))
|
M.window_resized(tonumber(sys.get_config("display.width")), tonumber(sys.get_config("display.height")))
|
||||||
@@ -121,11 +121,15 @@ local function create()
|
|||||||
local current_transition = nil
|
local current_transition = nil
|
||||||
|
|
||||||
local function create_transition(transition_id, node, fn, easing, duration, delay)
|
local function create_transition(transition_id, node, fn, easing, duration, delay)
|
||||||
|
assert(transition_id, "You must provide a valid transition id")
|
||||||
|
assert(node, "You must provide a node")
|
||||||
|
assert(fn, "You must provide a transition function")
|
||||||
|
|
||||||
local t = transitions[transition_id]
|
local t = transitions[transition_id]
|
||||||
-- find if there's already a transition for the node in
|
-- find if there's already a transition for the node in
|
||||||
-- question and if so update it instead of creating a new
|
-- question and if so update it instead of creating a new
|
||||||
-- transition
|
-- transition
|
||||||
for _,transition in ipairs(t) do
|
for _,transition in ipairs(t.transitions) do
|
||||||
if transition.node == node then
|
if transition.node == node then
|
||||||
transition.fn = fn
|
transition.fn = fn
|
||||||
transition.easing = easing
|
transition.easing = easing
|
||||||
@@ -169,10 +173,10 @@ local function create()
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function start_transition(transition_id, url)
|
local function start_transition(transition_id, url)
|
||||||
|
url = url or msg.url()
|
||||||
local t = transitions[transition_id]
|
local t = transitions[transition_id]
|
||||||
table.insert(t.urls, url)
|
table.insert(t.urls, url)
|
||||||
if t.in_progress_count == 0 then
|
if t.in_progress_count == 0 then
|
||||||
table.insert(t.urls, msg.url())
|
|
||||||
current_transition = t
|
current_transition = t
|
||||||
current_transition.id = transition_id
|
current_transition.id = transition_id
|
||||||
if #t.transitions > 0 then
|
if #t.transitions > 0 then
|
||||||
@@ -250,7 +254,11 @@ local function create()
|
|||||||
return instance
|
return instance
|
||||||
end
|
end
|
||||||
|
|
||||||
return instance
|
return setmetatable(instance, {
|
||||||
|
__call = function(t, ...)
|
||||||
|
return instance.handle(...)
|
||||||
|
end
|
||||||
|
})
|
||||||
end
|
end
|
||||||
|
|
||||||
function M.create(node)
|
function M.create(node)
|
||||||
|
|||||||
47
monarch/utils/async.lua
Normal file
47
monarch/utils/async.lua
Normal file
@@ -0,0 +1,47 @@
|
|||||||
|
local M = {}
|
||||||
|
|
||||||
|
local NOT_STARTED = "not_started"
|
||||||
|
local YIELDED = "yielded"
|
||||||
|
local RESUMED = "resumed"
|
||||||
|
local RUNNING = "running"
|
||||||
|
|
||||||
|
function M.async(fn)
|
||||||
|
local co = coroutine.running()
|
||||||
|
|
||||||
|
local state = NOT_STARTED
|
||||||
|
|
||||||
|
local function await(fn, ...)
|
||||||
|
state = RUNNING
|
||||||
|
fn(...)
|
||||||
|
if state ~= RUNNING then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
state = YIELDED
|
||||||
|
local r = { coroutine.yield() }
|
||||||
|
return unpack(r)
|
||||||
|
end
|
||||||
|
|
||||||
|
local function resume(...)
|
||||||
|
if state ~= RUNNING then
|
||||||
|
state = RUNNING
|
||||||
|
local ok, err = coroutine.resume(co, ...)
|
||||||
|
if not ok then
|
||||||
|
print(err)
|
||||||
|
print(debug.traceback())
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
if co then
|
||||||
|
return fn(await, resume)
|
||||||
|
else
|
||||||
|
co = coroutine.create(fn)
|
||||||
|
return resume(await, resume)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
return setmetatable(M, {
|
||||||
|
__call = function(t, ...)
|
||||||
|
return M.async(...)
|
||||||
|
end
|
||||||
|
})
|
||||||
@@ -6,13 +6,18 @@ function M.create()
|
|||||||
|
|
||||||
local callback = nil
|
local callback = nil
|
||||||
local callback_count = 0
|
local callback_count = 0
|
||||||
|
local all_callbacks_done = false
|
||||||
|
|
||||||
local function is_done()
|
local function is_done()
|
||||||
return callback_count == 0
|
return callback_count == 0
|
||||||
end
|
end
|
||||||
|
|
||||||
local function invoke_if_done()
|
local function invoke_if_done()
|
||||||
|
if all_callbacks_done then
|
||||||
|
print("Warning: The same callback will be invoked twice from the callback tracker!")
|
||||||
|
end
|
||||||
if callback_count == 0 and callback then
|
if callback_count == 0 and callback then
|
||||||
|
all_callbacks_done = true
|
||||||
local ok, err = pcall(callback)
|
local ok, err = pcall(callback)
|
||||||
if not ok then print(err) end
|
if not ok then print(err) end
|
||||||
end
|
end
|
||||||
@@ -41,26 +46,12 @@ function M.create()
|
|||||||
invoke_if_done()
|
invoke_if_done()
|
||||||
end
|
end
|
||||||
|
|
||||||
function instance.yield_until_done()
|
|
||||||
local co = coroutine.running()
|
|
||||||
callback = function()
|
|
||||||
local ok, err = coroutine.resume(co)
|
|
||||||
if not ok then
|
|
||||||
print(err)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
invoke_if_done()
|
|
||||||
if not is_done() then
|
|
||||||
coroutine.yield()
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
return instance
|
return instance
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
return setmetatable(M, {
|
return setmetatable(M, {
|
||||||
__call = function(_, ...)
|
__call = function(_, ...)
|
||||||
return M.create(...)
|
return M.create()
|
||||||
end
|
end
|
||||||
})
|
})
|
||||||
@@ -4,7 +4,10 @@ function M.seconds(amount)
|
|||||||
local co = coroutine.running()
|
local co = coroutine.running()
|
||||||
assert(co, "You must run this from within a coroutine")
|
assert(co, "You must run this from within a coroutine")
|
||||||
timer.delay(amount, false, function()
|
timer.delay(amount, false, function()
|
||||||
coroutine.resume(co)
|
local ok, err = coroutine.resume(co)
|
||||||
|
if not ok then
|
||||||
|
print(err)
|
||||||
|
end
|
||||||
end)
|
end)
|
||||||
coroutine.yield()
|
coroutine.yield()
|
||||||
end
|
end
|
||||||
@@ -13,10 +16,13 @@ function M.eval(fn, timeout)
|
|||||||
local co = coroutine.running()
|
local co = coroutine.running()
|
||||||
assert(co, "You must run this from within a coroutine")
|
assert(co, "You must run this from within a coroutine")
|
||||||
local start = socket.gettime()
|
local start = socket.gettime()
|
||||||
timer.delay(0.01, true, function(self, handle, time_elapsed)
|
timer.delay(0.02, true, function(self, handle, time_elapsed)
|
||||||
if fn() or (timeout and socket.gettime() > (start + timeout)) then
|
if fn() or (timeout and socket.gettime() > (start + timeout)) then
|
||||||
timer.cancel(handle)
|
timer.cancel(handle)
|
||||||
coroutine.resume(co)
|
local ok, err = coroutine.resume(co)
|
||||||
|
if not ok then
|
||||||
|
print(err)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end)
|
end)
|
||||||
coroutine.yield()
|
coroutine.yield()
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
function init(self)
|
function init(self)
|
||||||
local monarch = require "monarch.monarch"
|
local monarch = require "monarch.monarch"
|
||||||
local data = monarch.data(hash("screen_preload"))
|
local data = monarch.data(hash("screen_preload"))
|
||||||
data.count = data.count + 1
|
if data then data.count = data.count + 1 end
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -26,6 +26,8 @@ embedded_instances {
|
|||||||
" value: \"screen1:/go\"\n"
|
" value: \"screen1:/go\"\n"
|
||||||
" type: PROPERTY_TYPE_URL\n"
|
" type: PROPERTY_TYPE_URL\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
|
" property_decls {\n"
|
||||||
|
" }\n"
|
||||||
"}\n"
|
"}\n"
|
||||||
"embedded_components {\n"
|
"embedded_components {\n"
|
||||||
" id: \"collectionproxy\"\n"
|
" id: \"collectionproxy\"\n"
|
||||||
@@ -84,12 +86,15 @@ embedded_instances {
|
|||||||
" value: \"screen2\"\n"
|
" value: \"screen2\"\n"
|
||||||
" type: PROPERTY_TYPE_HASH\n"
|
" type: PROPERTY_TYPE_HASH\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
|
" property_decls {\n"
|
||||||
|
" }\n"
|
||||||
"}\n"
|
"}\n"
|
||||||
"embedded_components {\n"
|
"embedded_components {\n"
|
||||||
" id: \"collectionfactory\"\n"
|
" id: \"collectionfactory\"\n"
|
||||||
" type: \"collectionfactory\"\n"
|
" type: \"collectionfactory\"\n"
|
||||||
" data: \"prototype: \\\"/test/data/screen2.collection\\\"\\n"
|
" data: \"prototype: \\\"/test/data/screen2.collection\\\"\\n"
|
||||||
"load_dynamically: false\\n"
|
"load_dynamically: false\\n"
|
||||||
|
"dynamic_prototype: false\\n"
|
||||||
"\"\n"
|
"\"\n"
|
||||||
" position {\n"
|
" position {\n"
|
||||||
" x: 0.0\n"
|
" x: 0.0\n"
|
||||||
@@ -147,6 +152,8 @@ embedded_instances {
|
|||||||
" value: \"true\"\n"
|
" value: \"true\"\n"
|
||||||
" type: PROPERTY_TYPE_BOOLEAN\n"
|
" type: PROPERTY_TYPE_BOOLEAN\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
|
" property_decls {\n"
|
||||||
|
" }\n"
|
||||||
"}\n"
|
"}\n"
|
||||||
"embedded_components {\n"
|
"embedded_components {\n"
|
||||||
" id: \"collectionproxy\"\n"
|
" id: \"collectionproxy\"\n"
|
||||||
@@ -215,6 +222,8 @@ embedded_instances {
|
|||||||
" value: \"true\"\n"
|
" value: \"true\"\n"
|
||||||
" type: PROPERTY_TYPE_BOOLEAN\n"
|
" type: PROPERTY_TYPE_BOOLEAN\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
|
" property_decls {\n"
|
||||||
|
" }\n"
|
||||||
"}\n"
|
"}\n"
|
||||||
"embedded_components {\n"
|
"embedded_components {\n"
|
||||||
" id: \"collectionproxy\"\n"
|
" id: \"collectionproxy\"\n"
|
||||||
@@ -278,6 +287,8 @@ embedded_instances {
|
|||||||
" value: \"transition1:/go\"\n"
|
" value: \"transition1:/go\"\n"
|
||||||
" type: PROPERTY_TYPE_URL\n"
|
" type: PROPERTY_TYPE_URL\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
|
" property_decls {\n"
|
||||||
|
" }\n"
|
||||||
"}\n"
|
"}\n"
|
||||||
"embedded_components {\n"
|
"embedded_components {\n"
|
||||||
" id: \"collectionproxy\"\n"
|
" id: \"collectionproxy\"\n"
|
||||||
@@ -376,12 +387,15 @@ embedded_instances {
|
|||||||
" value: \"background\"\n"
|
" value: \"background\"\n"
|
||||||
" type: PROPERTY_TYPE_HASH\n"
|
" type: PROPERTY_TYPE_HASH\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
|
" property_decls {\n"
|
||||||
|
" }\n"
|
||||||
"}\n"
|
"}\n"
|
||||||
"embedded_components {\n"
|
"embedded_components {\n"
|
||||||
" id: \"collectionfactory\"\n"
|
" id: \"collectionfactory\"\n"
|
||||||
" type: \"collectionfactory\"\n"
|
" type: \"collectionfactory\"\n"
|
||||||
" data: \"prototype: \\\"/test/data/background.collection\\\"\\n"
|
" data: \"prototype: \\\"/test/data/background.collection\\\"\\n"
|
||||||
"load_dynamically: false\\n"
|
"load_dynamically: false\\n"
|
||||||
|
"dynamic_prototype: false\\n"
|
||||||
"\"\n"
|
"\"\n"
|
||||||
" position {\n"
|
" position {\n"
|
||||||
" x: 0.0\n"
|
" x: 0.0\n"
|
||||||
@@ -439,12 +453,15 @@ embedded_instances {
|
|||||||
" value: \"true\"\n"
|
" value: \"true\"\n"
|
||||||
" type: PROPERTY_TYPE_BOOLEAN\n"
|
" type: PROPERTY_TYPE_BOOLEAN\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
|
" property_decls {\n"
|
||||||
|
" }\n"
|
||||||
"}\n"
|
"}\n"
|
||||||
"embedded_components {\n"
|
"embedded_components {\n"
|
||||||
" id: \"collectionfactory\"\n"
|
" id: \"collectionfactory\"\n"
|
||||||
" type: \"collectionfactory\"\n"
|
" type: \"collectionfactory\"\n"
|
||||||
" data: \"prototype: \\\"/test/data/screen_preload.collection\\\"\\n"
|
" data: \"prototype: \\\"/test/data/screen_preload.collection\\\"\\n"
|
||||||
"load_dynamically: false\\n"
|
"load_dynamically: false\\n"
|
||||||
|
"dynamic_prototype: false\\n"
|
||||||
"\"\n"
|
"\"\n"
|
||||||
" position {\n"
|
" position {\n"
|
||||||
" x: 0.0\n"
|
" x: 0.0\n"
|
||||||
@@ -502,6 +519,8 @@ embedded_instances {
|
|||||||
" value: \"focus1:/go#focus1\"\n"
|
" value: \"focus1:/go#focus1\"\n"
|
||||||
" type: PROPERTY_TYPE_URL\n"
|
" type: PROPERTY_TYPE_URL\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
|
" property_decls {\n"
|
||||||
|
" }\n"
|
||||||
"}\n"
|
"}\n"
|
||||||
"embedded_components {\n"
|
"embedded_components {\n"
|
||||||
" id: \"collectionproxy\"\n"
|
" id: \"collectionproxy\"\n"
|
||||||
|
|||||||
@@ -16,12 +16,15 @@ embedded_instances {
|
|||||||
" z: 0.0\n"
|
" z: 0.0\n"
|
||||||
" w: 1.0\n"
|
" w: 1.0\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
|
" property_decls {\n"
|
||||||
|
" }\n"
|
||||||
"}\n"
|
"}\n"
|
||||||
"embedded_components {\n"
|
"embedded_components {\n"
|
||||||
" id: \"screensfactory\"\n"
|
" id: \"screensfactory\"\n"
|
||||||
" type: \"collectionfactory\"\n"
|
" type: \"collectionfactory\"\n"
|
||||||
" data: \"prototype: \\\"/test/data/screens.collection\\\"\\n"
|
" data: \"prototype: \\\"/test/data/screens.collection\\\"\\n"
|
||||||
"load_dynamically: false\\n"
|
"load_dynamically: false\\n"
|
||||||
|
"dynamic_prototype: false\\n"
|
||||||
"\"\n"
|
"\"\n"
|
||||||
" position {\n"
|
" position {\n"
|
||||||
" x: 0.0\n"
|
" x: 0.0\n"
|
||||||
|
|||||||
@@ -39,7 +39,7 @@ return function()
|
|||||||
|
|
||||||
local screens_instances = {}
|
local screens_instances = {}
|
||||||
|
|
||||||
local function is_shown(screen_id)
|
local function is_visible(screen_id)
|
||||||
return monarch.is_visible(screen_id)
|
return monarch.is_visible(screen_id)
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -65,9 +65,6 @@ return function()
|
|||||||
local function wait_until_visible(screen_id)
|
local function wait_until_visible(screen_id)
|
||||||
return wait_timeout(is_visible, screen_id)
|
return wait_timeout(is_visible, screen_id)
|
||||||
end
|
end
|
||||||
local function wait_until_shown(screen_id)
|
|
||||||
return wait_timeout(is_shown, screen_id)
|
|
||||||
end
|
|
||||||
local function wait_until_hidden(screen_id)
|
local function wait_until_hidden(screen_id)
|
||||||
return wait_timeout(is_hidden, screen_id)
|
return wait_timeout(is_hidden, screen_id)
|
||||||
end
|
end
|
||||||
@@ -77,6 +74,9 @@ return function()
|
|||||||
local function wait_until_not_busy()
|
local function wait_until_not_busy()
|
||||||
return wait_timeout(function() return not monarch.is_busy() end)
|
return wait_timeout(function() return not monarch.is_busy() end)
|
||||||
end
|
end
|
||||||
|
local function wait_until_stack(expected_screens)
|
||||||
|
return wait_timeout(function() return check_stack(expected_screens) end)
|
||||||
|
end
|
||||||
local function wait_until_loaded(screen_id)
|
local function wait_until_loaded(screen_id)
|
||||||
wait_until_done(function(done)
|
wait_until_done(function(done)
|
||||||
monarch.when_preloaded(screen_id, done)
|
monarch.when_preloaded(screen_id, done)
|
||||||
@@ -115,75 +115,79 @@ return function()
|
|||||||
|
|
||||||
it("should be able to show screens and go back to previous screens", function()
|
it("should be able to show screens and go back to previous screens", function()
|
||||||
monarch.show(SCREEN1_STR)
|
monarch.show(SCREEN1_STR)
|
||||||
assert(wait_until_shown(SCREEN1), "Screen1 was never shown")
|
assert(wait_until_stack({ SCREEN1 }))
|
||||||
assert_stack({ SCREEN1 })
|
|
||||||
|
|
||||||
monarch.show(SCREEN2)
|
monarch.show(SCREEN2)
|
||||||
assert(wait_until_hidden(SCREEN1), "Screen1 was never hidden")
|
assert(wait_until_stack({ SCREEN1, SCREEN2 }))
|
||||||
assert(wait_until_shown(SCREEN2), "Screen2 was never shown")
|
|
||||||
assert_stack({ SCREEN1, SCREEN2 })
|
|
||||||
|
|
||||||
monarch.back()
|
monarch.back()
|
||||||
assert(wait_until_hidden(SCREEN2), "Screen2 was never hidden")
|
assert(wait_until_stack({ SCREEN1 }))
|
||||||
assert(wait_until_shown(SCREEN1), "Screen1 was never shown")
|
|
||||||
assert_stack({ SCREEN1 })
|
|
||||||
|
|
||||||
monarch.back()
|
monarch.back()
|
||||||
assert(wait_until_hidden(SCREEN1), "Screen1 was never hidden")
|
assert(wait_until_stack({ }))
|
||||||
assert_stack({ })
|
|
||||||
end)
|
end)
|
||||||
|
|
||||||
it("should be able to replace screens at the top of the stack", function()
|
it("should be able to replace screens at the top of the stack", function()
|
||||||
monarch.show(SCREEN1_STR)
|
monarch.show(SCREEN1_STR)
|
||||||
assert(wait_until_shown(SCREEN1), "Screen1 was never shown")
|
assert(wait_until_stack({ SCREEN1 }), "Screen1 was never shown")
|
||||||
assert_stack({ SCREEN1 })
|
|
||||||
|
|
||||||
monarch.show(SCREEN2)
|
monarch.show(SCREEN2)
|
||||||
assert(wait_until_hidden(SCREEN1), "Screen1 was never hidden")
|
assert(wait_until_stack({ SCREEN1, SCREEN2 }))
|
||||||
assert(wait_until_shown(SCREEN2), "Screen2 was never shown")
|
|
||||||
assert_stack({ SCREEN1, SCREEN2 })
|
|
||||||
|
|
||||||
monarch.replace(SCREEN1)
|
monarch.replace(SCREEN1)
|
||||||
assert(wait_until_hidden(SCREEN2), "Screen2 was never hidden")
|
assert(wait_until_stack({ SCREEN1, SCREEN1 }))
|
||||||
assert(wait_until_shown(SCREEN1), "Screen1 was never shown")
|
|
||||||
assert_stack({ SCREEN1, SCREEN1 })
|
|
||||||
end)
|
end)
|
||||||
|
|
||||||
it("should be able to tell if a screen is visible or not", function()
|
it("should be able to tell if a screen is visible or not", function()
|
||||||
assert(not monarch.is_visible(SCREEN1))
|
assert(not monarch.is_visible(SCREEN1))
|
||||||
monarch.show(SCREEN1)
|
monarch.show(SCREEN1)
|
||||||
assert(wait_until_shown(SCREEN1), "Screen1 was never shown")
|
assert(wait_until_stack({ SCREEN1 }))
|
||||||
assert_stack({ SCREEN1 })
|
assert(wait_until_visible(SCREEN1))
|
||||||
assert(monarch.is_visible(SCREEN1))
|
|
||||||
|
|
||||||
monarch.show(SCREEN2)
|
monarch.show(SCREEN2)
|
||||||
assert(wait_until_hidden(SCREEN1), "Screen1 was never hidden")
|
assert(wait_until_stack({ SCREEN1, SCREEN2 }))
|
||||||
assert(wait_until_shown(SCREEN2), "Screen2 was never shown")
|
assert(wait_until_hidden(SCREEN1))
|
||||||
assert_stack({ SCREEN1, SCREEN2 })
|
assert(wait_until_visible(SCREEN2))
|
||||||
assert(not monarch.is_visible(SCREEN1))
|
|
||||||
assert(monarch.is_visible(SCREEN2))
|
|
||||||
|
|
||||||
monarch.show(POPUP1)
|
monarch.show(POPUP1)
|
||||||
assert(wait_until_shown(POPUP1), "Popup1 was never shown")
|
assert(wait_until_stack({ SCREEN1, SCREEN2, POPUP1 }))
|
||||||
assert_stack({ SCREEN1, SCREEN2, POPUP1 })
|
assert(wait_until_hidden(SCREEN1))
|
||||||
assert(not monarch.is_visible(SCREEN1))
|
assert(wait_until_visible(SCREEN2))
|
||||||
assert(monarch.is_visible(SCREEN2))
|
assert(wait_until_visible(POPUP1))
|
||||||
assert(monarch.is_visible(POPUP1))
|
|
||||||
end)
|
end)
|
||||||
|
|
||||||
it("should be able to show a screen without adding it to the stack", function()
|
it("should be able to show a screen without adding it to the stack", function()
|
||||||
monarch.show(BACKGROUND, { no_stack = true })
|
monarch.show(BACKGROUND, { no_stack = true })
|
||||||
assert(wait_until_shown(BACKGROUND), "Background was never shown")
|
assert(wait_until_visible(BACKGROUND), "Background was never shown")
|
||||||
assert_stack({ })
|
assert(wait_until_stack({ }))
|
||||||
|
|
||||||
monarch.show(SCREEN1)
|
monarch.show(SCREEN1)
|
||||||
assert(wait_until_shown(SCREEN1), "Screen1 was never shown")
|
assert(wait_until_stack({ SCREEN1 }))
|
||||||
assert_stack({ SCREEN1 })
|
end)
|
||||||
|
|
||||||
|
it("should be able to show a screen without adding it to the stack at any time", function()
|
||||||
|
monarch.show(SCREEN1)
|
||||||
|
assert(wait_until_not_busy())
|
||||||
|
assert(wait_until_stack({ SCREEN1 }))
|
||||||
|
|
||||||
|
monarch.show(BACKGROUND, { no_stack = true })
|
||||||
|
assert(wait_until_not_busy())
|
||||||
|
assert(wait_until_visible(BACKGROUND))
|
||||||
|
assert(wait_until_stack({ SCREEN1 }))
|
||||||
|
|
||||||
|
monarch.show(SCREEN2)
|
||||||
|
assert(wait_until_not_busy())
|
||||||
|
assert(wait_until_stack({ SCREEN1, SCREEN2 }))
|
||||||
|
|
||||||
|
monarch.back()
|
||||||
|
assert(wait_until_not_busy())
|
||||||
|
assert(wait_until_visible(SCREEN1))
|
||||||
|
assert(wait_until_stack({ SCREEN1 }))
|
||||||
end)
|
end)
|
||||||
|
|
||||||
it("should be able to hide a screen not added to the stack", function()
|
it("should be able to hide a screen not added to the stack", function()
|
||||||
monarch.show(BACKGROUND, { no_stack = true })
|
monarch.show(BACKGROUND, { no_stack = true })
|
||||||
assert(wait_until_shown(BACKGROUND), "Background was never shown")
|
assert(wait_until_visible(BACKGROUND), "Background was never shown")
|
||||||
assert_stack({ })
|
assert_stack({ })
|
||||||
|
|
||||||
monarch.hide(BACKGROUND)
|
monarch.hide(BACKGROUND)
|
||||||
@@ -193,36 +197,31 @@ return function()
|
|||||||
|
|
||||||
it("should be able to hide the top screen", function()
|
it("should be able to hide the top screen", function()
|
||||||
monarch.show(SCREEN1)
|
monarch.show(SCREEN1)
|
||||||
assert(wait_until_shown(SCREEN1), "Screen1 was never shown")
|
assert(wait_until_stack({ SCREEN1 }))
|
||||||
assert_stack({ SCREEN1 })
|
|
||||||
|
|
||||||
monarch.show(SCREEN2)
|
monarch.show(SCREEN2)
|
||||||
assert(wait_until_hidden(SCREEN1), "Screen1 was never hidden")
|
assert(wait_until_stack({ SCREEN1, SCREEN2 }))
|
||||||
assert(wait_until_shown(SCREEN2), "Screen2 was never shown")
|
|
||||||
assert_stack({ SCREEN1, SCREEN2 })
|
|
||||||
|
|
||||||
assert(monarch.hide(SCREEN1) == false)
|
assert(monarch.hide(SCREEN1) == false)
|
||||||
assert(monarch.hide(SCREEN2) == true)
|
assert(monarch.hide(SCREEN2) == true)
|
||||||
assert(wait_until_hidden(SCREEN2), "Screen2 was never hidden")
|
assert(wait_until_stack({ SCREEN1 }))
|
||||||
assert(wait_until_shown(SCREEN1), "Screen1 was never shown")
|
|
||||||
assert_stack({ SCREEN1 })
|
|
||||||
end)
|
end)
|
||||||
|
|
||||||
it("should be able to pass data to a screen when showing it or going back to it", function()
|
it("should be able to pass data to a screen when showing it or going back to it", function()
|
||||||
local data1 = { foo = "bar" }
|
local data1 = { foo = "bar" }
|
||||||
monarch.show(SCREEN1, nil, data1)
|
monarch.show(SCREEN1, nil, data1)
|
||||||
assert(wait_until_shown(SCREEN1), "Screen1 was never shown")
|
assert(wait_until_visible(SCREEN1), "Screen1 was never shown")
|
||||||
|
|
||||||
local data2 = { boo = "car" }
|
local data2 = { boo = "car" }
|
||||||
monarch.show(SCREEN2, nil, data2)
|
monarch.show(SCREEN2, nil, data2)
|
||||||
assert(wait_until_shown(SCREEN2), "Screen2 was never shown")
|
assert(wait_until_visible(SCREEN2), "Screen2 was never shown")
|
||||||
|
|
||||||
assert(monarch.data(SCREEN1) == data1, "Expected data on screen1 doesn't match actual data")
|
assert(monarch.data(SCREEN1) == data1, "Expected data on screen1 doesn't match actual data")
|
||||||
assert(monarch.data(SCREEN2) == data2, "Expected data on screen2 doesn't match actual data")
|
assert(monarch.data(SCREEN2) == data2, "Expected data on screen2 doesn't match actual data")
|
||||||
|
|
||||||
local data_back = { going = "back" }
|
local data_back = { going = "back" }
|
||||||
monarch.back(data_back)
|
monarch.back(data_back)
|
||||||
assert(wait_until_shown(SCREEN1))
|
assert(wait_until_visible(SCREEN1))
|
||||||
|
|
||||||
assert(monarch.data(SCREEN1) == data_back, "Expected data on screen1 doesn't match actual data")
|
assert(monarch.data(SCREEN1) == data_back, "Expected data on screen1 doesn't match actual data")
|
||||||
end)
|
end)
|
||||||
@@ -230,51 +229,40 @@ return function()
|
|||||||
|
|
||||||
it("should be able to show the same screen twice", function()
|
it("should be able to show the same screen twice", function()
|
||||||
monarch.show(SCREEN1)
|
monarch.show(SCREEN1)
|
||||||
assert(wait_until_shown(SCREEN1), "Screen1 was never shown")
|
assert(wait_until_stack({ SCREEN1 }))
|
||||||
assert_stack({ SCREEN1 })
|
|
||||||
monarch.show(SCREEN1)
|
monarch.show(SCREEN1)
|
||||||
assert(wait_until_shown(SCREEN1), "Screen1 was never shown")
|
assert(wait_until_stack({ SCREEN1, SCREEN1 }))
|
||||||
assert_stack({ SCREEN1, SCREEN1 })
|
|
||||||
end)
|
end)
|
||||||
|
|
||||||
|
|
||||||
it("should be able to clear the stack if trying to show the same screen twice", function()
|
it("should be able to clear the stack if trying to show the same screen twice", function()
|
||||||
monarch.show(SCREEN1)
|
monarch.show(SCREEN1)
|
||||||
assert(wait_until_shown(SCREEN1), "Screen1 was never shown")
|
assert(wait_until_stack({ SCREEN1 }))
|
||||||
assert_stack({ SCREEN1 })
|
|
||||||
monarch.show(SCREEN2)
|
monarch.show(SCREEN2)
|
||||||
assert(wait_until_shown(SCREEN2), "Screen2 was never shown")
|
assert(wait_until_stack({ SCREEN1, SCREEN2 }))
|
||||||
assert_stack({ SCREEN1, SCREEN2 })
|
|
||||||
monarch.show(SCREEN1, { clear = true })
|
monarch.show(SCREEN1, { clear = true })
|
||||||
assert(wait_until_shown(SCREEN1), "Screen1 was never shown")
|
assert(wait_until_stack({ SCREEN1 }))
|
||||||
assert_stack({ SCREEN1 })
|
|
||||||
end)
|
end)
|
||||||
|
|
||||||
|
|
||||||
it("should be able to show one popup on top of another if the Popup On Popup flag is set", function()
|
it("should be able to show one popup on top of another if the Popup On Popup flag is set", function()
|
||||||
monarch.show(SCREEN1)
|
monarch.show(SCREEN1)
|
||||||
assert(wait_until_shown(SCREEN1), "Screen1 was never shown")
|
assert(wait_until_stack({ SCREEN1 }))
|
||||||
assert_stack({ SCREEN1 })
|
|
||||||
monarch.show(POPUP1)
|
monarch.show(POPUP1)
|
||||||
assert(wait_until_shown(POPUP1), "Popup1 was never shown")
|
assert(wait_until_stack({ SCREEN1, POPUP1 }))
|
||||||
assert_stack({ SCREEN1, POPUP1 })
|
|
||||||
monarch.show(POPUP2)
|
monarch.show(POPUP2)
|
||||||
assert(wait_until_shown(POPUP2), "Popup2 was never shown")
|
assert(wait_until_stack({ SCREEN1, POPUP1, POPUP2 }))
|
||||||
assert_stack({ SCREEN1, POPUP1, POPUP2 })
|
|
||||||
end)
|
end)
|
||||||
|
|
||||||
|
|
||||||
it("should prevent further operations while hiding/showing a screen", function()
|
it("should be able to queue multiple display commands", function()
|
||||||
monarch.show(SCREEN1)
|
monarch.show(SCREEN1)
|
||||||
monarch.show(SCREEN2)
|
monarch.show(SCREEN2)
|
||||||
assert(wait_until_shown(SCREEN1), "Screen1 was never shown")
|
assert(wait_until_stack({ SCREEN1, SCREEN2 }))
|
||||||
assert(wait_until_shown(SCREEN2), "Screen2 was never shown")
|
|
||||||
assert_stack({ SCREEN1, SCREEN2 })
|
|
||||||
|
|
||||||
assert(monarch.back())
|
assert(monarch.back())
|
||||||
assert(monarch.back())
|
assert(monarch.back())
|
||||||
assert(wait_until_hidden(SCREEN1), "Screen1 was never hidden")
|
assert(wait_until_stack({}), "Stack never became empty")
|
||||||
assert(wait_until_hidden(SCREEN2), "Screen2 was never hidden")
|
|
||||||
end)
|
end)
|
||||||
|
|
||||||
|
|
||||||
@@ -292,84 +280,63 @@ return function()
|
|||||||
|
|
||||||
it("should close any open popups when showing a popup without the Popup On Popup flag", function()
|
it("should close any open popups when showing a popup without the Popup On Popup flag", function()
|
||||||
monarch.show(SCREEN1)
|
monarch.show(SCREEN1)
|
||||||
assert(wait_until_shown(SCREEN1), "Screen1 was never shown")
|
assert(wait_until_stack({ SCREEN1 }))
|
||||||
assert_stack({ SCREEN1 })
|
|
||||||
monarch.show(POPUP2)
|
monarch.show(POPUP2)
|
||||||
assert(wait_until_shown(POPUP2), "Popup2 was never shown")
|
assert(wait_until_stack({ SCREEN1, POPUP2 }))
|
||||||
assert_stack({ SCREEN1, POPUP2 })
|
|
||||||
monarch.show(POPUP1)
|
monarch.show(POPUP1)
|
||||||
assert(wait_until_shown(POPUP1), "Popup1 was never shown")
|
assert(wait_until_stack({ SCREEN1, POPUP1 }))
|
||||||
assert_stack({ SCREEN1, POPUP1 })
|
|
||||||
end)
|
end)
|
||||||
|
|
||||||
|
|
||||||
it("should close any open popups when showing a non-popup", function()
|
it("should close any open popups when showing a non-popup", function()
|
||||||
monarch.show(SCREEN1)
|
monarch.show(SCREEN1)
|
||||||
assert(wait_until_shown(SCREEN1), "Screen1 was never shown")
|
assert(wait_until_stack({ SCREEN1 }))
|
||||||
assert_stack({ SCREEN1 })
|
|
||||||
monarch.show(POPUP1)
|
monarch.show(POPUP1)
|
||||||
assert(wait_until_shown(POPUP1), "Popup1 was never shown")
|
assert(wait_until_stack({ SCREEN1, POPUP1 }))
|
||||||
assert_stack({ SCREEN1, POPUP1 })
|
|
||||||
monarch.show(POPUP2)
|
monarch.show(POPUP2)
|
||||||
assert(wait_until_shown(POPUP2), "Popup2 was never shown")
|
assert(wait_until_stack({ SCREEN1, POPUP1, POPUP2 }))
|
||||||
assert_stack({ SCREEN1, POPUP1, POPUP2 })
|
|
||||||
monarch.show(SCREEN2)
|
monarch.show(SCREEN2)
|
||||||
assert(wait_until_shown(SCREEN2), "Popup2 was never shown")
|
assert(wait_until_stack({ SCREEN1, SCREEN2 }))
|
||||||
assert_stack({ SCREEN1, SCREEN2 })
|
|
||||||
end)
|
end)
|
||||||
|
|
||||||
it("should close any open popups when replacing a non-popup", function()
|
it("should close any open popups when replacing a non-popup", function()
|
||||||
monarch.show(SCREEN1)
|
monarch.show(SCREEN1)
|
||||||
assert(wait_until_shown(SCREEN1), "Screen1 was never shown")
|
assert(wait_until_stack({ SCREEN1 }))
|
||||||
assert_stack({ SCREEN1 })
|
|
||||||
monarch.show(POPUP1)
|
monarch.show(POPUP1)
|
||||||
assert(wait_until_shown(POPUP1), "Popup1 was never shown")
|
assert(wait_until_stack({ SCREEN1, POPUP1 }))
|
||||||
assert_stack({ SCREEN1, POPUP1 })
|
|
||||||
monarch.show(POPUP2)
|
monarch.show(POPUP2)
|
||||||
assert(wait_until_shown(POPUP2), "Popup2 was never shown")
|
assert(wait_until_stack({ SCREEN1, POPUP1, POPUP2 }))
|
||||||
assert_stack({ SCREEN1, POPUP1, POPUP2 })
|
|
||||||
monarch.replace(SCREEN2)
|
monarch.replace(SCREEN2)
|
||||||
assert(wait_until_shown(SCREEN2), "Screen2 was never shown")
|
assert(wait_until_stack({ SCREEN2 }))
|
||||||
assert_stack({ SCREEN2 })
|
|
||||||
end)
|
end)
|
||||||
|
|
||||||
it("should replace a popup", function()
|
it("should replace a popup", function()
|
||||||
monarch.show(SCREEN1)
|
monarch.show(SCREEN1)
|
||||||
assert(wait_until_shown(SCREEN1), "Screen1 was never shown")
|
assert(wait_until_stack({ SCREEN1 }))
|
||||||
assert_stack({ SCREEN1 })
|
|
||||||
monarch.show(POPUP1)
|
monarch.show(POPUP1)
|
||||||
assert(wait_until_shown(POPUP1), "Popup1 was never shown")
|
assert(wait_until_stack({ SCREEN1, POPUP1 }))
|
||||||
assert_stack({ SCREEN1, POPUP1 })
|
|
||||||
monarch.replace(POPUP2)
|
monarch.replace(POPUP2)
|
||||||
assert(wait_until_shown(POPUP2), "Popup2 was never shown")
|
assert(wait_until_stack({ SCREEN1, POPUP2 }))
|
||||||
assert_stack({ SCREEN1, POPUP2 })
|
|
||||||
end)
|
end)
|
||||||
|
|
||||||
it("should replace a pop-up two levels down", function()
|
it("should replace a pop-up two levels down", function()
|
||||||
monarch.show(SCREEN1)
|
monarch.show(SCREEN1)
|
||||||
assert(wait_until_shown(SCREEN1), "Screen1 was never shown")
|
assert(wait_until_stack({ SCREEN1 }))
|
||||||
assert_stack({ SCREEN1 })
|
|
||||||
monarch.show(POPUP1)
|
monarch.show(POPUP1)
|
||||||
assert(wait_until_shown(POPUP1), "Popup1 was never shown")
|
assert(wait_until_stack({ SCREEN1, POPUP1 }))
|
||||||
assert_stack({ SCREEN1, POPUP1 })
|
|
||||||
monarch.show(POPUP2)
|
monarch.show(POPUP2)
|
||||||
assert(wait_until_shown(POPUP2), "Popup2 was never shown")
|
assert(wait_until_stack({ SCREEN1, POPUP1, POPUP2 }))
|
||||||
assert_stack({ SCREEN1, POPUP1, POPUP2 })
|
|
||||||
monarch.show(POPUP2, { pop = 2 })
|
monarch.show(POPUP2, { pop = 2 })
|
||||||
assert(wait_until_shown(POPUP2), "Popup2 was never shown")
|
assert(wait_until_stack({ SCREEN1, POPUP2 }))
|
||||||
assert_stack({ SCREEN1, POPUP2 })
|
|
||||||
end)
|
end)
|
||||||
|
|
||||||
it("shouldn't over-pop popups", function()
|
it("shouldn't over-pop popups", function()
|
||||||
monarch.show(SCREEN1)
|
monarch.show(SCREEN1)
|
||||||
assert(wait_until_shown(SCREEN1), "Screen1 was never shown")
|
assert(wait_until_stack({ SCREEN1 }))
|
||||||
assert_stack({ SCREEN1 })
|
|
||||||
monarch.show(POPUP1)
|
monarch.show(POPUP1)
|
||||||
assert(wait_until_shown(POPUP1), "Popup1 was never shown")
|
assert(wait_until_stack({ SCREEN1, POPUP1 }))
|
||||||
assert_stack({ SCREEN1, POPUP1 })
|
|
||||||
monarch.show(POPUP2, { pop = 10 })
|
monarch.show(POPUP2, { pop = 10 })
|
||||||
assert(wait_until_shown(POPUP2), "Popup2 was never shown")
|
assert(wait_until_stack({ SCREEN1, POPUP2 }))
|
||||||
assert_stack({ SCREEN1, POPUP2 })
|
|
||||||
end)
|
end)
|
||||||
|
|
||||||
it("should be able to get the id of the screen at the top and bottom of the stack", function()
|
it("should be able to get the id of the screen at the top and bottom of the stack", function()
|
||||||
@@ -379,7 +346,7 @@ return function()
|
|||||||
assert(monarch.bottom(-1) == nil)
|
assert(monarch.bottom(-1) == nil)
|
||||||
|
|
||||||
monarch.show(SCREEN1)
|
monarch.show(SCREEN1)
|
||||||
assert(wait_until_shown(SCREEN1), "Screen1 was never shown")
|
assert(wait_until_stack({ SCREEN1 }))
|
||||||
assert(monarch.top() == SCREEN1)
|
assert(monarch.top() == SCREEN1)
|
||||||
assert(monarch.top(0) == SCREEN1)
|
assert(monarch.top(0) == SCREEN1)
|
||||||
assert(monarch.top(1) == nil)
|
assert(monarch.top(1) == nil)
|
||||||
@@ -388,9 +355,7 @@ return function()
|
|||||||
assert(monarch.bottom(-1) == nil)
|
assert(monarch.bottom(-1) == nil)
|
||||||
|
|
||||||
monarch.show(SCREEN2)
|
monarch.show(SCREEN2)
|
||||||
assert(wait_until_hidden(SCREEN1), "Screen1 was never hidden")
|
assert(wait_until_stack({ SCREEN1, SCREEN2 }))
|
||||||
assert(wait_until_shown(SCREEN2), "Screen2 was never shown")
|
|
||||||
assert_stack({ SCREEN1, SCREEN2 })
|
|
||||||
assert(monarch.top(0) == SCREEN2)
|
assert(monarch.top(0) == SCREEN2)
|
||||||
assert(monarch.top(-1) == SCREEN1)
|
assert(monarch.top(-1) == SCREEN1)
|
||||||
assert(monarch.bottom(0) == SCREEN1)
|
assert(monarch.bottom(0) == SCREEN1)
|
||||||
@@ -399,8 +364,8 @@ return function()
|
|||||||
|
|
||||||
it("should be busy while transition is running", function()
|
it("should be busy while transition is running", function()
|
||||||
monarch.show(TRANSITION1)
|
monarch.show(TRANSITION1)
|
||||||
assert(wait_until_shown(TRANSITION1), "Transition1 was never shown")
|
|
||||||
assert(monarch.is_busy())
|
assert(monarch.is_busy())
|
||||||
|
assert(wait_until_visible(TRANSITION1), "Transition1 was never shown")
|
||||||
assert(wait_until_not_busy())
|
assert(wait_until_not_busy())
|
||||||
end)
|
end)
|
||||||
|
|
||||||
@@ -413,12 +378,26 @@ return function()
|
|||||||
assert(not monarch.is_preloading(TRANSITION1))
|
assert(not monarch.is_preloading(TRANSITION1))
|
||||||
end)
|
end)
|
||||||
|
|
||||||
|
it("should be able to preload a screen and keep it loaded", function()
|
||||||
|
assert(not monarch.is_preloading(TRANSITION1))
|
||||||
|
monarch.preload(TRANSITION1, { keep_loaded = true })
|
||||||
|
wait_until_done(function(done)
|
||||||
|
monarch.when_preloaded(TRANSITION1, done)
|
||||||
|
end)
|
||||||
|
|
||||||
|
monarch.show(TRANSITION1)
|
||||||
|
assert(wait_until_visible(TRANSITION1), "Transition1 was never shown")
|
||||||
|
monarch.back()
|
||||||
|
assert(wait_until_hidden(TRANSITION1), "Transition1 was never hidden")
|
||||||
|
assert(monarch.is_preloaded(TRANSITION1))
|
||||||
|
end)
|
||||||
|
|
||||||
it("should ignore any preload calls while busy", function()
|
it("should ignore any preload calls while busy", function()
|
||||||
monarch.show(TRANSITION1)
|
monarch.show(TRANSITION1)
|
||||||
-- previously a call to preload() while also showing a screen would
|
-- previously a call to preload() while also showing a screen would
|
||||||
-- lock up monarch. See issue #32
|
-- lock up monarch. See issue #32
|
||||||
monarch.preload(TRANSITION1)
|
monarch.preload(TRANSITION1)
|
||||||
assert(wait_until_shown(TRANSITION1), "Transition1 was never shown")
|
assert(wait_until_visible(TRANSITION1), "Transition1 was never shown")
|
||||||
end)
|
end)
|
||||||
|
|
||||||
it("should be able to notify listeners of navigation events", function()
|
it("should be able to notify listeners of navigation events", function()
|
||||||
@@ -428,11 +407,11 @@ return function()
|
|||||||
monarch.add_listener(URL2)
|
monarch.add_listener(URL2)
|
||||||
|
|
||||||
monarch.show(SCREEN1)
|
monarch.show(SCREEN1)
|
||||||
|
assert(wait_until_not_busy())
|
||||||
assert(mock_msg.messages(URL1)[1].message_id == monarch.SCREEN_TRANSITION_IN_STARTED)
|
assert(mock_msg.messages(URL1)[1].message_id == monarch.SCREEN_TRANSITION_IN_STARTED)
|
||||||
assert(mock_msg.messages(URL1)[1].message.screen == SCREEN1)
|
assert(mock_msg.messages(URL1)[1].message.screen == SCREEN1)
|
||||||
assert(mock_msg.messages(URL2)[1].message_id == monarch.SCREEN_TRANSITION_IN_STARTED)
|
assert(mock_msg.messages(URL2)[1].message_id == monarch.SCREEN_TRANSITION_IN_STARTED)
|
||||||
assert(mock_msg.messages(URL2)[1].message.screen == SCREEN1)
|
assert(mock_msg.messages(URL2)[1].message.screen == SCREEN1)
|
||||||
assert(wait_until_not_busy())
|
|
||||||
assert(mock_msg.messages(URL1)[2].message_id == monarch.SCREEN_TRANSITION_IN_FINISHED)
|
assert(mock_msg.messages(URL1)[2].message_id == monarch.SCREEN_TRANSITION_IN_FINISHED)
|
||||||
assert(mock_msg.messages(URL1)[2].message.screen == SCREEN1)
|
assert(mock_msg.messages(URL1)[2].message.screen == SCREEN1)
|
||||||
assert(mock_msg.messages(URL2)[2].message_id == monarch.SCREEN_TRANSITION_IN_FINISHED)
|
assert(mock_msg.messages(URL2)[2].message_id == monarch.SCREEN_TRANSITION_IN_FINISHED)
|
||||||
@@ -444,12 +423,12 @@ return function()
|
|||||||
|
|
||||||
assert(#mock_msg.messages(URL1) == 6)
|
assert(#mock_msg.messages(URL1) == 6)
|
||||||
assert(#mock_msg.messages(URL2) == 2)
|
assert(#mock_msg.messages(URL2) == 2)
|
||||||
assert(mock_msg.messages(URL1)[3].message_id == monarch.SCREEN_TRANSITION_OUT_STARTED)
|
assert(mock_msg.messages(URL1)[3].message_id == monarch.SCREEN_TRANSITION_IN_STARTED)
|
||||||
assert(mock_msg.messages(URL1)[3].message.screen == SCREEN1)
|
assert(mock_msg.messages(URL1)[3].message.screen == SCREEN2)
|
||||||
assert(mock_msg.messages(URL1)[4].message_id == monarch.SCREEN_TRANSITION_IN_STARTED)
|
assert(mock_msg.messages(URL1)[4].message_id == monarch.SCREEN_TRANSITION_IN_FINISHED)
|
||||||
assert(mock_msg.messages(URL1)[4].message.screen == SCREEN2)
|
assert(mock_msg.messages(URL1)[4].message.screen == SCREEN2)
|
||||||
assert(mock_msg.messages(URL1)[5].message_id == monarch.SCREEN_TRANSITION_IN_FINISHED)
|
assert(mock_msg.messages(URL1)[5].message_id == monarch.SCREEN_TRANSITION_OUT_STARTED)
|
||||||
assert(mock_msg.messages(URL1)[5].message.screen == SCREEN2)
|
assert(mock_msg.messages(URL1)[5].message.screen == SCREEN1)
|
||||||
assert(mock_msg.messages(URL1)[6].message_id == monarch.SCREEN_TRANSITION_OUT_FINISHED)
|
assert(mock_msg.messages(URL1)[6].message_id == monarch.SCREEN_TRANSITION_OUT_FINISHED)
|
||||||
assert(mock_msg.messages(URL1)[6].message.screen == SCREEN1)
|
assert(mock_msg.messages(URL1)[6].message.screen == SCREEN1)
|
||||||
|
|
||||||
@@ -458,24 +437,24 @@ return function()
|
|||||||
|
|
||||||
assert(#mock_msg.messages(URL1) == 10)
|
assert(#mock_msg.messages(URL1) == 10)
|
||||||
assert(#mock_msg.messages(URL2) == 2)
|
assert(#mock_msg.messages(URL2) == 2)
|
||||||
assert(mock_msg.messages(URL1)[7].message_id == monarch.SCREEN_TRANSITION_OUT_STARTED)
|
assert(mock_msg.messages(URL1)[7].message_id == monarch.SCREEN_TRANSITION_IN_STARTED)
|
||||||
assert(mock_msg.messages(URL1)[7].message.screen == SCREEN2)
|
assert(mock_msg.messages(URL1)[7].message.screen == SCREEN1)
|
||||||
assert(mock_msg.messages(URL1)[8].message_id == monarch.SCREEN_TRANSITION_IN_STARTED)
|
assert(mock_msg.messages(URL1)[8].message_id == monarch.SCREEN_TRANSITION_IN_FINISHED)
|
||||||
assert(mock_msg.messages(URL1)[8].message.screen == SCREEN1)
|
assert(mock_msg.messages(URL1)[8].message.screen == SCREEN1)
|
||||||
assert(mock_msg.messages(URL1)[9].message_id == monarch.SCREEN_TRANSITION_IN_FINISHED)
|
assert(mock_msg.messages(URL1)[9].message_id == monarch.SCREEN_TRANSITION_OUT_STARTED)
|
||||||
assert(mock_msg.messages(URL1)[9].message.screen == SCREEN1)
|
assert(mock_msg.messages(URL1)[9].message.screen == SCREEN2)
|
||||||
assert(mock_msg.messages(URL1)[10].message_id == monarch.SCREEN_TRANSITION_OUT_FINISHED)
|
assert(mock_msg.messages(URL1)[10].message_id == monarch.SCREEN_TRANSITION_OUT_FINISHED)
|
||||||
assert(mock_msg.messages(URL1)[10].message.screen == SCREEN2)
|
assert(mock_msg.messages(URL1)[10].message.screen == SCREEN2)
|
||||||
end)
|
end)
|
||||||
|
|
||||||
it("should be able to show a screen even while it is preloading", function()
|
it("should be able to show a screen even while it is preloading", function()
|
||||||
monarch.show(SCREEN_PRELOAD, nil, { count = 1 })
|
monarch.show(SCREEN_PRELOAD, nil, { count = 1 })
|
||||||
assert(wait_until_shown(SCREEN_PRELOAD), "Screen_preload was never shown")
|
assert(wait_until_visible(SCREEN_PRELOAD), "Screen_preload was never shown")
|
||||||
end)
|
end)
|
||||||
|
|
||||||
it("should be able to preload a screen and always keep it loaded", function()
|
it("should be able to preload a screen and always keep it loaded", function()
|
||||||
monarch.show(SCREEN_PRELOAD)
|
monarch.show(SCREEN_PRELOAD)
|
||||||
assert(wait_until_shown(SCREEN_PRELOAD), "Screen_preload was never shown")
|
assert(wait_until_visible(SCREEN_PRELOAD), "Screen_preload was never shown")
|
||||||
monarch.back()
|
monarch.back()
|
||||||
assert(wait_until_hidden(SCREEN_PRELOAD), "Screen_preload was never hidden")
|
assert(wait_until_hidden(SCREEN_PRELOAD), "Screen_preload was never hidden")
|
||||||
assert(monarch.is_preloaded(SCREEN_PRELOAD))
|
assert(monarch.is_preloaded(SCREEN_PRELOAD))
|
||||||
@@ -483,12 +462,12 @@ return function()
|
|||||||
|
|
||||||
it("should be able to reload a preloaded screen", function()
|
it("should be able to reload a preloaded screen", function()
|
||||||
monarch.show(SCREEN_PRELOAD, nil, { count = 1 })
|
monarch.show(SCREEN_PRELOAD, nil, { count = 1 })
|
||||||
assert(wait_until_shown(SCREEN_PRELOAD), "Screen_preload was never shown")
|
assert(wait_until_visible(SCREEN_PRELOAD), "Screen_preload was never shown")
|
||||||
-- first time the screen gets loaded it will increment the count
|
-- first time the screen gets loaded it will increment the count
|
||||||
assert(monarch.data(SCREEN_PRELOAD).count == 2)
|
assert(monarch.data(SCREEN_PRELOAD).count == 2)
|
||||||
|
|
||||||
monarch.show(SCREEN_PRELOAD, { clear = true, reload = true }, { count = 1 })
|
monarch.show(SCREEN_PRELOAD, { clear = true, reload = true }, { count = 1 })
|
||||||
assert(wait_until_shown(SCREEN_PRELOAD), "Screen_preload was never shown")
|
assert(wait_until_visible(SCREEN_PRELOAD), "Screen_preload was never shown")
|
||||||
-- second time the screen gets shown it will be reloaded and increment the count
|
-- second time the screen gets shown it will be reloaded and increment the count
|
||||||
assert(monarch.data(SCREEN_PRELOAD).count == 2)
|
assert(monarch.data(SCREEN_PRELOAD).count == 2)
|
||||||
end)
|
end)
|
||||||
@@ -499,13 +478,14 @@ return function()
|
|||||||
_G.focus1_lost = nil
|
_G.focus1_lost = nil
|
||||||
|
|
||||||
monarch.show(SCREEN1)
|
monarch.show(SCREEN1)
|
||||||
assert(wait_until_shown(SCREEN1), "Screen1 was never shown")
|
assert(wait_until_stack({ SCREEN1 }))
|
||||||
monarch.show(FOCUS1)
|
monarch.show(FOCUS1)
|
||||||
assert(wait_until_shown(FOCUS1), "Screen1 was never shown")
|
assert(wait_until_stack({ SCREEN1, FOCUS1 }))
|
||||||
|
assert(wait_until_visible(FOCUS1))
|
||||||
assert(_G.focus1_gained)
|
assert(_G.focus1_gained)
|
||||||
monarch.show(SCREEN1)
|
monarch.show(SCREEN1)
|
||||||
assert(wait_until_shown(SCREEN1), "Screen1 was never shown")
|
assert(wait_until_stack({ SCREEN1, FOCUS1, SCREEN1 }))
|
||||||
assert(wait_until_hidden(FOCUS1), "Focus1 was never hidden")
|
assert(wait_until_hidden(FOCUS1))
|
||||||
assert(_G.focus1_lost)
|
assert(_G.focus1_lost)
|
||||||
end)
|
end)
|
||||||
|
|
||||||
@@ -516,14 +496,14 @@ return function()
|
|||||||
|
|
||||||
-- proxy screen
|
-- proxy screen
|
||||||
monarch.show(SCREEN1)
|
monarch.show(SCREEN1)
|
||||||
wait_until_shown(SCREEN1)
|
wait_until_visible(SCREEN1)
|
||||||
assert(monarch.post(SCREEN1, "foobar"), "Expected monarch.post() to return true")
|
assert(monarch.post(SCREEN1, "foobar"), "Expected monarch.post() to return true")
|
||||||
cowait(0.1)
|
cowait(0.1)
|
||||||
assert(_G.screen1_foobar, "Screen1 never received a message")
|
assert(_G.screen1_foobar, "Screen1 never received a message")
|
||||||
|
|
||||||
-- factory screen
|
-- factory screen
|
||||||
monarch.show(SCREEN2)
|
monarch.show(SCREEN2)
|
||||||
wait_until_shown(SCREEN2)
|
wait_until_visible(SCREEN2)
|
||||||
assert(monarch.post(SCREEN2, "foobar"), "Expected monarch.post() to return true")
|
assert(monarch.post(SCREEN2, "foobar"), "Expected monarch.post() to return true")
|
||||||
cowait(0.1)
|
cowait(0.1)
|
||||||
assert(_G.screen2_foobar, "Screen2 never received a message")
|
assert(_G.screen2_foobar, "Screen2 never received a message")
|
||||||
@@ -536,7 +516,7 @@ return function()
|
|||||||
|
|
||||||
-- proxy screen
|
-- proxy screen
|
||||||
monarch.show(SCREEN1)
|
monarch.show(SCREEN1)
|
||||||
wait_until_shown(SCREEN1)
|
wait_until_visible(SCREEN1)
|
||||||
assert(monarch.post(SCREEN1, "foobar", { foo = "bar" }), "Expected monarch.post() to return true")
|
assert(monarch.post(SCREEN1, "foobar", { foo = "bar" }), "Expected monarch.post() to return true")
|
||||||
cowait(0.1)
|
cowait(0.1)
|
||||||
assert(_G.screen1_foobar, "Screen1 never received a message")
|
assert(_G.screen1_foobar, "Screen1 never received a message")
|
||||||
@@ -544,7 +524,7 @@ return function()
|
|||||||
|
|
||||||
-- factory screen
|
-- factory screen
|
||||||
monarch.show(SCREEN2)
|
monarch.show(SCREEN2)
|
||||||
wait_until_shown(SCREEN2)
|
wait_until_visible(SCREEN2)
|
||||||
assert(monarch.post(SCREEN2, "foobar", { foo = "bar" }), "Expected monarch.post() to return true")
|
assert(monarch.post(SCREEN2, "foobar", { foo = "bar" }), "Expected monarch.post() to return true")
|
||||||
cowait(0.1)
|
cowait(0.1)
|
||||||
assert(_G.screen2_foobar, "Screen2 never received a message")
|
assert(_G.screen2_foobar, "Screen2 never received a message")
|
||||||
@@ -556,9 +536,9 @@ return function()
|
|||||||
_G.screen1_foobar = nil
|
_G.screen1_foobar = nil
|
||||||
|
|
||||||
monarch.show(SCREEN1)
|
monarch.show(SCREEN1)
|
||||||
wait_until_shown(SCREEN1)
|
|
||||||
monarch.show(SCREEN2)
|
monarch.show(SCREEN2)
|
||||||
wait_until_shown(SCREEN2)
|
assert(wait_until_stack({ SCREEN1, SCREEN2 }))
|
||||||
|
assert(wait_until_hidden(SCREEN1))
|
||||||
local ok, err = monarch.post(SCREEN1, "foobar")
|
local ok, err = monarch.post(SCREEN1, "foobar")
|
||||||
assert(not ok and err, "Expected monarch.post() to return false plus an error message")
|
assert(not ok and err, "Expected monarch.post() to return false plus an error message")
|
||||||
cowait(0.1)
|
cowait(0.1)
|
||||||
@@ -568,7 +548,7 @@ return function()
|
|||||||
|
|
||||||
it("should not be able to post messages to proxy screens without a receiver url", function()
|
it("should not be able to post messages to proxy screens without a receiver url", function()
|
||||||
monarch.show(POPUP1)
|
monarch.show(POPUP1)
|
||||||
wait_until_shown(POPUP1)
|
wait_until_visible(POPUP1)
|
||||||
local ok, err = monarch.post(POPUP1, "foobar")
|
local ok, err = monarch.post(POPUP1, "foobar")
|
||||||
assert(not ok and err, "Expected monarch.post() to return false plus an error message")
|
assert(not ok and err, "Expected monarch.post() to return false plus an error message")
|
||||||
end)
|
end)
|
||||||
|
|||||||
@@ -8,6 +8,12 @@ local easing = require "monarch.transitions.easings"
|
|||||||
|
|
||||||
return function()
|
return function()
|
||||||
|
|
||||||
|
local function wait_timeout(fn, ...)
|
||||||
|
local args = { ... }
|
||||||
|
cowait(function() return fn(unpack(args)) end, 5)
|
||||||
|
return fn(...)
|
||||||
|
end
|
||||||
|
|
||||||
describe("transitions", function()
|
describe("transitions", function()
|
||||||
before(function()
|
before(function()
|
||||||
mock_msg.mock()
|
mock_msg.mock()
|
||||||
@@ -22,6 +28,28 @@ describe("transitions", function()
|
|||||||
end)
|
end)
|
||||||
|
|
||||||
|
|
||||||
|
it("should replace an existing transition with a new one", function()
|
||||||
|
local one = false
|
||||||
|
function dummy_transition1(node, to, easing, duration, delay, cb)
|
||||||
|
one = true
|
||||||
|
end
|
||||||
|
local two = false
|
||||||
|
function dummy_transition2(node, to, easing, duration, delay, cb)
|
||||||
|
two = true
|
||||||
|
end
|
||||||
|
|
||||||
|
local node = gui.new_box_node(vmath.vector3(), vmath.vector3(100, 100, 0))
|
||||||
|
local duration = 2
|
||||||
|
local t = transitions.create(node)
|
||||||
|
t.show_in(dummy_transition1, easing.OUT, duration, delay or 0)
|
||||||
|
t.show_in(dummy_transition2, easing.OUT, duration, delay or 0)
|
||||||
|
t.handle(monarch.TRANSITION.SHOW_IN)
|
||||||
|
|
||||||
|
wait_timeout(function() return one or two end)
|
||||||
|
assert(two)
|
||||||
|
assert(not one)
|
||||||
|
end)
|
||||||
|
|
||||||
it("should replay and immediately finish on layout change", function()
|
it("should replay and immediately finish on layout change", function()
|
||||||
function dummy_transition(node, to, easing, duration, delay, cb)
|
function dummy_transition(node, to, easing, duration, delay, cb)
|
||||||
print("dummy transition")
|
print("dummy transition")
|
||||||
|
|||||||
Reference in New Issue
Block a user