2021-03-12 16:19:43 +01:00
|
|
|
//---
|
|
|
|
// JustUI.jevent: GUI union event
|
|
|
|
//---
|
|
|
|
|
|
|
|
#ifndef _J_EVENT
|
|
|
|
#define _J_EVENT
|
|
|
|
|
|
|
|
#include <justui/defs.h>
|
|
|
|
#include <justui/jwidget.h>
|
|
|
|
|
|
|
|
#include <gint/keyboard.h>
|
2024-09-04 14:24:07 +02:00
|
|
|
#include <gint/defs/attributes.h>
|
2021-03-12 16:19:43 +01:00
|
|
|
|
|
|
|
/* jevent: GUI event
|
|
|
|
|
|
|
|
This type is mostly a union type that provides details on every event that
|
|
|
|
occurs in the GUI. These are mostly widget signaling state changes,
|
|
|
|
validations, and other GUI specifics that might require attention. Events
|
|
|
|
can either be reported to the user by the scene (upwards event) or notify
|
2022-06-19 23:36:39 +02:00
|
|
|
widgets of something occurring to them (downwards event).
|
2021-03-12 16:19:43 +01:00
|
|
|
|
|
|
|
JustUI tries hard to not invert flow control and leave the user to decide
|
|
|
|
when to produce downwards events. In a normal situation, events from
|
|
|
|
getkey() are passed to the scene using jscene_process_key() while reading
|
|
|
|
GUI events moving upwards with jscene_pollevent(). This way, the user can
|
|
|
|
decide to filter their key events or even craft some.
|
|
|
|
|
|
|
|
For the sake of convenience, a single function jscene_run() is provided that
|
|
|
|
implements a common form of main loop, which forwards keyboard events to the
|
|
|
|
scene and reports upwards GUI events and ignored key events.
|
|
|
|
|
|
|
|
Event IDs can be registered with j_register_event() and (usually) exposed as
|
|
|
|
global variables. Extensions are meaningful for custom widget types that
|
|
|
|
need their own upwards events. */
|
|
|
|
typedef struct {
|
|
|
|
/* Widget that emitted the event (if upwards), NULL otherwise */
|
|
|
|
void *source;
|
|
|
|
/* Type of event */
|
|
|
|
uint16_t type;
|
|
|
|
/* Reserved for future use */
|
|
|
|
uint16_t _;
|
|
|
|
|
|
|
|
/* Event details or data */
|
|
|
|
union {
|
2021-05-30 10:40:58 +02:00
|
|
|
/* JWIDGET_KEY events */
|
2021-03-12 16:19:43 +01:00
|
|
|
key_event_t key;
|
2022-11-06 19:51:28 +01:00
|
|
|
/* Custom generic value */
|
|
|
|
int data;
|
2021-03-12 16:19:43 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
} jevent;
|
|
|
|
|
2024-09-04 14:24:07 +02:00
|
|
|
/* Check if an event is a key press of the specified key with modifiers. */
|
|
|
|
GINLINE static bool jevent_is_press_mods(
|
|
|
|
jevent e, int key, bool shift, bool alpha) {
|
|
|
|
return e.type == JWIDGET_KEY
|
|
|
|
&& (e.key.type == KEYEV_DOWN || e.key.type == KEYEV_HOLD)
|
|
|
|
&& e.key.key == key
|
|
|
|
&& e.key.shift == shift
|
|
|
|
&& e.key.alpha == alpha;
|
|
|
|
}
|
|
|
|
|
|
|
|
#define jevent_is_press(E, KEY) jevent_is_press_mods(E, KEY, false, false)
|
|
|
|
#define jevent_is_shift_press(E, KEY) jevent_is_press_mods(E, KEY, true, false)
|
|
|
|
#define jevent_is_alpha_press(E, KEY) jevent_is_press_mods(E, KEY, false, true)
|
|
|
|
#define jevent_is_shift_alpha_press(E, KEY) \
|
|
|
|
jevent_is_press_mods(E, KEY, true, true)
|
|
|
|
|
2021-03-12 16:19:43 +01:00
|
|
|
#endif /* _J_EVENT */
|