diff --git a/firmware/application/main.cpp b/firmware/application/main.cpp index 54663811..4fd904ba 100755 --- a/firmware/application/main.cpp +++ b/firmware/application/main.cpp @@ -266,10 +266,7 @@ private: } void handle_lcd_frame_sync() { - if( ui::is_dirty() ) { - painter.paint_widget(top_widget); - ui::dirty_clear(); - } + painter.paint_widget_tree(top_widget); } void handle_sd_card_detect() { diff --git a/firmware/common/ui_painter.cpp b/firmware/common/ui_painter.cpp index 77f2c34e..1f772fa1 100644 --- a/firmware/common/ui_painter.cpp +++ b/firmware/common/ui_painter.cpp @@ -73,6 +73,13 @@ void Painter::fill_rectangle(const Rect r, const Color c) { display.fill_rectangle(r, c); } +void Painter::paint_widget_tree(Widget* const w) { + if( ui::is_dirty() ) { + paint_widget(w); + ui::dirty_clear(); + } +} + void Painter::paint_widget(Widget* const w) { if( w->hidden() ) { // Mark widget (and all children) as invisible. diff --git a/firmware/common/ui_painter.hpp b/firmware/common/ui_painter.hpp index aba85b77..40e03edf 100644 --- a/firmware/common/ui_painter.hpp +++ b/firmware/common/ui_painter.hpp @@ -53,11 +53,13 @@ public: void draw_rectangle(const Rect r, const Color c); void fill_rectangle(const Rect r, const Color c); - void paint_widget(Widget* const w); - + void paint_widget_tree(Widget* const w); + private: void draw_hline(Point p, size_t width, const Color c); void draw_vline(Point p, size_t height, const Color c); + + void paint_widget(Widget* const w); }; } /* namespace ui */