2009-01-27 13:23:36 +00:00
|
|
|
// Copyright (C) 2002-2009 Nikolaus Gebhardt
|
2007-05-20 18:03:49 +00:00
|
|
|
// This file is part of the "Irrlicht Engine".
|
|
|
|
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
|
|
|
|
|
|
|
#ifndef __I_TIMER_H_INCLUDED__
|
|
|
|
#define __I_TIMER_H_INCLUDED__
|
|
|
|
|
2007-09-07 06:11:47 +00:00
|
|
|
#include "IReferenceCounted.h"
|
2007-05-20 18:03:49 +00:00
|
|
|
|
|
|
|
namespace irr
|
|
|
|
{
|
|
|
|
|
|
|
|
//! Interface for getting and manipulating the virtual time
|
2007-09-07 06:11:47 +00:00
|
|
|
class ITimer : public virtual IReferenceCounted
|
2007-05-20 18:03:49 +00:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
|
|
|
|
//! destructor
|
|
|
|
virtual ~ITimer() {}
|
|
|
|
|
2008-05-22 11:51:37 +00:00
|
|
|
//! Returns current real time in milliseconds of the system.
|
2007-05-20 18:03:49 +00:00
|
|
|
/** This value does not start with 0 when the application starts.
|
2008-05-22 11:51:37 +00:00
|
|
|
For example in one implementation the value returned could be the
|
|
|
|
amount of milliseconds which have elapsed since the system was started.
|
|
|
|
*/
|
2007-09-17 16:09:50 +00:00
|
|
|
virtual u32 getRealTime() const = 0;
|
2007-05-20 18:03:49 +00:00
|
|
|
|
2008-05-22 11:51:37 +00:00
|
|
|
//! Returns current virtual time in milliseconds.
|
|
|
|
/** This value starts with 0 and can be manipulated using setTime(),
|
|
|
|
stopTimer(), startTimer(), etc. This value depends on the set speed of
|
|
|
|
the timer if the timer is stopped, etc. If you need the system time,
|
|
|
|
use getRealTime() */
|
2007-09-17 16:09:50 +00:00
|
|
|
virtual u32 getTime() const = 0;
|
2007-05-20 18:03:49 +00:00
|
|
|
|
|
|
|
//! sets current virtual time
|
|
|
|
virtual void setTime(u32 time) = 0;
|
|
|
|
|
2008-05-22 11:51:37 +00:00
|
|
|
//! Stops the virtual timer.
|
|
|
|
/** The timer is reference counted, which means everything which calls
|
|
|
|
stop() will also have to call start(), otherwise the timer may not
|
|
|
|
start/stop correctly again. */
|
2007-05-20 18:03:49 +00:00
|
|
|
virtual void stop() = 0;
|
|
|
|
|
|
|
|
//! Starts the virtual timer.
|
2008-05-22 11:51:37 +00:00
|
|
|
/** The timer is reference counted, which means everything which calls
|
|
|
|
stop() will also have to call start(), otherwise the timer may not
|
|
|
|
start/stop correctly again. */
|
2007-05-20 18:03:49 +00:00
|
|
|
virtual void start() = 0;
|
|
|
|
|
|
|
|
//! Sets the speed of the timer
|
2008-05-22 11:51:37 +00:00
|
|
|
/** The speed is the factor with which the time is running faster or
|
|
|
|
slower then the real system time. */
|
2007-05-20 18:03:49 +00:00
|
|
|
virtual void setSpeed(f32 speed = 1.0f) = 0;
|
|
|
|
|
|
|
|
//! Returns current speed of the timer
|
2008-05-22 11:51:37 +00:00
|
|
|
/** The speed is the factor with which the time is running faster or
|
|
|
|
slower then the real system time. */
|
2007-09-17 16:09:50 +00:00
|
|
|
virtual f32 getSpeed() const = 0;
|
2007-05-20 18:03:49 +00:00
|
|
|
|
|
|
|
//! Returns if the virtual timer is currently stopped
|
2007-09-17 16:09:50 +00:00
|
|
|
virtual bool isStopped() const = 0;
|
2007-05-20 18:03:49 +00:00
|
|
|
|
|
|
|
//! Advances the virtual time
|
|
|
|
/** Makes the virtual timer update the time value based on the real
|
|
|
|
time. This is called automatically when calling IrrlichtDevice::run(),
|
|
|
|
but you can call it manually if you don't use this method. */
|
|
|
|
virtual void tick() = 0;
|
|
|
|
};
|
|
|
|
|
|
|
|
} // end namespace irr
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|