diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/ft_get_fps_count.c | 14 | ||||
-rw-r--r-- | src/ft_key_loop.c | 2 | ||||
-rw-r--r-- | src/ft_time.c | 21 |
3 files changed, 23 insertions, 14 deletions
diff --git a/src/ft_get_fps_count.c b/src/ft_get_fps_count.c index 1f717e8..990f0ea 100644 --- a/src/ft_get_fps_count.c +++ b/src/ft_get_fps_count.c @@ -17,19 +17,19 @@ #include <time.h> void - ft_get_fps_count(clock_t dt, t_cub *cl) + ft_get_fps_count(clock_t before, t_cub *cl) { - static clock_t curr_time = 0; + static clock_t dt = 0; static uint16_t ticks = 0; + clock_t curr; - curr_time += dt; + curr = clock(); + dt += curr - before; ticks += 1; - if (cl->plist.fire == 1) - ft_handle_firing(dt, cl); - if (dt > 0 && ft_clock_to_ms(curr_time) > 1000.0) + if (dt > 0 && ft_clock_to_ms(dt) > 1000.0) { ft_sprintf(cl->fps_count, "fps: %hu", ticks); ticks = 0; - curr_time -= CLOCKS_PER_SEC; + dt = 0; } } diff --git a/src/ft_key_loop.c b/src/ft_key_loop.c index 22975f8..9ca9185 100644 --- a/src/ft_key_loop.c +++ b/src/ft_key_loop.c @@ -112,6 +112,6 @@ int cl->moves = (cl->key_input[0] == -1) ? (0) : (cl->moves); begin_frame = clock(); ft_draw_scene(cl); - ft_get_fps_count(clock() - begin_frame, cl); + ft_timings(begin_frame, cl); return (0); } diff --git a/src/ft_time.c b/src/ft_time.c index 2be702d..fb0b0d2 100644 --- a/src/ft_time.c +++ b/src/ft_time.c @@ -19,19 +19,28 @@ float ft_clock_to_ms(clock_t ticks) { - return ((ticks * 1000.0) / (float)CLOCKS_PER_SEC); + return (ticks * 1000.0 / (float)CLOCKS_PER_SEC); } void - ft_handle_firing(clock_t dt, t_cub *cl) + ft_handle_firing(clock_t before, t_cub *cl) { - static clock_t curr_time = 0; + static clock_t dt = 0; + clock_t curr; - curr_time += dt; - if (dt > 0 && ft_clock_to_ms(curr_time) > 300.0) + curr = clock(); + dt += curr - before; + if (dt > 0 && ft_clock_to_ms(dt) > 700.0) { cl->plist.fire = 0; - curr_time -= CLOCKS_PER_SEC; + dt = 0; } } +void + ft_timings(clock_t before, t_cub *cl) +{ + if (cl->plist.fire == 1) + ft_handle_firing(before, cl); + ft_get_fps_count(before, cl); +} |