2002-07-17 04:07:32 +08:00
|
|
|
//C++ header - Open Scene Graph - Copyright (C) 1998-2002 Robert Osfield
|
2001-10-04 23:12:57 +08:00
|
|
|
//Distributed under the terms of the GNU Library General Public License (LGPL)
|
|
|
|
//as published by the Free Software Foundation.
|
|
|
|
|
2001-09-20 07:52:12 +08:00
|
|
|
#ifndef OSG_FRAMESTAMP
|
|
|
|
#define OSG_FRAMESTAMP 1
|
|
|
|
|
|
|
|
#include <osg/Referenced>
|
|
|
|
|
2002-02-23 07:39:42 +08:00
|
|
|
#if defined(__sgi) || (defined(WIN32) && !defined(__MWERKS__))
|
2001-10-15 23:50:55 +08:00
|
|
|
#include <time.h>
|
|
|
|
#else
|
2001-09-20 07:52:12 +08:00
|
|
|
#include <ctime>
|
2001-10-15 23:50:55 +08:00
|
|
|
using std::tm;
|
|
|
|
#endif
|
2001-09-20 07:52:12 +08:00
|
|
|
|
|
|
|
namespace osg
|
|
|
|
{
|
|
|
|
|
|
|
|
/** Class which encapsulates the frame number, reference time and calander
|
|
|
|
* time of specific frame, used to synchonize operations on the scene graph
|
|
|
|
* and other machines when using a graphics cluster. Note the calander
|
|
|
|
* time can be an artificial simulation time or capture the real time
|
|
|
|
* of day etc.*/
|
|
|
|
class SG_EXPORT FrameStamp : public Referenced
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
|
|
|
|
FrameStamp();
|
|
|
|
FrameStamp(const FrameStamp& fs);
|
|
|
|
|
|
|
|
FrameStamp& operator = (const FrameStamp& fs);
|
|
|
|
|
|
|
|
void setFrameNumber(int fnum) { _frameNumber = fnum; }
|
|
|
|
int getFrameNumber() const { return _frameNumber; }
|
|
|
|
|
|
|
|
void setReferenceTime(double refTime) { _referenceTime = refTime; }
|
|
|
|
double getReferenceTime() const { return _referenceTime; }
|
|
|
|
|
2002-05-23 03:58:43 +08:00
|
|
|
void setCalendarTime(const tm& calendarTime);
|
|
|
|
void getCalendarTime(tm& calendarTime) const;
|
2003-01-10 17:25:42 +08:00
|
|
|
|
|
|
|
// keep public to allow it to be permit allocation which is
|
|
|
|
// not on the heap used osgcluster
|
|
|
|
virtual ~FrameStamp();
|
|
|
|
|
2001-09-20 07:52:12 +08:00
|
|
|
protected:
|
|
|
|
|
2003-01-10 17:25:42 +08:00
|
|
|
|
2001-09-20 07:52:12 +08:00
|
|
|
// note no dynamic memory is used so that data can be passed
|
|
|
|
// via a simple memory copy or within a data packet across
|
|
|
|
// the network.
|
|
|
|
|
|
|
|
int _frameNumber;
|
|
|
|
double _referenceTime;
|
|
|
|
|
|
|
|
|
|
|
|
// member varaibles of time.h's tm structure, copied here to
|
|
|
|
// ensure that all data is no dynamic. The tm structure itself
|
|
|
|
// is not completely consistent betweem implementations, which
|
|
|
|
// could be a problem when sending the FrameStamp across a network
|
|
|
|
// with differnt versions of tm (i.e mixing Unix and Windows.)
|
|
|
|
int tm_sec; /* Seconds. [0-60] (1 leap second) */
|
|
|
|
int tm_min; /* Minutes. [0-59] */
|
|
|
|
int tm_hour; /* Hours. [0-23] */
|
|
|
|
int tm_mday; /* Day. [1-31] */
|
|
|
|
int tm_mon; /* Month. [0-11] */
|
|
|
|
int tm_year; /* Year - 1900. */
|
|
|
|
int tm_wday; /* Day of week. [0-6] */
|
|
|
|
int tm_yday; /* Days in year. [0-365] */
|
|
|
|
int tm_isdst; /* DST. [-1/0/1]*/
|
|
|
|
|
|
|
|
|
|
|
|
};
|
|
|
|
|
2002-02-03 20:33:41 +08:00
|
|
|
}
|
2001-09-20 07:52:12 +08:00
|
|
|
|
|
|
|
|
|
|
|
#endif
|