X-Git-Url: https://git.verplant.org/?a=blobdiff_plain;f=src%2Ftimer.cpp;h=ee63f83c9ba0b5db5226cc6ab673c69b4e932263;hb=8daad02cf03b9cef0bc47c068cf216d5971c543b;hp=5b22c139392d91b73aa14542c1532bded2c51cf8;hpb=a5123e6e7071da6d73a1ef0b19bf4acb19981605;p=supertux.git diff --git a/src/timer.cpp b/src/timer.cpp index 5b22c1393..ee63f83c9 100644 --- a/src/timer.cpp +++ b/src/timer.cpp @@ -1,159 +1,42 @@ -// $Id$ -// -// SuperTux -// Copyright (C) 2004 Tobias Glaesser -// -// This program is free software; you can redistribute it and/or -// modify it under the terms of the GNU General Public License -// as published by the Free Software Foundation; either version 2 -// of the License, or (at your option) any later version. -// -// This program is distributed in the hope that it will be useful, -// but WITHOUT ANY WARRANTY; without even the implied warranty of -// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -// GNU General Public License for more details. -// -// You should have received a copy of the GNU General Public License -// along with this program; if not, write to the Free Software -// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA -// 02111-1307, USA. +#include -#include "SDL.h" -#include "defines.h" +#include #include "timer.h" -unsigned int st_pause_ticks, st_pause_count; +float global_time = 0; -unsigned int st_get_ticks(void) +Timer2::Timer2() + : period(0), cycle_start(0), cyclic(false) { - if(st_pause_count != 0) - return /*SDL_GetTicks()*/ - st_pause_ticks /*- SDL_GetTicks()*/ + st_pause_count; - else - return SDL_GetTicks() - st_pause_ticks; } -void st_pause_ticks_init(void) +Timer2::~Timer2() { - st_pause_ticks = 0; - st_pause_count = 0; -} - -void st_pause_ticks_start(void) -{ - if(st_pause_count == 0) - st_pause_count = SDL_GetTicks(); -} - -void st_pause_ticks_stop(void) -{ -if(st_pause_count == 0) -return; - - st_pause_ticks += SDL_GetTicks() - st_pause_count; - st_pause_count = 0; -} - -Timer::Timer() -{ - init(true); } void -Timer::init(bool st_ticks) +Timer2::start(float period, bool cyclic) { - period = 0; - time = 0; - get_ticks = st_ticks ? st_get_ticks : SDL_GetTicks; + this->period = period; + this->cyclic = cyclic; + cycle_start = global_time; } -void -Timer::start(unsigned int period_) +bool +Timer2::check() { - time = get_ticks(); - period = period_; -} - -void -Timer::stop() -{ - if(get_ticks == st_get_ticks) - init(true); - else - init(false); -} - -int -Timer::check() -{ - if((time != 0) && (time + period > get_ticks())) - return true; - else - { - time = 0; - return false; + if(period == 0) + return false; + + if(global_time - cycle_start >= period) { + if(cyclic) { + cycle_start = global_time - fmodf(global_time - cycle_start, period); + } else { + period = 0; } -} - -int -Timer::started() -{ - if(time != 0) return true; - else - return false; -} - -int -Timer::get_left() -{ - return (period - (get_ticks() - time)); -} - -int -Timer::get_gone() -{ - return (get_ticks() - time); -} - -void -Timer::fwrite(FILE* fi) -{ - unsigned int diff_ticks; - int tick_mode; - if(time != 0) - diff_ticks = get_ticks() - time; - else - diff_ticks = 0; - - ::fwrite(&period,sizeof(unsigned int),1,fi); - ::fwrite(&diff_ticks,sizeof(unsigned int),1,fi); - if(get_ticks == st_get_ticks) - tick_mode = true; - else - tick_mode = false; - ::fwrite(&tick_mode,sizeof(unsigned int),1,fi); -} - -void -Timer::fread(FILE* fi) -{ - unsigned int diff_ticks; - int tick_mode; - - ::fread(&period,sizeof(unsigned int),1,fi); - ::fread(&diff_ticks,sizeof(unsigned int),1,fi); - ::fread(&tick_mode,sizeof(unsigned int),1,fi); - - if (tick_mode) - get_ticks = st_get_ticks; - else - get_ticks = SDL_GetTicks; - - if (diff_ticks != 0) - time = get_ticks() - diff_ticks; - else - time = 0; + } + return false; } -/* EOF */