mirror of
https://github.com/seekrs/MacroLibX.git
synced 2026-01-12 15:13:34 +00:00
fixing performance issue in text pipeline, working on event system
This commit is contained in:
@@ -6,7 +6,7 @@
|
||||
/* By: maldavid <kbz_8.dev@akel-engine.com> +#+ +:+ +#+ */
|
||||
/* +#+#+#+#+#+ +#+ */
|
||||
/* Created: 2022/10/05 16:30:19 by maldavid #+# #+# */
|
||||
/* Updated: 2023/04/11 21:32:43 by maldavid ### ########.fr */
|
||||
/* Updated: 2023/04/12 11:31:28 by maldavid ### ########.fr */
|
||||
/* */
|
||||
/* ************************************************************************** */
|
||||
|
||||
@@ -39,28 +39,43 @@ namespace mlx
|
||||
case SDL_KEYDOWN:
|
||||
{
|
||||
_keys[_event.key.keysym.scancode] = static_cast<uint8_t>(action::down);
|
||||
if(_events_hooks[0].hook)
|
||||
_events_hooks[0].hook(_event.key.keysym.scancode, _events_hooks[0].param);
|
||||
break;
|
||||
}
|
||||
|
||||
case SDL_KEYUP:
|
||||
{
|
||||
_keys[_event.key.keysym.scancode] = static_cast<uint8_t>(action::up);
|
||||
if(_key_hook.hook)
|
||||
_key_hook.hook(SDL_GetScancodeName(_event.key.keysym.scancode), _key_hook.param);
|
||||
if(_events_hooks[1].hook)
|
||||
_events_hooks[1].hook(_event.key.keysym.scancode, _events_hooks[1].param);
|
||||
break;
|
||||
}
|
||||
|
||||
case SDL_MOUSEBUTTONDOWN:
|
||||
{
|
||||
_mouse[_event.button.button] = static_cast<uint8_t>(action::down);
|
||||
if(_events_hooks[2].hook)
|
||||
_events_hooks[2].hook(_event.button.button, _events_hooks[2].param);
|
||||
break;
|
||||
}
|
||||
|
||||
case SDL_MOUSEBUTTONUP:
|
||||
{
|
||||
_mouse[_event.button.button] = static_cast<uint8_t>(action::up);
|
||||
if(_mouse_hook.hook)
|
||||
_mouse_hook.hook(std::string("mouse").c_str(), _mouse_hook.param);
|
||||
if(_events_hooks[3].hook)
|
||||
_events_hooks[3].hook(_event.button.button, _events_hooks[3].param);
|
||||
break;
|
||||
}
|
||||
|
||||
case SDL_WINDOWEVENT:
|
||||
{
|
||||
switch(_event.window.event)
|
||||
{
|
||||
//case
|
||||
|
||||
default : break;
|
||||
}
|
||||
break;
|
||||
}
|
||||
|
||||
|
||||
@@ -6,7 +6,7 @@
|
||||
/* By: maldavid <kbz_8.dev@akel-engine.com> +#+ +:+ +#+ */
|
||||
/* +#+#+#+#+#+ +#+ */
|
||||
/* Created: 2022/10/05 16:27:35 by maldavid #+# #+# */
|
||||
/* Updated: 2023/04/11 21:41:33 by maldavid ### ########.fr */
|
||||
/* Updated: 2023/04/12 13:47:02 by maldavid ### ########.fr */
|
||||
/* */
|
||||
/* ************************************************************************** */
|
||||
|
||||
@@ -25,7 +25,7 @@ namespace mlx
|
||||
|
||||
struct Hook
|
||||
{
|
||||
std::function<int(const char*, void*)> hook;
|
||||
std::function<int(int, void*)> hook;
|
||||
void* param = nullptr;
|
||||
};
|
||||
|
||||
@@ -53,9 +53,11 @@ namespace mlx
|
||||
inline constexpr void enableAutoRepeat() noexcept { _auto_repeat = true; }
|
||||
inline constexpr void disableAutoRepeat() noexcept { _auto_repeat = false; }
|
||||
|
||||
inline void mouseHook(int (*funct_ptr)(const char*, void*), void* param) noexcept { _mouse_hook.hook = funct_ptr; _mouse_hook.param = param; }
|
||||
inline void keyHook(int (*funct_ptr)(const char*, void*), void* param) noexcept { _key_hook.hook = funct_ptr; _key_hook.param = param; }
|
||||
inline void exposeHook(int (*funct_ptr)(const char*, void*), void* param) noexcept { _expose_hook.hook = funct_ptr; _expose_hook.param = param; }
|
||||
inline void onEvent(int event, int (*funct_ptr)(int, void*), void* param) noexcept
|
||||
{
|
||||
_events_hooks[event].hook = funct_ptr;
|
||||
_events_hooks[event].param = param;
|
||||
}
|
||||
|
||||
~Input() = default;
|
||||
|
||||
@@ -63,10 +65,9 @@ namespace mlx
|
||||
std::array<uint8_t, SDL_NUM_SCANCODES> _keys;
|
||||
SDL_Event _event;
|
||||
std::array<uint8_t, 8> _mouse;
|
||||
std::vector<class* MLX_Window> _window;
|
||||
|
||||
Hook _mouse_hook;
|
||||
Hook _key_hook;
|
||||
Hook _expose_hook;
|
||||
std::array<Hook, 5> _events_hooks;
|
||||
|
||||
int _x = 0;
|
||||
int _y = 0;
|
||||
|
||||
Reference in New Issue
Block a user