From f5c83d0609d2fd2030a2339a4a7d75d96fdf1b15 Mon Sep 17 00:00:00 2001 From: Loic Guegan Date: Mon, 2 Jan 2023 08:10:43 +0100 Subject: [PATCH] Simplify editor events processing --- examples/wxWidgets/main.cpp | 10 ++-------- src/CGEditor.cpp | 10 ++++++++++ src/CGEditor.hpp | 6 +++++- 3 files changed, 17 insertions(+), 9 deletions(-) diff --git a/examples/wxWidgets/main.cpp b/examples/wxWidgets/main.cpp index 9d5274a..7d2f59e 100644 --- a/examples/wxWidgets/main.cpp +++ b/examples/wxWidgets/main.cpp @@ -71,15 +71,9 @@ private: Refresh(); } - // Now handle event - bool redraw=false; + // Now handle generated events from last user inputs Update(); - for(const cgeditor::Event &e: status.Events){ - HandleEvent(e); - redraw=true; - } - status.Events.clear(); - if(redraw){ + if(ProcessEvents()){ Refresh(); } } diff --git a/src/CGEditor.cpp b/src/CGEditor.cpp index 737db39..2da0520 100644 --- a/src/CGEditor.cpp +++ b/src/CGEditor.cpp @@ -92,4 +92,14 @@ void CGEditor::DrawComponent(Component *c) { } } +bool CGEditor::ProcessEvents(){ + bool processed=false; + for(const cgeditor::Event &e: status.Events){ + HandleEvent(e); + processed=true; + } + status.Events.clear(); + return processed; +} + } // namespace cgeditor \ No newline at end of file diff --git a/src/CGEditor.hpp b/src/CGEditor.hpp index e463170..e113325 100644 --- a/src/CGEditor.hpp +++ b/src/CGEditor.hpp @@ -23,10 +23,14 @@ class CGEditor { protected: Status status; - ///@brief Draw the Chess Game Editor on the canvas using current status + /// @brief Draw the Chess Game Editor on the canvas using current status void Draw(); + /// @brief Process the events generated during the drawing + bool ProcessEvents(); /// @brief Draw an element on the canvas virtual void DrawElement(const Element &) = 0; + /// @brief Handle event that occured during editor drawing + virtual void HandleEvent(const Event &) = 0; public: CGEditor();