diff options
Diffstat (limited to 'src/graphic')
| -rw-r--r-- | src/graphic/event.c | 72 | ||||
| -rw-r--r-- | src/graphic/state.c | 82 |
2 files changed, 154 insertions, 0 deletions
diff --git a/src/graphic/event.c b/src/graphic/event.c new file mode 100644 index 0000000..c5986d4 --- /dev/null +++ b/src/graphic/event.c @@ -0,0 +1,72 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* event.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: charles <charles.cabergs@gmail.com> +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2020/05/14 15:25:52 by charles #+# #+# */ +/* Updated: 2020/05/14 16:39:13 by charles ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "scop.h" + +static void st_handle_keydown(t_state *state, SDL_Keycode sym) +{ + if (sym == SDLK_ESCAPE) + state->running = false; + else if (sym == SDLK_p) + { + if (state->polygon_mode == GL_FILL) + state->polygon_mode = GL_LINE; + else if (state->polygon_mode == GL_LINE) + state->polygon_mode = GL_POINT; + else if (state->polygon_mode == GL_POINT) + state->polygon_mode = GL_FILL; + GL_CALL(glPolygonMode(GL_FRONT_AND_BACK, state->polygon_mode)); + } +} + +static void st_handle_mousewheel(t_state *state, int y) +{ + if (y > 0) + { + state->fov -= M_PI / 70.0f; + if (state->fov <= M_PI_4 / 3) + state->fov = M_PI_4 / 3; + } + else if (y < 0) + { + state->fov += M_PI / 70.0f; + if (state->fov >= M_PI - M_PI_4 / 3) + state->fov = M_PI - M_PI_4 / 3; + } + scene_update_proj(&state->scene, state->fov, state->width, state->height); +} + +void event_handle(t_state *state) +{ + SDL_Event e; + + while (SDL_PollEvent(&e)) + { + if (e.type == SDL_QUIT) + state->running = false; + else if (e.type == SDL_KEYDOWN) + st_handle_keydown(state, e.key.keysym.sym); + else if (e.type == SDL_MOUSEWHEEL) + st_handle_mousewheel(state, e.wheel.y); + else if (e.type == SDL_WINDOWEVENT) + { + if (e.window.event == SDL_WINDOWEVENT_RESIZED) + { + SDL_GL_GetDrawableSize( + state->window, &state->width, &state->height); + scene_update_proj(&state->scene, state->fov, + state->width, state->height); + glViewport(0, 0, state->width, state->height); + } + } + } +} diff --git a/src/graphic/state.c b/src/graphic/state.c new file mode 100644 index 0000000..c3aaa8e --- /dev/null +++ b/src/graphic/state.c @@ -0,0 +1,82 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* state.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: charles <charles.cabergs@gmail.com> +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2020/05/11 01:31:10 by charles #+# #+# */ +/* Updated: 2020/05/14 16:39:59 by charles ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "scop.h" + +bool state_init(t_state *state, t_model_data *data) +{ + if (SDL_Init(SDL_INIT_VIDEO) < 0) + return (false); + SDL_GL_SetAttribute(SDL_GL_CONTEXT_MAJOR_VERSION, 4); + SDL_GL_SetAttribute(SDL_GL_CONTEXT_MINOR_VERSION, 0); + SDL_GL_SetAttribute(SDL_GL_CONTEXT_PROFILE_MASK, SDL_GL_CONTEXT_PROFILE_CORE); + SDL_GL_SetAttribute(SDL_GL_DOUBLEBUFFER, 1); + state->window = SDL_CreateWindow( + "scop", SDL_WINDOWPOS_UNDEFINED, SDL_WINDOWPOS_UNDEFINED, + WINDOW_WIDTH, WINDOW_HEIGHT, SDL_WINDOW_OPENGL | SDL_WINDOW_RESIZABLE); + if (state->window == NULL) + return (false); + state->context = SDL_GL_CreateContext(state->window); + if (glewInit() != GLEW_OK) + return (false); + SDL_GL_SetSwapInterval(1); + GL_CALL(glEnable(GL_DEPTH_TEST)); + + if (!shader_init(&state->shader) + || (state->scene.texture = texture_create(data->texture_filepath)) == 0) + return (false); + scene_init(&state->scene, data); + + state->fov = M_PI_4; + state->running = true; + state->polygon_mode = GL_FILL; + SDL_GL_GetDrawableSize(state->window, &state->width, &state->height); + GL_CALL(glViewport(0, 0, state->width, state->height)); + return (true); +} + +void state_run(t_state *state) +{ + float rotation; + + scene_update_model(&state->scene, M_PI_4); + scene_update_proj(&state->scene, M_PI_4, state->width, state->height); + rotation = M_PI_4; + while (state->running) + { + GL_CALL(glClearColor(0.1f, 0.1f, 0.1f, 1.0f)); + GL_CALL(glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT)); + + GL_CALL(glUseProgram(state->shader.id)); + GL_CALL(glActiveTexture(GL_TEXTURE0)); + GL_CALL(glBindTexture(GL_TEXTURE_2D, state->scene.texture)); + shader_set_uniforms(&state->shader, &state->scene); + + GL_CALL(glBindVertexArray(state->scene.vertex_array)); + GL_CALL(glDrawElements(GL_TRIANGLES, + state->scene.index_buf_num, GL_UNSIGNED_INT, (void*)0)); + + scene_update_model(&state->scene, rotation); + SDL_GL_SwapWindow(state->window); + event_handle(state); + rotation += M_PI / 250.0; + } +} + +void state_quit(t_state *state) +{ + scene_quit(&state->scene); + GL_CALL(glDeleteProgram(state->shader.id)); + SDL_GL_DeleteContext(state->context); + SDL_DestroyWindow(state->window); + SDL_Quit(); +} |
