2021-10-03 13:36:05 +03:00
|
|
|
/**
|
|
|
|
|
* @file view_dispatcher.h
|
2024-03-20 17:54:07 +03:00
|
|
|
* @brief GUI: ViewDispatcher API
|
|
|
|
|
*
|
2024-08-07 04:49:41 +01:00
|
|
|
* ViewDispatcher is used to connect several Views to a Gui instance, switch between them and handle various events.
|
|
|
|
|
* This is useful in applications featuring an advanced graphical user interface.
|
|
|
|
|
*
|
|
|
|
|
* Internally, ViewDispatcher employs a FuriEventLoop instance together with two separate
|
|
|
|
|
* message queues for input and custom event handling. See FuriEventLoop for more information.
|
|
|
|
|
*
|
|
|
|
|
* If no multi-view or complex event handling capabilities are required, consider using ViewHolder instead.
|
|
|
|
|
*
|
2024-03-20 17:54:07 +03:00
|
|
|
* @warning Views added to a ViewDispatcher MUST NOT be in a ViewStack at the same time.
|
2021-10-03 13:36:05 +03:00
|
|
|
*/
|
|
|
|
|
|
2021-01-08 07:42:48 +03:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
|
|
#include "view.h"
|
|
|
|
|
#include "gui.h"
|
2021-07-12 21:56:14 +03:00
|
|
|
#include "scene_manager.h"
|
2021-01-08 07:42:48 +03:00
|
|
|
|
[FL-140] Core api dynamic records (#296)
* SYSTEM: tickless mode with deep sleep.
* Move FreeRTOS ticks to lptim2
* API: move all sumbodules init routines to one place. Timebase: working lptim2 at tick source.
* API Timebase: lp-timer routines, timer access safe zones prediction and synchronization. FreeRTOS: adjust configuration for tickless mode.
* NFC: support for tickless mode.
* API Timebase: improve tick error handling in IRQ. Apploader: use insomnia mode to run applications.
* BLE: prevent sleep while core2 starting
* HAL: nap while in insomnia mode
* init records work
* try to implement record delete
* tests and flapp
* flapp subsystem
* new core functions to get app stat, simplify core code
* fix thread termination
* add strdup to core
* fix tests
* Refactoring: remove all unusued parts, update API usage, aggreagate API sources and headers, new record storage
* Refactoring: update furi record api usage, cleanup code
* Fix broken merge for freertos apps
* Core, Target: fix compilation warnings
* Drop firmware target local
* HAL Timebase, Power, Clock: semaphore guarded access to clock and power modes, better sleep mode.
* SD-Filesystem: wait for all deps to arrive before adding widget. Core, BLE: disable debug dump to serial.
* delete old app example-ipc
* delete old app fatfs list
* fix strobe app, add input header
* delete old display driver
* comment old app qr-code
* fix sd-card test, add forced widget update
* remove unused new core test
* increase heap to 128k
* comment and assert old core tests
* fix syntax
Co-authored-by: Aleksandr Kutuzov <alleteam@gmail.com>
2021-01-21 02:09:26 +10:00
|
|
|
#ifdef __cplusplus
|
|
|
|
|
extern "C" {
|
|
|
|
|
#endif
|
|
|
|
|
|
2021-10-03 13:36:05 +03:00
|
|
|
/** ViewDispatcher view_port placement */
|
2021-01-08 07:42:48 +03:00
|
|
|
typedef enum {
|
2021-11-24 20:21:12 +04:00
|
|
|
ViewDispatcherTypeDesktop, /**< Desktop layer: fullscreen with status bar on top of it. For internal usage. */
|
|
|
|
|
ViewDispatcherTypeWindow, /**< Window layer: with status bar */
|
|
|
|
|
ViewDispatcherTypeFullscreen /**< Fullscreen layer: without status bar */
|
2021-01-08 07:42:48 +03:00
|
|
|
} ViewDispatcherType;
|
|
|
|
|
|
|
|
|
|
typedef struct ViewDispatcher ViewDispatcher;
|
|
|
|
|
|
2021-10-03 13:36:05 +03:00
|
|
|
/** Prototype for custom event callback */
|
2021-07-12 21:56:14 +03:00
|
|
|
typedef bool (*ViewDispatcherCustomEventCallback)(void* context, uint32_t event);
|
|
|
|
|
|
2021-10-03 13:36:05 +03:00
|
|
|
/** Prototype for navigation event callback */
|
2021-07-12 21:56:14 +03:00
|
|
|
typedef bool (*ViewDispatcherNavigationEventCallback)(void* context);
|
|
|
|
|
|
2021-10-03 13:36:05 +03:00
|
|
|
/** Prototype for tick event callback */
|
2021-07-12 21:56:14 +03:00
|
|
|
typedef void (*ViewDispatcherTickEventCallback)(void* context);
|
|
|
|
|
|
2021-05-25 13:19:07 +03:00
|
|
|
/** Allocate ViewDispatcher instance
|
2021-10-03 13:36:05 +03:00
|
|
|
*
|
|
|
|
|
* @return pointer to ViewDispatcher instance
|
2021-01-08 07:42:48 +03:00
|
|
|
*/
|
2024-03-19 23:43:52 +09:00
|
|
|
ViewDispatcher* view_dispatcher_alloc(void);
|
2021-01-08 07:42:48 +03:00
|
|
|
|
[FL-3893] JS modules (#3841)
* feat: backport js_gpio from unleashed
* feat: backport js_keyboard, TextInputModel::minimum_length from unleashed
* fix: api version inconsistency
* style: js_gpio
* build: fix submodule ._ .
* refactor: js_gpio
* docs: type declarations for gpio
* feat: gpio interrupts
* fix: js_gpio freeing, resetting and minor stylistic changes
* style: js_gpio
* style: mlib array, fixme's
* feat: js_gpio adc
* feat: js_event_loop
* docs: js_event_loop
* feat: js_event_loop subscription cancellation
* feat: js_event_loop + js_gpio integration
* fix: js_event_loop memory leak
* feat: stop event loop on back button
* test: js: basic, math, event_loop
* feat: js_event_loop queue
* feat: js linkage to previously loaded plugins
* build: fix ci errors
* feat: js module ordered teardown
* feat: js_gui_defer_free
* feat: basic hourglass view
* style: JS ASS (Argument Schema for Scripts)
* fix: js_event_loop mem leaks and lifetime problems
* fix: crashing test and pvs false positives
* feat: mjs custom obj destructors, gui submenu view
* refactor: yank js_gui_defer_free (yuck)
* refactor: maybe_unsubscribe
* empty_screen, docs, typing fix-ups
* docs: navigation event & demo
* feat: submenu setHeader
* feat: text_input
* feat: text_box
* docs: text_box availability
* ci: silence irrelevant pvs low priority warning
* style: use furistring
* style: _get_at -> _safe_get
* fix: built-in module name assignment
* feat: js_dialog; refactor, optimize: js_gui
* docs: js_gui
* ci: silence pvs warning: Memory allocation is infallible
* style: fix storage spelling
* feat: foreign pointer signature checks
* feat: js_storage
* docs: js_storage
* fix: my unit test was breaking other tests ;_;
* ci: fix ci?
* Make doxygen happy
* docs: flipper, math, notification, global
* style: review suggestions
* style: review fixups
* fix: badusb demo script
* docs: badusb
* ci: add nofl
* ci: make linter happy
* Bump api version
Co-authored-by: Aleksandr Kutuzov <alleteam@gmail.com>
2024-10-14 21:42:11 +03:00
|
|
|
/** Allocate ViewDispatcher instance with an externally owned event loop. If
|
|
|
|
|
* this constructor is used instead of `view_dispatcher_alloc`, the burden of
|
|
|
|
|
* freeing the event loop is placed on the caller.
|
|
|
|
|
*
|
|
|
|
|
* @param loop pointer to FuriEventLoop instance
|
|
|
|
|
* @return pointer to ViewDispatcher instance
|
|
|
|
|
*/
|
|
|
|
|
ViewDispatcher* view_dispatcher_alloc_ex(FuriEventLoop* loop);
|
|
|
|
|
|
2021-05-25 13:19:07 +03:00
|
|
|
/** Free ViewDispatcher instance
|
2024-08-07 04:49:41 +01:00
|
|
|
*
|
|
|
|
|
* @warning All added views MUST be removed using view_dispatcher_remove_view()
|
|
|
|
|
* before calling this function.
|
2021-10-03 13:36:05 +03:00
|
|
|
*
|
|
|
|
|
* @param view_dispatcher pointer to ViewDispatcher
|
2021-01-08 07:42:48 +03:00
|
|
|
*/
|
|
|
|
|
void view_dispatcher_free(ViewDispatcher* view_dispatcher);
|
|
|
|
|
|
2021-05-25 13:19:07 +03:00
|
|
|
/** Enable queue support
|
2021-10-03 13:36:05 +03:00
|
|
|
*
|
2024-08-07 04:49:41 +01:00
|
|
|
* @deprecated Do NOT use in new code and remove all calls to it from existing code.
|
|
|
|
|
* The queue support is now always enabled during construction. If no queue support
|
|
|
|
|
* is required, consider using ViewHolder instead.
|
2021-10-03 13:36:05 +03:00
|
|
|
*
|
|
|
|
|
* @param view_dispatcher ViewDispatcher instance
|
2021-05-25 13:19:07 +03:00
|
|
|
*/
|
2024-08-07 04:49:41 +01:00
|
|
|
FURI_DEPRECATED void view_dispatcher_enable_queue(ViewDispatcher* view_dispatcher);
|
2021-05-25 13:19:07 +03:00
|
|
|
|
2021-06-20 11:15:48 +03:00
|
|
|
/** Send custom event
|
2021-10-03 13:36:05 +03:00
|
|
|
*
|
|
|
|
|
* @param view_dispatcher ViewDispatcher instance
|
|
|
|
|
* @param[in] event The event
|
2021-06-20 11:15:48 +03:00
|
|
|
*/
|
|
|
|
|
void view_dispatcher_send_custom_event(ViewDispatcher* view_dispatcher, uint32_t event);
|
|
|
|
|
|
2021-07-12 21:56:14 +03:00
|
|
|
/** Set custom event handler
|
2021-10-03 13:36:05 +03:00
|
|
|
*
|
2021-07-12 21:56:14 +03:00
|
|
|
* Called on Custom Event, if it is not consumed by view
|
2021-10-03 13:36:05 +03:00
|
|
|
*
|
|
|
|
|
* @param view_dispatcher ViewDispatcher instance
|
|
|
|
|
* @param callback ViewDispatcherCustomEventCallback instance
|
2021-06-30 20:43:29 +03:00
|
|
|
*/
|
2021-07-12 21:56:14 +03:00
|
|
|
void view_dispatcher_set_custom_event_callback(
|
|
|
|
|
ViewDispatcher* view_dispatcher,
|
|
|
|
|
ViewDispatcherCustomEventCallback callback);
|
2021-06-30 20:43:29 +03:00
|
|
|
|
2021-07-12 21:56:14 +03:00
|
|
|
/** Set navigation event handler
|
2021-10-03 13:36:05 +03:00
|
|
|
*
|
2021-07-12 21:56:14 +03:00
|
|
|
* Called on Input Short Back Event, if it is not consumed by view
|
2021-10-03 13:36:05 +03:00
|
|
|
*
|
|
|
|
|
* @param view_dispatcher ViewDispatcher instance
|
|
|
|
|
* @param callback ViewDispatcherNavigationEventCallback instance
|
2021-06-30 20:43:29 +03:00
|
|
|
*/
|
2021-07-12 21:56:14 +03:00
|
|
|
void view_dispatcher_set_navigation_event_callback(
|
|
|
|
|
ViewDispatcher* view_dispatcher,
|
|
|
|
|
ViewDispatcherNavigationEventCallback callback);
|
2021-06-30 20:43:29 +03:00
|
|
|
|
2021-07-12 21:56:14 +03:00
|
|
|
/** Set tick event handler
|
2021-10-03 13:36:05 +03:00
|
|
|
*
|
[FL-3893] JS modules (#3841)
* feat: backport js_gpio from unleashed
* feat: backport js_keyboard, TextInputModel::minimum_length from unleashed
* fix: api version inconsistency
* style: js_gpio
* build: fix submodule ._ .
* refactor: js_gpio
* docs: type declarations for gpio
* feat: gpio interrupts
* fix: js_gpio freeing, resetting and minor stylistic changes
* style: js_gpio
* style: mlib array, fixme's
* feat: js_gpio adc
* feat: js_event_loop
* docs: js_event_loop
* feat: js_event_loop subscription cancellation
* feat: js_event_loop + js_gpio integration
* fix: js_event_loop memory leak
* feat: stop event loop on back button
* test: js: basic, math, event_loop
* feat: js_event_loop queue
* feat: js linkage to previously loaded plugins
* build: fix ci errors
* feat: js module ordered teardown
* feat: js_gui_defer_free
* feat: basic hourglass view
* style: JS ASS (Argument Schema for Scripts)
* fix: js_event_loop mem leaks and lifetime problems
* fix: crashing test and pvs false positives
* feat: mjs custom obj destructors, gui submenu view
* refactor: yank js_gui_defer_free (yuck)
* refactor: maybe_unsubscribe
* empty_screen, docs, typing fix-ups
* docs: navigation event & demo
* feat: submenu setHeader
* feat: text_input
* feat: text_box
* docs: text_box availability
* ci: silence irrelevant pvs low priority warning
* style: use furistring
* style: _get_at -> _safe_get
* fix: built-in module name assignment
* feat: js_dialog; refactor, optimize: js_gui
* docs: js_gui
* ci: silence pvs warning: Memory allocation is infallible
* style: fix storage spelling
* feat: foreign pointer signature checks
* feat: js_storage
* docs: js_storage
* fix: my unit test was breaking other tests ;_;
* ci: fix ci?
* Make doxygen happy
* docs: flipper, math, notification, global
* style: review suggestions
* style: review fixups
* fix: badusb demo script
* docs: badusb
* ci: add nofl
* ci: make linter happy
* Bump api version
Co-authored-by: Aleksandr Kutuzov <alleteam@gmail.com>
2024-10-14 21:42:11 +03:00
|
|
|
* @warning Requires the event loop to be owned by the view dispatcher, i.e.
|
|
|
|
|
* it should have been instantiated with `view_dispatcher_alloc`, not
|
|
|
|
|
* `view_dispatcher_alloc_ex`.
|
|
|
|
|
*
|
2021-10-03 13:36:05 +03:00
|
|
|
* @param view_dispatcher ViewDispatcher instance
|
|
|
|
|
* @param callback ViewDispatcherTickEventCallback
|
|
|
|
|
* @param tick_period callback call period
|
2021-06-30 20:43:29 +03:00
|
|
|
*/
|
2021-07-12 21:56:14 +03:00
|
|
|
void view_dispatcher_set_tick_event_callback(
|
|
|
|
|
ViewDispatcher* view_dispatcher,
|
|
|
|
|
ViewDispatcherTickEventCallback callback,
|
|
|
|
|
uint32_t tick_period);
|
2021-06-30 20:43:29 +03:00
|
|
|
|
2021-07-12 21:56:14 +03:00
|
|
|
/** Set event callback context
|
2021-10-03 13:36:05 +03:00
|
|
|
*
|
|
|
|
|
* @param view_dispatcher ViewDispatcher instance
|
|
|
|
|
* @param context pointer to context
|
2021-06-30 20:43:29 +03:00
|
|
|
*/
|
2021-07-12 21:56:14 +03:00
|
|
|
void view_dispatcher_set_event_callback_context(ViewDispatcher* view_dispatcher, void* context);
|
2021-06-30 20:43:29 +03:00
|
|
|
|
2024-06-10 18:53:08 +01:00
|
|
|
/** Get event_loop instance
|
|
|
|
|
*
|
2024-08-07 04:49:41 +01:00
|
|
|
* Use the return value to connect additional supported primitives (message queues, timers, etc)
|
|
|
|
|
* to this ViewDispatcher instance's event loop.
|
2024-06-10 18:53:08 +01:00
|
|
|
*
|
2024-08-07 04:49:41 +01:00
|
|
|
* @warning Do NOT call furi_event_loop_run() on the returned instance, it is done internally
|
|
|
|
|
* in the view_dispatcher_run() call.
|
2024-06-10 18:53:08 +01:00
|
|
|
*
|
|
|
|
|
* @param view_dispatcher ViewDispatcher instance
|
|
|
|
|
*
|
|
|
|
|
* @return The event_loop instance.
|
|
|
|
|
*/
|
|
|
|
|
FuriEventLoop* view_dispatcher_get_event_loop(ViewDispatcher* view_dispatcher);
|
|
|
|
|
|
2021-05-25 13:19:07 +03:00
|
|
|
/** Run ViewDispatcher
|
2021-10-03 13:36:05 +03:00
|
|
|
*
|
2024-08-07 04:49:41 +01:00
|
|
|
* This function will start the event loop and block until view_dispatcher_stop() is called
|
|
|
|
|
* or the current thread receives a FuriSignalExit signal.
|
2021-10-03 13:36:05 +03:00
|
|
|
*
|
|
|
|
|
* @param view_dispatcher ViewDispatcher instance
|
2021-05-25 13:19:07 +03:00
|
|
|
*/
|
|
|
|
|
void view_dispatcher_run(ViewDispatcher* view_dispatcher);
|
|
|
|
|
|
|
|
|
|
/** Stop ViewDispatcher
|
2021-10-03 13:36:05 +03:00
|
|
|
*
|
|
|
|
|
* @param view_dispatcher ViewDispatcher instance
|
2021-05-25 13:19:07 +03:00
|
|
|
*/
|
|
|
|
|
void view_dispatcher_stop(ViewDispatcher* view_dispatcher);
|
|
|
|
|
|
|
|
|
|
/** Add view to ViewDispatcher
|
2021-10-03 13:36:05 +03:00
|
|
|
*
|
|
|
|
|
* @param view_dispatcher ViewDispatcher instance
|
|
|
|
|
* @param view_id View id to register
|
|
|
|
|
* @param view View instance
|
2021-01-08 07:42:48 +03:00
|
|
|
*/
|
|
|
|
|
void view_dispatcher_add_view(ViewDispatcher* view_dispatcher, uint32_t view_id, View* view);
|
|
|
|
|
|
2021-05-25 13:19:07 +03:00
|
|
|
/** Remove view from ViewDispatcher
|
2021-10-03 13:36:05 +03:00
|
|
|
*
|
|
|
|
|
* @param view_dispatcher ViewDispatcher instance
|
|
|
|
|
* @param view_id View id to remove
|
2021-03-05 19:47:27 +10:00
|
|
|
*/
|
|
|
|
|
void view_dispatcher_remove_view(ViewDispatcher* view_dispatcher, uint32_t view_id);
|
|
|
|
|
|
2021-05-25 13:19:07 +03:00
|
|
|
/** Switch to View
|
2021-10-03 13:36:05 +03:00
|
|
|
*
|
|
|
|
|
* @param view_dispatcher ViewDispatcher instance
|
|
|
|
|
* @param view_id View id to register
|
|
|
|
|
* @warning switching may be delayed till input events complementarity
|
|
|
|
|
* reached
|
2021-01-08 07:42:48 +03:00
|
|
|
*/
|
|
|
|
|
void view_dispatcher_switch_to_view(ViewDispatcher* view_dispatcher, uint32_t view_id);
|
|
|
|
|
|
2021-10-06 18:41:22 +03:00
|
|
|
/** Send ViewPort of this ViewDispatcher instance to front
|
|
|
|
|
*
|
|
|
|
|
* @param view_dispatcher ViewDispatcher instance
|
|
|
|
|
*/
|
|
|
|
|
void view_dispatcher_send_to_front(ViewDispatcher* view_dispatcher);
|
|
|
|
|
|
|
|
|
|
/** Send ViewPort of this ViewDispatcher instance to back
|
|
|
|
|
*
|
|
|
|
|
* @param view_dispatcher ViewDispatcher instance
|
|
|
|
|
*/
|
|
|
|
|
void view_dispatcher_send_to_back(ViewDispatcher* view_dispatcher);
|
|
|
|
|
|
2021-05-25 13:19:07 +03:00
|
|
|
/** Attach ViewDispatcher to GUI
|
2021-10-03 13:36:05 +03:00
|
|
|
*
|
|
|
|
|
* @param view_dispatcher ViewDispatcher instance
|
|
|
|
|
* @param gui GUI instance to attach to
|
|
|
|
|
* @param[in] type The type
|
2021-01-08 07:42:48 +03:00
|
|
|
*/
|
|
|
|
|
void view_dispatcher_attach_to_gui(
|
|
|
|
|
ViewDispatcher* view_dispatcher,
|
|
|
|
|
Gui* gui,
|
|
|
|
|
ViewDispatcherType type);
|
[FL-140] Core api dynamic records (#296)
* SYSTEM: tickless mode with deep sleep.
* Move FreeRTOS ticks to lptim2
* API: move all sumbodules init routines to one place. Timebase: working lptim2 at tick source.
* API Timebase: lp-timer routines, timer access safe zones prediction and synchronization. FreeRTOS: adjust configuration for tickless mode.
* NFC: support for tickless mode.
* API Timebase: improve tick error handling in IRQ. Apploader: use insomnia mode to run applications.
* BLE: prevent sleep while core2 starting
* HAL: nap while in insomnia mode
* init records work
* try to implement record delete
* tests and flapp
* flapp subsystem
* new core functions to get app stat, simplify core code
* fix thread termination
* add strdup to core
* fix tests
* Refactoring: remove all unusued parts, update API usage, aggreagate API sources and headers, new record storage
* Refactoring: update furi record api usage, cleanup code
* Fix broken merge for freertos apps
* Core, Target: fix compilation warnings
* Drop firmware target local
* HAL Timebase, Power, Clock: semaphore guarded access to clock and power modes, better sleep mode.
* SD-Filesystem: wait for all deps to arrive before adding widget. Core, BLE: disable debug dump to serial.
* delete old app example-ipc
* delete old app fatfs list
* fix strobe app, add input header
* delete old display driver
* comment old app qr-code
* fix sd-card test, add forced widget update
* remove unused new core test
* increase heap to 128k
* comment and assert old core tests
* fix syntax
Co-authored-by: Aleksandr Kutuzov <alleteam@gmail.com>
2021-01-21 02:09:26 +10:00
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
|
}
|
|
|
|
|
#endif
|