fix event func
This commit is contained in:
		| @@ -5,7 +5,7 @@ namespace sandbox | |||||||
| { | { | ||||||
|   void local_panel::on_attach()  |   void local_panel::on_attach()  | ||||||
|   { |   { | ||||||
|     VE_CONNECT(local_panel); |     VE::CONNECT(this); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   void local_panel::render() |   void local_panel::render() | ||||||
| @@ -15,8 +15,7 @@ namespace sandbox | |||||||
|     { |     { | ||||||
|       auto f = []()  |       auto f = []()  | ||||||
|       { |       { | ||||||
|         VE::event e { test_event::TEST_EVEN , std::string("test event message from thread") }; |         VE::EMIT(test_event::TEST_EVEN, std::string("test event message from thread")); | ||||||
|         VE_EMIT(e); |  | ||||||
|       }; |       }; | ||||||
|       std::thread th(f); |       std::thread th(f); | ||||||
|       th.detach(); |       th.detach(); | ||||||
| @@ -26,8 +25,7 @@ namespace sandbox | |||||||
|  |  | ||||||
|     if (ImGui::Button(VE::style::icon::ICON_STOP, ImVec2(28, 30)))  |     if (ImGui::Button(VE::style::icon::ICON_STOP, ImVec2(28, 30)))  | ||||||
|     { |     { | ||||||
|       VE::event e { test_event::TEST_EVEN , std::string("test icon button") }; |       VE::EMIT(test_event::TEST_EVEN, std::string("test icon button")); | ||||||
|       VE_EMIT(e); |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     ImGui::Text(VE::style::icon::ICON_PAINT_BRUSH, "  Paint" ); |     ImGui::Text(VE::style::icon::ICON_PAINT_BRUSH, "  Paint" ); | ||||||
|   | |||||||
| @@ -47,7 +47,6 @@ namespace sandbox | |||||||
|    |    | ||||||
|   void opengl_panel::on_attach()  |   void opengl_panel::on_attach()  | ||||||
|   { |   { | ||||||
|     VE_CONNECT(opengl_panel); |  | ||||||
|     hack::log()("on_attach"); |     hack::log()("on_attach"); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -5,7 +5,7 @@ namespace sandbox | |||||||
| { | { | ||||||
|   void test_panel::on_attach()  |   void test_panel::on_attach()  | ||||||
|   { |   { | ||||||
|     VE_CONNECT(test_panel); |     VE::CONNECT(this); | ||||||
|     hack::log()("on_attach", VE::application::get()->get_glfw()->width()); |     hack::log()("on_attach", VE::application::get()->get_glfw()->width()); | ||||||
|   } |   } | ||||||
|  |  | ||||||
| @@ -18,8 +18,7 @@ namespace sandbox | |||||||
|  |  | ||||||
|     if (ImGui::Button("RUN test_panel_1", ImVec2(128, 130)))  |     if (ImGui::Button("RUN test_panel_1", ImVec2(128, 130)))  | ||||||
|     { |     { | ||||||
|       VE::event e { test_event::TEST_EVEN , std::string("test event message tp 1") }; |       VE::EMIT(test_event::TEST_EVEN, std::string("test event message tp 1")); | ||||||
|       VE_EMIT(e); |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     ImGui::End(); |     ImGui::End(); | ||||||
|   | |||||||
| @@ -5,17 +5,21 @@ namespace sandbox | |||||||
| { | { | ||||||
|   void test_panel_2::on_attach()  |   void test_panel_2::on_attach()  | ||||||
|   { |   { | ||||||
|     VE_CONNECT(test_panel_2); |     VE::CONNECT(this); | ||||||
|  |  | ||||||
|     // ATTENTION: активировать сигнальную систему в детях-компонентах |     // ATTENTION: активировать сигнальную систему в детях-компонентах | ||||||
|     m_local_panel.on_attach(); |     m_local_panel.on_attach(); | ||||||
|  |  | ||||||
|     for (int i = 0; i < 200; ++i) |     // for (int i = 0; i < 200; ++i) | ||||||
|     { |     // { | ||||||
|  |     //   auto lp = std::make_shared<local_panel>(); | ||||||
|  |     //   lp->on_attach(); | ||||||
|  |     //   m_local_panel_hub.push_back(lp); | ||||||
|  |     // } | ||||||
|  |  | ||||||
|     auto lp = std::make_shared<local_panel>(); |     auto lp = std::make_shared<local_panel>(); | ||||||
|     lp->on_attach(); |     lp->on_attach(); | ||||||
|     m_local_panel_hub.push_back(lp); |     m_local_panel_hub.push_back(lp); | ||||||
|     } |  | ||||||
|  |  | ||||||
|     hack::log()("on_attach"); |     hack::log()("on_attach"); | ||||||
|   } |   } | ||||||
|   | |||||||
| @@ -66,4 +66,18 @@ namespace VE | |||||||
|       } |       } | ||||||
|     } |     } | ||||||
|   }; |   }; | ||||||
|  |  | ||||||
|  |   template <typename T> | ||||||
|  |   void CONNECT(T* obj)  | ||||||
|  |   { | ||||||
|  |     VE::event_manager::instance().connect(obj, &T::on_event); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   template <typename TYPE, typename DATA> | ||||||
|  |   void EMIT(TYPE t, DATA d) | ||||||
|  |   { | ||||||
|  |     VE::event_manager::instance().emit(VE::event{ t, d }); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   inline void emit() {} | ||||||
| } | } | ||||||
|   | |||||||
| @@ -113,8 +113,6 @@ namespace VE | |||||||
|   { |   { | ||||||
|     glfwSetKeyCallback(m_win, [](GLFWwindow* w, int key, int scancode, int action, int mods) |     glfwSetKeyCallback(m_win, [](GLFWwindow* w, int key, int scancode, int action, int mods) | ||||||
|     { |     { | ||||||
|       event e{ action, key }; |  | ||||||
|  |  | ||||||
|       // HERE |       // HERE | ||||||
|       // тут одноврекменно срабатывает только один сигнал |       // тут одноврекменно срабатывает только один сигнал | ||||||
|       // т.е. если нажада клавиша и удерживается сигнал о повторе идет |       // т.е. если нажада клавиша и удерживается сигнал о повторе идет | ||||||
| @@ -125,22 +123,21 @@ namespace VE | |||||||
|       { |       { | ||||||
|         case GLFW_PRESS: |         case GLFW_PRESS: | ||||||
|         { |         { | ||||||
|           e.m_type = event_type::KEY_PRESSED; |           VE::EMIT(event_type::KEY_PRESSED, key); | ||||||
|           break; |           break; | ||||||
|         } |         } | ||||||
|         case GLFW_RELEASE: |         case GLFW_RELEASE: | ||||||
|         { |         { | ||||||
|           e.m_type = event_type::KEY_RELEASED; |           VE::EMIT(event_type::KEY_RELEASED, key); | ||||||
|           break; |           break; | ||||||
|         } |         } | ||||||
| 				case GLFW_REPEAT: | 				case GLFW_REPEAT: | ||||||
| 				{ | 				{ | ||||||
|           e.m_type = event_type::KEY_REPEATE; |           VE::EMIT(event_type::KEY_REPEATE, key); | ||||||
|           break; |           break; | ||||||
| 				} | 				} | ||||||
|       } |       } | ||||||
|  |  | ||||||
|       VE_EMIT(e); |  | ||||||
|     }); |     }); | ||||||
|   } |   } | ||||||
|  |  | ||||||
| @@ -148,8 +145,6 @@ namespace VE | |||||||
|   { |   { | ||||||
| 		glfwSetMouseButtonCallback(m_win, [](GLFWwindow* w, int button, int action, int mods) | 		glfwSetMouseButtonCallback(m_win, [](GLFWwindow* w, int button, int action, int mods) | ||||||
| 		{ | 		{ | ||||||
|       event e{ action, button }; |  | ||||||
|  |  | ||||||
| 			switch (action) | 			switch (action) | ||||||
| 			{ | 			{ | ||||||
| 				case GLFW_PRESS: | 				case GLFW_PRESS: | ||||||
| @@ -159,29 +154,27 @@ namespace VE | |||||||
|           std::chrono::duration<double, std::milli> duration = local - time; |           std::chrono::duration<double, std::milli> duration = local - time; | ||||||
|  |  | ||||||
|           if (duration.count() > 10 && duration.count() < 200) |           if (duration.count() > 10 && duration.count() < 200) | ||||||
|             e.m_type = event_type::MOUSE_BUTTON_DOUBLE_PRESSED; |             VE::EMIT(event_type::MOUSE_BUTTON_DOUBLE_PRESSED, button); | ||||||
|           else |           else | ||||||
|             e.m_type = event_type::MOUSE_BUTTON_PRESSED; |             VE::EMIT(event_type::MOUSE_BUTTON_PRESSED, button); | ||||||
|  |  | ||||||
|           time = local; |           time = local; | ||||||
| 					break; | 					break; | ||||||
| 				} | 				} | ||||||
| 				case GLFW_RELEASE: | 				case GLFW_RELEASE: | ||||||
| 				{ | 				{ | ||||||
|           e.m_type = event_type::MOUSE_BUTTON_RELEASED; |           VE::EMIT(event_type::MOUSE_BUTTON_RELEASED, button); | ||||||
| 					break; | 					break; | ||||||
| 				} | 				} | ||||||
| 			} | 			} | ||||||
|  |  | ||||||
|       VE_EMIT(e); |  | ||||||
| 		}); | 		}); | ||||||
|  |  | ||||||
| 		glfwSetScrollCallback(m_win, [](GLFWwindow* w, double xOffset, double yOffset) | 		glfwSetScrollCallback(m_win, [](GLFWwindow* w, double xOffset, double yOffset) | ||||||
| 		{ | 		{ | ||||||
|       try |       try | ||||||
|       { |       { | ||||||
|         event e{ event_type::MOUSE_SCROLL, std::pair<float, float>{ static_cast<float>(xOffset), static_cast<float>(yOffset) } }; |         auto data = std::pair<float, float>{ static_cast<float>(xOffset), static_cast<float>(yOffset) }; | ||||||
|         VE_EMIT(e); |         VE::EMIT(event_type::MOUSE_SCROLL, data); | ||||||
|       } |       } | ||||||
|       catch(std::exception& e) |       catch(std::exception& e) | ||||||
|       { |       { | ||||||
| @@ -193,8 +186,8 @@ namespace VE | |||||||
| 		{ | 		{ | ||||||
|       try |       try | ||||||
|       { |       { | ||||||
|         event e{ event_type::MOUSE_CURSOR_POSITION, std::pair<float, float>{ static_cast<float>(xPos), static_cast<float>(yPos) } }; |         auto data = std::pair<float, float>{ static_cast<float>(xPos), static_cast<float>(yPos) }; | ||||||
|         VE_EMIT(e); |         VE::EMIT(event_type::MOUSE_CURSOR_POSITION, data); | ||||||
|       } |       } | ||||||
|       catch(std::exception& e) |       catch(std::exception& e) | ||||||
|       { |       { | ||||||
| @@ -215,8 +208,8 @@ namespace VE | |||||||
|  |  | ||||||
|       try |       try | ||||||
|       { |       { | ||||||
|         event e{ event_type::WINDOW_RESIZE, std::pair<float, float>{ static_cast<float>(width), static_cast<float>(height) } }; |         auto data = std::pair<float, float>{ static_cast<float>(width), static_cast<float>(height) }; | ||||||
|         VE_EMIT(e); |         VE::EMIT(event_type::WINDOW_RESIZE, data); | ||||||
|       } |       } | ||||||
|       catch(std::exception& e) |       catch(std::exception& e) | ||||||
|       { |       { | ||||||
| @@ -228,8 +221,7 @@ namespace VE | |||||||
|     { |     { | ||||||
|       try |       try | ||||||
|       { |       { | ||||||
|         event e{ event_type::WINDOW_CLOSE, nullptr }; |         VE::EMIT(event_type::WINDOW_CLOSE, nullptr); | ||||||
|         VE_EMIT(e); |  | ||||||
|       } |       } | ||||||
|       catch(std::exception& e) |       catch(std::exception& e) | ||||||
|       { |       { | ||||||
| @@ -241,8 +233,7 @@ namespace VE | |||||||
|     { |     { | ||||||
|       try |       try | ||||||
|       { |       { | ||||||
|         event e{ event_type::WINDOW_FOCUS, focused }; |         VE::EMIT(event_type::WINDOW_FOCUS, focused); | ||||||
|         VE_EMIT(e); |  | ||||||
|       } |       } | ||||||
|       catch(std::exception& e) |       catch(std::exception& e) | ||||||
|       { |       { | ||||||
|   | |||||||
| @@ -10,10 +10,6 @@ | |||||||
|     void update() override;\ |     void update() override;\ | ||||||
|     void on_event(VE::event e) override |     void on_event(VE::event e) override | ||||||
|  |  | ||||||
| #define VE_CONNECT(DEF_CLASS) VE::event_manager::instance().connect(this, &DEF_CLASS::on_event); |  | ||||||
|  |  | ||||||
| #define VE_EMIT(e) VE::event_manager::instance().emit(e) |  | ||||||
|  |  | ||||||
| #define VE_PUSH_FONT(def_font, def_size)\ | #define VE_PUSH_FONT(def_font, def_size)\ | ||||||
|   ImGui::PushFont(VE::style::fonts::get_font(VE::style::fonts::font_type::def_font, def_size))  |   ImGui::PushFont(VE::style::fonts::get_font(VE::style::fonts::font_type::def_font, def_size))  | ||||||
| #define VE_POP_FONT() ImGui::PopFont() | #define VE_POP_FONT() ImGui::PopFont() | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user