| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283 |
- #include "widget.h"
- #include "widget_i.h"
- #include <cmsis_os.h>
- #include <flipper.h>
- #include "gui.h"
- #include "gui_i.h"
- // TODO add mutex to widget ops
- struct Widget {
- void* gui;
- bool is_enabled;
- WidgetDrawCallback draw_callback;
- void* draw_callback_context;
- WidgetInputCallback input_callback;
- void* input_callback_context;
- };
- Widget* widget_alloc(WidgetDrawCallback callback, void* callback_context) {
- Widget* widget = furi_alloc(sizeof(Widget));
- widget->is_enabled = true;
- return widget;
- }
- void widget_free(Widget* widget) {
- assert(widget);
- assert(widget->gui == NULL);
- free(widget);
- }
- void widget_enabled_set(Widget* widget, bool enabled) {
- assert(widget);
- widget->is_enabled = enabled;
- widget_update(widget);
- }
- bool widget_is_enabled(Widget* widget) {
- assert(widget);
- return widget->is_enabled;
- }
- void widget_draw_callback_set(Widget* widget, WidgetDrawCallback callback, void* context) {
- assert(widget);
- widget->draw_callback = callback;
- widget->draw_callback_context = context;
- }
- void widget_input_callback_set(Widget* widget, WidgetInputCallback callback, void* context) {
- assert(widget);
- widget->input_callback = callback;
- widget->input_callback_context = context;
- }
- void widget_update(Widget* widget) {
- assert(widget);
- if(widget->gui) gui_update(widget->gui);
- }
- void widget_gui_set(Widget* widget, Gui* gui) {
- assert(widget);
- assert(gui);
- widget->gui = gui;
- }
- void widget_draw(Widget* widget, CanvasApi* canvas_api) {
- assert(widget);
- assert(canvas_api);
- assert(widget->gui);
- if(widget->draw_callback) {
- widget->draw_callback(canvas_api, widget->draw_callback_context);
- }
- }
- void widget_input(Widget* widget, InputEvent* event) {
- assert(widget);
- assert(event);
- assert(widget->gui);
- if(widget->input_callback) widget->input_callback(event, widget->input_callback_context);
- }
|