mirror of
https://github.com/seekrs/MacroLibX.git
synced 2026-01-11 22:53:34 +00:00
adding SDL initialisation and quit, improving inputs code readability
This commit is contained in:
@@ -6,7 +6,7 @@
|
|||||||
/* By: maldavid <kbz_8.dev@akel-engine.com> +#+ +:+ +#+ */
|
/* By: maldavid <kbz_8.dev@akel-engine.com> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2022/10/04 22:10:52 by maldavid #+# #+# */
|
/* Created: 2022/10/04 22:10:52 by maldavid #+# #+# */
|
||||||
/* Updated: 2023/04/25 15:12:57 by maldavid ### ########.fr */
|
/* Updated: 2023/08/28 10:19:53 by maldavid ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
@@ -14,10 +14,17 @@
|
|||||||
#include <renderer/images/texture.h>
|
#include <renderer/images/texture.h>
|
||||||
#include <renderer/core/render_core.h>
|
#include <renderer/core/render_core.h>
|
||||||
#include <array>
|
#include <array>
|
||||||
|
#include <core/errors.h>
|
||||||
#include <utils/endian.h>
|
#include <utils/endian.h>
|
||||||
|
|
||||||
namespace mlx::core
|
namespace mlx::core
|
||||||
{
|
{
|
||||||
|
Application::Application() : _in(std::make_unique<Input>())
|
||||||
|
{
|
||||||
|
if(SDL_Init(SDL_INIT_VIDEO | SDL_INIT_EVENTS | SDL_INIT_TIMER) != 0)
|
||||||
|
error::report(e_kind::fatal_error, "SDL error : unable to init all subsystems : %s", SDL_GetError());
|
||||||
|
}
|
||||||
|
|
||||||
void Application::run() noexcept
|
void Application::run() noexcept
|
||||||
{
|
{
|
||||||
while(_in->is_running())
|
while(_in->is_running())
|
||||||
@@ -52,4 +59,9 @@ namespace mlx::core
|
|||||||
Texture* texture = static_cast<Texture*>(ptr);
|
Texture* texture = static_cast<Texture*>(ptr);
|
||||||
texture->destroy();
|
texture->destroy();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Application::~Application()
|
||||||
|
{
|
||||||
|
SDL_Quit();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -6,7 +6,7 @@
|
|||||||
/* By: maldavid <kbz_8.dev@akel-engine.com> +#+ +:+ +#+ */
|
/* By: maldavid <kbz_8.dev@akel-engine.com> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2022/10/04 21:49:46 by maldavid #+# #+# */
|
/* Created: 2022/10/04 21:49:46 by maldavid #+# #+# */
|
||||||
/* Updated: 2023/04/25 15:23:31 by maldavid ### ########.fr */
|
/* Updated: 2023/08/28 10:19:35 by maldavid ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
@@ -30,7 +30,7 @@ namespace mlx::core
|
|||||||
class Application
|
class Application
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
Application() : _in(std::make_unique<Input>()) {}
|
Application();
|
||||||
|
|
||||||
inline void getMousePos(int* x, int* y) noexcept;
|
inline void getMousePos(int* x, int* y) noexcept;
|
||||||
inline void mouseMove(void* win, int x, int y) noexcept;
|
inline void mouseMove(void* win, int x, int y) noexcept;
|
||||||
@@ -58,7 +58,7 @@ namespace mlx::core
|
|||||||
|
|
||||||
void run() noexcept;
|
void run() noexcept;
|
||||||
|
|
||||||
~Application() = default;
|
~Application();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
std::list<Texture> _textures;
|
std::list<Texture> _textures;
|
||||||
|
|||||||
@@ -6,11 +6,12 @@
|
|||||||
/* By: maldavid <kbz_8.dev@akel-engine.com> +#+ +:+ +#+ */
|
/* By: maldavid <kbz_8.dev@akel-engine.com> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2022/10/05 16:30:19 by maldavid #+# #+# */
|
/* Created: 2022/10/05 16:30:19 by maldavid #+# #+# */
|
||||||
/* Updated: 2023/04/19 12:14:38 by maldavid ### ########.fr */
|
/* Updated: 2023/08/28 10:49:03 by maldavid ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
#include "inputs.h"
|
#include "inputs.h"
|
||||||
|
#include <mlx.h>
|
||||||
#include <cstring>
|
#include <cstring>
|
||||||
|
|
||||||
namespace mlx
|
namespace mlx
|
||||||
@@ -40,91 +41,93 @@ namespace mlx
|
|||||||
uint32_t id = _event.window.windowID;
|
uint32_t id = _event.window.windowID;
|
||||||
if(!_events_hooks.count(id))
|
if(!_events_hooks.count(id))
|
||||||
continue;
|
continue;
|
||||||
|
auto& hooks = _events_hooks[id];
|
||||||
|
|
||||||
switch(_event.type)
|
switch(_event.type)
|
||||||
{
|
{
|
||||||
case SDL_KEYDOWN:
|
case SDL_KEYDOWN:
|
||||||
{
|
{
|
||||||
_keys[_event.key.keysym.scancode] = static_cast<uint8_t>(action::down);
|
_keys[_event.key.keysym.scancode] = static_cast<uint8_t>(action::down);
|
||||||
if(_events_hooks[id][0].hook)
|
if(hooks[MLX_KEYDOWN].hook)
|
||||||
_events_hooks[id][0].hook(_event.key.keysym.scancode, _events_hooks[id][0].param);
|
hooks[MLX_KEYDOWN].hook(_event.key.keysym.scancode, hooks[MLX_KEYDOWN].param);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
case SDL_KEYUP:
|
case SDL_KEYUP:
|
||||||
{
|
{
|
||||||
_keys[_event.key.keysym.scancode] = static_cast<uint8_t>(action::up);
|
_keys[_event.key.keysym.scancode] = static_cast<uint8_t>(action::up);
|
||||||
if(_events_hooks[id][1].hook)
|
if(hooks[MLX_KEYUP].hook)
|
||||||
_events_hooks[id][1].hook(_event.key.keysym.scancode, _events_hooks[id][1].param);
|
hooks[MLX_KEYUP].hook(_event.key.keysym.scancode, hooks[MLX_KEYUP].param);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
case SDL_MOUSEBUTTONDOWN:
|
case SDL_MOUSEBUTTONDOWN:
|
||||||
{
|
{
|
||||||
_mouse[_event.button.button] = static_cast<uint8_t>(action::down);
|
_mouse[_event.button.button] = static_cast<uint8_t>(action::down);
|
||||||
if(_events_hooks[id][2].hook)
|
if(hooks[MLX_MOUSEDOWN].hook)
|
||||||
_events_hooks[id][2].hook(_event.button.button, _events_hooks[id][2].param);
|
hooks[MLX_MOUSEDOWN].hook(_event.button.button, hooks[MLX_MOUSEDOWN].param);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
case SDL_MOUSEBUTTONUP:
|
case SDL_MOUSEBUTTONUP:
|
||||||
{
|
{
|
||||||
_mouse[_event.button.button] = static_cast<uint8_t>(action::up);
|
_mouse[_event.button.button] = static_cast<uint8_t>(action::up);
|
||||||
if(_events_hooks[id][3].hook)
|
if(hooks[MLX_MOUSEUP].hook)
|
||||||
_events_hooks[id][3].hook(_event.button.button, _events_hooks[id][3].param);
|
hooks[MLX_MOUSEUP].hook(_event.button.button, hooks[MLX_MOUSEUP].param);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
case SDL_WINDOWEVENT:
|
case SDL_WINDOWEVENT:
|
||||||
{
|
{
|
||||||
|
auto& win_hook = hooks[MLX_WINDOW_EVENT];
|
||||||
switch(_event.window.event)
|
switch(_event.window.event)
|
||||||
{
|
{
|
||||||
case SDL_WINDOWEVENT_CLOSE:
|
case SDL_WINDOWEVENT_CLOSE:
|
||||||
{
|
{
|
||||||
if(_events_hooks[id][4].hook)
|
if(win_hook.hook)
|
||||||
_events_hooks[id][4].hook(0, _events_hooks[id][4].param);
|
win_hook.hook(0, win_hook.param);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case SDL_WINDOWEVENT_MOVED:
|
case SDL_WINDOWEVENT_MOVED:
|
||||||
{
|
{
|
||||||
if(_events_hooks[id][4].hook)
|
if(win_hook.hook)
|
||||||
_events_hooks[id][4].hook(1, _events_hooks[id][4].param);
|
win_hook.hook(1, win_hook.param);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case SDL_WINDOWEVENT_MINIMIZED:
|
case SDL_WINDOWEVENT_MINIMIZED:
|
||||||
{
|
{
|
||||||
if(_events_hooks[id][4].hook)
|
if(win_hook.hook)
|
||||||
_events_hooks[id][4].hook(2, _events_hooks[id][4].param);
|
win_hook.hook(2, win_hook.param);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case SDL_WINDOWEVENT_MAXIMIZED:
|
case SDL_WINDOWEVENT_MAXIMIZED:
|
||||||
{
|
{
|
||||||
if(_events_hooks[id][4].hook)
|
if(win_hook.hook)
|
||||||
_events_hooks[id][4].hook(3, _events_hooks[id][4].param);
|
win_hook.hook(3, win_hook.param);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case SDL_WINDOWEVENT_ENTER:
|
case SDL_WINDOWEVENT_ENTER:
|
||||||
{
|
{
|
||||||
if(_events_hooks[id][4].hook)
|
if(win_hook.hook)
|
||||||
_events_hooks[id][4].hook(4, _events_hooks[id][4].param);
|
win_hook.hook(4, win_hook.param);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case SDL_WINDOWEVENT_FOCUS_GAINED:
|
case SDL_WINDOWEVENT_FOCUS_GAINED:
|
||||||
{
|
{
|
||||||
if(_events_hooks[id][4].hook)
|
if(win_hook.hook)
|
||||||
_events_hooks[id][4].hook(4, _events_hooks[id][4].param);
|
win_hook.hook(4, win_hook.param);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case SDL_WINDOWEVENT_LEAVE:
|
case SDL_WINDOWEVENT_LEAVE:
|
||||||
{
|
{
|
||||||
if(_events_hooks[id][4].hook)
|
if(win_hook.hook)
|
||||||
_events_hooks[id][4].hook(5, _events_hooks[id][4].param);
|
win_hook.hook(5, win_hook.param);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case SDL_WINDOWEVENT_FOCUS_LOST:
|
case SDL_WINDOWEVENT_FOCUS_LOST:
|
||||||
{
|
{
|
||||||
if(_events_hooks[id][4].hook)
|
if(win_hook.hook)
|
||||||
_events_hooks[id][4].hook(4, _events_hooks[id][4].param);
|
win_hook.hook(4, win_hook.param);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -1,59 +0,0 @@
|
|||||||
run
|
|
||||||
a
|
|
||||||
q
|
|
||||||
run
|
|
||||||
bt
|
|
||||||
q
|
|
||||||
run
|
|
||||||
a
|
|
||||||
q
|
|
||||||
run
|
|
||||||
bt
|
|
||||||
a
|
|
||||||
y
|
|
||||||
q
|
|
||||||
run
|
|
||||||
p (i / 400) * 100
|
|
||||||
q
|
|
||||||
run
|
|
||||||
bt
|
|
||||||
q
|
|
||||||
run
|
|
||||||
bt
|
|
||||||
q
|
|
||||||
b create_image
|
|
||||||
run
|
|
||||||
tui n
|
|
||||||
n
|
|
||||||
n
|
|
||||||
n
|
|
||||||
n
|
|
||||||
n
|
|
||||||
n
|
|
||||||
n
|
|
||||||
n
|
|
||||||
s
|
|
||||||
n
|
|
||||||
n
|
|
||||||
s
|
|
||||||
s
|
|
||||||
n
|
|
||||||
n
|
|
||||||
n
|
|
||||||
n
|
|
||||||
n
|
|
||||||
n
|
|
||||||
n
|
|
||||||
n
|
|
||||||
n
|
|
||||||
n
|
|
||||||
n
|
|
||||||
n
|
|
||||||
n
|
|
||||||
n
|
|
||||||
n
|
|
||||||
n
|
|
||||||
n
|
|
||||||
s
|
|
||||||
s
|
|
||||||
q
|
|
||||||
@@ -6,7 +6,7 @@
|
|||||||
/* By: maldavid <kbz_8.dev@akel-engine.com> +#+ +:+ +#+ */
|
/* By: maldavid <kbz_8.dev@akel-engine.com> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2022/10/04 17:55:21 by maldavid #+# #+# */
|
/* Created: 2022/10/04 17:55:21 by maldavid #+# #+# */
|
||||||
/* Updated: 2023/08/02 12:36:11 by maldavid ### ########.fr */
|
/* Updated: 2023/08/28 10:52:33 by maldavid ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user