Space cleanup pass on the headers

git-svn-id: svn+ssh://svn.code.sf.net/p/supertuxkart/code/main/trunk@12817 178a84e3-b1eb-0310-8ba1-8eac791a3b58
This commit is contained in:
curaga 2013-05-30 19:47:39 +00:00
parent c5bb98d1e4
commit 57c3cbae3e
215 changed files with 2591 additions and 2591 deletions

View File

@ -60,7 +60,7 @@ public:
// ------------------------------------------------------------------------
/** A static function that checks if the given ID is an addon. This is
* done by testing if the directory name is in the addons directory.
* done by testing if the directory name is in the addons directory.
*/
static bool isAddon(const std::string &directory)
{
@ -131,7 +131,7 @@ public:
/** Initialises the object from an XML node. */
Addon(const XMLNode &xml);
// ------------------------------------------------------------------------
/** Sets the sort order used in the comparison function. It is static, so
/** Sets the sort order used in the comparison function. It is static, so
* that each instance can access the sort order. */
static void setSortOrder(SortOrder so) { m_sort_order = so; }
// ------------------------------------------------------------------------
@ -166,7 +166,7 @@ public:
/** Returns the name of the addon. */
const core::stringw& getDescription() const { return m_description; }
// ------------------------------------------------------------------------
/** Returns the date (in seconds since epoch) when the addon was
/** Returns the date (in seconds since epoch) when the addon was
* uploaded. */
Time::TimeType getDate() const { return m_date; }
// ------------------------------------------------------------------------
@ -179,8 +179,8 @@ public:
/** Returns the installed revision number of an addon. */
int getInstalledRevision() const { return m_installed_revision; }
// ------------------------------------------------------------------------
/** Returns the latest revision number of this addon.
* m_revision>m_installed_revision if a newer revision is available
/** Returns the latest revision number of this addon.
* m_revision>m_installed_revision if a newer revision is available
* online. */
int getRevision() const { return m_revision; }
// ------------------------------------------------------------------------
@ -212,7 +212,7 @@ public:
} // iconNeedsUpdate
// ------------------------------------------------------------------------
/** Marks this addon to be installed. If the addon is marked as being
* installed, it also updates the installed revision number to be the
* installed, it also updates the installed revision number to be the
* same as currently available revision number. */
void setInstalled(bool state)
{
@ -221,28 +221,28 @@ public:
m_installed_revision = m_revision;
} // setInstalled
// ------------------------------------------------------------------------
/** Returns true if the icon of this addon was downloaded and is ready
/** Returns true if the icon of this addon was downloaded and is ready
* to be displayed. */
bool iconReady() const { return m_icon_ready; }
// ------------------------------------------------------------------------
/** Marks that the icon for this addon can be displayed. */
void setIconReady()
{
void setIconReady()
{
m_icon_revision = m_revision;
m_icon_ready=true;
m_icon_ready=true;
} // setIconReady
// ------------------------------------------------------------------------
/** Returns the size of the compressed package. */
int getSize() const { return m_size; }
// ------------------------------------------------------------------------
/** Returns the directory in which this type of addons is stored (in a
/** Returns the directory in which this type of addons is stored (in a
* separate subdirectory). A kart is stored in .../karts/X and tracks in
* .../tracks/X. If further types are added here, make sure that the
* name return ends with a "/".
*/
std::string getTypeDirectory() const
{
if(m_type=="kart")
if(m_type=="kart")
return "karts/";
else if(m_type=="track")
return "tracks/";
@ -261,7 +261,7 @@ public:
bool testStatus(AddonStatus n) const {return (m_status & n) !=0; }
// ------------------------------------------------------------------------
/** Returns the directory in which this addon is installed. */
std::string getDataDir() const
std::string getDataDir() const
{
return file_manager->getAddonsFile(getTypeDirectory()+m_dir_name);
} // getDataDir
@ -273,10 +273,10 @@ public:
{
switch(m_sort_order)
{
case SO_DEFAULT:
if(testStatus(AS_FEATURED) &&
case SO_DEFAULT:
if(testStatus(AS_FEATURED) &&
!a.testStatus(AS_FEATURED)) return true;
if(!testStatus(AS_FEATURED) &&
if(!testStatus(AS_FEATURED) &&
a.testStatus(AS_FEATURED)) return false;
// Otherwise fall through to name comparison!
case SO_NAME:
@ -300,10 +300,10 @@ public:
{
switch(m_sort_order)
{
case SO_DEFAULT:
if(testStatus(AS_FEATURED) &&
case SO_DEFAULT:
if(testStatus(AS_FEATURED) &&
!a.testStatus(AS_FEATURED)) return true;
if(!testStatus(AS_FEATURED) &&
if(!testStatus(AS_FEATURED) &&
a.testStatus(AS_FEATURED)) return false;
// Otherwise fall through to name comparison!
case SO_NAME:

View File

@ -68,7 +68,7 @@ public:
bool uninstall(const Addon &addon);
void reInit();
// ------------------------------------------------------------------------
/** Returns true if the list of online addons has been downloaded. This is
/** Returns true if the list of online addons has been downloaded. This is
* used to grey out the 'addons' entry till a network connections could be
* established. */
bool onlineReady() const {return m_state.getAtomic()==STATE_READY; }

View File

@ -31,13 +31,13 @@ class XMLNode;
*/
class DummyNetworkHttp : public INetworkHttp
{
public:
virtual ~DummyNetworkHttp() {}
virtual void startNetworkThread() {}
virtual void stopNetworkThread() {}
virtual void insertReInit() {}
virtual Request *downloadFileAsynchron(const std::string &url,
virtual Request *downloadFileAsynchron(const std::string &url,
const std::string &save = "",
int priority = 1,
bool manage_memory=true) { return NULL; }

View File

@ -38,20 +38,20 @@ private:
public:
/** If stk has permission to access the internet (for news
* server etc).
* IPERM_NOT_ASKED: The user needs to be asked if he wants to
* IPERM_NOT_ASKED: The user needs to be asked if he wants to
* grant permission
* IPERM_ALLOWED: STK is allowed to access server.
* IPERM_NOT_ALLOWED: STK must not access external servers. */
enum InternetPermission {IPERM_NOT_ASKED =0,
IPERM_ALLOWED =1,
IPERM_NOT_ALLOWED=2 };
public:
virtual ~INetworkHttp() {}
virtual void startNetworkThread() = 0;
virtual void stopNetworkThread() = 0;
virtual void insertReInit() = 0;
virtual Request *downloadFileAsynchron(const std::string &url,
virtual Request *downloadFileAsynchron(const std::string &url,
const std::string &save = "",
int priority = 1,
bool manage_memory=true) = 0;
@ -59,7 +59,7 @@ public:
static void create();
static INetworkHttp *get() { return m_network_http; }
static void destroy();
}; // NetworkHttp

View File

@ -45,8 +45,8 @@ class NetworkHttp : public INetworkHttp
private:
/** The list of pointes to all requests. */
Synchronised< std::priority_queue<Request*,
std::vector<Request*>,
Synchronised< std::priority_queue<Request*,
std::vector<Request*>,
Request::Compare > > m_all_requests;
/** The current requested being worked on. */
@ -79,7 +79,7 @@ public:
void startNetworkThread();
void stopNetworkThread();
void insertReInit();
Request *downloadFileAsynchron(const std::string &url,
Request *downloadFileAsynchron(const std::string &url,
const std::string &save = "",
int priority = 1,
bool manage_memory=true);

View File

@ -81,7 +81,7 @@ private:
* the delay between messages. */
core::stringw m_all_news_messages;
/** Stores the news message display count from the user config file.
/** Stores the news message display count from the user config file.
*/
std::vector<int> m_saved_display_count;
@ -99,7 +99,7 @@ public:
~NewsManager();
const core::stringw
getNextNewsMessage();
const core::stringw
const core::stringw
getImportantMessage();
void init();
void addNewsMessage(const core::stringw &s);

View File

@ -73,7 +73,7 @@ private:
public:
LEAK_CHECK()
Request(HttpCommands command, int priority,
Request(HttpCommands command, int priority,
bool manage_memory=true);
Request(HttpCommands command, int priority, bool manage_memory,
const std::string &url, const std::string &save);

View File

@ -72,11 +72,11 @@ public:
virtual void update(float dt, Vec3 *xyz=NULL, Vec3 *hpr=NULL,
Vec3 *scale=NULL);
/** This needs to be implemented by the inheriting classes. It is called
* once per frame from the track. It has a dummy implementation that
* just asserts so that this class can be instantiated in
* once per frame from the track. It has a dummy implementation that
* just asserts so that this class can be instantiated in
* CannonAnimation. */
virtual void update(float dt) {assert(false); };
void setInitialTransform(const Vec3 &xyz,
void setInitialTransform(const Vec3 &xyz,
const Vec3 &hpr);
void reset();
// ------------------------------------------------------------------------
@ -84,17 +84,17 @@ public:
void setPlaying(bool playing) {m_playing = playing; }
// ------------------------------------------------------------------------
float getAnimationDuration() const
{
float duration = -1;
const Ipo* currIpo;
for_in (currIpo, m_all_ipos)
{
duration = std::max(duration, currIpo->getEndTime());
}
return duration;
}

View File

@ -79,14 +79,14 @@ private:
/** Stores the inital rotation of the object. */
Vec3 m_initial_hpr;
private:
float getCubicBezier(float t, float p0, float p1,
float getCubicBezier(float t, float p0, float p1,
float p2, float p3) const;
void approximateBezier(float t0, float t1,
void approximateBezier(float t0, float t1,
const Vec3 &p0, const Vec3 &p1,
const Vec3 &h0, const Vec3 &h2,
unsigned int rec_level = 0);
public:
IpoData(const XMLNode &curve, float fps, bool reverse);
IpoData(const XMLNode &curve, float fps, bool reverse);
void readCurve(const XMLNode &node, bool reverse);
void readIPO(const XMLNode &node, float fps, bool reverse);
float approximateLength(float t0, float t1,
@ -118,7 +118,7 @@ public:
Ipo(const XMLNode &curve, float fps=25, bool reverse=false);
virtual ~Ipo();
Ipo *clone();
void update(float time, Vec3 *xyz=NULL, Vec3 *hpr=NULL,
void update(float time, Vec3 *xyz=NULL, Vec3 *hpr=NULL,
Vec3 *scale=NULL);
float get(float time, unsigned int index) const;
void setInitialTransform(const Vec3 &xyz, const Vec3 &hpr);
@ -128,7 +128,7 @@ public:
/** Returns the raw data points for this IPO. */
const std::vector<Vec3>& getPoints() const { return m_ipo_data->m_points; }
// ------------------------------------------------------------------------
/** Returns the last specified time (i.e. not considering any extend
/** Returns the last specified time (i.e. not considering any extend
* types). */
float getEndTime() const { return m_ipo_data->m_end_time; }
}; // Ipo

View File

@ -45,15 +45,15 @@ class ThreeDAnimation : public AnimationBase
{
private:
TrackObject *m_object;
/** True if a collision with this object should trigger
/** True if a collision with this object should trigger
* rescuing a kart. */
bool m_crash_reset;
/** True if a collision with this object should trigger
/** True if a collision with this object should trigger
* "exploding" a kart. */
bool m_explode_kart;
/** We have to store the rotation value as computed in blender, since
* irrlicht uses a different order, so for rotation animations we
* can not use the value returned by getRotation from a scene node. */
@ -71,7 +71,7 @@ public:
virtual ~ThreeDAnimation();
virtual void update(float dt);
// ------------------------------------------------------------------------
/** Returns true if a collision with this object should
/** Returns true if a collision with this object should
* trigger a rescue. */
bool isCrashReset() const { return m_crash_reset; }
bool isExplodeKartObject() const { return m_explode_kart; }

View File

@ -24,7 +24,7 @@
/**
/**
* \brief Dummy sound when ogg or openal aren't available
* \ingroup audio
*/
@ -33,10 +33,10 @@ class DummySFX : public SFXBase
public:
DummySFX(SFXBuffer* buffer, bool positional, float gain) {}
virtual ~DummySFX() {}
/** Late creation, if SFX was initially disabled */
virtual bool init() { return true; }
virtual void position(const Vec3 &position) {}
virtual void setLoop(bool status) {}
virtual void play() {}
@ -48,9 +48,9 @@ public:
virtual SFXManager::SFXStatus getStatus() { return SFXManager::SFX_STOPPED; }
virtual void onSoundEnabledBack() {}
virtual void setRolloff(float rolloff) {}
virtual const SFXBuffer* getBuffer() const { return NULL; }
}; // DummySFX

View File

@ -39,7 +39,7 @@ public:
virtual void updateFaster(float percent, float pitch) = 0;
virtual void update () = 0;
virtual bool isPlaying () = 0;
virtual ~Music () {};
};

View File

@ -39,7 +39,7 @@ public:
virtual void updateFaster(float percent, float pitch) {}
virtual void update () {}
virtual bool isPlaying () { return false; }
virtual ~MusicDummy () {}
};

View File

@ -45,16 +45,16 @@ private:
stringw m_title;
std::string m_normal_filename;
std::string m_fast_filename;
std::vector<std::string> m_all_tracks;
std::vector<std::string> m_all_tracks;
//int m_numLoops;
/** If faster music is enabled at all (either separate file or using
* the pitch shift approach). */
bool m_enable_fast;
bool m_enable_fast;
float m_gain;
float m_adjusted_gain;
/** Either time for fading faster music in, or time to change pitch. */
float m_faster_time;
/** Maximum pitch for faster music. */
@ -66,15 +66,15 @@ private:
SOUND_FADING, //!< normal music fading out, faster fading in
SOUND_FASTER, //!< change pitch of normal music
SOUND_FAST} //!< playing faster music or max pitch reached
m_mode;
m_mode;
float m_time_since_faster;
// The constructor is private so that the
// The constructor is private so that the
// static create function must be used.
MusicInformation (const XMLNode *root, const std::string &filename);
public:
LEAK_CHECK()
#if (defined(WIN32) || defined(_WIN32)) && !defined(__MINGW32__)
#pragma warning(disable:4290)
#endif
@ -94,10 +94,10 @@ public:
void pauseMusic ();
void resumeMusic ();
void volumeMusic (float gain);
void setTemporaryVolume(float gain);
void resetTemporaryVolume() { volumeMusic(m_adjusted_gain); }
void switchToFastMusic();
bool isPlaying() const;
}; // MusicInformation

View File

@ -36,14 +36,14 @@ class Vec3;
*/
class MusicManager : public NoCopy
{
private:
private:
MusicInformation *m_current_music;
/** If the sound could not be initialized, e.g. if the player doesn't has
* a sound card, we want to avoid anything sound related so we crash the
* a sound card, we want to avoid anything sound related so we crash the
* game. */
bool m_initialized;
std::map<std::string, MusicInformation*>
bool m_initialized;
std::map<std::string, MusicInformation*>
m_all_music;
void loadMusicInformation();
@ -64,15 +64,15 @@ public:
m_current_music->resumeMusic(); }
void switchToFastMusic() {if(m_current_music)
m_current_music->switchToFastMusic();}
void setMasterMusicVolume(float gain);
float getMasterMusicVolume() const { return m_masterGain; }
MusicInformation *getCurrentMusic() {return m_current_music; }
MusicInformation *getCurrentMusic() {return m_current_music; }
/**
* @throw runtime_error if the music file could not be found/opened
*/
*/
MusicInformation *getMusicInformation(const std::string& filename);
void loadMusicFromOneDir(const std::string& dir);

View File

@ -62,7 +62,7 @@ public:
virtual bool resumeMusic();
virtual void volumeMusic (float gain);
virtual bool isPlaying();
protected:
bool empty();
bool check(const char* what);
@ -79,7 +79,7 @@ private:
bool m_error;
bool m_playing;
ALuint m_soundBuffers[2];
ALuint m_soundSource;
ALenum nb_channels;

View File

@ -30,7 +30,7 @@
class Vec3;
/**
/**
* \brief The base class for sound effects.
* It gets a sound buffer from the sound
* manager, which is shared between all instances. Do create a new sound
@ -43,10 +43,10 @@ class SFXBase : public NoCopy
{
public:
virtual ~SFXBase() {}
/** Late creation, if SFX was initially disabled */
virtual bool init() = 0;
virtual void position(const Vec3 &position) = 0;
virtual void setLoop(bool status) = 0;
virtual void play() = 0;
@ -55,7 +55,7 @@ public:
virtual void resume() = 0;
virtual void speed(float factor) = 0;
virtual void volume(float gain) = 0;
virtual SFXManager::SFXStatus
virtual SFXManager::SFXStatus
getStatus() = 0;
virtual void onSoundEnabledBack() = 0;
virtual void setRolloff(float rolloff) = 0;

View File

@ -45,64 +45,64 @@ class XMLNode;
class SFXBuffer
{
private:
/** Whether the contents of the file was loaded */
bool m_loaded;
/** The file that contains the OGG audio data */
std::string m_file;
ALuint m_buffer;
bool m_positional;
float m_rolloff;
float m_gain;
float m_max_dist;
bool loadVorbisBuffer(const std::string &name, ALuint buffer);
public:
SFXBuffer(const std::string& file,
bool positional,
float rolloff,
float max_width,
float gain);
SFXBuffer(const std::string& file,
const XMLNode* node);
~SFXBuffer()
{
}
/**
* \brief load the buffer from file into OpenAL.
* \note If this buffer is already loaded, this call does nothing and returns false
* \return whether loading was successful
*/
bool load();
/**
* \brief Frees the loaded buffer
* Cannot appear in destructor because copy-constructors may be used,
* and the OpenAL source must not be deleted on a copy
*/
void unload();
/** \return whether this buffer was loaded from disk */
bool isLoaded() const { return m_loaded; }
/** Only returns a valid buffer if isLoaded() returned true */
ALuint getBufferID() const { return m_buffer; }
bool isPositional() const { return m_positional; }
float getRolloff() const { return m_rolloff; }
float getGain() const { return m_gain; }
float getMaxDist() const { return m_max_dist; }
std::string getFileName() const { return m_file; }
void setPositional(bool positional) { m_positional = positional; }
LEAK_CHECK()
};

View File

@ -78,18 +78,18 @@ public:
SFX_INITIAL = 3
};
private:
private:
/** Listener position */
Vec3 m_position;
/** The buffers and info for all sound effects. These are shared among all
* instances of SFXOpenal. */
std::map<std::string, SFXBuffer*> m_all_sfx_types;
/** The actual instances (sound sources) */
std::vector<SFXBase*> m_all_sfx;
/** To play non-positional sounds without having to create a new object for each */
static std::map<std::string, SFXBase*> m_quick_sounds;
@ -101,7 +101,7 @@ private:
void loadSfx();
bool loadVorbisBuffer(const std::string &name,
bool loadVorbisBuffer(const std::string &name,
ALuint buffer);
public:
SFXManager();
@ -116,12 +116,12 @@ public:
float max_width,
float gain);
SFXBase* createSoundSource(SFXBuffer* info,
SFXBase* createSoundSource(SFXBuffer* info,
const bool addToSFXList=true,
const bool owns_buffer=false);
SFXBase* createSoundSource(const std::string &name,
SFXBase* createSoundSource(const std::string &name,
const bool addToSFXList=true);
void deleteSFX(SFXBase *sfx);
void deleteSFXMapping(const std::string &name);
void pauseAll();
@ -129,19 +129,19 @@ public:
bool soundExist(const std::string &name);
void setMasterSFXVolume(float gain);
float getMasterSFXVolume() const { return m_master_gain; }
static bool checkError(const std::string &context);
static const std::string getErrorString(int err);
void positionListener(const Vec3 &position, const Vec3 &front);
SFXBase* quickSound(const std::string &soundName);
/** Called when sound was muted/unmuted */
void soundToggled(const bool newValue);
/** Prints the list of currently loaded sounds to stdout. Useful to debug audio leaks */
void dump();
Vec3 getListenerPos() const { return m_position; }
};

View File

@ -43,29 +43,29 @@ private:
bool m_ok;
bool m_positional;
float m_defaultGain;
/** The OpenAL source contains this info, but if audio is disabled initially then
the sound source won't be created and we'll be left with no clue when enabling
sounds later */
bool m_loop;
/** Contains a volume if set through the "volume" method, or a negative number if
this method was not called.
The OpenAL source contains this info, but if audio is disabled initially then
the sound source won't be created and we'll be left with no clue when enabling
sounds later. */
float m_gain;
bool m_owns_buffer;
public:
SFXOpenAL(SFXBuffer* buffer, bool positional, float gain,
bool owns_buffer = false);
virtual ~SFXOpenAL();
/** Late creation, if SFX was initially disabled */
virtual bool init();
virtual void play();
virtual void setLoop(bool status);
virtual void stop();
@ -79,9 +79,9 @@ public:
virtual void setRolloff(float rolloff);
virtual const SFXBuffer* getBuffer() const { return m_soundBuffer; }
LEAK_CHECK()
}; // SFXOpenAL
#endif

View File

@ -42,7 +42,7 @@ class ChallengeData;
* \brief The state of a challenge for one player.
* Each Challenge has one ChallengeData associcated, which stores
* the actual data about the challenge.
*
*
* \ingroup challenges
*/
class Challenge : public NoCopy
@ -52,9 +52,9 @@ private:
CH_ACTIVE, // challenge possible, but not yet solved
CH_SOLVED} // challenge was solved
m_state[RaceManager::DIFFICULTY_COUNT];
ChallengeData* m_data;
public:
Challenge(ChallengeData* data)
{
@ -71,24 +71,24 @@ public:
// ------------------------------------------------------------------------
/** Returns if this challenge was solved at the specified difficulty.
*/
bool isSolved(RaceManager::Difficulty d) const
bool isSolved(RaceManager::Difficulty d) const
{
return m_state[d]==CH_SOLVED;
} // isSolved
// ------------------------------------------------------------------------
/** Returns true if this challenge was solved at any difficult.
*/
bool isSolvedAtAnyDifficulty() const
bool isSolvedAtAnyDifficulty() const
{
return m_state[0]==CH_SOLVED || m_state[1]==CH_SOLVED ||
m_state[2]==CH_SOLVED;
m_state[2]==CH_SOLVED;
} // isSolvedAtAnyDifficulty
// ------------------------------------------------------------------------
/** True if this challenge is active at the given difficulty.
*/
bool isActive(RaceManager::Difficulty d) const
bool isActive(RaceManager::Difficulty d) const
{
return m_state[d]==CH_ACTIVE;
return m_state[d]==CH_ACTIVE;
} // isActive
// ------------------------------------------------------------------------
/** Sets this challenge to be active.

View File

@ -48,11 +48,11 @@ public:
class UnlockableFeature
{
public:
std::string m_name; // internal name
irr::core::stringw m_user_name; // not all types of feature have one
RewardType m_type;
const irr::core::stringw getUnlockedMessage() const;
}; // UnlockableFeature
// ------------------------------------------------------------------------
@ -69,8 +69,8 @@ private:
* a race challenge). */
enum ChallengeModeType
{
CM_GRAND_PRIX,
CM_SINGLE_RACE,
CM_GRAND_PRIX,
CM_SINGLE_RACE,
CM_ANY
};
@ -105,29 +105,29 @@ private:
/** Number of trophies required to access this challenge */
int m_num_trophies;
irr::core::stringw m_challenge_description;
public:
#ifdef WIN32
ChallengeData(const std::string& filename);
#else
ChallengeData(const std::string& filename) throw(std::runtime_error);
#endif
virtual ~ChallengeData() {}
/** sets the right parameters in RaceManager to try this challenge */
void setRace(RaceManager::Difficulty d) const;
virtual void check() const;
virtual bool isChallengeFulfilled() const;
virtual bool isGPFulfilled() const;
void addUnlockTrackReward(const std::string &track_name);
void addUnlockModeReward(const std::string &internal_mode_name,
void addUnlockModeReward(const std::string &internal_mode_name,
const irr::core::stringw &user_mode_name);
void addUnlockGPReward(const std::string &gp_name);
void addUnlockDifficultyReward(const std::string &internal_name,
void addUnlockDifficultyReward(const std::string &internal_name,
const irr::core::stringw &user_name);
void addUnlockKartReward(const std::string &internal_name,
const irr::core::stringw &user_name);
@ -135,13 +135,13 @@ public:
// ------------------------------------------------------------------------
/** Returns the version number of this challenge. */
int getVersion() const { return m_version; }
// ------------------------------------------------------------------------
/** Returns the list of unlockable features for this challenge.
/** Returns the list of unlockable features for this challenge.
*/
const std::vector<UnlockableFeature>&
getFeatures() const { return m_feature; }
// ------------------------------------------------------------------------
/** Returns the id of the challenge. */
const std::string &getId() const { return m_id; }
@ -149,21 +149,21 @@ public:
// ------------------------------------------------------------------------
/** Sets the id of this challenge. */
void setId(const std::string& s) { m_id = s; }
// ------------------------------------------------------------------------
/** Returns the track associated with this challenge. */
const std::string& getTrackId() const
{
const std::string& getTrackId() const
{
assert(m_mode==CM_SINGLE_RACE);
return m_track_id;
return m_track_id;
} // getTrackId
// ------------------------------------------------------------------------
/** Returns the id of the grand prix associated with this challenge. */
const std::string& getGPId() const
{
const std::string& getGPId() const
{
assert(m_mode==CM_GRAND_PRIX);
return m_gp_id;
return m_gp_id;
} // getGPId
// ------------------------------------------------------------------------
@ -177,26 +177,26 @@ public:
// ------------------------------------------------------------------------
/** Get number of required trophies to start this challenge */
int getNumTrophies() const { return m_num_trophies; }
// ------------------------------------------------------------------------
// ------------------------------------------------------------------------
/** Returns if this challenge is a grand prix. */
bool isGrandPrix() const { return m_mode == CM_GRAND_PRIX; }
// ------------------------------------------------------------------------
// ------------------------------------------------------------------------
/** Returns if this challenge is a grand prix. */
bool isSingleRace() const { return m_mode == CM_SINGLE_RACE; }
// ------------------------------------------------------------------------
// ------------------------------------------------------------------------
/** Returns the challenge mode of this challenge. */
ChallengeModeType getMode() const { return m_mode; }
// ------------------------------------------------------------------------
/** Returns the minor mode of this challenge. */
RaceManager::MinorRaceModeType getMinorMode() const { return m_minor; }
// ------------------------------------------------------------------------
/** Returns the description of this challenge.
/** Returns the description of this challenge.
*/
const irr::core::stringw& getChallengeDescription() const
const irr::core::stringw& getChallengeDescription() const
{
return m_challenge_description;
} // getChallengeDescription
// ------------------------------------------------------------------------
/** Returns the minimum position the player must have in order to win.
*/
@ -208,8 +208,8 @@ public:
// ------------------------------------------------------------------------
/** Returns the number of karts to use.
*/
int getNumKarts(RaceManager::Difficulty difficulty) const
{
int getNumKarts(RaceManager::Difficulty difficulty) const
{
return m_num_karts[difficulty];
} // getNumKarts
// ------------------------------------------------------------------------
@ -223,17 +223,17 @@ public:
/** Return the energy that a kart must at least have at the end of a race.
*/
int getEnergy(RaceManager::Difficulty difficulty) const
{
{
return m_energy[difficulty];
} // getEnergy
// ------------------------------------------------------------------------
/** Returns the name of the AI to use (used for boss challenge).
*/
const std::string& getAIKartIdent(RaceManager::Difficulty difficulty) const
{
return m_ai_kart_ident[difficulty];
{
return m_ai_kart_ident[difficulty];
}
}; // ChallengeData
#endif // HEADER_CHALLENGE_DATA_HPP

View File

@ -41,43 +41,43 @@ const int CHALLENGE_POINTS[] = { 8, 9, 10 };
class GameSlot
{
std::string m_kart_ident;
/** Profile names can change, so rather than try to make sure all renames
* are done everywhere, assign a unique ID to each profiler.
* Will save much headaches.
*/
std::string m_player_unique_id;
/** Contains whether each feature of the challenge is locked or unlocked */
std::map<std::string, bool> m_locked_features;
/** Recently unlocked features (they are waiting here
* until they are shown to the user) */
std::vector<const ChallengeData*> m_unlocked_features;
std::map<std::string, Challenge*> m_challenges_state;
/** A pointer to the current challenge, or NULL
/** A pointer to the current challenge, or NULL
* if no challenge is active. */
const Challenge *m_current_challenge;
friend class UnlockManager;
void computeActive();
int m_points;
/** Set to false after the initial stuff (intro, select kart, etc.) */
bool m_first_time;
int m_easy_challenges;
int m_medium_challenges;
int m_hard_challenges;
public:
// do NOT attempt to pass 'player_unique_id' by reference here. I don't
// know why (compiler bug maybe?) but this screws up everything. Better
// do NOT attempt to pass 'player_unique_id' by reference here. I don't
// know why (compiler bug maybe?) but this screws up everything. Better
// pass by copy.
GameSlot(std::string player_unique_id)
{
@ -90,36 +90,36 @@ public:
m_current_challenge = NULL;
}
~GameSlot();
const std::string& getPlayerID() const { return m_player_unique_id; }
const std::string& getKartIdent () const { return m_kart_ident; }
void setKartIdent(const std::string& kart_ident)
void setKartIdent(const std::string& kart_ident)
{
m_kart_ident = kart_ident;
m_kart_ident = kart_ident;
}
/** Returns the list of recently unlocked features (e.g. call at the end
/** Returns the list of recently unlocked features (e.g. call at the end
* of a race to know if any features were unlocked) */
const std::vector<const ChallengeData*>
const std::vector<const ChallengeData*>
getRecentlyCompletedChallenges() {return m_unlocked_features;}
/** Clear the list of recently unlocked challenges */
void clearUnlocked () {m_unlocked_features.clear(); }
bool isLocked (const std::string& feature);
void lockFeature (Challenge *challenge);
void unlockFeature (Challenge* c, RaceManager::Difficulty d,
void unlockFeature (Challenge* c, RaceManager::Difficulty d,
bool do_save=true);
void raceFinished ();
void grandPrixFinished ();
void save (std::ofstream& file, const std::string& name);
void setCurrentChallenge(const std::string &challenge_id);
/** Returns the number of points accumulated. */
int getPoints () const { return m_points; }
// ------------------------------------------------------------------------
@ -140,11 +140,11 @@ public:
// ------------------------------------------------------------------------
const Challenge *getCurrentChallenge() const { return m_current_challenge; }
// ------------------------------------------------------------------------
/** Returns a challenge given the challenge id.
/** Returns a challenge given the challenge id.
*/
const Challenge* getChallenge(const std::string& id) const
{
std::map<std::string, Challenge*>::const_iterator it =
std::map<std::string, Challenge*>::const_iterator it =
m_challenges_state.find(id);
assert(it!=m_challenges_state.end());
return it->second;

View File

@ -44,19 +44,19 @@ private:
SFXBase *m_locked_sound;
void load ();
typedef std::map<std::string, ChallengeData*> AllChallengesType;
AllChallengesType m_all_challenges;
std::map<std::string, GameSlot*> m_game_slots;
void readAllChallengesInDirs(const std::vector<std::string>* all_dirs);
/** ID of the active player */
std::string m_current_game_slot;
friend class GameSlot;
public:
UnlockManager ();
~UnlockManager ();
@ -65,33 +65,33 @@ public:
void save ();
bool createSlotsIfNeeded();
bool deleteSlotsIfNeeded();
const ChallengeData *getChallenge (const std::string& id);
bool isSupportedVersion(const ChallengeData &challenge);
/** Eye- (or rather ear-) candy. Play a sound when user tries to access a locked area */
void playLockSound() const;
const std::string& getCurrentSlotID() const { return m_current_game_slot; }
GameSlot* getCurrentSlot()
{
assert(m_game_slots.find(m_current_game_slot) != m_game_slots.end());
return m_game_slots[m_current_game_slot];
}
/** \param slotid name of the player */
void setCurrentSlot(std::string slotid) { m_current_game_slot = slotid; }
void findWhatWasUnlocked(int pointsBefore, int pointsNow,
std::vector<std::string>& tracks,
std::vector<std::string>& gps);
PlayerProfile* getCurrentPlayer();
void updateActiveChallengeList();
}; // UnlockManager
extern UnlockManager* unlock_manager;

View File

@ -47,22 +47,22 @@ enum DeviceConfigType
class DeviceConfig : public NoCopy
{
protected:
Binding m_bindings[PA_COUNT];
int m_plugged; //!< How many devices connected to the system which uses this config?
bool m_enabled; //!< If set to false, this device will be ignored. Currently for gamepads only
std::string m_name;
DeviceConfigType m_type;
DeviceConfig(DeviceConfigType type)
{
m_type = type;
m_enabled = true;
}
/**
* \brief internal helper method for DeviceConfig::getGameAction and DeviceConfig::getMenuAction
*/
@ -72,62 +72,62 @@ protected:
const PlayerAction firstActionToCheck,
const PlayerAction lastActionToCheck,
PlayerAction* action /* out */ );
public:
std::string getName () const { return m_name; };
irr::core::stringw toString ();
DeviceConfigType getType () const { return m_type; }
/** Get a user-readable string describing the bound action */
irr::core::stringw getBindingAsString(const PlayerAction action) const;
/** Get an internal unique string describing the bound action */
irr::core::stringw getMappingIdString (const PlayerAction action) const;
void serialize (std::ofstream& stream);
bool deserializeAction (irr::io::IrrXMLReader* xml);
void setBinding (const PlayerAction action,
const Input::InputType type,
const int id,
Input::AxisDirection direction = Input::AD_NEUTRAL,
wchar_t character=0);
void setPlugged () { m_plugged++; }
bool isPlugged () const { return m_plugged > 0; }
int getNumberOfDevices () const { return m_plugged; }
/**
* \brief Searches for a game actions associated with the given input event
* \note Don't call this directly unless you are KeyboardDevice or GamepadDevice
* \param[out] action the result, only set if method returned true
* \return whether finding an action associated to this input was successful
*/
bool getGameAction (Input::InputType type,
bool getGameAction (Input::InputType type,
const int id,
const int value,
PlayerAction* action /* out */);
/**
* \brief Searches for a game actions associated with the given input event
* \note Don't call this directly unless you are KeyboardDevice or GamepadDevice
* \param[out] action the result, only set if method returned true
* \return whether finding an action associated to this input was successful
*/
bool getMenuAction (Input::InputType type,
bool getMenuAction (Input::InputType type,
const int id,
const int value,
PlayerAction* action /* out */);
Binding& getBinding (int i) {return m_bindings[i];}
bool hasBindingFor(const int buttonID) const;
bool hasBindingFor(const int buttonID, PlayerAction from, PlayerAction to) const;
/** At this time only relevant for gamepads, keyboards are always enabled */
bool isEnabled() const { return m_enabled; }
void setEnabled(bool newValue) { m_enabled = newValue; }
};
@ -141,10 +141,10 @@ class KeyboardConfig : public DeviceConfig
{
public:
void setDefaultBinds ();
void serialize (std::ofstream& stream);
KeyboardConfig ();
};
@ -157,16 +157,16 @@ public:
*/
class GamepadConfig : public DeviceConfig
{
private:
/** Number of axis this device has. */
int m_axis_count;
/** Number of buttons this device has. */
int m_button_count;
public:
irr::core::stringw toString ();
void serialize (std::ofstream& stream);
@ -180,8 +180,8 @@ public:
void setNumberOfButtons(int count) { m_button_count = count; }
// ------------------------------------------------------------------------
/** Sets the number of axis this device has. */
void setNumberOfAxis(int count) { m_axis_count = count; }
// ~GamepadConfig();
void setNumberOfAxis(int count) { m_axis_count = count; }
// ~GamepadConfig();
};
#endif

View File

@ -34,54 +34,54 @@ using namespace irr;
class PlayerProfile : public NoCopy
{
protected:
/**
* For saving to config file.
* WARNING : m_player_group has to be declared before the other userconfigparams!
*/
GroupUserConfigParam m_player_group;
WStringUserConfigParam m_name;
BoolUserConfigParam m_is_guest_account;
#ifdef DEBUG
unsigned int m_magic_number;
#endif
IntUserConfigParam m_use_frequency;
/** Profile names can change, so rather than try to make sure all renames are done everywhere,
* assign a unique ID to each profiler. Will save much headaches.
*/
StringUserConfigParam m_unique_id;
int64_t generateUniqueId(const char* playerName);
public:
/**
* Constructor to create a new player that didn't exist before
*/
PlayerProfile(const core::stringw& name);
/**
* Constructor to deserialize a player that was saved to a XML file
* (...UserConfigParam classes will automagically take care of serializing all
* create players to the user's config file)
*/
PlayerProfile(const XMLNode* node);
~PlayerProfile()
{
#ifdef DEBUG
m_magic_number = 0xDEADBEEF;
#endif
}
void setName(const core::stringw& name)
{
{
#ifdef DEBUG
assert(m_magic_number == 0xABCD1234);
#endif
@ -89,7 +89,7 @@ public:
}
core::stringw getName() const
{
{
#ifdef DEBUG
assert(m_magic_number == 0xABCD1234);
#endif
@ -97,22 +97,22 @@ public:
}
bool isGuestAccount() const
{
{
#ifdef DEBUG
assert(m_magic_number == 0xABCD1234);
assert(m_magic_number == 0xABCD1234);
#endif
return m_is_guest_account;
}
int getUseFrequency() const
{
if (m_is_guest_account) return -1;
else return m_use_frequency;
}
void incrementUseFrequency();
// please do NOT try to optimise this to return a reference, I don't know why,
// maybe compiler bug, but hell breaks loose when you do that
std::string getUniqueID() const

View File

@ -54,7 +54,7 @@ private:
}; // SavedGPKart
protected:
/**
* For saving to config file.
* WARNING : m_savedgp_group has to be declared before the other userconfigparams!
@ -95,7 +95,7 @@ public:
void setKarts(const std::vector<RaceManager::KartStatus> &kart_list);
void clearKarts();
void loadKarts(std::vector<RaceManager::KartStatus> & kart_list);
// ------------------------------------------------------------------------
/** Returns the player id for this saved GP. */
const std::string getPlayerID() const { return m_player_id; }
@ -137,9 +137,9 @@ public:
/** Finds the right SavedGrandPrix given the specified data, or
* NULL if no matching GP was found.
*/
static SavedGrandPrix* getSavedGP(const std::string &player,
const std::string &gpid,
int difficulty, int total_karts,
static SavedGrandPrix* getSavedGP(const std::string &player,
const std::string &gpid,
int difficulty, int total_karts,
int player_karts)
{
for (int n=0; n<UserConfigParams::m_saved_grand_prix_list.size(); n++)

View File

@ -35,7 +35,7 @@ class KartProperties;
class MusicInformation;
class XMLNode;
/**
/**
* \brief Global STK configuration information.
* Parameters here can be tuned without recompilation, but the user shouldn't actually modify
* them. It also includes the list of default kart physics parameters which are used for
@ -46,7 +46,7 @@ class STKConfig : public NoCopy
{
protected:
/** Default kart properties. */
KartProperties *m_default_kart_properties;
KartProperties *m_default_kart_properties;
public:
/** What to do if a kart already has a powerup when it hits a bonus box:
@ -54,9 +54,9 @@ public:
* - SAME: give it one more item of the type it currently has.
* - ONLY_IF_SAME: only give it one more item if the randomly chosen item
* has the same type as the currently held item. */
enum {POWERUP_MODE_NEW,
POWERUP_MODE_SAME,
POWERUP_MODE_ONLY_IF_SAME}
enum {POWERUP_MODE_NEW,
POWERUP_MODE_SAME,
POWERUP_MODE_ONLY_IF_SAME}
m_same_powerup_mode;
static float UNDEFINED;
@ -78,7 +78,7 @@ public:
before they disappear. */
float m_explosion_impulse_objects;/**<Impulse of explosion on moving
objects, e.g. road cones, ... */
float m_penalty_time; /**< Penalty time when starting too
float m_penalty_time; /**< Penalty time when starting too
early. */
float m_delay_finish_time; /**<Delay after a race finished before
the results are displayed. */
@ -107,7 +107,7 @@ public:
before it is ignored. */
bool m_enable_networking;
/** Disable steering if skidding is stopped. This can help in making
/** Disable steering if skidding is stopped. This can help in making
* skidding more controllable (since otherwise when trying to steer while
* steering is reset to match the graphics it often results in the kart
* crashing). */
@ -119,11 +119,11 @@ public:
float m_ai_acceleration; /**<Between 0 and 1, default being 1, can be
used to give a handicap to AIs */
std::vector<float>
m_leader_intervals; /**<Interval in follow the leader till
last kart is reomved. */
float m_leader_time_per_kart; /**< Additional time to each leader
float m_leader_time_per_kart; /**< Additional time to each leader
interval for each additional kart. */
std::vector<int> m_switch_items; /**< How to switch items. */
/** The number of points a kart on position X has more than the

View File

@ -25,7 +25,7 @@
(so that defaults to 0)
1: Removed singleWindowMenu, newKeyboardStyle, oldStatusDisplay,
added config-version number
Version 1 can read version 0 without any problems, so
Version 1 can read version 0 without any problems, so
SUPPORTED_CONFIG_VERSION is 0.
2: Changed to SDL keyboard bindings
3: Added username (userid was used for ALL players)
@ -61,7 +61,7 @@ class XMLNode;
class XMLWriter;
/**
* The base of a set of small utilities to enable quickly adding/removing
* The base of a set of small utilities to enable quickly adding/removing
* stuff to/from config painlessly.
*/
class UserConfigParam
@ -106,26 +106,26 @@ class IntUserConfigParam : public UserConfigParam
{
int m_value;
int m_default_value;
public:
IntUserConfigParam(int default_value, const char* param_name,
IntUserConfigParam(int default_value, const char* param_name,
const char* comment = NULL);
IntUserConfigParam(int default_value, const char* param_name,
GroupUserConfigParam* group,
IntUserConfigParam(int default_value, const char* param_name,
GroupUserConfigParam* group,
const char* comment = NULL);
void write(XMLWriter& stream) const;
void findYourDataInAChildOf(const XMLNode* node);
void findYourDataInAnAttributeOf(const XMLNode* node);
irr::core::stringw toString() const;
void revertToDefaults() { m_value = m_default_value; }
operator int() const { return m_value; }
int& operator++(int dummy) { m_value++; return m_value; }
int& operator=(const int& v) { m_value = v; return m_value; }
int& operator=(const IntUserConfigParam& v)
int& operator=(const IntUserConfigParam& v)
{ m_value = (int)v; return m_value; }
}; // IntUserConfigParam
@ -134,24 +134,24 @@ class TimeUserConfigParam : public UserConfigParam
{
Time::TimeType m_value;
Time::TimeType m_default_value;
public:
TimeUserConfigParam(Time::TimeType default_value, const char* param_name,
TimeUserConfigParam(Time::TimeType default_value, const char* param_name,
const char* comment = NULL);
TimeUserConfigParam(Time::TimeType default_value, const char* param_name,
TimeUserConfigParam(Time::TimeType default_value, const char* param_name,
GroupUserConfigParam* group, const char* comment=NULL);
void write(XMLWriter& stream) const;
void findYourDataInAChildOf(const XMLNode* node);
void findYourDataInAnAttributeOf(const XMLNode* node);
irr::core::stringw toString() const;
void revertToDefaults() { m_value = m_default_value; }
operator Time::TimeType() const { return m_value; }
Time::TimeType& operator=(const Time::TimeType& v)
Time::TimeType& operator=(const Time::TimeType& v)
{ m_value = v; return m_value; }
Time::TimeType& operator=(const TimeUserConfigParam& v)
Time::TimeType& operator=(const TimeUserConfigParam& v)
{ m_value = (int)v; return m_value; }
}; // TimeUserConfigParam
@ -160,29 +160,29 @@ class StringUserConfigParam : public UserConfigParam
{
std::string m_value;
std::string m_default_value;
public:
StringUserConfigParam(const char* default_value, const char* param_name,
StringUserConfigParam(const char* default_value, const char* param_name,
const char* comment = NULL);
StringUserConfigParam(const char* default_value, const char* param_name,
GroupUserConfigParam* group,
StringUserConfigParam(const char* default_value, const char* param_name,
GroupUserConfigParam* group,
const char* comment = NULL);
void write(XMLWriter& stream) const;
void findYourDataInAChildOf(const XMLNode* node);
void findYourDataInAnAttributeOf(const XMLNode* node);
void revertToDefaults() { m_value = m_default_value; }
std::string getDefaultValue() const { return m_default_value; }
irr::core::stringw toString() const { return m_value.c_str(); }
operator std::string() const { return m_value; }
std::string& operator=(const std::string& v)
{ m_value = v; return m_value; }
std::string& operator=(const StringUserConfigParam& v)
std::string& operator=(const StringUserConfigParam& v)
{ m_value = (std::string)v; return m_value; }
const char* c_str() const { return m_value.c_str(); }
@ -193,28 +193,28 @@ class WStringUserConfigParam : public UserConfigParam
{
stringw m_value;
stringw m_default_value;
public:
WStringUserConfigParam(const stringw& default_value,
WStringUserConfigParam(const stringw& default_value,
const char* param_name,
const char* comment = NULL);
WStringUserConfigParam(const stringw& default_value,
WStringUserConfigParam(const stringw& default_value,
const char* param_name,
GroupUserConfigParam* group,
GroupUserConfigParam* group,
const char* comment = NULL);
void write(XMLWriter& stream) const;
void findYourDataInAChildOf(const XMLNode* node);
void findYourDataInAnAttributeOf(const XMLNode* node);
void revertToDefaults() { m_value = m_default_value; }
irr::core::stringw toString() const { return m_value; }
operator stringw() const { return m_value; }
stringw& operator=(const stringw& v) { m_value = v; return m_value; }
stringw& operator=(const WStringUserConfigParam& v)
stringw& operator=(const WStringUserConfigParam& v)
{ m_value = (stringw)v; return m_value; }
const wchar_t* c_str() const { return m_value.c_str(); }
}; // WStringUserConfigParam
@ -224,23 +224,23 @@ class BoolUserConfigParam : public UserConfigParam
{
bool m_value;
bool m_default_value;
public:
BoolUserConfigParam(bool default_value, const char* param_name,
BoolUserConfigParam(bool default_value, const char* param_name,
const char* comment = NULL);
BoolUserConfigParam(bool default_value, const char* param_name,
GroupUserConfigParam* group,
BoolUserConfigParam(bool default_value, const char* param_name,
GroupUserConfigParam* group,
const char* comment = NULL);
void write(XMLWriter& stream) const;
void findYourDataInAChildOf(const XMLNode* node);
void findYourDataInAnAttributeOf(const XMLNode* node);
irr::core::stringw toString() const;
void revertToDefaults() { m_value = m_default_value; }
operator bool() const { return m_value; }
bool& operator=(const bool& v) { m_value = v; return m_value; }
bool& operator=(const BoolUserConfigParam& v)
bool& operator=(const BoolUserConfigParam& v)
{ m_value = (bool)v; return m_value; }
}; // BoolUserConfigParam
@ -249,36 +249,36 @@ class FloatUserConfigParam : public UserConfigParam
{
float m_value;
float m_default_value;
public:
FloatUserConfigParam(float default_value, const char* param_name,
FloatUserConfigParam(float default_value, const char* param_name,
const char* comment = NULL);
FloatUserConfigParam(float default_value, const char* param_name,
GroupUserConfigParam* group,
FloatUserConfigParam(float default_value, const char* param_name,
GroupUserConfigParam* group,
const char* comment = NULL);
void write(XMLWriter& stream) const;
void findYourDataInAChildOf(const XMLNode* node);
void findYourDataInAnAttributeOf(const XMLNode* node);
irr::core::stringw toString() const;
void revertToDefaults() { m_value = m_default_value; }
operator float() const { return m_value; }
float& operator=(const float& v) { m_value = v; return m_value; }
float& operator=(const FloatUserConfigParam& v)
float& operator=(const FloatUserConfigParam& v)
{ m_value = (float)v; return m_value; }
}; // FloatUserConfigParam
// ============================================================================
enum AnimType {ANIMS_NONE = 0,
enum AnimType {ANIMS_NONE = 0,
ANIMS_PLAYERS_ONLY = 1,
ANIMS_ALL = 2 };
/** Using X-macros for setting-possible values is not very pretty, but it's a
/** Using X-macros for setting-possible values is not very pretty, but it's a
* no-maintenance case :
* when you want to add a new parameter, just add one signle line below and
* everything else automagically works (including default value, saving to
* when you want to add a new parameter, just add one signle line below and
* everything else automagically works (including default value, saving to
* file, loading from file)
*/
@ -300,53 +300,53 @@ namespace UserConfigParams
// ---- Audio
PARAM_PREFIX GroupUserConfigParam m_audio_group
PARAM_DEFAULT( GroupUserConfigParam("Audio", "Audio Settings") );
PARAM_PREFIX BoolUserConfigParam m_sfx
PARAM_DEFAULT( BoolUserConfigParam(true, "sfx_on", &m_audio_group,
"Whether sound effects are enabled or not (true or false)") );
PARAM_PREFIX BoolUserConfigParam m_music
PARAM_DEFAULT( BoolUserConfigParam(true, "music_on",
&m_audio_group,
PARAM_DEFAULT( BoolUserConfigParam(true, "music_on",
&m_audio_group,
"Whether musics are enabled or not (true or false)") );
PARAM_PREFIX FloatUserConfigParam m_sfx_volume
PARAM_DEFAULT( FloatUserConfigParam(1.0, "sfx_volume",
PARAM_DEFAULT( FloatUserConfigParam(1.0, "sfx_volume",
&m_audio_group, "Volume for sound effects, see openal AL_GAIN "
"for interpretation") );
PARAM_PREFIX FloatUserConfigParam m_music_volume
PARAM_DEFAULT( FloatUserConfigParam(0.7f, "music_volume",
PARAM_DEFAULT( FloatUserConfigParam(0.7f, "music_volume",
&m_audio_group, "Music volume from 0.0 to 1.0") );
// ---- Race setup
PARAM_PREFIX GroupUserConfigParam m_race_setup_group
PARAM_DEFAULT( GroupUserConfigParam("RaceSetup",
PARAM_DEFAULT( GroupUserConfigParam("RaceSetup",
"Race Setup Settings") );
PARAM_PREFIX IntUserConfigParam m_num_karts
PARAM_DEFAULT( IntUserConfigParam(4, "numkarts",
&m_race_setup_group,
PARAM_DEFAULT( IntUserConfigParam(4, "numkarts",
&m_race_setup_group,
"Default number of karts. -1 means use all") );
PARAM_PREFIX IntUserConfigParam m_num_laps
PARAM_DEFAULT( IntUserConfigParam(4, "numlaps",
PARAM_DEFAULT( IntUserConfigParam(4, "numlaps",
&m_race_setup_group, "Default number of laps.") );
PARAM_PREFIX IntUserConfigParam m_difficulty
PARAM_DEFAULT( IntUserConfigParam(0, "difficulty",
&m_race_setup_group,
PARAM_DEFAULT( IntUserConfigParam(0, "difficulty",
&m_race_setup_group,
"Default race difficulty. 0=easy, 1=medium, 2=hard") );
PARAM_PREFIX IntUserConfigParam m_game_mode
PARAM_DEFAULT( IntUserConfigParam(0, "game_mode",
&m_race_setup_group,
PARAM_DEFAULT( IntUserConfigParam(0, "game_mode",
&m_race_setup_group,
"Game mode. 0=standard, 1=time trial, 2=follow "
"the leader, 3=3 strikes") );
PARAM_PREFIX StringUserConfigParam m_default_kart
PARAM_DEFAULT( StringUserConfigParam("tux", "kart",
PARAM_DEFAULT( StringUserConfigParam("tux", "kart",
"Kart to select by default (the last used kart)") );
PARAM_PREFIX StringUserConfigParam m_last_used_kart_group
PARAM_DEFAULT( StringUserConfigParam("all", "last_kart_group",
PARAM_DEFAULT( StringUserConfigParam("all", "last_kart_group",
"Last selected kart group") );
// ---- Wiimote data
PARAM_PREFIX GroupUserConfigParam m_wiimote_group
PARAM_DEFAULT( GroupUserConfigParam("WiiMote",
PARAM_DEFAULT( GroupUserConfigParam("WiiMote",
"Settings for the wiimote") );
PARAM_PREFIX FloatUserConfigParam m_wiimote_max
PARAM_DEFAULT( FloatUserConfigParam(90.0f, "wiimote-max",
@ -386,11 +386,11 @@ namespace UserConfigParams
PARAM_DEFAULT( BoolUserConfigParam(false, "player_last",
&m_gp_start_order,
"Always put the player at the back or not (Bully mode).") );
// ---- Video
PARAM_PREFIX GroupUserConfigParam m_video_group
PARAM_DEFAULT( GroupUserConfigParam("Video", "Video Settings") );
PARAM_PREFIX IntUserConfigParam m_width
PARAM_DEFAULT( IntUserConfigParam(1024, "width", &m_video_group,
"Screen/window width in pixels") );
@ -398,34 +398,34 @@ namespace UserConfigParams
PARAM_DEFAULT( IntUserConfigParam(768, "height", &m_video_group,
"Screen/window height in pixels") );
PARAM_PREFIX BoolUserConfigParam m_fullscreen
PARAM_DEFAULT( BoolUserConfigParam(false, "fullscreen",
PARAM_DEFAULT( BoolUserConfigParam(false, "fullscreen",
&m_video_group) );
PARAM_PREFIX IntUserConfigParam m_prev_width
PARAM_DEFAULT( IntUserConfigParam(1024, "prev_width",
PARAM_DEFAULT( IntUserConfigParam(1024, "prev_width",
&m_video_group, "Previous screen/window width") );
PARAM_PREFIX IntUserConfigParam m_prev_height
PARAM_DEFAULT( IntUserConfigParam(768, "prev_height",
PARAM_DEFAULT( IntUserConfigParam(768, "prev_height",
&m_video_group,"Previous screen/window height") );
PARAM_PREFIX BoolUserConfigParam m_prev_fullscreen
PARAM_DEFAULT( BoolUserConfigParam(false, "prev_fullscreen",
PARAM_DEFAULT( BoolUserConfigParam(false, "prev_fullscreen",
&m_video_group) );
PARAM_PREFIX BoolUserConfigParam m_remember_window_location
PARAM_DEFAULT( BoolUserConfigParam(false, "remember_window_location",
PARAM_DEFAULT( BoolUserConfigParam(false, "remember_window_location",
&m_video_group) );
PARAM_PREFIX IntUserConfigParam m_window_x
PARAM_DEFAULT( IntUserConfigParam(-1, "window_x",
PARAM_DEFAULT( IntUserConfigParam(-1, "window_x",
&m_video_group,"If remember_window_location is true") );
PARAM_PREFIX IntUserConfigParam m_window_y
PARAM_DEFAULT( IntUserConfigParam(-1, "window_y",
PARAM_DEFAULT( IntUserConfigParam(-1, "window_y",
&m_video_group,"If remember_window_location is true") );
PARAM_PREFIX BoolUserConfigParam m_display_fps
PARAM_DEFAULT( BoolUserConfigParam(false, "show_fps",
PARAM_DEFAULT( BoolUserConfigParam(false, "show_fps",
&m_video_group, "Display frame per seconds") );
PARAM_PREFIX IntUserConfigParam m_max_fps
PARAM_DEFAULT( IntUserConfigParam(120, "max_fps",
PARAM_DEFAULT( IntUserConfigParam(120, "max_fps",
&m_video_group, "Maximum fps, should be at least 60") );
// Renderer type (OpenGL, Direct3D9, Direct3D8, Software, etc)
@ -439,11 +439,11 @@ namespace UserConfigParams
/** Wiimote debugging. */
PARAM_PREFIX bool m_wiimote_debug PARAM_DEFAULT( false );
/** Debug gamepads by visualising their values. */
PARAM_PREFIX bool m_gamepad_visualisation PARAM_DEFAULT( false );
/** If material debugging (printing terrain specific slowdown)
/** If material debugging (printing terrain specific slowdown)
* is enabled. */
PARAM_PREFIX bool m_material_debug PARAM_DEFAULT( false );
@ -464,28 +464,28 @@ namespace UserConfigParams
/** True if follow-the-leader debug information should be printed. */
PARAM_PREFIX bool m_ftl_debug PARAM_DEFAULT( false );
/** True if currently developed tutorial debugging is enabled. */
PARAM_PREFIX bool m_tutorial_debug PARAM_DEFAULT( false );
/** Verbosity level for debug messages. Note that error and
/** Verbosity level for debug messages. Note that error and
* important warnings must always be printed. */
PARAM_PREFIX int m_verbosity PARAM_DEFAULT( 0 );
PARAM_PREFIX bool m_no_start_screen PARAM_DEFAULT( false );
PARAM_PREFIX bool m_race_now PARAM_DEFAULT( false );
/** True to test funky ambient/diffuse/specularity in RGB &
/** True to test funky ambient/diffuse/specularity in RGB &
* all anisotropic */
PARAM_PREFIX bool m_rendering_debug PARAM_DEFAULT( false );
/** True if graphical profiler should be displayed */
PARAM_PREFIX bool m_profiler_enabled PARAM_DEFAULT( false );
/** True if hardware skinning should be enabled */
PARAM_PREFIX bool m_hw_skinning_enabled PARAM_DEFAULT( false );
/** True if Christmas Mode should be enabled */
PARAM_PREFIX bool m_xmas_enabled PARAM_DEFAULT( false );
@ -496,15 +496,15 @@ namespace UserConfigParams
PARAM_DEFAULT( StringUserConfigParam("localhost", "server_adress",
"Information about last server used") );
PARAM_PREFIX IntUserConfigParam m_server_port
PARAM_DEFAULT( IntUserConfigParam(2305, "server_port",
PARAM_DEFAULT( IntUserConfigParam(2305, "server_port",
"Information about last server used") );
// ---- Graphic Quality
PARAM_PREFIX GroupUserConfigParam m_graphics_quality
PARAM_DEFAULT( GroupUserConfigParam("GFX",
PARAM_DEFAULT( GroupUserConfigParam("GFX",
"Graphics Quality Settings") );
// On OSX 10.4 and before there may be driver issues with FBOs, so to be
// On OSX 10.4 and before there may be driver issues with FBOs, so to be
// safe disable them by default
#ifdef __APPLE__
#if MAC_OS_X_VERSION_MIN_REQUIRED < MAC_OS_X_VERSION_10_5
@ -515,50 +515,50 @@ namespace UserConfigParams
#else
#define FBO_DEFAULT true
#endif
PARAM_PREFIX BoolUserConfigParam m_fbo
PARAM_DEFAULT( BoolUserConfigParam(FBO_DEFAULT, "fbo",
PARAM_DEFAULT( BoolUserConfigParam(FBO_DEFAULT, "fbo",
&m_graphics_quality, "Use frame buffer objects (FBOs)") );
PARAM_PREFIX BoolUserConfigParam m_graphical_effects
PARAM_DEFAULT( BoolUserConfigParam(true, "anim_gfx",
PARAM_DEFAULT( BoolUserConfigParam(true, "anim_gfx",
&m_graphics_quality, "Scenery animations") );
PARAM_PREFIX BoolUserConfigParam m_weather_effects
PARAM_DEFAULT( BoolUserConfigParam(true, "weather_gfx",
PARAM_DEFAULT( BoolUserConfigParam(true, "weather_gfx",
&m_graphics_quality, "Weather effects") );
PARAM_PREFIX IntUserConfigParam m_show_steering_animations
PARAM_DEFAULT( IntUserConfigParam(ANIMS_ALL,
PARAM_DEFAULT( IntUserConfigParam(ANIMS_ALL,
"steering_animations", &m_graphics_quality,
"Whether to display kart animations (0=disabled for all; "
"1=enabled for humans, disabled for AIs; 2=enabled for all") );
PARAM_PREFIX IntUserConfigParam m_anisotropic
PARAM_DEFAULT( IntUserConfigParam(8, "anisotropic",
PARAM_DEFAULT( IntUserConfigParam(8, "anisotropic",
&m_graphics_quality,
"Quality of anisotropic filtering (usual values include 2-4-8-16; 0 to disable)") );
PARAM_PREFIX BoolUserConfigParam m_trilinear
PARAM_DEFAULT( BoolUserConfigParam(true, "trilinear",
PARAM_DEFAULT( BoolUserConfigParam(true, "trilinear",
&m_graphics_quality,
"Whether trilinear filtering is allowed to be "
"used (true or false)") );
PARAM_PREFIX IntUserConfigParam m_antialiasing
PARAM_DEFAULT( IntUserConfigParam(0,
PARAM_DEFAULT( IntUserConfigParam(0,
"antialiasing", &m_graphics_quality,
"Whether antialiasing is enabled (0 = disabled, 1 = 2x, 2 = 4x, 3 = 8x") );
PARAM_PREFIX BoolUserConfigParam m_vsync
PARAM_DEFAULT( BoolUserConfigParam(false, "vsync",
PARAM_DEFAULT( BoolUserConfigParam(false, "vsync",
&m_graphics_quality,
"Whether vertical sync is enabled") );
PARAM_PREFIX BoolUserConfigParam m_pixel_shaders
PARAM_DEFAULT( BoolUserConfigParam(true, "pixel_shaders",
PARAM_DEFAULT( BoolUserConfigParam(true, "pixel_shaders",
&m_graphics_quality,
"Whether to enable pixel shaders (splatting, normal maps, ...)") );
PARAM_PREFIX BoolUserConfigParam m_postprocess_enabled
PARAM_DEFAULT( BoolUserConfigParam(false,
PARAM_DEFAULT( BoolUserConfigParam(false,
"postprocess_enabled", &m_graphics_quality,
"Whether post-processing (motion blur...) should "
"be enabled") );
// ---- Misc
PARAM_PREFIX BoolUserConfigParam m_cache_overworld
PARAM_DEFAULT( BoolUserConfigParam(true, "cache-overworld") );
@ -567,8 +567,8 @@ namespace UserConfigParams
PARAM_DEFAULT( BoolUserConfigParam(false, "minimal-race-gui") );
// TODO : is this used with new code? does it still work?
PARAM_PREFIX BoolUserConfigParam m_crashed
PARAM_DEFAULT( BoolUserConfigParam(false, "crashed") );
PARAM_DEFAULT( BoolUserConfigParam(false, "crashed") );
#if defined(WIN32) && !defined(__CYGWIN__)
// No console on windows
# define CONSOLE_DEFAULT false
@ -579,43 +579,43 @@ namespace UserConfigParams
PARAM_PREFIX BoolUserConfigParam m_log_errors_to_console
PARAM_DEFAULT( BoolUserConfigParam(
CONSOLE_DEFAULT, "log_errors", "Enable logging to console.") );
PARAM_PREFIX IntUserConfigParam m_reverse_look_threshold
PARAM_DEFAULT( IntUserConfigParam(0, "reverse_look_threshold",
PARAM_DEFAULT( IntUserConfigParam(0, "reverse_look_threshold",
"If the kart is driving backwards faster than this value,\n"
"switch automatically to reverse camera (set to 0 to disable).") );
PARAM_PREFIX IntUserConfigParam m_camera_style
PARAM_DEFAULT( IntUserConfigParam(Camera::CS_MODERN,
PARAM_DEFAULT( IntUserConfigParam(Camera::CS_MODERN,
"camera_style", "Camera Style") );
PARAM_PREFIX StringUserConfigParam m_item_style
PARAM_DEFAULT( StringUserConfigParam("items", "item_style",
PARAM_DEFAULT( StringUserConfigParam("items", "item_style",
"Name of the .items file to use.") );
PARAM_PREFIX StringUserConfigParam m_last_track
PARAM_DEFAULT( StringUserConfigParam("olivermath", "last_track",
"Name of the last track used.") );
PARAM_DEFAULT( StringUserConfigParam("olivermath", "last_track",
"Name of the last track used.") );
PARAM_PREFIX StringUserConfigParam m_last_used_track_group
PARAM_DEFAULT( StringUserConfigParam("all", "last_track_group",
"Last selected track group") );
PARAM_PREFIX StringUserConfigParam m_skin_file
PARAM_DEFAULT( StringUserConfigParam("Peach.stkskin", "skin_file",
"Name of the skin to use") );
PARAM_PREFIX WStringUserConfigParam m_default_player
PARAM_DEFAULT( WStringUserConfigParam(L"", "default_player",
PARAM_DEFAULT( WStringUserConfigParam(L"", "default_player",
"Which player to use by default (if empty, will prompt)") );
// ---- Addon server related entries
PARAM_PREFIX GroupUserConfigParam m_addon_group
PARAM_DEFAULT( GroupUserConfigParam("AddonAndNews",
PARAM_DEFAULT( GroupUserConfigParam("AddonAndNews",
"Addon and news related settings") );
PARAM_PREFIX StringUserConfigParam m_server_addons
PARAM_DEFAULT( StringUserConfigParam("http://stkaddons.net/dl/xml",
"server_addons",
"server_addons",
&m_addon_group,
"The server used for addon."));
@ -625,18 +625,18 @@ namespace UserConfigParams
"Time news was updated last.") );
PARAM_PREFIX IntUserConfigParam m_news_frequency
PARAM_DEFAULT( IntUserConfigParam(0, "news_frequency",
PARAM_DEFAULT( IntUserConfigParam(0, "news_frequency",
&m_addon_group,
"How often news should be updated.") );
PARAM_PREFIX StringUserConfigParam m_display_count
PARAM_DEFAULT( StringUserConfigParam("", "news_display_count",
PARAM_DEFAULT( StringUserConfigParam("", "news_display_count",
&m_addon_group,
"How often all news messages "
"have been displayed") );
PARAM_PREFIX IntUserConfigParam m_last_important_message_id
PARAM_DEFAULT( IntUserConfigParam(-1, "last_important_message_id",
PARAM_DEFAULT( IntUserConfigParam(-1, "last_important_message_id",
&m_addon_group,
"Don't show important message "
"with this or a lower id again") );
@ -654,16 +654,16 @@ namespace UserConfigParams
"Time addon-list was updated last.") );
PARAM_PREFIX StringUserConfigParam m_language
PARAM_DEFAULT( StringUserConfigParam("system", "language",
PARAM_DEFAULT( StringUserConfigParam("system", "language",
"Which language to use (language code or 'system')") );
PARAM_PREFIX BoolUserConfigParam m_artist_debug_mode
PARAM_DEFAULT( BoolUserConfigParam(false, "artist_debug_mode",
"Whether to enable track debugging features") );
// TODO? implement blacklist for new irrlicht device and GUI
PARAM_PREFIX std::vector<std::string> m_blacklist_res;
PARAM_PREFIX PtrVector<PlayerProfile> m_all_players;
/** List of all saved GPs. */
@ -701,13 +701,13 @@ namespace UserConfigParams
class UserConfig : public NoCopy
{
private:
/** Filename of the user config file. */
std::string m_filename;
irr::core::stringw m_warning;
public:
/** Create the user config object; does not actually load it,
/** Create the user config object; does not actually load it,
* UserConfig::loadConfig needs to be called. */
UserConfig();
~UserConfig();
@ -718,7 +718,7 @@ public:
const irr::core::stringw& getWarning() { return m_warning; }
void resetWarning() { m_warning=""; }
void setWarning(irr::core::stringw& warning) { m_warning=warning; }
void addDefaultPlayer();
}; // UserConfig

View File

@ -34,8 +34,8 @@ public:
//! adds a mesh to the buffers with the given offset
/** \Return: Returns an array of ID numbers */
core::array<s32> addMesh(IMesh* mesh,
core::vector3df pos = core::vector3df(0,0,0),
core::array<s32> addMesh(IMesh* mesh,
core::vector3df pos = core::vector3df(0,0,0),
core::vector3df rot = core::vector3df(0,0,0),
core::vector3df scale = core::vector3df(1,1,1));
@ -46,7 +46,7 @@ public:
//! adds a mesh buffer with the given transformation
/** \Return: Returns the ID of this mesh buffer */
s32 addMeshBuffer(IMeshBuffer* buffer,
core::vector3df pos = core::vector3df(0,0,0),
core::vector3df pos = core::vector3df(0,0,0),
core::vector3df rot = core::vector3df(0,0,0),
core::vector3df scale = core::vector3df(1,1,1));
@ -57,13 +57,13 @@ public:
//! updates bouding box from internal buffers
void recalculateBoundingBox();
//! Moves a mesh,
/** mesh buffers in clean destination buffers will be moved immediately,
//! Moves a mesh,
/** mesh buffers in clean destination buffers will be moved immediately,
ones in dirty buffers will be left until the next update */
core::array<bool> moveMesh(const core::array<s32>& bufferIDs, const core::matrix4 &newMatrix);
//! Moves a mesh buffer
/** if the destination buffer is clean it will be moved immediately,
/** if the destination buffer is clean it will be moved immediately,
if a member of a dirty buffer, it will be left until the next update */
bool moveMeshBuffer(const s32 id, const core::matrix4 &newMatrix);
@ -85,13 +85,13 @@ public:
//! Returns pointer to a mesh buffer.
/** \param nr: Zero based index of the mesh buffer. The maximum value is
getMeshBufferCount() - 1;
\return Returns the pointer to the mesh buffer or
\return Returns the pointer to the mesh buffer or
NULL if there is no such mesh buffer. */
virtual IMeshBuffer* getMeshBuffer(u32 nr) const;
//! Returns pointer to a mesh buffer which fits a material
/** \param material: material to search for
\return Returns the pointer to the mesh buffer or
\return Returns the pointer to the mesh buffer or
NULL if there is no such mesh buffer. */
virtual IMeshBuffer* getMeshBuffer( const video::SMaterial &material) const;
@ -124,8 +124,8 @@ private:
struct SBufferReference
{
SBufferReference()
: SourceBuffer(0), DestReference(0), FirstVertex(0), VertexCount(0),
SBufferReference()
: SourceBuffer(0), DestReference(0), FirstVertex(0), VertexCount(0),
FirstIndex(0), IndexCount(0), Initialized(false) { }
IMeshBuffer* SourceBuffer;

View File

@ -71,7 +71,7 @@ private:
/** Camera's mode. */
Mode m_mode;
/** The index of this camera which is the index of the kart it is
/** The index of this camera which is the index of the kart it is
* attached to. */
unsigned int m_index;
@ -134,9 +134,9 @@ private:
{
public:
/** The camera type:
EC_STATIC_FOLLOW_KART A static camera that always points at the
EC_STATIC_FOLLOW_KART A static camera that always points at the
kart.
EC_AHEAD_OF_KART A camera that flies ahead of the kart
EC_AHEAD_OF_KART A camera that flies ahead of the kart
always pointing at the kart.
*/
typedef enum {EC_STATIC_FOLLOW_KART,
@ -144,7 +144,7 @@ private:
EndCameraType m_type;
/** Position of the end camera. */
Vec3 m_position;
Vec3 m_position;
/** Distance to kart by which this camera is activated. */
float m_distance2;
@ -162,7 +162,7 @@ private:
m_type = EC_AHEAD_OF_KART;
else
{
fprintf(stderr,
fprintf(stderr,
"Invalid camera type '%s' - camera is ignored.\n",
s.c_str());
return false;
@ -179,12 +179,12 @@ private:
* \param xyz Position to test for distance.
* \returns True if xyz is close enough to this camera.
*/
bool isReached(const Vec3 &xyz)
bool isReached(const Vec3 &xyz)
{ return (xyz-m_position).length2() < m_distance2; }
}; // EndCameraInformation
// ------------------------------------------------------------------------
/** List of all end camera information. This information is shared
/** List of all end camera information. This information is shared
* between all cameras, so it's static. */
static AlignedArray<EndCameraInformation> m_end_cameras;
@ -200,7 +200,7 @@ private:
void computeNormalCameraPosition(Vec3 *wanted_position,
Vec3 *wanted_target);
void handleEndCamera(float dt);
void getCameraSettings(float *above_kart, float *cam_angle,
void getCameraSettings(float *above_kart, float *cam_angle,
float *side_way, float *distance,
bool *smoothing);
void positionCamera(float dt, float above_kart, float cam_angle,
@ -220,15 +220,15 @@ public:
// ------------------------------------------------------------------------
/** Remove all cameras. */
static void removeAllCameras()
{
static void removeAllCameras()
{
for(unsigned int i=0; i<m_all_cameras.size(); i++)
delete m_all_cameras[i];
m_all_cameras.clear();
} // removeAllCameras
// ------------------------------------------------------------------------
/** Creates a camera and adds it to the list of all cameras. Also the
/** Creates a camera and adds it to the list of all cameras. Also the
* camera index (which determines which viewport to use in split screen)
* is set.
*/
@ -275,7 +275,7 @@ public:
// ------------------------------------------------------------------------
/** Returns the scaling in x/y direction for this camera. */
const core::vector2df& getScaling() const {return m_scaling; }
// ------------------------------------------------------------------------
/** Returns the camera scene node. */
scene::ICameraSceneNode *getCameraSceneNode() { return m_camera; }

View File

@ -41,7 +41,7 @@ class Explosion : public HitSFX
private:
float m_remaining_time;
scene::IParticleSystemSceneNode *m_node;
public:
Explosion(const Vec3& coord, const char* explosion_sound);
~Explosion();

View File

@ -39,11 +39,11 @@ class HWSkinningCallback : public video::IShaderConstantSetCallBack
private:
//const video::SMaterial *m_used_material;
scene::IAnimatedMeshSceneNode* m_node;
public:
HWSkinningCallback(scene::IAnimatedMeshSceneNode* node);
virtual ~HWSkinningCallback();
/* virtual void OnSetMaterial(const video::SMaterial& material)
{
m_used_material=&material;

View File

@ -26,7 +26,7 @@ class Vec3;
/**
* \ingroup graphics
* A small interface for effects to be used when a kart is hit. That
* includes a sound effect only, or a graphical effect (like an
* includes a sound effect only, or a graphical effect (like an
* explosion).
*/
class HitEffect: public NoCopy

View File

@ -31,7 +31,7 @@ class HitSFX : public HitEffect
private:
/** The sfx to play. */
SFXBase* m_sfx;
public:
HitSFX(const Vec3& coord, const char* explosion_sound);
~HitSFX();

View File

@ -55,7 +55,7 @@ class PerCameraNode;
class PostProcessing;
/**
* \brief class that creates the irrLicht device and offers higher-level
* \brief class that creates the irrLicht device and offers higher-level
* ways to manage the 3D scene
* \ingroup graphics
*/
@ -74,15 +74,15 @@ private:
gui::IGUIFont *m_race_font;
/** Post-processing. */
PostProcessing *m_post_processing;
/** Flag to indicate if a resolution change is pending (which will be
* acted upon in the next update). None means no change, yes means
* change to new resolution and trigger confirmation dialog.
* change to new resolution and trigger confirmation dialog.
* Cancel indicates a change of the resolution (back to the original
* one), but no confirmation dialog. */
enum {RES_CHANGE_NONE, RES_CHANGE_YES,
enum {RES_CHANGE_NONE, RES_CHANGE_YES,
RES_CHANGE_CANCEL} m_resolution_changing;
public:
/** A simple class to store video resolutions. */
class VideoMode
@ -100,26 +100,26 @@ private:
void setupViewports();
video::E_DRIVER_TYPE getEngineDriverType(int index);
/** Whether the mouse cursor is currently shown */
bool m_pointer_shown;
/** Internal method that applies the resolution in user settings. */
void applyResolutionSettings();
void createListOfVideoModes();
bool m_request_screenshot;
#ifdef DEBUG
/** Used to visualise skeletons. */
std::vector<irr::scene::IAnimatedMeshSceneNode*> m_debug_meshes;
void drawDebugMeshes();
void drawJoint(bool drawline, bool drawname,
void drawJoint(bool drawline, bool drawname,
irr::scene::ISkinnedMesh::SJoint* joint,
irr::scene::ISkinnedMesh* mesh, int id);
#endif
void doScreenShot();
public:
IrrDriver();
@ -130,10 +130,10 @@ public:
void setAllMaterialFlags(scene::IMesh *mesh) const;
scene::IAnimatedMesh *getAnimatedMesh(const std::string &name);
scene::IMesh *getMesh(const std::string &name);
video::ITexture *applyMask(video::ITexture* texture,
const std::string& mask_path);
video::ITexture *applyMask(video::ITexture* texture,
const std::string& mask_path);
void displayFPS();
bool OnEvent(const irr::SEvent &event);
bool OnEvent(const irr::SEvent &event);
void setAmbientLight(const video::SColor &light);
video::ITexture *getTexture(const std::string &filename,
bool is_premul=false,
@ -141,9 +141,9 @@ public:
bool complain_if_not_found=true);
void grabAllTextures(const scene::IMesh *mesh);
void dropAllTextures(const scene::IMesh *mesh);
scene::IMesh *createQuadMesh(const video::SMaterial *material=NULL,
scene::IMesh *createQuadMesh(const video::SMaterial *material=NULL,
bool create_one_quad=false);
scene::IMesh *createTexturedQuadMesh(const video::SMaterial *material,
scene::IMesh *createTexturedQuadMesh(const video::SMaterial *material,
const double w, const double h);
scene::ISceneNode *addWaterNode(scene::IMesh *mesh, float wave_height,
float wave_speed, float wave_length);
@ -152,17 +152,17 @@ public:
const video::SColor &color=video::SColor(128, 255, 255, 255));
scene::IMeshSceneNode*addMesh(scene::IMesh *mesh,
scene::ISceneNode *parent=NULL);
PerCameraNode *addPerCameraMesh(scene::IMesh* mesh,
PerCameraNode *addPerCameraMesh(scene::IMesh* mesh,
scene::ICameraSceneNode* node,
scene::ISceneNode *parent = NULL);
scene::ISceneNode *addBillboard(const core::dimension2d< f32 > size,
video::ITexture *texture,
scene::ISceneNode *addBillboard(const core::dimension2d< f32 > size,
video::ITexture *texture,
scene::ISceneNode* parent=NULL);
scene::IParticleSystemSceneNode
*addParticleNode(bool default_emitter=true);
scene::ISceneNode *addSkyDome(video::ITexture *texture, int hori_res,
int vert_res, float texture_percent,
int vert_res, float texture_percent,
float sphere_percent);
scene::ISceneNode *addSkyBox(const std::vector<video::ITexture*> &texture_names);
void removeNode(scene::ISceneNode *node);
@ -170,7 +170,7 @@ public:
void removeTexture(video::ITexture *t);
scene::IAnimatedMeshSceneNode
*addAnimatedMesh(scene::IAnimatedMesh *mesh);
scene::ICameraSceneNode
scene::ICameraSceneNode
*addCameraSceneNode();
Camera *addCamera(unsigned int index, AbstractKart *kart);
void removeCameraSceneNode(scene::ICameraSceneNode *camera);
@ -182,31 +182,31 @@ public:
void cancelResChange();
bool moveWindow(const int x, const int y);
void showPointer();
void hidePointer();
bool isPointerShown() const { return m_pointer_shown; }
core::position2di getMouseLocation();
void printRenderStats();
bool supportsSplatting();
void requestScreenshot();
void draw2dTriangle(const core::vector2df &a, const core::vector2df &b,
const core::vector2df &c,
const core::vector2df &c,
const video::ITexture *texture = NULL,
const video::SColor *ca=NULL,
const video::SColor *ca=NULL,
const video::SColor *cb=NULL,
const video::SColor *cc=NULL);
// ------------------------------------------------------------------------
/** Returns a list of all video modes supports by the graphics card. */
const std::vector<VideoMode>& getVideoModes() const { return m_modes; }
// ------------------------------------------------------------------------
/** Returns the frame size. */
const core::dimension2d<u32>& getFrameSize() const
const core::dimension2d<u32>& getFrameSize() const
{ return m_video_driver->getCurrentRenderTargetSize(); }
// ------------------------------------------------------------------------
/** Returns the irrlicht device. */
@ -219,7 +219,7 @@ public:
scene::ISceneManager *getSceneManager() const { return m_scene_manager; }
// ------------------------------------------------------------------------
/** Returns the gui environment, used to add widgets to a screen. */
gui::IGUIEnvironment *getGUI() const { return m_gui_env; }
gui::IGUIEnvironment *getGUI() const { return m_gui_env; }
// ------------------------------------------------------------------------
/** Returns the current real time, which might not be 0 at start of the
* application. Value in msec. */
@ -233,20 +233,20 @@ public:
void clearDebugMesh() { m_debug_meshes.clear(); }
// ------------------------------------------------------------------------
/** Adds a debug mesh to be displaed. */
void addDebugMesh(scene::IAnimatedMeshSceneNode *node)
{
m_debug_meshes.push_back(node);
void addDebugMesh(scene::IAnimatedMeshSceneNode *node)
{
m_debug_meshes.push_back(node);
} // addDebugMesh
#endif
// --------------------- RTT --------------------
/**
* Class that provides RTT (currently, only when no other 3D rendering
* Class that provides RTT (currently, only when no other 3D rendering
* in the main scene is required)
* Provides an optional 'setupRTTScene' method to make it quick and easy
* to prepare rendering of 3D objects but you can also manually set the
* to prepare rendering of 3D objects but you can also manually set the
* scene/camera. If you use the factory 'setupRTTScene', cleanup can be
* done through 'tearDownRTTScene' (destructor will also do this). If
* done through 'tearDownRTTScene' (destructor will also do this). If
* you set it up manually, you need to clean it up manually.
*/
class RTTProvider
@ -254,57 +254,57 @@ public:
/** A pointer to texture on which a scene is rendered. Only used
* in between beginRenderToTexture() and endRenderToTexture calls. */
video::ITexture *m_render_target_texture;
bool m_persistent_texture;
/** Main node of the RTT scene */
scene::ISceneNode *m_rtt_main_node;
scene::ICameraSceneNode *m_camera;
scene::ILightSceneNode *m_light;
/** Irrlicht video driver. */
video::IVideoDriver *m_video_driver;
public:
RTTProvider(const core::dimension2du &dimension,
RTTProvider(const core::dimension2du &dimension,
const std::string &name, bool persistent_texture);
~RTTProvider();
/**
* \brief Quick utility method to setup a scene from a plain list
* \brief Quick utility method to setup a scene from a plain list
* of models
*
* Sets up a given vector of meshes for render-to-texture. Ideal to
* embed a 3D object inside the GUI. If there are multiple meshes,
* the first mesh is considered to be the root, and all following
* meshes will have their locations relative to the location of the
* the first mesh is considered to be the root, and all following
* meshes will have their locations relative to the location of the
* first mesh.
*
* \param mesh The list of meshes to add to the scene
* \param mesh_location Location of each fo these meshes
* \param model_frames For animated meshes, which frame to use
* \param model_frames For animated meshes, which frame to use
* (value can be -1 to set none)
* When frame is not -1, the corresponding
* When frame is not -1, the corresponding
* IMesh must be an IAnimatedMesh.
* \pre The 3 vectors have the same size.
*/
void setupRTTScene(PtrVector<scene::IMesh, REF>& mesh,
void setupRTTScene(PtrVector<scene::IMesh, REF>& mesh,
AlignedArray<Vec3>& mesh_location,
AlignedArray<Vec3>& mesh_scale,
const std::vector<int>& model_frames);
/** Optional 'angle' parameter will rotate the object added
/** Optional 'angle' parameter will rotate the object added
* *through setupRTTScene* */
video::ITexture* renderToTexture(float angle=-1,
bool is_2d_render=false);
void tearDownRTTScene();
};
}; // IrrDriver

View File

@ -53,12 +53,12 @@ private:
std::vector<int> m_detail;
std::vector<irr::scene::ISceneNode*> m_nodes;
std::set<scene::ISceneNode*> m_nodes_set;
std::string m_group_name;
/** The normal level of detail can be overwritten. If
/** The normal level of detail can be overwritten. If
* m_forced_lod is >=0, only this level is be used. */
int m_forced_lod;
@ -70,27 +70,27 @@ private:
WAS_SHOWN,
WAS_HIDDEN
};
PreviousVisibility m_previous_visibility;
public:
LODNode(std::string group_name, scene::ISceneNode* parent, scene::ISceneManager* mgr, s32 id=-1);
virtual ~LODNode();
//! returns the axis aligned bounding box of this node
virtual const core::aabbox3d<f32>& getBoundingBox() const { return Box; }
/*
//! Returns a reference to the current relative transformation matrix.
//! This is the matrix, this scene node uses instead of scale, translation
//! and rotation.
virtual core::matrix4& getRelativeTransformationMatrix() { return RelativeTransformationMatrix; }
//! Returns the relative transformation of the scene node.
virtual core::matrix4 getRelativeTransformation() const { return RelativeTransformationMatrix; }
*/
/**
* Adds a node associated with a level of detail.
* \note The LOD levels must be added in ascending order.
@ -99,7 +99,7 @@ public:
* \param reparent If true, node will be removed from its current parent first
*/
void add(int level, scene::ISceneNode* node, bool reparent);
void forceLevelOfDetail(int n);
/** Get the highest level of detail node */
@ -108,9 +108,9 @@ public:
if (m_nodes.size() > 0) return m_nodes[0];
else return NULL;
}
std::vector<scene::ISceneNode*>& getAllNodes() { return m_nodes; }
//! OnAnimate() is called just before rendering the whole scene.
/** This method will be called once per frame, independent
of whether the scene node is visible or not. */
@ -118,7 +118,7 @@ public:
virtual void OnRegisterSceneNode();
virtual void render();
virtual scene::ESCENE_NODE_TYPE getType() const { return (scene::ESCENE_NODE_TYPE)scene::ESNT_LOD_NODE; }
const std::string& getGroupName() const { return m_group_name; }

View File

@ -65,19 +65,19 @@ public:
{
EMIT_ON_DRIVE = 0,
EMIT_ON_SKID,
EMIT_KINDS_COUNT
};
enum CollisionReaction
{
NORMAL,
RESCUE,
PUSH_BACK
};
private:
enum Shaders
{
SHADER_NORMAL_MAP,
@ -89,7 +89,7 @@ private:
SHADER_GRASS,
SHADER_COUNT
};
video::ITexture *m_texture;
unsigned int m_index;
std::string m_texname;
@ -118,46 +118,46 @@ private:
bool m_zipper;
/** If a kart is rescued when driving on this surface. */
bool m_drive_reset;
/** Speed of the 'main' wave in the water shader. Only used if
m_graphical_effect == WATER_SHADER */
float m_water_shader_speed_1;
/** Speed of the 'secondary' waves in the water shader. Only used if
m_graphical_effect == WATER_SHADER */
float m_water_shader_speed_2;
/** If a kart is rescued when crashing into this surface. */
CollisionReaction m_collision_reaction;
/** Particles to show on touch */
std::string m_collision_particles;
float m_grass_speed;
float m_grass_amplitude;
/** If the property should be ignored in the physics. Example would be
* plants that a kart can just drive through. */
bool m_ignore;
bool m_add;
bool m_fog;
ParticleKind* m_particles_effects[EMIT_KINDS_COUNT];
/** For normal maps */
std::string m_normal_map_tex;
std::string m_normal_map_shader_lightmap;
//bool m_normal_map_uv2; //!< Whether to use a second UV layer for normal map
bool m_is_heightmap;
bool m_parallax_map;
float m_parallax_height;
/** Texture clamp bitmask */
unsigned int m_clamp_tex;
bool m_lighting;
bool m_smooth_reflection_shader;
bool m_alpha_testing;
@ -166,7 +166,7 @@ private:
/** True if backface culliing should be enabled. */
bool m_backface_culling;
/** Set to true to disable writing to the Z buffer. Usually to be used with alpha blending */
bool m_disable_z_write;
@ -178,7 +178,7 @@ private:
bool m_lightmap;
/** True if (additive) lightmapping is enabled for this material. */
bool m_additive_lightmap;
bool m_high_tire_adhesion;
/** How much the top speed is reduced per second. */
float m_slowdown_time;
@ -200,50 +200,50 @@ private:
* if a zipper is used. If this value is <0 the kart specific value will
* be used. */
float m_zipper_max_speed_increase;
/** Time a zipper stays activated. If this value is <0 the kart specific
/** Time a zipper stays activated. If this value is <0 the kart specific
* value will be used. */
float m_zipper_duration;
/** A one time additional speed gain - the kart will instantly add this
/** A one time additional speed gain - the kart will instantly add this
* amount of speed to its current speed. If this value is <0 the kart
* specific value will be used. */
float m_zipper_speed_gain;
/** Time it takes for the zipper advantage to fade out. If this value
/** Time it takes for the zipper advantage to fade out. If this value
* is <0 the kart specific value will be used. */
float m_zipper_fade_out_time;
/** Additional engine force. */
float m_zipper_engine_force;
std::string m_mask;
/** If m_splatting is true, indicates the first splatting texture */
std::string m_splatting_texture_1;
/** If m_splatting is true, indicates the second splatting texture */
std::string m_splatting_texture_2;
/** If m_splatting is true, indicates the third splatting texture */
std::string m_splatting_texture_3;
std::string m_splatting_texture_3;
/** If m_splatting is true, indicates the fourth splatting texture */
std::string m_splatting_texture_4;
std::string m_splatting_lightmap;
std::vector<irr::video::IShaderConstantSetCallBack*> m_shaders;
/** Only used if bubble effect is enabled */
std::map<scene::IMeshBuffer*, BubbleEffectProvider*> m_bubble_provider;
bool m_deprecated;
void init (unsigned int index);
void install (bool is_full_path=false, bool complain_if_not_found=true);
void initCustomSFX(const XMLNode *sfx);
void initParticlesEffect(const XMLNode *node);
public:
Material(const XMLNode *node, int index, bool deprecated);
Material(const std::string& fname, int index,
Material(const std::string& fname, int index,
bool is_full_path=false,
bool complain_if_not_found=true);
~Material ();
@ -251,7 +251,7 @@ public:
void setSFXSpeed(SFXBase *sfx, float speed) const;
void setMaterialProperties(video::SMaterial *m, scene::IMeshBuffer* mb);
void adjustForFog(scene::ISceneNode* parent, video::SMaterial *m, bool use_fog) const;
/** Returns the ITexture associated with this material. */
video::ITexture *getTexture() const { return m_texture; }
bool isIgnore () const { return m_ignore; }
@ -264,16 +264,16 @@ public:
/** Returns if this material should trigger a rescue if a kart
* crashes against it. */
CollisionReaction getCollisionReaction() const { return m_collision_reaction; }
std::string getCrashResetParticles() const { return m_collision_particles; }
bool highTireAdhesion () const { return m_high_tire_adhesion; }
const std::string&
const std::string&
getTexFname () const { return m_texname; }
int getIndex () const { return m_index; }
bool isTransparent () const { return m_alpha_testing || m_alpha_blending || m_add; }
// ------------------------------------------------------------------------
/** Returns true if this materials need pre-multiply of alpha. */
bool isPreMul() const {return m_adjust_image==ADJ_PREMUL; }
@ -299,7 +299,7 @@ public:
bool isBelowSurface () const { return m_below_surface; }
// ------------------------------------------------------------------------
/** Returns true if this material is a surface, i.e. it is going to be
* ignored for the physics, but the information is needed e.g. for
* ignored for the physics, but the information is needed e.g. for
* gfx. See m_below_surface for more details. */
bool isSurface () const { return m_surface; }
// ------------------------------------------------------------------------
@ -307,15 +307,15 @@ public:
* terrain. The string will be "" if no special sfx exists. */
const std::string &
getSFXName () const { return m_sfx_name; }
bool isFogEnabled() const { return m_fog; }
/**
* \brief Get the kind of particles that are to be used on this material, in the given conditions
* \return The particles to use, or NULL if none
*/
const ParticleKind* getParticlesWhen(ParticleConditions cond) const { return m_particles_effects[cond]; }
// ------------------------------------------------------------------------
/** Returns true if a kart falling over this kind of material triggers
* the special falling camera. */
@ -336,7 +336,7 @@ public:
} // getZipperParameter
bool isNormalMap() const { return m_graphical_effect == GE_NORMAL_MAP; }
void onMadeVisible(scene::IMeshBuffer* who);
void onHidden(scene::IMeshBuffer* who);
void isInitiallyHidden(scene::IMeshBuffer* who);

View File

@ -50,15 +50,15 @@ public:
MaterialManager();
~MaterialManager();
void loadMaterial ();
Material* getMaterialFor(video::ITexture* t,
Material* getMaterialFor(video::ITexture* t,
scene::IMeshBuffer *mb);
void setAllMaterialFlags(video::ITexture* t,
void setAllMaterialFlags(video::ITexture* t,
scene::IMeshBuffer *mb);
void adjustForFog(video::ITexture* t,
void adjustForFog(video::ITexture* t,
scene::IMeshBuffer *mb,
scene::ISceneNode* parent,
bool use_fog) const;
void setAllUntexturedMaterialFlags(scene::IMeshBuffer *mb) const;
int addEntity (Material *m);
@ -72,7 +72,7 @@ public:
void popTempMaterial ();
void makeMaterialsPermanent();
bool hasMaterial(const std::string& fname);
Material* getLatestMaterial() { return m_materials[m_materials.size()-1]; }
}; // MaterialManager

View File

@ -36,12 +36,12 @@ class MovingTexture : public NoCopy
private:
/** Translation increment per second. */
float m_dx, m_dy;
/** Delta set by user and count */
float m_dt;
float m_count;
bool m_isAnimatedByStep;
/** Current x,y position. */
float m_x, m_y;
/** The texture matrix of this texture. */

View File

@ -46,14 +46,14 @@ class Track;
class ParticleEmitter : public NoCopy
{
private:
/** Irrlicht's particle systems. */
scene::IParticleSystemSceneNode *m_node;
Vec3 m_position;
scene::ISceneNode* m_parent;
/** The emitters. Access to these is needed to adjust the number of
* particles per second. */
scene::IParticleEmitter *m_emitter;
@ -61,23 +61,23 @@ private:
#if VISUALIZE_BOX_EMITTER
std::vector<scene::ISceneNode*> m_visualisation;
#endif
const ParticleKind *m_particle_type;
unsigned int m_magic_number;
/** Decay of emission rate, in particles per second */
int m_emission_decay_rate;
/** The irrlicht emitter contains this info, but as an int. We want it as a float */
float m_min_rate, m_max_rate;
public:
LEAK_CHECK()
ParticleEmitter (const ParticleKind* type,
ParticleEmitter (const ParticleKind* type,
const Vec3 &position,
scene::ISceneNode* parent = NULL);
virtual ~ParticleEmitter();
@ -85,22 +85,22 @@ public:
void setCreationRateAbsolute(float fraction);
void setCreationRateRelative(float f);
int getCreationRate();
void setPosition(const Vec3 &pos);
const ParticleKind* getParticlesInfo() const { return m_particle_type; }
void setParticleType(const ParticleKind* p);
void resizeBox(float size);
void clearParticles();
scene::IParticleSystemSceneNode* getNode() { return m_node; }
/** call this if the node was freed otherwise */
void unsetNode() { m_node = NULL; }
void addHeightMapAffector(Track* t);
};
#endif

View File

@ -40,54 +40,54 @@ enum EmitterShape
class ParticleKind : public NoCopy
{
private:
/** Size of the particles. */
//float m_particle_size;
float m_max_size;
float m_min_size;
int m_angle_spread;
float m_velocity_x;
float m_velocity_y;
float m_velocity_z;
EmitterShape m_shape;
/** Minimal emission rate in particles per second */
int m_min_rate;
/** Maximal emission rate in particles per second */
int m_max_rate;
int m_lifetime_min;
int m_lifetime_max;
int m_fadeout_time;
video::SColor m_min_start_color;
video::SColor m_max_start_color;
/** Strength of gravity, not sure what the units are. Make it 0 to disable */
float m_gravity_strength;
/** Time it takes for gravity to completely replace the emission force */
int m_force_lost_to_gravity_time;
/** For box emitters only */
float m_box_x, m_box_y, m_box_z;
/** Distance from camera at which particles start fading out, or negative if disabled */
float m_fade_away_start, m_fade_away_end;
int m_emission_decay_rate;
std::string m_name;
std::string m_material_file;
public:
/**
* @brief Load a XML file describing a type of particles
* @param file Name of the file to load (no full path)
@ -96,48 +96,48 @@ public:
ParticleKind(const std::string file);
virtual ~ParticleKind() {}
float getMaxSize () const { return m_max_size; }
float getMinSize () const { return m_min_size; }
int getMinRate () const { return m_min_rate; }
int getMaxRate () const { return m_max_rate; }
EmitterShape getShape () const { return m_shape; }
Material* getMaterial () const;
int getMaxLifetime () const { return m_lifetime_max; }
int getMinLifetime () const { return m_lifetime_min; }
int getFadeoutTime () const { return m_fadeout_time; }
video::SColor getMinColor() const { return m_min_start_color; }
video::SColor getMaxColor() const { return m_max_start_color; }
float getBoxSizeX () const { return m_box_x; }
float getBoxSizeY () const { return m_box_y; }
float getBoxSizeZ () const { return m_box_z; }
int getAngleSpread () const { return m_angle_spread; }
float getVelocityX () const { return m_velocity_x; }
float getVelocityY () const { return m_velocity_y; }
float getVelocityZ () const { return m_velocity_z; }
/** Get the strength of gravity, not sure what the units are. Will be 0 if disabled. */
float getGravityStrength() const { return m_gravity_strength; }
/** Get the time it takes for gravity to completely replace the emission force. Meaningless if gravity is disabled. */
int getForceLostToGravityTime() const { return m_force_lost_to_gravity_time; }
float getFadeAwayStart() const { return m_fade_away_start; }
float getFadeAwayEnd () const { return m_fade_away_end; }
void setBoxSizeXZ (float x, float z) { m_box_x = x; m_box_z = z; }
int getEmissionDecayRate() const { return m_emission_decay_rate; }
std::string getName() const { return m_name; }
};

View File

@ -31,23 +31,23 @@
class ParticleKindManager : public NoCopy
{
private:
std::map<std::string, ParticleKind*> m_per_track_kinds;
std::map<std::string, ParticleKind*> m_kinds;
static ParticleKindManager* singleton;
ParticleKindManager();
public:
virtual ~ParticleKindManager();
ParticleKind* getParticles(const std::string &name);
void cleanUpTrackSpecificGfx();
void cleanup();
static ParticleKindManager* get();
};
#endif

View File

@ -37,7 +37,7 @@ namespace irr
const int ESNT_PER_CAMERA_NODE = MAKE_IRR_ID('p','c','a','m');
}
}
/**
* \brief manages smoke particle effects
* \ingroup graphics
@ -50,31 +50,31 @@ private:
scene::ICameraSceneNode* m_camera;
scene::ISceneNode* m_child;
public:
PerCameraNode(scene::ISceneNode* parent, scene::ISceneManager* mgr, s32 id,
scene::ICameraSceneNode* camera, scene::IMesh* mesh);
virtual ~PerCameraNode();
//! returns the axis aligned bounding box of this node
virtual const core::aabbox3d<f32>& getBoundingBox() const { return Box; }
//! Returns a reference to the current relative transformation matrix.
//! This is the matrix, this scene node uses instead of scale, translation
//! and rotation.
virtual core::matrix4& getRelativeTransformationMatrix() { return RelativeTransformationMatrix; }
//! Returns the relative transformation of the scene node.
virtual core::matrix4 getRelativeTransformation() const { return RelativeTransformationMatrix; }
void setCamera(scene::ICameraSceneNode* camera);
virtual void OnRegisterSceneNode();
virtual void render();
virtual scene::ESCENE_NODE_TYPE getType() const { return (scene::ESCENE_NODE_TYPE)scene::ESNT_PER_CAMERA_NODE; }
scene::ISceneNode* getChild() { return m_child; }
};

View File

@ -1,5 +1,5 @@
// SuperTuxKart - a fun racing game with go-kart
// Copyright (C) 2011-2013 the SuperTuxKart team
// Copyright (C) 2011-2013 the SuperTuxKart team
// Copyright (C) 2013 Joerg Henrichs
//
// This program is free software; you can redistribute it and/or
@ -42,7 +42,7 @@ private:
video::SMaterial m_blur_material;
bool m_supported;
/** Boost time, how long the boost should be displayed. This also
* affects the strength of the effect: longer boost time will
* have a stronger effect. */
@ -67,11 +67,11 @@ private:
/** The vertices for the rectangle used for each camera. This includes
* the vertex position, normal, and texture coordinate. */
std::vector<Quad> m_vertices;
public:
PostProcessing(video::IVideoDriver* video_driver);
virtual ~PostProcessing();
void reset();
/** Those should be called around the part where we render the scene to be post-processed */
void beginCapture();
@ -80,13 +80,13 @@ public:
/** Render the post-processed scene */
void render();
/** Is the hardware able to use post-processing? */
inline bool isSupported() const {return m_supported;}
/** Use motion blur for a short time */
void giveBoost(unsigned int cam_index);
/** Implement IShaderConstantsSetCallback. Shader constants setter for post-processing */
virtual void OnSetConstants(video::IMaterialRendererServices *services, s32 user_data);
};

View File

@ -39,21 +39,21 @@ class Rain
PerCameraNode* m_node[RAIN_RING_COUNT];
std::vector<irr::video::SMaterial*> m_materials;
float m_x[RAIN_RING_COUNT];
float m_y[RAIN_RING_COUNT];
float m_next_lightning;
bool m_lightning;
SFXBase* m_thunder_sound;
public:
Rain(Camera* camera, irr::scene::ISceneNode* parent);
~Rain();
void update(float dt);
void setPosition(const irr::core::vector3df& position);
void setCamera(scene::ICameraSceneNode* camera);
};

View File

@ -90,7 +90,7 @@ public:
scene::IAnimatedMeshSceneNode* getSceneNode() { return m_scene_node; }
// ------------------------------------------------------------------------
/** Moves the referee to the specified position. */
void setPosition(const Vec3 &xyz)
void setPosition(const Vec3 &xyz)
{m_scene_node->setPosition(xyz.toIrrVector()); }
// ------------------------------------------------------------------------
/** Sets the rotation of the scene node (in degrees).
@ -105,7 +105,7 @@ public:
* start of a race. */
static const Vec3& getStartOffset() {return m_st_start_offset; }
// ------------------------------------------------------------------------
/** Returns the rotation of the mesh so that it faces the kart (when
/** Returns the rotation of the mesh so that it faces the kart (when
* applied to a kart with heading 0). */
static const Vec3& getStartRotation() {return m_st_start_rotation; }
}; // Referee

View File

@ -30,7 +30,7 @@ namespace irr
}
using namespace irr;
/**
/**
* \brief This class is used to enable a shadow for a kart.
* For now it uses a simple texture to simulate the shadow, real time shadows might
* be added later.

View File

@ -33,7 +33,7 @@ using namespace irr;
/** This class is used for debugging. It allows to show an arbitrary curve
* in the race. The curve is shown as a 'tunnel', i.e. in the constructor
* you can specify the width and height of this tunnel. Each point then
* you can specify the width and height of this tunnel. Each point then
* adds 4 vertices: point + (+- width/2, +- height2, 0). That's not
* exact (if the curve is not parallel to the z axis), but good enough for
* debugging.
@ -64,7 +64,7 @@ private:
void addEmptyMesh();
public:
ShowCurve(float width, float height,
ShowCurve(float width, float height,
const irr::video::SColor &color = video::SColor(77, 0, 179, 0));
~ShowCurve();
void addPoint(const Vec3 &pnt);

View File

@ -61,7 +61,7 @@ private:
/** Material to use for the skid marks. */
video::SMaterial *m_material;
// ------------------------------------------------------------------------
class SkidMarkQuads : public scene::SMeshBuffer, public NoCopy
{
@ -76,11 +76,11 @@ private:
/** For culling, we need the overall radius of the skid marks. We
* approximate this by maintaining an axis-aligned boundary box. */
core::aabbox3df m_aabb;
video::SColor m_start_color;
public:
SkidMarkQuads (const Vec3 &left, const Vec3 &right,
SkidMarkQuads (const Vec3 &left, const Vec3 &right,
video::SMaterial *material, float z_offset,
video::SColor* custom_color = NULL);
void add (const Vec3 &left,
@ -104,12 +104,12 @@ private:
public:
SkidMarks(const AbstractKart& kart, float width=0.2f);
~SkidMarks();
void update (float dt, bool force_skid_marks=false,
video::SColor* custom_color = NULL);
void update (float dt, bool force_skid_marks=false,
video::SColor* custom_color = NULL);
void reset();
void adjustFog(bool enabled);
}; // SkidMarks
#endif

View File

@ -63,7 +63,7 @@ private:
/** The time a kart was in slipstream. */
float m_slipstream_time;
/** Slipstream mode: either nothing happening, or the kart is collecting
* 'slipstream credits', or the kart is using accumulated credits. */
enum {SS_NONE, SS_COLLECT, SS_USE} m_slipstream_mode;
@ -72,7 +72,7 @@ private:
* This value is current area, i.e. takes the kart position into account. */
Quad *m_slipstream_quad;
/** This is slipstream area if the kart is at 0,0,0 without rotation. From
/** This is slipstream area if the kart is at 0,0,0 without rotation. From
* this value m_slipstream_area is computed by applying the kart transform. */
Quad *m_slipstream_original_quad;

View File

@ -35,22 +35,22 @@ using namespace irr;
class Stars : public NoCopy
{
private:
/** Vector containing the stars */
std::vector<scene::ISceneNode*> m_nodes;
/** The scene node of the kart to which the stars belong. */
scene::ISceneNode *m_parent_kart_node;
/** Center around which stars rotate */
core::vector3df m_center;
/** Whether stars are currently enabled */
bool m_enabled;
float m_fade_in_time;
float m_remaining_time;
public:
Stars (scene::ISceneNode* parentKart, core::vector3df center);
~Stars ();

View File

@ -32,7 +32,7 @@ namespace GUIEngine
{
class Widget;
class Screen;
/**
* \ingroup guiengine
*/
@ -42,7 +42,7 @@ namespace GUIEngine
GAME,
INGAME_MENU
}; // GameState
/**
* \brief Abstract base class you must override from to use the GUI engine
* \ingroup guiengine
@ -54,118 +54,118 @@ namespace GUIEngine
* Whether we are in game mode
*/
GameState m_game_mode;
/**
* This stack will contain menu names (e.g. main.stkgui),
* This stack will contain menu names (e.g. main.stkgui),
* and/or 'race'.
*/
std::vector<std::string> m_menu_stack;
void pushMenu(std::string name);
void setGameState(GameState state);
public:
LEAK_CHECK()
/** inits an AbstractStateManager is MENU state */
AbstractStateManager();
virtual ~AbstractStateManager() { }
/** \brief adds a menu at the top of the screens stack */
void pushScreen(Screen* screen);
/** \brief replaces the menu at the top of the screens stack
* (i.e. pops the topmost screen and adds this one instead, but
* without displaying the second-topmost menu of the stack
* (i.e. pops the topmost screen and adds this one instead, but
* without displaying the second-topmost menu of the stack
* in-between)
*/
void replaceTopMostScreen(Screen* screen);
/**
* \brief removes the menu at the top of the screens stack
* If the stack becomes empty after performing the pop (i.e. if it
* If the stack becomes empty after performing the pop (i.e. if it
* contained only one item prior to the call), the game is aborted.
* In other cases, the second-topmost screen is displayed.
*/
void popMenu();
/**
* \brief clears the menu stack and starts afresh with a new stack
* \brief clears the menu stack and starts afresh with a new stack
* containing only the given screen
*/
void resetAndGoToScreen(Screen* screen);
/**
* \brief Sets the whole menu stack.
* Only the topmost screen will be inited/shown, but others remain
* under for cases where the user wants to go back.
* \param screens an array containing the menus that should go into
* stack. The first item will be the bottom item in the stack, the
* \param screens an array containing the menus that should go into
* stack. The first item will be the bottom item in the stack, the
* last item will be the stack top. Array must be NULL-terminated.
*/
void resetAndSetStack(Screen* screens[]);
/**
* \brief call to make the state manager enter game mode.
* Causes the menu stack to be cleared; all widgets shown on screen
* are removed
*/
void enterGameState();
/** \return the current state of the game */
GameState getGameState();
/** \brief to be called after e.g. a resolution switch */
void reshowTopMostMenu();
template<typename T>
void hardResetAndGoToScreen()
{
{
if (m_game_mode != GAME) GUIEngine::getCurrentScreen()->tearDown();
m_menu_stack.clear();
GUIEngine::clearScreenCache();
T* instance = T::getInstance();
m_menu_stack.push_back(instance->getName());
setGameState(MENU);
switchToScreen(instance->getName().c_str());
getCurrentScreen()->init();
onTopMostScreenChanged();
}
/* ***********************************
* methods to override in children *
*********************************** */
/**
* \brief callback invoked whenever escape was pressed (or any
* \brief callback invoked whenever escape was pressed (or any
* similar cancel operation)
*/
virtual void escapePressed() = 0;
/**
* \brief callback invoked when game mode changes (e.g. goes from
* \brief callback invoked when game mode changes (e.g. goes from
* "menu" to "in-game")
*/
virtual void onGameStateChange(GameState new_state) = 0;
/**
* \brief callback invoked when the stack is emptied (all menus are
* popped out). This is essentially a request to close the
* popped out). This is essentially a request to close the
* application (since a game can't run without a state)
*/
virtual void onStackEmptied() = 0;
virtual void onTopMostScreenChanged() = 0;
}; // Class AbstractStateManager
} // GUIEngine
#endif

View File

@ -29,10 +29,10 @@
namespace GUIEngine
{
class Widget;
/**
* \brief Represents a GUI widgets container.
*
*
* Abstract base class for both Screen and ModalDialog.
*
* \ingroup guiengine
@ -42,39 +42,39 @@ namespace GUIEngine
protected:
/** the widgets in this screen */
PtrVector<Widget, HOLD> m_widgets;
/**
* AbstractTopLevelContainer is generally able to determine its first
* widget just fine, but in highly complex screens (e.g. multiplayer
* kart selection) you can help it by providing the first widget
* widget just fine, but in highly complex screens (e.g. multiplayer
* kart selection) you can help it by providing the first widget
* manually.
*/
Widget* m_first_widget;
/**
* AbstractTopLevelContainer is generally able to determine its last
* widget just fine, but in highly complex screens (e.g. multiplayer
* kart selection) you can help it by providing the first widget
* kart selection) you can help it by providing the first widget
* manually.
*/
Widget* m_last_widget;
void addWidgetsRecursively(PtrVector<Widget>& widgets,
void addWidgetsRecursively(PtrVector<Widget>& widgets,
Widget* parent=NULL);
public:
AbstractTopLevelContainer();
virtual ~AbstractTopLevelContainer() {}
virtual int getWidth() = 0;
virtual int getHeight() = 0;
/** \return an object by name, or NULL if not found */
Widget* getWidget(const char* name);
/** \return an object by irrlicht ID, or NULL if not found */
Widget* getWidget(const int id);
/** This function searches and returns a widget by name, cast as specified type,
* if that widget is found and the type is correct.
* \param name The name of the widget to find
@ -88,26 +88,26 @@ namespace GUIEngine
if (out != NULL && outCasted == NULL)
{
fprintf(stderr, "Screen::getWidget : Widget '%s' of type '%s'"
"cannot be casted to requested type '%s'!\n", name,
typeid(*out).name(), typeid(T).name());
"cannot be casted to requested type '%s'!\n", name,
typeid(*out).name(), typeid(T).name());
abort();
}
return outCasted;
}
static Widget* getWidget(const char* name,
static Widget* getWidget(const char* name,
PtrVector<Widget>* within_vector);
static Widget* getWidget(const int id,
PtrVector<Widget>* within_vector);
Widget* getFirstWidget(PtrVector<Widget>* within_vector=NULL);
Widget* getLastWidget(PtrVector<Widget>* within_vector=NULL);
void elementsWereDeleted(PtrVector<Widget>* within_vector = NULL);
bool isMyChild(Widget* widget) const;
}; // AbstractTopLevelContainer
} // namespace GUIEngine
#endif

View File

@ -46,12 +46,12 @@ namespace irr
* See \ref gui_overview for more information.
*/
namespace GUIEngine
{
{
class Screen;
class Widget;
class Skin;
class AbstractStateManager;
/** \brief Returns the widget currently focused by given player, or NULL if none.
* \note Do NOT use irrLicht's GUI focus facilities; it's too limited for our
* needs, so we use ours. (i.e. always call these functions are never those
@ -72,7 +72,7 @@ namespace GUIEngine
* in IGUIEnvironment)
*/
bool isFocusedForPlayer(const Widget*w, const int playerID);
/**
* In an attempt to make getters as fast as possible, by possibly still allowing inlining
* These fields should never be accessed outside of the GUI engine.
@ -93,10 +93,10 @@ namespace GUIEngine
extern AbstractStateManager* g_state_manager;
extern Widget* g_focus_for_player[MAX_PLAYER_COUNT];
}
/** Widgets that need to be notified at every frame can add themselves there (FIXME: unclean) */
extern PtrVector<Widget, REF> needsUpdate;
/**
* \brief Call this method to init the GUI engine.
* \pre A irrlicht device and its corresponding video drivers must have been created
@ -105,32 +105,32 @@ namespace GUIEngine
* \param state_manager An instance of a class derived from abstract base AbstractStateManager
*/
void init(irr::IrrlichtDevice* device, irr::video::IVideoDriver* driver, AbstractStateManager* state_manager);
void cleanUp();
void deallocate();
/**
* \return the irrlicht device object
*/
inline irr::IrrlichtDevice* getDevice() { return Private::g_device; }
/**
* \return the irrlicht GUI environment object
*/
inline irr::gui::IGUIEnvironment* getGUIEnv() { return Private::g_env; }
/**
* \return the irrlicht video driver object
*/
inline irr::video::IVideoDriver* getDriver() { return Private::g_driver; }
/**
* \return the smaller font (useful for less important messages)
*/
inline irr::gui::ScalableFont* getSmallFont() { return Private::g_small_font; }
/**
* \return the "normal" font (useful for text)
*/
@ -140,7 +140,7 @@ namespace GUIEngine
* \return the "large" font (useful for text)
*/
inline irr::gui::ScalableFont* getLargeFont() { return Private::g_large_font; }
/**
* \return the "high-res digits" font (useful for big numbers)
*/
@ -150,19 +150,19 @@ namespace GUIEngine
* \return the "title" font (it's bigger and orange, useful for headers/captions)
*/
inline irr::gui::ScalableFont* getTitleFont() { return Private::g_title_font; }
/**
* \return the currently shown screen, or NULL if none
*/
inline Screen* getCurrentScreen() { return Private::g_current_screen; }
/**
* \return the state manager being used, as passed to GUIEngine::init
*/
inline AbstractStateManager* getStateManager() { return Private::g_state_manager; }
void clearScreenCache();
/**
* \pre GUIEngine::init must have been called first
* \return the skin object used to render widgets
@ -170,74 +170,74 @@ namespace GUIEngine
inline Skin* getSkin() { return Private::g_skin; }
Screen* getScreenNamed(const char* name);
/** \return the height of the title font in pixels */
int getTitleFontHeight();
/** \return the height of the font in pixels */
int getFontHeight();
/** \return the height of the small font in pixels */
int getSmallFontHeight();
/**
* \pre the value returned by this function is only valid when invoked from GUIEngine::render
* \return the time delta between the last two frames
*/
float getLatestDt();
/**
* \brief shows a message at the bottom of the screen for a while
* \param message the message to display
* \param time the time to display the message, in seconds
*/
void showMessage(const wchar_t* message, const float time=5.0f);
/** \brief Add a screen to the list of screens known by the gui engine */
void addScreenToList(Screen* screen);
/** \brief Low-level mean to change current screen.
* \note Do not use directly. Use a state manager instead to get higher-level functionnality.
*/
void switchToScreen(const char* );
/** \brief erases the currently displayed screen, removing all added irrLicht widgets
* \note Do not use directly. Use a state manager instead to get higher-level functionnality.
*/
void clear();
void update(float dt);
/** \brief like GUIEngine::clear, but to be called before going into game */
void cleanForGame();
/** \brief to be called after e.g. a resolution switch */
void reshowCurrentScreen();
/**
* \brief called on every frame to trigger the rendering of the GUI
*/
void render(float dt);
/** \brief renders a "loading" screen */
void renderLoading(bool clearIcons = true);
/** \brief to spice up a bit the loading icon : add icons to the loading screen */
void addLoadingIcon(irr::video::ITexture* icon);
/** \brief Finds a widget from its name (PROP_ID) in the current screen/dialog
* \param name the name (PROP_ID) of the widget to search for
* \return the widget that bears that name, or NULL if it was not found
*/
Widget* getWidget(const char* name);
/** \brief Finds a widget from its irrlicht widget ID in the current screen/dialog
* \param name the irrlicht widget ID (not to be confused with PROP_ID, which is a string)
* of the widget to search for
* \return the widget that bears that irrlicht ID, or NULL if it was not found
*/
Widget* getWidget(const int id);
/**
* \brief call when skin in user config was updated
*/

View File

@ -28,7 +28,7 @@
*/
namespace GUIEngine
{
/**
* \ingroup guiengine
*/
@ -37,9 +37,9 @@ namespace GUIEngine
EVENT_BLOCK,
EVENT_LET
};
class Widget;
/**
* \brief Class to handle irrLicht events (GUI and input as well)
*
@ -59,30 +59,30 @@ namespace GUIEngine
EventPropagation onWidgetActivated(Widget* w, const int playerID);
void navigateUp(const int playerID, Input::InputType type, const bool pressedDown);
void navigateDown(const int playerID, Input::InputType type, const bool pressedDown);
/** \brief send an event to the GUI module user's event callback
* \param widget the widget that triggerred this event
* \param name the name/ID (PROP_ID) of the widget that triggerred this event
* \param playerID ID of the player that triggerred this event
*/
void sendEventToUser(Widget* widget, std::string& name, const int playerID);
/** Last position of the mouse cursor */
irr::core::vector2di m_mouse_pos;
public:
LEAK_CHECK()
EventHandler();
~EventHandler();
/**
* All irrLicht events will go through this (input as well GUI; input events are
* immediately delegated to the input module, GUI events are processed here)
*/
bool OnEvent (const irr::SEvent &event);
/**
* When the input module is done processing an input and mapped it to an action,
* and this action needs to be applied to the GUI (e.g. fire pressed, left
@ -90,15 +90,15 @@ namespace GUIEngine
*/
void processGUIAction(const PlayerAction action, int deviceID, const unsigned int value,
Input::InputType type, const int playerID);
/** Get the mouse position */
const irr::core::vector2di& getMousePos() const { return m_mouse_pos; }
/** singleton access */
static EventHandler* get();
static void deallocate();
};
}
#endif

View File

@ -27,10 +27,10 @@ namespace GUIEngine
{
class Widget;
class AbstractTopLevelContainer;
class LayoutManager
{
/**
* \brief Receives as string the raw property value retrieved from XML file.
* Will try to make sense of it, as an absolute value or a percentage.
@ -40,9 +40,9 @@ namespace GUIEngine
* Returns false if couldn't convert to either
*/
static bool convertToCoord(std::string& x, int* absolute /* out */, int* percentage /* out */);
static void recursivelyReadCoords(PtrVector<Widget>& widgets);
/**
* \brief Recursive call that lays out children widget within parent (or screen if none).
*
@ -51,10 +51,10 @@ namespace GUIEngine
*/
static void doCalculateLayout(PtrVector<Widget>& widgets, AbstractTopLevelContainer* topLevelContainer,
Widget* parent);
public:
/**
* \brief Recursive call that lays out children widget within parent (or screen if none).
*
@ -62,13 +62,13 @@ namespace GUIEngine
* of the remaining children, as well as absolute sizes and locations.
*/
static void calculateLayout(PtrVector<Widget>& widgets, AbstractTopLevelContainer* topLevelContainer);
/**
* \brief Find a widget's x, y, w and h coords from what is specified in the XML properties.
* Most notably, expands coords relative to parent and percentages.
*/
static void applyCoords(Widget* self, AbstractTopLevelContainer* topLevelContainer, Widget* parent);
/**
* \brief Find a widget's x, y, w and h coords from what is specified in the XML properties.
* (First step; 'applyCoords' is the second step)

View File

@ -38,13 +38,13 @@ namespace GUIEngine
class Widget;
class TextBoxWidget;
class ButtonWidget;
enum ModalDialogLocation
{
MODAL_DIALOG_LOCATION_CENTER = 0,
MODAL_DIALOG_LOCATION_BOTTOM = 1
};
/**
* \brief Abstract base class representing a modal dialog.
* Only once instance at a time (if you create a 2nd the first will be destroyed).
@ -57,16 +57,16 @@ namespace GUIEngine
private:
/** Because C++ doesn't support constructor delegation... */
void doInit(const float percentWidth, const float percentHeight);
ModalDialogLocation m_dialog_location;
protected:
irr::gui::IGUIWindow* m_irrlicht_window;
irr::core::rect< irr::s32 > m_area;
InputManager::InputDriverMode m_previous_mode;
/**
* \brief Creates a modal dialog with given percentage of screen width and height
*/
@ -80,57 +80,57 @@ namespace GUIEngine
virtual void onEnterPressedInternal();
void clearWindow();
/** \brief Callback invoked when the dialog was loaded from the XML file (if the constructor
* that takes a XML file as argument is used)
*/
virtual void loadedFromFile() {}
public:
LEAK_CHECK()
virtual ~ModalDialog();
/** Returns whether to block event propagation (usually, you will want to block events you processed) */
virtual EventPropagation processEvent(const std::string& eventSource){ return EVENT_LET; }
irr::gui::IGUIWindow* getIrrlichtElement()
{
return m_irrlicht_window;
}
static void dismiss();
static void onEnterPressed();
static ModalDialog* getCurrent();
static bool isADialogActive();
/** Override to change what happens on escape pressed */
virtual void escapePressed() { dismiss(); }
/** Override to be notified of updates */
virtual void onUpdate(float dt) { }
/**
* \brief Optional callback invoked very early, before widgets have been added (contrast with
* init(), which is invoked afer widgets were added)
*/
virtual void beforeAddingWidgets() {}
/** \brief Optional callback invoked after widgets have been add()ed */
virtual void init() {}
/**
* \brief Implementing callback from AbstractTopLevelContainer
*/
virtual int getWidth() { return m_area.getWidth(); }
/**
* \brief Implementing callback from AbstractTopLevelContainer
*/
virtual int getHeight() { return m_area.getHeight(); }
bool isMyIrrChild(irr::gui::IGUIElement* widget) const { return m_irrlicht_window->isMyChild(widget); }
};
};
}
#endif

View File

@ -39,41 +39,41 @@ class ScalableFont : public IGUIFontBitmap
bool m_mono_space_digits;
irr::video::SColor m_shadow_color;
struct TextureInfo
{
irr::core::stringc m_file_name;
bool m_has_alpha;
float m_scale;
bool m_exclude_from_max_height_calculation;
TextureInfo()
{
m_has_alpha = false;
m_scale = 1.0f;
}
};
std::map<int /* texture file ID */, TextureInfo> m_texture_files;
void doReadXmlFile(io::IXMLReader* xml);
bool m_is_hollow_copy;
bool m_rtl;
/** Position in range [0..1] of the single tab stop we support */
float m_tab_stop;
public:
LEAK_CHECK()
bool m_black_border;
ScalableFont* m_fallback_font;
float m_fallback_font_scale;
int m_fallback_kerning_width;
//! constructor
ScalableFont(IGUIEnvironment* env, const io::path& filename);
@ -91,7 +91,7 @@ public:
out->m_is_hollow_copy = true;
return out;
}
//! destructor
virtual ~ScalableFont();
@ -108,7 +108,7 @@ public:
virtual void draw(const core::stringw& text, const core::rect<s32>& position,
video::SColor color, bool hcenter,
bool vcenter, const core::rect<s32>* clip, bool ignoreRTL);
//! returns the dimension of a text
virtual core::dimension2d<u32> getDimension(const wchar_t* text) const;
@ -142,12 +142,12 @@ public:
void setScale(const float scale);
float getScale() const { return m_scale; }
void updateRTL();
/** \param pos position of the tab stop, in range [0..1] */
void setTabStop(float pos) { m_tab_stop = pos; }
private:
struct SFontArea
@ -158,7 +158,7 @@ private:
s32 width;
u32 spriteno;
};
int getCharWidth(const SFontArea& area, const bool fallback) const;
s32 getAreaIDFromCharacter(const wchar_t c, bool* fallback_font) const;
const SFontArea &getAreaFromCharacter(const wchar_t c, bool* fallback_font) const;

View File

@ -96,7 +96,7 @@ namespace GUIEngine
class Screen : public AbstractTopLevelContainer
{
private:
/** True if the race (if it is running) should be paused when this
/** True if the race (if it is running) should be paused when this
* screen is shown. The RaceResultGUI uses this to leave the race
* running while it is being shown. */
bool m_pause_race;
@ -180,7 +180,7 @@ namespace GUIEngine
*/
void setNeeds3D(bool needs3D) { m_render_3d = needs3D; }
/**
/**
* \brief Callback invoked when loading this menu.
*
* \pre Children widgets of this menu have been created by the time
@ -216,7 +216,7 @@ namespace GUIEngine
*/
virtual void beforeAddingWidget() {}
/**
/**
* \brief Callback invoked when entering this menu (after the
* widgets have been added).
*
@ -227,7 +227,7 @@ namespace GUIEngine
*/
virtual void init();
/**
/**
* \brief Callback invoked before leaving this menu.
*
* \note The same instance of your object may be entered/left more
@ -237,7 +237,7 @@ namespace GUIEngine
*/
virtual void tearDown();
/**
/**
* \brief Called when escape is pressed.
* \return true if the screen should be closed,
* false if you handled the press another way
@ -283,7 +283,7 @@ namespace GUIEngine
int deviceID,
const unsigned int value,
Input::InputType type,
int playerId)
int playerId)
{ return EVENT_LET; }
/** Callback you can use if you want to know when the user pressed

View File

@ -40,91 +40,91 @@ using namespace irr;
/**
\page skin Overview of GUI skin
The GUIEngine::Skin is the one handling skinning. It loads images and their
sizing from a XML file. Since the irrLicht way of handling skin is quite
"boxy" and results in games looking like Window 95, this class overrides it
The GUIEngine::Skin is the one handling skinning. It loads images and their
sizing from a XML file. Since the irrLicht way of handling skin is quite
"boxy" and results in games looking like Window 95, this class overrides it
very much; in pretty much all callbacks, rather drawing plainly what irrLicht
asks it to draw, it first checks which widget we're asked to render and
asks it to draw, it first checks which widget we're asked to render and
redirects the call to a more specific method.
Furthermore, since irrLicht widgets were quite basic, a few widgets were
created by combining several irrLicht widgets (e.g. 2 buttons and a label in
a box make a spinner). Because of this, some jumping through hoops is
Furthermore, since irrLicht widgets were quite basic, a few widgets were
created by combining several irrLicht widgets (e.g. 2 buttons and a label in
a box make a spinner). Because of this, some jumping through hoops is
performed (we get a callback for each of these sub-widgets, but want to draw
the whole thing as a single block)
There are two types of images : some will be simply stretched as a whole,
others will have non-stretchable borders (you cannot choose which one you
must use, it's hardcoded for each element type; though, as you will see
below, for all "advanced stretching" images you can easily fake "simple
There are two types of images : some will be simply stretched as a whole,
others will have non-stretchable borders (you cannot choose which one you
must use, it's hardcoded for each element type; though, as you will see
below, for all "advanced stretching" images you can easily fake "simple
stretch")
\section Describing a skin in a XML file
All elements will have at least 2 properties :
\li \c type="X" : sets what you're skinning with this entry
\li \c image="skinDirectory/imageName.png" : sets which image is used for
\li \c image="skinDirectory/imageName.png" : sets which image is used for
this element
For more information, I highly recommend simply looking at existing skins,
For more information, I highly recommend simply looking at existing skins,
they will show the format of the XML file describing a skin quite well.
\section states Widget States
Most elements also support states :
\li \c state="neutral"
\li \c state="focused"
\li \c state="down"
You can thus give different looks for different states. Not all widgets
support all states, see entries and comments below to know what's
You can thus give different looks for different states. Not all widgets
support all states, see entries and comments below to know what's
supported. Note that checkboxes are an exception and have the following
styles :
\li \lc "neutral+unchecked"
\li \lc "neutral+checked"
\li \lc "focused+unchecked"
\li \lc "focused+checked"
\section stretch Advanced stretching
"Advanced stretching" images are split this way :
\code
+----+--------------------+----+
| | | |
+----+--------------------+----+
| | | |
| | | |
| | | |
| | | |
| | | |
+----+--------------------+----+
| | | |
| | | |
+----+--------------------+----+
\endcode
The center border will be stretched in all directions. The 4 corners will not
stretch at all. Horizontal borders will stretch horizontally, vertical
borders will stretch vertically. Use properties left_border="X"
stretch at all. Horizontal borders will stretch horizontally, vertical
borders will stretch vertically. Use properties left_border="X"
right_border="X" top_border="X" bottom_border="X" to specify the size of each
border in pixels (setting all borders to '0' makes the whole image scaled).
In some cases, you may not want vertical stretching to occur (like if the left
and right sides of the image must not be stretched vertically, e.g. for the
spinner). In this case, pass parameter preserve_h_aspect_ratios="true" to
and right sides of the image must not be stretched vertically, e.g. for the
spinner). In this case, pass parameter preserve_h_aspect_ratios="true" to
make the left and right areas stretch by keeping their aspect ratio.
Some components may fill the full inner area with stuff; others will only take
a smaller area at the center. To adjust for this, there are properties
a smaller area at the center. To adjust for this, there are properties
"hborder_out_portion" and "vborder_out_portion" that take a float from 0 to 1,
representing the percentage of each border that goes out of the widget's area
(this might include stuff like shadows, etc.). The 'h' one is for horizontal
(this might include stuff like shadows, etc.). The 'h' one is for horizontal
borders, the 'v' one is for vertical borders.
Finnally : the image is split, as shown above, into 9 areas. In some cases,
you may not want all areas to be rendered. Then you can pass parameter
areas="body+left+right+top+bottom" and explicitely specify which parts you
want to see. The 4 corner areas are only visible when the border that
Finnally : the image is split, as shown above, into 9 areas. In some cases,
you may not want all areas to be rendered. Then you can pass parameter
areas="body+left+right+top+bottom" and explicitely specify which parts you
want to see. The 4 corner areas are only visible when the border that
intersect at this corner are enabled.
*/
/**
@ -132,10 +132,10 @@ using namespace irr;
*/
namespace GUIEngine
{
/**
* In order to avoid calculating render information every frame, it's
* stored in a SkinWidgetContainer for each widget (or each widget part
* In order to avoid calculating render information every frame, it's
* stored in a SkinWidgetContainer for each widget (or each widget part
* if it requires many)
* \ingroup guiengine
*/
@ -143,40 +143,40 @@ namespace GUIEngine
{
public:
int m_skin_x, m_skin_y, m_skin_w, m_skin_h;
bool m_skin_dest_areas_inited;
bool m_skin_dest_areas_yflip_inited;
int m_skin_dest_x, m_skin_dest_y, m_skin_dest_x2, m_skin_dest_y2;
// see comments in Skin::drawBoxFromStretchableTexture for
// see comments in Skin::drawBoxFromStretchableTexture for
// explaination of what these are
core::rect<s32> m_skin_dest_area_left;
core::rect<s32> m_skin_dest_area_center;
core::rect<s32> m_skin_dest_area_right;
core::rect<s32> m_skin_dest_area_top;
core::rect<s32> m_skin_dest_area_bottom;
core::rect<s32> m_skin_dest_area_top_left;
core::rect<s32> m_skin_dest_area_top_right;
core::rect<s32> m_skin_dest_area_bottom_left;
core::rect<s32> m_skin_dest_area_bottom_right;
// y flip
core::rect<s32> m_skin_dest_area_left_yflip;
core::rect<s32> m_skin_dest_area_center_yflip;
core::rect<s32> m_skin_dest_area_right_yflip;
core::rect<s32> m_skin_dest_area_top_yflip;
core::rect<s32> m_skin_dest_area_bottom_yflip;
core::rect<s32> m_skin_dest_area_top_left_yflip;
core::rect<s32> m_skin_dest_area_top_right_yflip;
core::rect<s32> m_skin_dest_area_bottom_left_yflip;
core::rect<s32> m_skin_dest_area_bottom_right_yflip;
core::rect<s32> m_skin_dest_area_bottom_right_yflip;
short m_skin_r, m_skin_g, m_skin_b;
SkinWidgetContainer()
{
m_skin_dest_areas_inited = false;
@ -190,13 +190,13 @@ namespace GUIEngine
m_skin_b = -1;
} // SkinWidgetContainer
}; // class SkinWidgetContainer
// ========================================================================
class Widget;
/**
* \brief class containing render params for the
* 'drawBoxFromStretchableTexture' function see \ref skin for more
* \brief class containing render params for the
* 'drawBoxFromStretchableTexture' function see \ref skin for more
* information about skinning in STK
* \ingroup guiengine
*/
@ -205,15 +205,15 @@ namespace GUIEngine
video::ITexture* m_image;
bool m_y_flip_set;
public:
public:
int m_left_border, m_right_border, m_top_border, m_bottom_border;
bool m_preserve_h_aspect_ratios;
float m_hborder_out_portion, m_vborder_out_portion;
// this parameter is a bit special since it's the only one that can
// change at runtime
bool m_vertical_flip;
/** bitmap containing which areas to render */
int areas;
// possible values in areas
@ -222,33 +222,33 @@ namespace GUIEngine
static const int RIGHT = 4;
static const int TOP = 8;
static const int BOTTOM = 16;
core::rect<s32> m_source_area_left;
core::rect<s32> m_source_area_center;
core::rect<s32> m_source_area_right;
core::rect<s32> m_source_area_top;
core::rect<s32> m_source_area_bottom;
core::rect<s32> m_source_area_top_left;
core::rect<s32> m_source_area_top_right;
core::rect<s32> m_source_area_bottom_left;
core::rect<s32> m_source_area_bottom_right;
core::rect<s32> m_source_area_bottom_right;
// y-flipped coords
core::rect<s32> m_source_area_left_yflip;
core::rect<s32> m_source_area_center_yflip;
core::rect<s32> m_source_area_right_yflip;
core::rect<s32> m_source_area_top_yflip;
core::rect<s32> m_source_area_bottom_yflip;
core::rect<s32> m_source_area_top_left_yflip;
core::rect<s32> m_source_area_top_right_yflip;
core::rect<s32> m_source_area_bottom_left_yflip;
core::rect<s32> m_source_area_bottom_right_yflip;
BoxRenderParams();
void setTexture(video::ITexture* image);
void calculateYFlipIfNeeded();
@ -256,7 +256,7 @@ namespace GUIEngine
/** Returns the image for this BoxRenderParams. */
video::ITexture* getImage() { return m_image; }
}; // BoxRenderParams
// ========================================================================
/**
* \brief Object used to render the GUI widgets
@ -266,75 +266,75 @@ namespace GUIEngine
class Skin : public gui::IGUISkin
{
gui::IGUISkin* m_fallback_skin;
video::ITexture* bg_image;
std::vector<Widget*> m_tooltips;
std::vector<bool> m_tooltip_at_mouse;
#ifdef USE_PER_LINE_BACKGROUND
public:
#endif
LEAK_CHECK()
void drawBoxFromStretchableTexture(SkinWidgetContainer* w,
void drawBoxFromStretchableTexture(SkinWidgetContainer* w,
const core::rect< s32 > &dest,
BoxRenderParams& params,
BoxRenderParams& params,
bool deactivated=false,
const core::rect<s32>* clipRect=NULL);
private:
// my utility methods, to work around irrlicht's very
// my utility methods, to work around irrlicht's very
// Windows-95-like-look-enforcing skin system
void process3DPane(gui::IGUIElement *element,
void process3DPane(gui::IGUIElement *element,
const core::rect< s32 > &rect, const bool pressed);
void drawButton(Widget* w, const core::rect< s32 > &rect,
void drawButton(Widget* w, const core::rect< s32 > &rect,
const bool pressed, const bool focused);
void drawProgress(Widget* w, const core::rect< s32 > &rect,
void drawProgress(Widget* w, const core::rect< s32 > &rect,
const bool pressed, const bool focused);
void drawRibbon(const core::rect< s32 > &rect, Widget* widget,
void drawRibbon(const core::rect< s32 > &rect, Widget* widget,
const bool pressed, bool focused);
void drawRibbonChild(const core::rect< s32 > &rect, Widget* widget,
const bool pressed, bool focused);
void drawSpinnerChild(const core::rect< s32 > &rect, Widget* widget,
const bool pressed, bool focused);
void drawSpinnerBody(const core::rect< s32 > &rect, Widget* widget,
void drawSpinnerBody(const core::rect< s32 > &rect, Widget* widget,
const bool pressed, bool focused);
void drawGauge(const core::rect< s32 > &rect, Widget* widget,
void drawGauge(const core::rect< s32 > &rect, Widget* widget,
bool focused);
void drawGaugeFill(const core::rect< s32 > &rect, Widget* widget,
void drawGaugeFill(const core::rect< s32 > &rect, Widget* widget,
bool focused);
void drawCheckBox(const core::rect< s32 > &rect, Widget* widget,
void drawCheckBox(const core::rect< s32 > &rect, Widget* widget,
bool focused);
void drawList(const core::rect< s32 > &rect, Widget* widget,
void drawList(const core::rect< s32 > &rect, Widget* widget,
bool focused);
void drawListHeader(const core::rect< s32 > &rect, Widget* widget);
void drawListSelection(const core::rect< s32 > &rect, Widget* widget,
bool focused, const core::rect< s32 > *clip);
void drawIconButton(const core::rect< s32 > &rect, Widget* widget,
void drawIconButton(const core::rect< s32 > &rect, Widget* widget,
const bool pressed, bool focused);
void drawScrollbarBackground(const core::rect< s32 > &rect);
void drawScrollbarThumb(const core::rect< s32 > &rect);
void drawScrollbarButton(const core::rect< s32 > &rect,
void drawScrollbarButton(const core::rect< s32 > &rect,
const bool pressed, const bool bottomArrow);
void drawTooltip(Widget* widget, bool atMouse);
public:
// dirty way to have dialogs that zoom in
bool m_dialog;
float m_dialog_size;
/**
* \brief load a skin from the file specified in the user configuration file
* \throw std::runtime_error if file cannot be read
*/
Skin(gui::IGUISkin* fallback_skin);
~Skin();
static video::SColor getColor(const std::string &name);
void renderSections(PtrVector<Widget>* within_vector=NULL);
void drawBgImage();
@ -342,73 +342,73 @@ namespace GUIEngine
void drawBadgeOn(const Widget* widget, const core::rect<s32>& rect);
// irrlicht's callbacks
virtual void draw2DRectangle (gui::IGUIElement *element,
virtual void draw2DRectangle (gui::IGUIElement *element,
const video::SColor &color,
const core::rect< s32 > &pos,
const core::rect< s32 > &pos,
const core::rect< s32 > *clip);
virtual void draw3DButtonPanePressed(gui::IGUIElement *element,
virtual void draw3DButtonPanePressed(gui::IGUIElement *element,
const core::rect< s32 > &rect,
const core::rect< s32 > *clip);
virtual void draw3DButtonPaneStandard(gui::IGUIElement *element,
const core::rect< s32 > &rect,
const core::rect< s32 > &rect,
const core::rect< s32 > *clip);
virtual void draw3DMenuPane (gui::IGUIElement *element,
const core::rect< s32 > &rect,
virtual void draw3DMenuPane (gui::IGUIElement *element,
const core::rect< s32 > &rect,
const core::rect< s32 > *clip);
virtual void draw3DSunkenPane (gui::IGUIElement *element,
video::SColor bgcolor,
bool flat, bool fillBackGround,
const core::rect< s32 > &rect,
virtual void draw3DSunkenPane (gui::IGUIElement *element,
video::SColor bgcolor,
bool flat, bool fillBackGround,
const core::rect< s32 > &rect,
const core::rect< s32 > *clip);
virtual void draw3DTabBody (gui::IGUIElement *element, bool border,
bool background,
const core::rect< s32 > &rect,
const core::rect< s32 > *clip,
s32 tabHeight=-1,
bool background,
const core::rect< s32 > &rect,
const core::rect< s32 > *clip,
s32 tabHeight=-1,
gui::EGUI_ALIGNMENT alignment=
gui::EGUIA_UPPERLEFT);
virtual void draw3DTabButton (gui::IGUIElement *element,
bool active,
const core::rect< s32 > &rect,
const core::rect< s32 > *clip,
virtual void draw3DTabButton (gui::IGUIElement *element,
bool active,
const core::rect< s32 > &rect,
const core::rect< s32 > *clip,
gui::EGUI_ALIGNMENT alignment=
gui::EGUIA_UPPERLEFT);
virtual void draw3DToolBar (gui::IGUIElement *element,
const core::rect< s32 > &rect,
virtual void draw3DToolBar (gui::IGUIElement *element,
const core::rect< s32 > &rect,
const core::rect< s32 > *clip);
virtual core::rect< s32 >
draw3DWindowBackground(gui::IGUIElement *element,
bool drawTitleBar,
video::SColor titleBarColor,
virtual core::rect< s32 >
draw3DWindowBackground(gui::IGUIElement *element,
bool drawTitleBar,
video::SColor titleBarColor,
const core::rect< s32 > &rect,
const core::rect< s32 > *clip,
core::rect<s32>* checkClientArea=0);
virtual void drawIcon (gui::IGUIElement *element,
gui::EGUI_DEFAULT_ICON icon,
const core::position2di position,
u32 starttime, u32 currenttime,
bool loop=false,
virtual void drawIcon (gui::IGUIElement *element,
gui::EGUI_DEFAULT_ICON icon,
const core::position2di position,
u32 starttime, u32 currenttime,
bool loop=false,
const core::rect< s32 > *clip=NULL);
virtual video::SColor getColor (gui::EGUI_DEFAULT_COLOR color) const;
virtual const wchar_t*
virtual const wchar_t*
getDefaultText(gui::EGUI_DEFAULT_TEXT text) const;
virtual gui::IGUIFont* getFont(gui::EGUI_DEFAULT_FONT which=
gui::EGDF_DEFAULT) const ;
virtual u32 getIcon (gui::EGUI_DEFAULT_ICON icon) const ;
virtual s32 getSize (gui::EGUI_DEFAULT_SIZE size) const ;
virtual gui::IGUISpriteBank * getSpriteBank () const ;
virtual void setColor (gui::EGUI_DEFAULT_COLOR which,
virtual void setColor (gui::EGUI_DEFAULT_COLOR which,
video::SColor newColor);
virtual void setDefaultText (gui::EGUI_DEFAULT_TEXT which,
virtual void setDefaultText (gui::EGUI_DEFAULT_TEXT which,
const wchar_t* newText);
virtual void setFont (gui::IGUIFont *font,
virtual void setFont (gui::IGUIFont *font,
gui::EGUI_DEFAULT_FONT which=gui::EGDF_DEFAULT);
virtual void setIcon (gui::EGUI_DEFAULT_ICON icon, u32 index);
virtual void setSize (gui::EGUI_DEFAULT_SIZE which, s32 size);
virtual void setSpriteBank (gui::IGUISpriteBank *bank);
void drawTooltips();
video::ITexture* getImage(const char* name);
gui::IGUISkin* getFallbackSkin() { return m_fallback_skin; }

View File

@ -33,9 +33,9 @@ namespace irr
namespace GUIEngine
{
class DynamicRibbonWidget;
enum WidgetType
{
WTYPE_NONE = -1,
@ -54,7 +54,7 @@ namespace GUIEngine
WTYPE_TEXTBOX,
WTYPE_PROGRESS
};
enum BadgeType
{
/** display a lock on the widget, to mean a certain game feature is locked */
@ -72,8 +72,8 @@ namespace GUIEngine
/** An hourglass badge to indocate loading */
LOADING_BADGE = 64
};
enum Property
{
PROP_ID = 100,
@ -102,10 +102,10 @@ namespace GUIEngine
PROP_MAX_ROWS,
PROP_WRAP_AROUND
};
bool isWithinATextBox();
void setWithinATextBox(bool in);
/**
* \brief The nearly-abstract base of all widgets
* (not fully abstract since a bare Widget can be created for the sole goal of containing
@ -122,8 +122,8 @@ namespace GUIEngine
* \ingroup guiengine
*/
class Widget : public SkinWidgetContainer
{
protected:
{
protected:
unsigned int m_magic_number;
// FIXME: find better ways than hackish "friend"?
@ -137,19 +137,19 @@ namespace GUIEngine
friend class LayoutManager;
friend class ModalDialog;
friend class AbstractTopLevelContainer;
/** Used during loading, by the layout engine. After layout is done this is not read anymore. */
int m_absolute_x, m_absolute_y, m_absolute_w, m_absolute_h;
int m_absolute_reverse_x, m_absolute_reverse_y;
float m_relative_x, m_relative_y, m_relative_w, m_relative_h;
/** PROP_TEXT is a special case : since it can be translated it can't
* go in the map above, which uses narrow strings */
irr::core::stringw m_text;
/** Whether the text in m_text is right-to-left */
bool m_is_text_rtl;
/** When true, this widget shall use a bigger and more colourful font */
bool m_title_font;
@ -159,41 +159,41 @@ namespace GUIEngine
* irrLicht widget can not directly contain this state
*/
bool m_selected[MAX_PLAYER_COUNT];
/**
* Whether to descend in the children of this widget when searching a widget
* from its ID or name. (children classes can override this value as they please)
*/
bool m_check_inside_me;
/**
* called when right key is pressed and focus is on widget.
* called when right key is pressed and focus is on widget.
* Returns 'EVENT_LET' if user's event handler should be notified of a change.
* Override in children to be notified of left/right events and/or make
* the event propagate to the user's event handler.
*/
virtual EventPropagation rightPressed(const int playerID) { return EVENT_BLOCK; }
/**
* called when left key is pressed and focus is on widget.
* called when left key is pressed and focus is on widget.
* Returns 'EVENT_LET' if user's event handler should be notified of a change.
* Override in children to be notified of left/right events and/or make
* the event propagate to the user's event handler.
*/
virtual EventPropagation leftPressed (const int playerID) { return EVENT_BLOCK; }
/** used when you set eventSupervisors - see m_event_handler explainations below
called when one of a widget's children is hovered.
\return 'EVENT_LET' if main event handler should be notified of a change, 'EVENT_BLOCK' otherwise */
virtual EventPropagation mouseHovered(Widget* child, const int playerID) { return EVENT_BLOCK; }
/** override in children if you need to know when the widget is focused.
* \return whether to block event */
virtual EventPropagation focused(const int playerID) { setWithinATextBox(false); return EVENT_LET; }
/** override in children if you need to know when the widget is unfocused. */
virtual void unfocused(const int playerID, Widget* new_focus) { }
/**
* An irrlicht parent (most often used to put widgets in dialogs)
*/
@ -203,13 +203,13 @@ namespace GUIEngine
* IrrLicht widget created to represent this object.
*/
irr::gui::IGUIElement* m_element;
/** numerical ID used by irrLicht to identify this widget
* (not the same as the string identificator specified in the XML file)
*/
int m_id;
/** Usually, only one widget at a time can be focused. There is however a special case where all
players can move through the screen. This variable will then be used as a bitmask to contain
which players beyong player 1 have this widget focused. */
@ -220,7 +220,7 @@ namespace GUIEngine
/** Type of this widget */
WidgetType m_type;
/**
* If this widget has any children, they go here. Children can be either
* specified in the XML file (e.g. Ribbon or Div children), or can also
@ -228,27 +228,27 @@ namespace GUIEngine
* one irrlicht widgets (e.g. Spinner)
*/
PtrVector<Widget> m_children;
/** A bitmask of which badges to show, if any; choices are *_BADGE, defined above */
int m_badges;
/** A simple flag that can be raised to hide this widget */
bool m_deactivated;
/** Set to false if widget is something that should not receive focus */
bool m_focusable;
bool m_bottom_bar;
bool m_top_bar;
/** If a badge wouldn't look too pretty on the very side of the widget */
int m_badge_x_shift;
bool m_has_tooltip;
irr::core::stringw m_tooltip_text;
public:
/**
* This is set to NULL by default; set to something else in a widget to mean
* that events happening on this widget should also be passed to m_event_handler->transmitEvent,
@ -257,29 +257,29 @@ namespace GUIEngine
* one irrlicht widgets (e.g. Spinner, Ribbon)
*/
Widget* m_event_handler;
/**
* Whether this widget supports multiplayer interaction (i.e. whether this widget can be
* used by players other than by the game master)
*/
bool m_supports_multiplayer;
/** Instead of searching for widget IDs smaller/greater than that of this object, navigation
through widgets will start from these IDs (if they are set). */
int m_tab_down_root;
/** Instead of searching for widget IDs smaller/greater than that of this object, navigation
through widgets will start from these IDs (if they are set). */
int m_tab_up_root;
/** Coordinates of the widget once added (the difference between those x/h and PROP_WIDTH/PROP_HEIGHT is
that the props are read in raw form from the XML file; PROP_WIDTH can then be e.g. "10%" and w,
once the widget is added, will be e.g. 80.) */
int m_x, m_y, m_w, m_h;
/** Whether to show a bounding box around this widget (used for sections) */
bool m_show_bounding_box;
/** Only used if m_show_bounding_box is true */
bool m_is_bounding_box_round;
@ -290,7 +290,7 @@ namespace GUIEngine
2) Theorically, in 'add()', derived widgets should checked if this value is set, and use
it instead of creating a new ID if it is. In practice, it's not widely implemented (FIXME) */
int m_reserved_id;
/**
* A map that holds values for all specified widget properties (in the XML file)
*
@ -300,16 +300,16 @@ namespace GUIEngine
* \note Not all widgets use all properties, some widgets may ignore some properties.
*/
std::map<Property, std::string> m_properties;
Widget(WidgetType type, bool reserve_id = false);
virtual ~Widget();
/**
* Set the irrlicht widget to be used as parent of this widget next time Widget::add()
* is invoked on this widget.
*/
void setParent(irr::gui::IGUIElement* parent);
/**
* \brief Sets the widget (and its children, if any) visible or not.
* Note that setting a widget invisible implicitely calls setDeactivated(), and setting
@ -320,19 +320,19 @@ namespace GUIEngine
/** Returns if the element is visible. */
bool isVisible() const;
/**
* Call to resize/move the widget. Not all widgets can resize gracefully.
*/
virtual void move(const int x, const int y, const int w, const int h);
/**
* Get whether this widget is selected (only makes sense in some cases where
* a widget is part of a bigger widget, e.g. in ribbons, and a selected item
* is kept)
*/
bool isSelected(const int playerID) const { return m_selected[playerID]; }
bool isBottomBar() const { return m_bottom_bar; }
bool isTopBar () const { return m_top_bar; }
@ -340,23 +340,23 @@ namespace GUIEngine
* \name Enabling or disabling widgets
* \{
*/
/** \brief undos setDeactivated() */
virtual void setActivated();
/** \brief greys out the widget, making it not clickable for the user */
virtual void setDeactivated();
/**
* \}
*/
/**
* \name Accessing the underlying irrlicht element
* \{
*/
/**
* Get the underlying irrLicht GUI element, casted to the right type.
*/
@ -387,7 +387,7 @@ namespace GUIEngine
* Get the underlying irrLicht GUI element
*/
irr::gui::IGUIElement* getIrrlichtElement() { return m_element; }
void moveIrrlichtElement();
bool isSameIrrlichtWidgetAs(const Widget* ref) const { return m_element == ref->m_element; }
@ -402,8 +402,8 @@ namespace GUIEngine
* it will generally work to set the properties before add() is called, modifying
* the widget after it was added will require other widget-specific calls.
*/
/**
/**
* Sets the text of a widget from a wchar_t.
* Handy for many constant strings used in stk.
*
@ -412,8 +412,8 @@ namespace GUIEngine
* is add()ed
*/
virtual void setText(const wchar_t *s);
/**
/**
* Sets the text of a widget from a stringw.
* \note This method uses the virtual setText(wchar_t*) function, so only the latter
* needs to be overwritten by other classes.
@ -425,10 +425,10 @@ namespace GUIEngine
/** Returns the text of a widget. */
const irr::core::stringw &getText() const {return m_text; }
/** \return Type of this widget */
WidgetType getType() const { return m_type; }
/**
* Get the irrlicht widget ID attributed to this widget
* \pre Only call this method after the widget has been add()ed
@ -437,38 +437,38 @@ namespace GUIEngine
/** Get whether this object is allowed to receive focus */
bool isFocusable() const { return m_focusable; }
void setFocusable(bool f) { m_focusable = f; }
/**
* \}
*/
/**
* \name Focus management
* \{
*/
/**
* Focus the widget for the given player.
* \param playerID ID of the player you want to set/unset focus for, starting from 0
*/
void setFocusForPlayer(const int playerID);
/**
* Find whether this widget is focused by a given player.
* \param playerID ID of the player you want to set/unset focus for, starting from 0
* \return whether this widget is focused by a given player.
*/
bool isFocusedForPlayer(const int playerID);
/** Internal method, do not call it. Call the functions in GUIEngine instead to unset focus. */
void unsetFocusForPlayer(const int playerID);
/**
* \}
*/
/**
* \name ID Counter Functions
* Functions used to generate IDs for new widgets. The domain of each ID
@ -478,19 +478,19 @@ namespace GUIEngine
* sequential with focusable widgets in order not to break keyboard navigation).
* \{
*/
static void resetIDCounters();
/**
* \brief Provides a new unique ID on each call, for widgets that can be focused.
*/
static int getNewID();
/**
* \brief Provides a new unique ID on each call, for widgets that can not be focused.
*/
static int getNewNoFocusID();
/**
* \brief get whether the given ID represents an ID of a widget that can be focused
* \return whether the given ID represents an ID of a widget that can be focused
@ -498,22 +498,22 @@ namespace GUIEngine
* Widget::getNewNoFocusID())
*/
static bool isFocusableId(const int id);
/**
* \}
*/
/**
* \name Handling children
* If this widget is a container and has children.
* \{
*/
/**
* \return a read-only view of the childrens of this widget, if any
*/
const PtrVector<Widget>& getChildren() const { return m_children; }
PtrVector<Widget>& getChildren() { return m_children; }
/**
@ -527,65 +527,65 @@ namespace GUIEngine
* \return whether deletion was successful
*/
bool deleteChild(const char* id);
/**
* \}
*/
/**
* \{
* \name Callbacks for subclasses
* Classes that subclass Widget to provide actual implementations may override/implement these
* methods to change behaviour or be notified of some events.
*/
/**
* \brief Override in children to possibly receive updates (you may need to register to
* them first)
*/
virtual void update(float delta) { }
/** All widgets, including their parents (m_event_handler) will be notified on event through
this call. Must return whether main (GUI engine user) event callback should be notified or not.
Note that in the case of a hierarchy of widgets (with m_event_handler), only the topmost widget
of the chain decides whether the main handler is notified; return value is not read for others. */
virtual EventPropagation transmitEvent(Widget* w,
const std::string& originator,
const int playerID)
virtual EventPropagation transmitEvent(Widget* w,
const std::string& originator,
const int playerID)
{ return EVENT_LET; }
/**
* \brief Create and add the irrLicht widget(s) associated with this object.
* Call after Widget was read from XML file and laid out.
*/
virtual void add();
/**
* \brief Called when irrLicht widgets cleared. Forget all references to them, they're no more valid.
*/
virtual void elementRemoved();
bool searchInsideMe() const { return m_check_inside_me; }
/** When inferring widget size from its label length, this method will be called to
* if/how much space must be added to the raw label's size for the widget to be large enough */
virtual int getWidthNeededAroundLabel() const { return 0; }
/** When inferring widget size from its label length, this method will be called to
* if/how much space must be added to the raw label's size for the widget to be large enough */
virtual int getHeightNeededAroundLabel() const { return 0; }
/**
* \}
*/
/**
* \name Badge support
* "Badges" are icons that can appear on top of some widgets.
* \{
*/
/**
/**
* \brief adds a particular badge to this widget.
* The STK widget toolkit has support for "badges". Badges are icon overlays displayed
* on the corner of a widget; they are useful to convey information visually.
@ -594,8 +594,8 @@ namespace GUIEngine
{
m_badges |= int(badge_bit);
}
/**
/**
* \brief removes a particular bade from this widget, if it had it.
* \see GUIEngine::Widget::setBadge for more info on badge support
*/
@ -603,7 +603,7 @@ namespace GUIEngine
{
m_badges &= (~int(badge_bit));
}
/** \brief sets this widget to have no badge
* \see GUIEngine::Widget::setBadge for more info on badge support
*/
@ -611,7 +611,7 @@ namespace GUIEngine
{
m_badges = 0;
}
/**
* \brief Get which badges are currently on this widget
* \return a bitmask of BadgeType values
@ -620,31 +620,31 @@ namespace GUIEngine
{
return m_badges;
}
/**
* \}
*/
/**
* \name Tooltip support
* \{
*/
bool hasTooltip() const { return m_has_tooltip; }
/** Only call if hasTooltip() returned true */
irr::core::stringw getTooltipText() const { return m_tooltip_text; }
void setTooltip(irr::core::stringw s) { m_tooltip_text = s; m_has_tooltip = true; }
/**
* \}
*/
bool ok() const { return (m_magic_number == 0xCAFEC001); }
};
}
#endif

View File

@ -48,8 +48,8 @@ public:
Input::AxisDirection getDirection() const {return m_dir;}
// ------------------------------------------------------------------------
/** Defines all values of this binding. */
void set(Input::InputType type, int id,
Input::AxisDirection dir,
void set(Input::InputType type, int id,
Input::AxisDirection dir,
wchar_t character)
{
m_type = type; m_id=id; m_dir=dir; m_character=character;

View File

@ -81,7 +81,7 @@ private:
/** Will be non-null in single-player mode */
StateManager::ActivePlayer* m_single_player;
/**
* Helper method, only used internally. Takes care of analyzing keyboard input.
*
@ -93,7 +93,7 @@ private:
InputDevice *mapKeyboardInput ( int btnID, InputManager::InputDriverMode mode,
StateManager::ActivePlayer **player /* out */,
PlayerAction *action /* out */);
/** If this is flag is set the next fire event (if the fire key is not
/** If this is flag is set the next fire event (if the fire key is not
* mapped to anything else) will be mapped to 'select'. This is used
* in the kart select GUI to support the old way of adding players by
* pressing fire. */
@ -106,7 +106,7 @@ public:
DeviceManager();
// ---- Assign mode ----
PlayerAssignMode getAssignMode() const { return m_assign_mode; }
void setAssignMode(const PlayerAssignMode assignMode);
@ -120,8 +120,8 @@ public:
GamePadDevice* getGamePadFromIrrID(const int i);
void clearGamepads() { m_gamepads.clearAndDeleteAll(); }
/** Returns the keyboard that has a binding for this button, or NULL if none */
bool getConfigForGamepad(const int sdl_id, const core::stringc& pname, GamepadConfig **config);
bool getConfigForGamepad(const int sdl_id, const core::stringc& pname, GamepadConfig **config);
// ---- Keyboard(s) ----
void addEmptyKeyboard();
void addKeyboard(KeyboardDevice* d);
@ -137,9 +137,9 @@ public:
* \brief Delete the given config and removes DeviceManager references to it.
*/
bool deleteConfig(DeviceConfig* config);
/** Given some input, finds to which device it belongs and, using the corresponding device object,
* maps this input to the corresponding player and game action.
* maps this input to the corresponding player and game action.
*
* \return false if player/action could not be set.
* \note Special case : can return 'true' but set action to PA_BEFORE_FIRST if the input was used but
@ -160,14 +160,14 @@ public:
InputDevice* getLatestUsedDevice();
bool initialize();
void serialize();
StateManager::ActivePlayer* getSinglePlayer() { return m_single_player; }
void setSinglePlayer(StateManager::ActivePlayer* p) { m_single_player = p; }
// ------------------------------------------------------------------------
/** Sets or reset the 'map fire to select' option.
*/
void mapFireToSelect(bool v) {m_map_fire_to_select = v; }
}; // DeviceManager

View File

@ -40,10 +40,10 @@ const int MULTIPLIER_MOUSE = 750;
struct Input
{
static const int MAX_VALUE = 32768;
static const int HAT_H_ID = 100;
static const int HAT_V_ID = 101;
enum AxisDirection
{
AD_NEGATIVE,
@ -70,12 +70,12 @@ struct Input
wchar_t m_character;
Input()
: m_type(IT_NONE), m_device_id(0), m_button_id(0),
: m_type(IT_NONE), m_device_id(0), m_button_id(0),
m_axis_direction(0), m_character(0)
{
// Nothing to do.
}
/** Creates an Input instance which represents an arbitrary way of getting
* game input using a type specifier and 3 integers.
*
@ -93,19 +93,19 @@ struct Input
* IT_MOUSEMOTION: id0 - axis index (0 -> X, 1 -> Y). Mouse wheel is
* represented as buttons!
* IT_MOUSEBUTTON: id0 - button number (1 -> left, 2 -> middle, 3 -> right,
* ...)
* ...)
*
* Note: For joystick bindings that are actice in the menu the joystick's
* index should be zero. The binding will react to all joysticks connected
* to the system.
*/
Input(InputType ntype, int deviceID , int btnID = 0, int axisDirection= 0)
: m_type(ntype), m_device_id(deviceID), m_button_id(btnID),
Input(InputType ntype, int deviceID , int btnID = 0, int axisDirection= 0)
: m_type(ntype), m_device_id(deviceID), m_button_id(btnID),
m_axis_direction(axisDirection)
{
// Nothing to do.
}
}; // struct Input
/**
@ -115,7 +115,7 @@ struct Input
enum PlayerAction
{
PA_BEFORE_FIRST = -1,
PA_STEER_LEFT = 0,
PA_STEER_RIGHT,
PA_ACCEL,
@ -126,14 +126,14 @@ enum PlayerAction
PA_FIRE,
PA_LOOK_BACK,
PA_PAUSE_RACE,
PA_MENU_UP,
PA_MENU_DOWN,
PA_MENU_LEFT,
PA_MENU_RIGHT,
PA_MENU_SELECT,
PA_MENU_CANCEL,
PA_COUNT
};
@ -146,7 +146,7 @@ const PlayerAction PA_LAST_MENU_ACTION = PA_MENU_CANCEL;
* \brief human-readable strings for each PlayerAction
* \ingroup input
*/
static std::string KartActionStrings[PA_COUNT] = {std::string("steerLeft"),
static std::string KartActionStrings[PA_COUNT] = {std::string("steerLeft"),
std::string("steerRight"),
std::string("accel"),
std::string("brake"),

View File

@ -31,16 +31,16 @@ protected:
DeviceConfig* m_configuration;
public:
/** If device has a name; unused for keyboards since AFAIK we
/** If device has a name; unused for keyboards since AFAIK we
* can't tell keyboards apart. */
std::string m_name;
InputDevice();
void setConfiguration(DeviceConfig *config) {m_configuration = config;}
DeviceConfig *getConfiguration() {return m_configuration;}
DeviceType getType() const { return m_type; };
void setPlayer(StateManager::ActivePlayer* owner);
StateManager::ActivePlayer *getPlayer() { return m_player; }
};
@ -53,23 +53,23 @@ class KeyboardDevice : public InputDevice
{
public:
KeyboardDevice();
KeyboardDevice(KeyboardConfig *configuration);
/**
* Checks if this key belongs to this device. if yes, sets action and
* Checks if this key belongs to this device. if yes, sets action and
* returns true; otherwise returns false
*
* \param id ID of the key that was pressed
* \param mode Used to determine whether to bind menu actions or
* \param id ID of the key that was pressed
* \param mode Used to determine whether to bind menu actions or
* game actions
* \param[out] action The action associated to this input (only check
* \param[out] action The action associated to this input (only check
* this value if method returned true)
*/
bool processAndMapInput(const int id, InputManager::InputDriverMode mode,
PlayerAction* action);
};
/**
@ -78,60 +78,60 @@ public:
*/
class GamePadDevice : public InputDevice
{
void resetAxisDirection(const int axis, Input::AxisDirection direction,
void resetAxisDirection(const int axis, Input::AxisDirection direction,
StateManager::ActivePlayer* player);
bool m_buttonPressed[SEvent::SJoystickEvent::NUMBER_OF_BUTTONS];
public:
Input::AxisDirection *m_prevAxisDirections;
/** used to determine if an axis is valid; an axis is considered valid
* when at least 2 different values are read from this axis (if an axis
* keeps on sending the exact same value continuously, chances are that
* it's not meant by the user - for instance some gamepads have hats or
/** used to determine if an axis is valid; an axis is considered valid
* when at least 2 different values are read from this axis (if an axis
* keeps on sending the exact same value continuously, chances are that
* it's not meant by the user - for instance some gamepads have hats or
* analog switches that get reported as axis, we even had a report that
* on linux some hard disks may be reported as gamepads with
* on linux some hard disks may be reported as gamepads with
* uninteresting axis values)
*/
int *m_prevAxisValue;
/** \see m_prevAxisValue */
bool *m_axis_ok;
int m_deadzone;
int m_index;
int m_axis_count;
int m_button_count;
/** Constructor for GamePadDevice from a connected gamepad for which no
/** Constructor for GamePadDevice from a connected gamepad for which no
* configuration existed (defaults will be used)
* \param irrIndex Index of stick as given by irrLicht.
*/
GamePadDevice(const int irrIndex, const std::string name,
GamePadDevice(const int irrIndex, const std::string name,
const int axis_number,
const int btnAmount, GamepadConfig *configuration);
~GamePadDevice();
bool isButtonPressed(const int i);
void setButtonPressed(const int i, bool isButtonPressed);
/**
* Invoked when this device it used. Verifies if the key/button that
* was pressed is associated with a binding. If yes, sets action and
* Invoked when this device it used. Verifies if the key/button that
* was pressed is associated with a binding. If yes, sets action and
* returns true; otherwise returns false.
*
* \param player Only passed to know where to send 'axis reset's
* \param player Only passed to know where to send 'axis reset's
* when necessary
* \param id ID of the key that was pressed or of the axis
* \param id ID of the key that was pressed or of the axis
* that was triggered (depending on
* the value of the 'type' parameter)
* \param mode Used to determine whether to map menu actions or
* \param mode Used to determine whether to map menu actions or
* game actions
* \param[out] action The action associated to this input (only check
* \param[out] action The action associated to this input (only check
* this value if method returned true)
*
* \return Whether the pressed key/button is bound with an action
*/
bool processAndMapInput(Input::InputType type, const int id,
bool processAndMapInput(Input::InputType type, const int id,
const int value,
InputManager::InputDriverMode mode,
StateManager::ActivePlayer* player,

View File

@ -29,8 +29,8 @@
class DeviceManager;
/**
* \brief Class to handle input.
/**
* \brief Class to handle input.
* \ingroup input
*/
class InputManager: public NoCopy
@ -51,7 +51,7 @@ public:
// to put a delay before a new gamepad axis move is considered in menu
bool m_timer_in_use;
float m_timer;
private:
DeviceManager *m_device_manager;
@ -59,16 +59,16 @@ private:
std::set<int> m_sensed_input_high_kbd;
InputDriverMode m_mode;
/** When at true, only the master player can play with menus */
bool m_master_player_only;
/* Helper values to store and track the relative mouse movements. If these
* values exceed the deadzone value the input is reported to the game. This
* makes the mouse behave like an analog axis on a gamepad/joystick.
*/
int m_mouse_val_x, m_mouse_val_y;
void dispatchInput(Input::InputType, int deviceID, int btnID, Input::AxisDirection direction, int value);
void handleStaticAction(int id0, int value);
void inputSensing(Input::InputType type, int deviceID, int btnID, Input::AxisDirection axisDirection, int value);
@ -76,24 +76,24 @@ public:
InputManager();
~InputManager();
// void initGamePadDevices();
//void input();
GUIEngine::EventPropagation input(const irr::SEvent& event);
DeviceManager* getDeviceList() { return m_device_manager; }
void setMode(InputDriverMode);
void setMode(InputDriverMode);
bool isInMode(InputDriverMode);
InputDriverMode getMode() { return m_mode; }
InputDriverMode getMode() { return m_mode; }
/** When this mode is enabled, only the master player will be able to play with menus (only works in 'assign' mode) */
void setMasterPlayerOnly(bool enabled);
/** Returns whether only the master player should be allowed to perform changes in menus */
bool masterPlayerOnly() const;
void update(float dt);
/** Returns the ID of the player that plays with the keyboard, or -1 if none */
int getPlayerKeyboardID() const;
};

View File

@ -39,25 +39,25 @@ private:
/** Handle to the corresponding WiiUse wiimote handle */
wiimote_t* m_wiimote_handle;
/** Index of this element the arrays of wiimotes */
int m_wiimote_id;
/** Corresponding gamepad managed by the DeviceManager */
GamePadDevice* m_gamepad_device;
/** Corresponding Irrlicht gamepad event */
Synchronised<irr::SEvent> m_irr_event;
/** Whether the wiimote received a "disconnected" event */
bool m_connected;
void resetIrrEvent();
void printDebugInfo() const;
public:
/** Resets internal state and creates the corresponding gamepad device */
Wiimote(wiimote_t* wiimote_handle, int wiimote_id,
Wiimote(wiimote_t* wiimote_handle, int wiimote_id,
GamepadConfig* gamepad_config);
~Wiimote();

View File

@ -47,18 +47,18 @@ class WiimoteManager
private:
/** List of all connected wiimotes. */
std::vector<Wiimote*> m_wiimotes;
/** WiiUse wiimote handles */
wiimote_t** m_all_wiimote_handles;
int m_number_wiimotes;
// While the wiimote code can technically work without threading,
// its too slow (high latency), but it is useful for debugging.
#define WIIMOTE_THREADING
#ifdef WIIMOTE_THREADING
/** Wiimote state update thread */
pthread_t m_thread;
/** Shut the update thread? */
bool m_shut;
#endif
@ -74,19 +74,19 @@ private:
public:
WiimoteManager();
~WiimoteManager();
/** Sets the wiimote to be enabled. */
static void enable() { m_enabled = true; }
/** Returns if the wii was enabled on the command line. */
static bool isEnabled() { return m_enabled; }
void launchDetection(int timeout);
void update();
void cleanup();
void enableAccelerometer(bool state);
/** A simple listener to allow the user to connect wiimotes. It
* will display a feedback windows (# wiimotes connected or 'no wiimotes
* found').
@ -104,7 +104,7 @@ public:
// ------------------------------------------------------------------------
/** Returns the number of wiimotes connected. */
unsigned int getNumberOfWiimotes() const {return m_wiimotes.size();}
}; // class WiimoteManager

View File

@ -58,7 +58,7 @@ private:
/** Directory to store screenshots in. */
std::string m_screenshot_dir;
std::vector<std::string>
std::vector<std::string>
m_texture_search_path,
m_model_search_path,
m_music_search_path;
@ -131,7 +131,7 @@ public:
*/
void pushMusicSearchPath(const std::string& path)
{
m_music_search_path.push_back(path);
m_music_search_path.push_back(path);
} // pushMusicSearchPath
// ------------------------------------------------------------------------
/** Removes the last added directory from the music search path.
@ -141,8 +141,8 @@ public:
/** Returns true if the specified file exists.
*/
bool fileExists(const std::string& path)
{
return m_file_system->existFile(path.c_str());
{
return m_file_system->existFile(path.c_str());
} // fileExists
}; // FileManager

View File

@ -60,20 +60,20 @@ private:
std::map<std::string, core::stringw> m_attributes;
/** List of all sub nodes. */
std::vector<XMLNode *> m_nodes;
void readXML(io::IXMLReader *xml);
std::string m_file_name;
public:
LEAK_CHECK();
XMLNode(io::IXMLReader *xml);
/** \throw runtime_error if the file is not found */
XMLNode(const std::string &filename);
~XMLNode();
const std::string &getName() const {return m_name; }
const XMLNode *getNode(const std::string &name) const;
const void getNodes(const std::string &s, std::vector<XMLNode*>& out) const;
@ -100,9 +100,9 @@ public:
int getXYZ(Vec3 *vaslue) const;
int getHPR(core::vector3df *value) const;
int getHPR(Vec3 *value) const;
bool hasChildNamed(const char* name) const;
/** Handy functions to test the bit pattern returned by get(vector3df*).*/
static bool hasX(int b) { return (b&1)==1; }
static bool hasY(int b) { return (b&2)==2; }

View File

@ -32,12 +32,12 @@ class XMLWriter
{
std::ofstream m_base;
public:
XMLWriter(const char* dest);
XMLWriter& operator<< (const irr::core::stringw& txt);
XMLWriter& operator<< (const wchar_t* txt);
template<typename T>
XMLWriter& operator<< (const T t)
{
@ -46,9 +46,9 @@ public:
(*this) << tmp;
return *this;
}
void close();
bool is_open() { return m_base.is_open(); }
};

View File

@ -31,13 +31,13 @@ class AbstractKart;
class Item;
class SFXBase;
/** This objects is permanently available in a kart and stores information
/** This objects is permanently available in a kart and stores information
* about addons. If a kart has no attachment, this object will have the
* attachment type ATTACH_NOTHING. This way other tests for attachment
* in STK do not have to additionally test if there is an attachment, all
* tests for a type will always be valid.
* Certain attachments need additional coding, this is supported by
* a 'plugin' mechanism: This attachment will forward certain calls to
* a 'plugin' mechanism: This attachment will forward certain calls to
* (see attachment_pluging abstract class). Compared to normal subclassing
* (i.e. replacing the attachment object each time an attachment changes)
* this has less overhead (since the attachment class always creates
@ -78,7 +78,7 @@ private:
/** Scene node of the attachment, which will be attached to the kart's
* scene node. */
scene::IAnimatedMeshSceneNode
scene::IAnimatedMeshSceneNode
*m_node;
/** Used by bombs so that it's not passed back to previous owner. */
@ -90,7 +90,7 @@ private:
/** Pseudo random number generator. */
RandomGenerator m_random;
/** Ticking sound for the bomb */
SFXBase *m_bomb_sound;
@ -101,7 +101,7 @@ public:
void hitBanana(Item *item, int new_attachment=-1);
void update (float dt);
void handleCollisionWithKart(AbstractKart *other);
void set (AttachmentType type, float time,
void set (AttachmentType type, float time,
AbstractKart *previous_kart=NULL);
// ------------------------------------------------------------------------
@ -122,7 +122,7 @@ public:
AbstractKart* getPreviousOwner() const { return m_previous_owner; }
// ------------------------------------------------------------------------
/** Returns additional weight for the kart. */
float weightAdjust() const {
float weightAdjust() const {
return m_type==ATTACH_ANVIL ? stk_config->m_anvil_weight : 0.0f; }
// ------------------------------------------------------------------------
/** Return the currently associated scene node (used by e.g the swatter) */

View File

@ -38,16 +38,16 @@ private:
Material *m_all_icons [Attachment::ATTACH_MAX];
public:
AttachmentManager() {};
~AttachmentManager();
~AttachmentManager();
void removeTextures ();
void loadModels ();
// ------------------------------------------------------------------------
/** Returns the mest for a certain attachment.
* \param type Type of the attachment needed. */
scene::IAnimatedMesh *getMesh(Attachment::AttachmentType type) const
scene::IAnimatedMesh *getMesh(Attachment::AttachmentType type) const
{return m_attachments[type]; }
// ------------------------------------------------------------------------
/** Returns the icon to display in the race gui if a kart
/** Returns the icon to display in the race gui if a kart
* has an attachment. */
const Material* getIcon (int type) const {return m_all_icons [type]; }
// ------------------------------------------------------------------------

View File

@ -29,31 +29,31 @@ class Attachment;
* This is the base class for a plugin into an attachment. Plugins are
* used to handle attachment specific data so that the attachment class
* that is used in every kart isn't overloaded. It could be done by
* inheriting from Attachment, but then every time an attachment is
* inheriting from Attachment, but then every time an attachment is
* changed, we could delete and create a new SceneNode. To avoid this
* overhead, we use plugins to encapsulate additional code for some
* plugins.
*/
class AttachmentPlugin
{
protected:
protected:
/** Kart the attachment is attached to. */
AbstractKart *m_kart;
public:
/** Constructor for a plugin. */
AttachmentPlugin(AbstractKart *kart)
AttachmentPlugin(AbstractKart *kart)
{
m_kart = kart;
}
virtual ~AttachmentPlugin() {}
// ------------------------------------------------------------------------
/** Updates a plugin. This is called once each time frame. If the
* function returns true, the attachment is discarded. */
virtual bool updateAndTestFinished(float dt) = 0;
// ------------------------------------------------------------------------
/** Called when the animation of the Attachment's node is done. */
virtual void onAnimationEnd() {}

View File

@ -39,7 +39,7 @@ private:
static float m_st_max_distance; // maximum distance for a bowling ball to be attracted
static float m_st_max_distance_squared;
static float m_st_force_to_target;
/** If a bowling ball has hit something, this flag is set to indicate
* if a kart was hit or not. The sound effect is only played if a
* kart was hit. */
@ -53,7 +53,7 @@ public:
virtual bool hit(AbstractKart* kart, PhysicalObject* obj=NULL);
virtual HitEffect *getHitEffect() const;
}; // Bowling
#endif

View File

@ -49,19 +49,19 @@ private:
public:
Cake (AbstractKart *kart);
static void init (const XMLNode &node, scene::IMesh *cake_model);
virtual const core::stringw
virtual const core::stringw
getHitString(const AbstractKart *kart) const;
virtual bool hit(AbstractKart* kart, PhysicalObject* obj=NULL);
// ------------------------------------------------------------------------
virtual void hitTrack () { hit(NULL); }
// ------------------------------------------------------------------------
/** Kinematic objects are not allowed to have a velocity (assertion in
* bullet), so we have to do our own velocity handling here. This
/** Kinematic objects are not allowed to have a velocity (assertion in
* bullet), so we have to do our own velocity handling here. This
* function returns the velocity of this object. */
virtual const btVector3 &getVelocity() const {return m_initial_velocity;}
// ------------------------------------------------------------------------
/** Kinematic objects are not allowed to have a velocity (assertion in
* bullet), so we have to do our own velocity handling here. This
/** Kinematic objects are not allowed to have a velocity (assertion in
* bullet), so we have to do our own velocity handling here. This
* function sets the velocity of this object.
* \param v Linear velocity of this object.
*/

View File

@ -59,7 +59,7 @@ private:
/** An offset that is added when doing the raycast for terrain. This
* is useful in case that the position of the object is just under
* the terrain (perhaps due to floating point errors), and would
* the terrain (perhaps due to floating point errors), and would
* otherwise result in an invalid terrain. */
Vec3 m_position_offset;
@ -74,8 +74,8 @@ protected:
AbstractKart* m_owner;
/** Type of the powerup. */
PowerupManager::PowerupType
m_type;
PowerupManager::PowerupType
m_type;
/** Collision shape of this Flyable. */
btCollisionShape *m_shape;
@ -124,25 +124,25 @@ protected:
/** Size of the model. */
static Vec3 m_st_extend[PowerupManager::POWERUP_MAX];
/** Time since thrown. used so a kart can't hit himself when trying
/** Time since thrown. used so a kart can't hit himself when trying
* something, and also to put some time limit to some collectibles */
float m_time_since_thrown;
/** Set to something > -1 if this flyable should auto-destrcut after
/** Set to something > -1 if this flyable should auto-destrcut after
* a while. */
float m_max_lifespan;
/** If set to true, the kart that throwns this flyable can't collide
/** If set to true, the kart that throwns this flyable can't collide
* with it for a short time. */
bool m_owner_has_temporary_immunity;
void getClosestKart(const AbstractKart **minKart,
void getClosestKart(const AbstractKart **minKart,
float *minDistSquared,
Vec3 *minDelta,
Vec3 *minDelta,
const AbstractKart* inFrontOf=NULL,
const bool backwards=false) const;
void getLinearKartItemIntersection(const Vec3 &origin,
void getLinearKartItemIntersection(const Vec3 &origin,
const AbstractKart *target_kart,
float item_XY_velocity, float gravity,
float forw_offset,
@ -152,15 +152,15 @@ protected:
/** init bullet for moving objects like projectiles */
void createPhysics(float y_offset,
const Vec3 &velocity,
btCollisionShape *shape,
btCollisionShape *shape,
float restitution,
const float gravity=0.0f,
const bool rotates=false,
const bool rotates=false,
const bool turn_around=false,
const btTransform* customDirection=NULL);
public:
Flyable (AbstractKart* kart,
Flyable (AbstractKart* kart,
PowerupManager::PowerupType type,
float mass=1.0f);
virtual ~Flyable ();
@ -175,7 +175,7 @@ public:
void explode(AbstractKart* kart, PhysicalObject* obj=NULL,
bool secondary_hits=true);
// ------------------------------------------------------------------------
/** If true the up velocity of the flyable will be adjust so that the
/** If true the up velocity of the flyable will be adjust so that the
* flyable stays at a height close to the average height.
* \param f True if the up velocity should be adjusted. */
void setAdjustUpVelocity(bool f) { m_adjust_up_velocity = f; }

View File

@ -98,7 +98,7 @@ private:
/** Stores the original rotation of an item. This is used in
* case of a switch to restore the rotation of a bubble gum
* (bubble gums don't rotate, but it will be replaced with
* a nitro which rotates, and so overwrites the original
* a nitro which rotates, and so overwrites the original
* rotation). */
Vec3 m_original_hpr;
@ -115,7 +115,7 @@ private:
scene::IMesh *m_original_mesh;
scene::IMesh *m_original_lowmesh;
/** The original position - saves calls to m_node->getPosition()
/** The original position - saves calls to m_node->getPosition()
* and then converting this value to a Vec3. */
Vec3 m_xyz;
@ -123,28 +123,28 @@ private:
unsigned int m_item_id;
/** Set to false if item should not rotate. */
bool m_rotate;
/** Optionally set this if this item was laid by a particular kart. in
* this case the 'm_deactive_time' will also be set - see below. */
bool m_rotate;
/** Optionally set this if this item was laid by a particular kart. in
* this case the 'm_deactive_time' will also be set - see below. */
const AbstractKart *m_event_handler;
/** Kart that emitted this item if any */
const AbstractKart *m_emitter;
/** Optionally if item was placed by a kart, a timer can be used to
/** Optionally if item was placed by a kart, a timer can be used to
* temporarly deactivate collision so a kart is not hit by its own item */
float m_deactive_time;
/** Counts how often an item is used before it disappears. Used for
/** Counts how often an item is used before it disappears. Used for
* bubble gum to make them disappear after a while. A value >0
* indicates that the item still exists, =0 that the item can be
* deleted, and <0 that the item will never be deleted. */
int m_disappear_counter;
/** callback used if type == ITEM_TRIGGER */
TriggerItemListener* m_listener;
/** square distance at which item is collected */
float m_distance_2;
@ -155,8 +155,8 @@ private:
* >0 if it is to the right of the center, and undefined if this quad
* is not on any quad. */
float m_distance_from_center;
/** The closest point to the left and right of this item at which it
/** The closest point to the left and right of this item at which it
* would not be collected. Used by the AI to avoid items. */
Vec3 *m_avoidance_points[2];
@ -167,7 +167,7 @@ private:
public:
Item(ItemType type, const Vec3& xyz, const Vec3& normal,
scene::IMesh* mesh, scene::IMesh* lowres_mesh);
Item(const Vec3& xyz, float distance,
Item(const Vec3& xyz, float distance,
TriggerItemListener* trigger);
virtual ~Item ();
void update (float delta);
@ -176,13 +176,13 @@ public:
void reset();
void switchTo(ItemType type, scene::IMesh *mesh, scene::IMesh *lowmesh);
void switchBack();
const AbstractKart* getEmitter() const { return m_emitter; }
// ------------------------------------------------------------------------
/** Returns true if the Kart is close enough to hit this item, the item is
* not deactivated anymore, and it wasn't placed by this kart (this is
/** Returns true if the Kart is close enough to hit this item, the item is
* not deactivated anymore, and it wasn't placed by this kart (this is
* e.g. used to avoid that a kart hits a bubble gum it just dropped).
* \param kart Kart to test.
* \param xyz Location of kart (avoiding to use kart->getXYZ() so that
@ -196,19 +196,19 @@ public:
private:
// ------------------------------------------------------------------------
/** Returns true if the Kart is close enough to hit this item, the item is
* not deactivated anymore, and it wasn't placed by this kart (this is
/** Returns true if the Kart is close enough to hit this item, the item is
* not deactivated anymore, and it wasn't placed by this kart (this is
* e.g. used to avoid that a kart hits a bubble gum it just dropped).
* This function only uses the 2d coordinates, and it used by the AI only.
* \param kart Kart to test.
* \param xyz Location of kart (avoiding to use kart->getXYZ() so that
* kart.hpp does not need to be included here).
*/
bool hitKart (const core::vector2df &xyz,
bool hitKart (const core::vector2df &xyz,
const AbstractKart *kart=NULL) const
{
if(m_event_handler==kart && m_deactive_time >0) return false;
float d2 = (m_xyz.getX()-xyz.X)*(m_xyz.getX()-xyz.X)
float d2 = (m_xyz.getX()-xyz.X)*(m_xyz.getX()-xyz.X)
+ (m_xyz.getZ()-xyz.Y)*(m_xyz.getZ()-xyz.Y);
return d2 < m_distance_2;
} // hitKart
@ -222,7 +222,7 @@ protected:
* \param line The line segment which is tested if it is close enough
* to this item so that this item would be collected.
*/
bool hitLine(const core::line2df &line,
bool hitLine(const core::line2df &line,
const AbstractKart *kart=NULL) const
{
if(m_event_handler==kart && m_deactive_time >0) return false;
@ -243,7 +243,7 @@ public:
ItemType getType() const { return m_type; }
// ------------------------------------------------------------------------
/** Returns true if this item is currently collected. */
bool wasCollected() const { return m_collected;}
bool wasCollected() const { return m_collected;}
// ------------------------------------------------------------------------
/** Returns true if this item is used up and can be removed. */
bool isUsedUp() const {return m_disappear_counter==0; }
@ -257,8 +257,8 @@ public:
* hits a banana: by the time the explosion animation is ended and the
* kart is back at its original position, the banana would be back again
* and therefore hit the kart again. See Attachment::hitBanana for more
* details.
* \param f Time till the item can be used again.
* details.
* \param f Time till the item can be used again.
*/
void setDisableTime(float f) { m_time_till_return = f; }
// ------------------------------------------------------------------------
@ -271,13 +271,13 @@ public:
/** Returns the index of the graph node this item is on. */
int getGraphNode() const { return m_graph_node; }
// ------------------------------------------------------------------------
/** Returns the distance from center: negative means left of center,
/** Returns the distance from center: negative means left of center,
* positive means right of center. */
float getDistanceFromCenter() const { return m_distance_from_center; }
// ------------------------------------------------------------------------
/** Returns a point to the left or right of the item which will not trigger
* a collection of this item.
* \param left If true, return a point to the left, else a point to
* \param left If true, return a point to the left, else a point to
* the right. */
const Vec3 *getAvoidancePoint(bool left) const
{

View File

@ -39,7 +39,7 @@ class ItemManager : public NoCopy
private:
/** Stores all item models. */
static std::vector<scene::IMesh *> m_item_mesh;
/** Stores all low-resolution item models. */
static std::vector<scene::IMesh *> m_item_lowres_mesh;
@ -58,11 +58,11 @@ public:
// ------------------------------------------------------------------------
/** Return an instance of the item manager (it does not automatically
* create one, call create for that). */
static ItemManager *get() {
assert(m_item_manager);
static ItemManager *get() {
assert(m_item_manager);
return m_item_manager;
} // get
// ========================================================================
private:
/** The vector of all items of the current track. */
@ -70,7 +70,7 @@ private:
AllItemTypes m_all_items;
/** Stores which items are on which quad. m_items_in_quads[#quads]
* contains all items that are not on a quad. Note that this
* contains all items that are not on a quad. Note that this
* field is undefined if no QuadGraph exist, e.g. in battle mode. */
std::vector< AllItemTypes > *m_items_in_quads;
@ -90,10 +90,10 @@ private:
void setSwitchItems(const std::vector<int> &switch_items);
public:
Item* newItem (Item::ItemType type, const Vec3& xyz,
const Vec3 &normal,
Item* newItem (Item::ItemType type, const Vec3& xyz,
const Vec3 &normal,
AbstractKart* parent=NULL);
Item* newItem (const Vec3& xyz, float distance,
Item* newItem (const Vec3& xyz, float distance,
TriggerItemListener* listener);
void update (float delta);
void checkItemHit (AbstractKart* kart);
@ -113,7 +113,7 @@ public:
// ------------------------------------------------------------------------
/** Returns a reference to the array of all items on the specified quad.
*/
const AllItemTypes& getItemsInQuads(unsigned int n) const
const AllItemTypes& getItemsInQuads(unsigned int n) const
{
assert(m_items_in_quads);
assert(n<(*m_items_in_quads).size());

View File

@ -56,7 +56,7 @@ public:
// ------------------------------------------------------------------------
/** Sets the keep-alive value. Setting it to 0 will remove the plunger
* at the next update - which is used if the rubber band snaps.
* at the next update - which is used if the rubber band snaps.
*/
void setKeepAlive(float t) {m_keep_alive = t;}
// ------------------------------------------------------------------------

View File

@ -63,7 +63,7 @@ public:
int getNum () const {return m_number;}
// ------------------------------------------------------------------------
/** Returns the type of this powerup. */
PowerupManager::PowerupType
PowerupManager::PowerupType
getType () const {return m_type; }
// ------------------------------------------------------------------------
};

View File

@ -41,7 +41,7 @@ class XMLNode;
/** This class manages all powerups. It reads in powerup.xml to get the data,
* initialise the static member of some flyables (i.e. powerup.xml contains
* info about cakes, plunger etc which needs to be stored), and maintains
* the 'weights' (used in randomly chosing which item was collected) for all
* the 'weights' (used in randomly chosing which item was collected) for all
* items depending on position. The latter is done so that as the first player
* you get less advantageous items (but no useless ones either, e.g. anchor),
* while as the last you get more useful ones.
@ -49,14 +49,14 @@ class XMLNode;
* The position in a race is mapped to one of five position classes:
* first, top, middle, bottom, last - e.g. for a 6 player game the distribution
* is:
* position 1 2 3 4 5 6
* position 1 2 3 4 5 6
* class first top middle middle bottom last
* For each class the weight distribution is read in from powerup.xml:
* <!-- bubble cake bowl zipper plunger switch para anvil -->
* <last w="0 1 1 2 2 0 2 2" />
* So a (well, in this case 'the') player belonging to the class 'last'
* will not get a bubble gum or switch. Cakes and bowling balls have
* lower probability.
* lower probability.
* At the start of each race two mappings are computed in updateWeightsForRace:
* m_position_to_class maps each postion to the class using the function
* convertPositionToClass.
@ -74,12 +74,12 @@ public:
// The anvil and parachute must be at the end of the enum, and the
// zipper just before them (see Powerup::hitBonusBox).
enum PowerupType {POWERUP_NOTHING,
POWERUP_FIRST,
POWERUP_BUBBLEGUM = POWERUP_FIRST,
POWERUP_FIRST,
POWERUP_BUBBLEGUM = POWERUP_FIRST,
POWERUP_CAKE,
POWERUP_BOWLING, POWERUP_ZIPPER, POWERUP_PLUNGER,
POWERUP_SWITCH, POWERUP_SWATTER, POWERUP_RUBBERBALL,
POWERUP_PARACHUTE,
POWERUP_PARACHUTE,
POWERUP_ANVIL, //powerup.cpp assumes these two come last
POWERUP_LAST=POWERUP_ANVIL,
POWERUP_MAX
@ -88,7 +88,7 @@ public:
/** The different position classes, used to map a kart's position to a
* weight distribution for the different powerups. The battle mode is
* listed as a separate 'position' - this way the same implementation
* as used for normal racing can be used to define which items are
* as used for normal racing can be used to define which items are
* available in battle mode*/
enum PositionClass {POSITION_FIRST,
POSITION_TOP33,
@ -139,10 +139,10 @@ private:
PowerupType getPowerupType(const std::string &name) const;
void loadWeights(const XMLNode &root,
void loadWeights(const XMLNode &root,
const std::string &class_name,
PositionClass position_class);
PositionClass convertPositionToClass(unsigned int num_karts,
PositionClass convertPositionToClass(unsigned int num_karts,
unsigned int position);
public:
PowerupManager ();
@ -152,19 +152,19 @@ public:
void LoadPowerup (PowerupType type, const XMLNode &node);
void updateWeightsForRace(unsigned int num_karts);
Material* getIcon (int type) const {return m_all_icons [type];}
PowerupManager::PowerupType
PowerupManager::PowerupType
getRandomPowerup(unsigned int pos, unsigned int *n);
/** Returns the mesh for a certain powerup.
/** Returns the mesh for a certain powerup.
* \param type Mesh type for which the model is returned. */
irr::scene::IMesh
irr::scene::IMesh
*getMesh (int type) const {return m_all_meshes[type];}
float getForceToTarget(int type) const {return m_all_force_to_target[type];}
float getMaxDistance (int type) const {return m_all_max_distance[type];}
float getMaxTurnAngle (int type) const {return m_all_max_turn_angle[type];}
const btVector3&
const btVector3&
getExtend (int type) const {return m_all_extends[type];}
float getBallCollectTime() const {return m_rubber_ball_collect_time;}
void setBallCollectTime(float time) {m_rubber_ball_collect_time=time;}
void setBallCollectTime(float time) {m_rubber_ball_collect_time=time;}
};

View File

@ -45,7 +45,7 @@ private:
typedef std::vector<Flyable*> Projectiles;
typedef std::vector<HitEffect*> HitEffects;
/** The list of all active projectiles, i.e. projectiles which are
/** The list of all active projectiles, i.e. projectiles which are
* currently moving on the track. */
Projectiles m_active_projectiles;
@ -66,9 +66,9 @@ public:
void Deactivate (Flyable *p) {}
void removeTextures ();
// ------------------------------------------------------------------------
/** Adds a special hit effect to be shown.
/** Adds a special hit effect to be shown.
* \param hit_effect The hit effect to be added. */
void addHitEffect(HitEffect *hit_effect)
void addHitEffect(HitEffect *hit_effect)
{ m_active_hit_effects.push_back(hit_effect); }
};

View File

@ -43,10 +43,10 @@ private:
/** A class variable to store the default interval size. */
static float m_st_interval;
/** A class variable to store the default squash duration. */
static float m_st_squash_duration;
/** A class variable to store the default squash slowdown. */
static float m_st_squash_slowdown;
@ -62,7 +62,7 @@ private:
static float m_st_max_height_difference;
/** Distance between ball and target at which the ball will start to
* bounce faster (which makes more 'ping' sfx for the driver to
* bounce faster (which makes more 'ping' sfx for the driver to
* hear it coming closer, but also higher probability to hit the
* target and not fly over it). */
static float m_st_fast_ping_distance;
@ -86,10 +86,10 @@ private:
* that there are not too many rubber balls on the track in races with many
* karts. */
static float m_time_between_balls;
/** This factor is used to influence how much the rubber ball should aim
* at its target early. It used the 'distance to center of track' of its
* target, and adjusts the interpolation control points to be more or
* target, and adjusts the interpolation control points to be more or
* less at the same (relative) distance from center. If the factor is
* 1, the rubber ball will aim to be at the same relative distance,
* if the factor is 0, the rubber ball will aim directly at the
@ -110,7 +110,7 @@ private:
* m_control_points[3]. */
int m_last_aimed_graph_node;
/** Keep the last two, current, and next aiming points
/** Keep the last two, current, and next aiming points
* for interpolation. */
Vec3 m_control_points[4];
@ -132,8 +132,8 @@ private:
float m_length_cp_2_3;
/** The parameter for the spline, m_t in [0,1]. This is not directly
* related to the time, since depending on the distance between
* the two control points different increments must be used for m_t.
* related to the time, since depending on the distance between
* the two control points different increments must be used for m_t.
* For example, if the distance is 10 m, and assuming a speed of
* 10 m/s for the ball, then each second must add '1' to m_t. If
* the distance on the other hand is 200 m, then 10/200 = 1/20 per
@ -149,13 +149,13 @@ private:
/** How long it takes from one bounce of the ball to the next. */
float m_interval;
/** This flag is set if the target is within the fast ping distance. It
/** This flag is set if the target is within the fast ping distance. It
* will cause the rubber ball to decrese the jump height and intervall. */
bool m_fast_ping;
/** Distance to target. This is measured in terms of 'distance along
* track', but also takes the 3d distance and height difference into
* account (in case that the target is on a different part of the
/** Distance to target. This is measured in terms of 'distance along
* track', but also takes the 3d distance and height difference into
* account (in case that the target is on a different part of the
* track) */
float m_distance_to_target;
@ -169,7 +169,7 @@ private:
* it indicates that the ball is targeting another kart atm. */
float m_delete_timer;
/** The current maximum height of the ball. This value will be
/** The current maximum height of the ball. This value will be
* reduced if the ball gets closer to the target. */
float m_current_max_height;
@ -179,7 +179,7 @@ private:
* used to keep track of the state of this ball. */
bool m_aiming_at_target;
/** This variable counts how often a ball tunneled (in consecutive
/** This variable counts how often a ball tunneled (in consecutive
* frames). If a ball tunnels a certain number of times, it is
* considered stuck and will be removed. */
unsigned int m_tunnel_count;
@ -189,10 +189,10 @@ private:
/** Sound effect to be played when a ball hits a kart. */
SFXBase *m_hit_sfx;
void computeTarget();
void updateDistanceToTarget();
unsigned int getSuccessorToHitTarget(unsigned int node_index,
unsigned int getSuccessorToHitTarget(unsigned int node_index,
float *f=NULL);
void getNextControlPoint();
float updateHeight();

View File

@ -43,7 +43,7 @@ private:
RB_TO_TRACK} /**< Rubber band is attached to track. */
m_attached_state;
/** True if plunger was fired backwards. */
bool m_is_backward;
bool m_is_backward;
/** If rubber band is attached to track, the coordinates. */
Vec3 m_hit_position;
/** The plunger the rubber band is attached to. */
@ -60,7 +60,7 @@ private:
/** The kart a plunger might have hit. */
AbstractKart *m_hit_kart;
/** Stores the end of the rubber band (i.e. the side attached to the
/** Stores the end of the rubber band (i.e. the side attached to the
* plunger. */
Vec3 m_end_position;

View File

@ -53,7 +53,7 @@ private:
Moveable *m_target;
SFXBase *m_swat_sound;
/** True if the swatter is removing an attached bomb. */
bool m_removing_bomb;
@ -63,12 +63,12 @@ private:
/** The scene node where a bomb is saved (in case that the swatter
* replaces a bomb. */
scene::ISceneNode *m_bomb_scene_node;
/** For some reason the built-in animation system doesn't work correctly here?? */
float m_swat_bomb_frame;
const core::stringw getHitString(const AbstractKart *kart) const;
public:
Swatter(AbstractKart *kart, bool was_bomb,
scene::ISceneNode* bomb_scene_node);
@ -84,14 +84,14 @@ public:
// ------------------------------------------------------------------------
virtual void onAnimationEnd();
// ------------------------------------------------------------------------
private:
/** Determine the nearest kart or item and update the current target accordingly */
void chooseTarget();
/** If there is a current target, point to it, otherwise adopt the default position */
void pointToTarget();
/** Squash karts or items that are around the end position (determined using a joint) of the swatter */
void squashThingsAround();
}; // Swatter

View File

@ -39,7 +39,7 @@ class Skidding;
class SlipStream;
/** An abstract interface for the actual karts. Some functions are actually
* implemented here in order to allow inlining.
* implemented here in order to allow inlining.
* \ingroup karts
*/
class AbstractKart : public Moveable
@ -75,7 +75,7 @@ protected:
AbstractKartAnimation *m_kart_animation;
public:
AbstractKart(const std::string& ident,
AbstractKart(const std::string& ident,
int world_kart_id,
int position, const btTransform& init_transform);
virtual ~AbstractKart();
@ -100,7 +100,7 @@ public:
// Access to the kart properties.
// ------------------------------------------------------------------------
/** Returns the kart properties of this kart. */
const KartProperties* getKartProperties() const
const KartProperties* getKartProperties() const
{ return m_kart_properties; }
// ------------------------------------------------------------------------
/** Sets the kart properties. */
@ -116,7 +116,7 @@ public:
* speed. */
virtual float getMaxSteerAngle () const = 0;
// ------------------------------------------------------------------------
/** Returns the time till full steering is reached for this kart.
/** Returns the time till full steering is reached for this kart.
* This can depend on the current steering value, which must be >= 0.
*/
virtual float getTimeFullSteer(float steer) const = 0;
@ -155,7 +155,7 @@ public:
* animation is being shown. */
AbstractKartAnimation *getKartAnimation() { return m_kart_animation; }
// ------------------------------------------------------------------------
const AbstractKartAnimation *getKartAnimation() const
const AbstractKartAnimation *getKartAnimation() const
{ return m_kart_animation; }
// ------------------------------------------------------------------------
/** Sets a new kart animation. */
@ -167,7 +167,7 @@ public:
/** Returns the index of this kart in world. */
unsigned int getWorldKartId() const { return m_world_kart_id; }
// ------------------------------------------------------------------------
/** Saves the old controller in m_saved_controller and stores a new
/** Saves the old controller in m_saved_controller and stores a new
* controller. The save controller is needed in case of a reset.
* \param controller The new controller to use (atm it's always an
* end controller). */
@ -223,7 +223,7 @@ public:
* bonus and maluses that are currently applied. */
virtual float getCurrentMaxSpeed() const = 0;
// ------------------------------------------------------------------------
/** Returns how much increased speed time is left over in the given
/** Returns how much increased speed time is left over in the given
* category. Not pure abstract, since there is no need to implement this
* e.g. in Ghost.
* \param category Which category to report on. */
@ -237,14 +237,14 @@ public:
* \param fade_out_time How long the maximum speed will fade out linearly.
*/
virtual void increaseMaxSpeed(unsigned int category, float add_speed,
float engine_force, float duration,
float engine_force, float duration,
float fade_out_time) = 0;
// ------------------------------------------------------------------------
/** Defines a slowdown, which is in fraction of top speed.
* \param category The category for which the speed is increased.
* \param max_speed_fraction Fraction of top speed to allow only.
* \param fade_in_time How long till maximum speed is capped. */
virtual void setSlowdown(unsigned int category, float max_speed_fraction,
virtual void setSlowdown(unsigned int category, float max_speed_fraction,
float fade_in_time) = 0;
// ------------------------------------------------------------------------
/** Returns the remaining collected energy. */
@ -282,20 +282,20 @@ public:
/** Plays a beep sfx. */
virtual void beep() = 0;
// ------------------------------------------------------------------------
/** This function will play a particular character voice for this kart.
* It returns whether or not a character voice sample exists for the
* particular event. If there is no voice sample, a default can be
/** This function will play a particular character voice for this kart.
* It returns whether or not a character voice sample exists for the
* particular event. If there is no voice sample, a default can be
* played instead. */
virtual bool playCustomSFX(unsigned int type) = 0;
// ------------------------------------------------------------------------
/** Show fire to go with a zipper. */
virtual void showZipperFire() = 0;
// ------------------------------------------------------------------------
/** Sets zipper time, and apply one time additional speed boost. It can be
/** Sets zipper time, and apply one time additional speed boost. It can be
* used with a specific material, in which case the zipper parmaters are
* taken from this material (parameters that are <0 will be using the
* kart-specific values from kart-properties. */
virtual void handleZipper(const Material *m=NULL,
virtual void handleZipper(const Material *m=NULL,
bool play_sound=false) = 0;
// ------------------------------------------------------------------------
/** Returns true if this kart has finished the race. */
@ -329,14 +329,14 @@ public:
/** Returns true if the kart is 'resting', i.e. (nearly) not moving. */
virtual bool isInRest() const = 0;
// ------------------------------------------------------------------------
/** Starts the engine sound effect. Called once the track intro phase is
/** Starts the engine sound effect. Called once the track intro phase is
* over. */
virtual void startEngineSFX() = 0;
// ------------------------------------------------------------------------
/** Stores the current suspension length. This function is called from
* world after all karts are in resting position (see
* World::resetAllKarts), so that the default suspension rest length can
* be stored. This is then used later to move the wheels depending on
/** Stores the current suspension length. This function is called from
* world after all karts are in resting position (see
* World::resetAllKarts), so that the default suspension rest length can
* be stored. This is then used later to move the wheels depending on
* actual suspension, so that when a kart is in rest, the wheels are at
* the position at which they were modelled. */
virtual void setSuspensionLength() = 0;

View File

@ -27,7 +27,7 @@
class AbstractKart;
/** The base class for all kart animation, like rescue, explosion, or cannon.
* Kart animations are done by removing the physics body from the physics
* Kart animations are done by removing the physics body from the physics
* world, and instead modifying the rotation and position of the kart
* directly. They are registered with the kart, and only one can be
* used at the same time. The memory is handled by the kart object, so
@ -48,7 +48,7 @@ protected:
float m_timer;
public:
AbstractKartAnimation(AbstractKart *kart,
AbstractKartAnimation(AbstractKart *kart,
const std::string &name);
virtual ~AbstractKartAnimation();
virtual void update(float dt);

View File

@ -22,8 +22,8 @@
#include "karts/abstract_kart_animation.hpp"
#include "utils/vec3.hpp"
/** This animation shoots the kart to a specified point on the track.
*
/** This animation shoots the kart to a specified point on the track.
*
* \ingroup karts
*/
@ -34,8 +34,8 @@ class Ipo;
class CannonAnimation: public AbstractKartAnimation
{
protected:
/** This is the difference between the position of the kart when the
* cannon line is crossed and the curve interpolation at t=0. This
/** This is the difference between the position of the kart when the
* cannon line is crossed and the curve interpolation at t=0. This
* is added to each interpolated curve value to give the final
* kart position (so the kart moves relative to the curve). */
Vec3 m_delta;
@ -51,6 +51,6 @@ public:
CannonAnimation(AbstractKart *kart, Ipo *ipo);
virtual ~CannonAnimation();
virtual void update(float dt);
}; // CannonAnimation
#endif

View File

@ -22,11 +22,11 @@
#include "karts/abstract_kart_animation.hpp"
#include "utils/vec3.hpp"
/**
/**
* \brief This class is a 'mixin' for kart, and handles the animated explosion.
* I.e. it will throw the kart a certain amount in the air, rotate it
* randomly, and after the specified time period let it land at the
* same spot where it was hit, therefore avoiding any problems of
* same spot where it was hit, therefore avoiding any problems of
* karts being pushed on wrong parts of the track, and making explosion
* more 'fair' (it can't happen that one explosion give you actually
* a benefit by pushing you forwards.

View File

@ -28,8 +28,8 @@
/** \defgroup karts */
/** A ghost kart. It does not have a phsyics representation. It gets two
* transforms from the replay objects at two consecutive time steps,
/** A ghost kart. It does not have a phsyics representation. It gets two
* transforms from the replay objects at two consecutive time steps,
* and will interpolate between those positions depending on the current
* time
*/
@ -44,13 +44,13 @@ private:
std::vector<ReplayBase::KartReplayEvent> m_replay_events;
/** Pointer to the last index in m_all_times that is smaller than
/** Pointer to the last index in m_all_times that is smaller than
* the current world time. */
unsigned int m_current_transform;
/** Index of the next kart replay event. */
unsigned int m_next_event;
void updateTransform(float t, float dt);
public:
GhostKart(const std::string& ident);

View File

@ -52,8 +52,8 @@ class SkidMarks;
class SlipStream;
class Stars;
/** The main kart class. All type of karts are of this object, but with
* different controllers. The controllers are what turn a kart into a
/** The main kart class. All type of karts are of this object, but with
* different controllers. The controllers are what turn a kart into a
* player kart (i.e. the controller handle input), or an AI kart (the
* controller runs the AI code to set steering etc).
* Kart has two base classes: the most important one is moveable (which
@ -76,17 +76,17 @@ private:
/** True if kart is flying (for debug purposes only). */
bool m_flying;
/** Set when hitting bubblegum */
bool m_has_caught_nolok_bubblegum;
/** Reset position. */
btTransform m_reset_transform;
/** This object handles all skidding. */
Skidding *m_skidding;
/** The main controller of this object, used for driving. This
/** The main controller of this object, used for driving. This
* controller is used to run the kart. It will be replaced
* with an end kart controller when the kart finishes the race. */
Controller *m_controller;
@ -107,18 +107,18 @@ private:
/** For stars rotating around head effect */
Stars *m_stars_effect;
private:
/** True if the kart hasn't moved since 'ready-set-go' - used to
/** True if the kart hasn't moved since 'ready-set-go' - used to
* determine startup boost. */
bool m_has_started;
/**<Maximum engine rpm's for the current gear*/
float m_max_gear_rpm;
/** A short time after a collision acceleration is disabled to allow
/** A short time after a collision acceleration is disabled to allow
* the karts to bounce back*/
float m_bounce_back_time;
float m_bounce_back_time;
/** Time a kart is invulnerable. */
float m_invulnerable_time;
@ -126,7 +126,7 @@ private:
/** How long a kart is being squashed. If this is >0
* the kart is squashed. */
float m_squash_time;
/** If > 0 then bubble gum effect is on */
float m_bubblegum_time;
@ -148,13 +148,13 @@ private:
// -----------------
/** The shadow of a kart. */
Shadow *m_shadow;
/** If a kart is flying, the shadow is disabled (since it is
* stuck to the kart, i.e. the shadow would be flying, too). */
bool m_shadow_enabled;
ParticleEmitter *m_sky_particles_emitter;
/** All particle effects. */
KartGFX *m_kart_gfx;
@ -163,14 +163,14 @@ private:
/** Handles all slipstreaming. */
SlipStream *m_slipstream;
/** Rotation compared to the start position, same for all wheels */
float m_wheel_rotation;
/** Rotation change in the last time delta, same for all wheels */
float m_wheel_rotation_dt;
/** For each wheel it stores the suspension length after the karts are at
/** For each wheel it stores the suspension length after the karts are at
* the start position, i.e. the suspension will be somewhat compressed.
* The bullet suspensionRestLength is the value when the suspension is not
* at all compressed. */
@ -182,7 +182,7 @@ private:
float m_finish_time;
bool m_finished_race;
/** When a kart has its view blocked by the plunger, this variable will be
/** When a kart has its view blocked by the plunger, this variable will be
* > 0 the number it contains is the time left before removing plunger. */
float m_view_blocked_by_plunger;
float m_speed;
@ -210,13 +210,13 @@ private:
float getActualWheelForce();
void crashed();
void loadData(RaceManager::KartType type, bool animatedModel);
public:
Kart(const std::string& ident, unsigned int world_kart_id,
int position, const btTransform& init_transform);
virtual ~Kart();
virtual void init(RaceManager::KartType type);
virtual void updateGraphics(float dt, const Vec3& off_xyz,
virtual void updateGraphics(float dt, const Vec3& off_xyz,
const btQuaternion& off_rotation);
virtual void createPhysics ();
virtual void updateWeight ();
@ -226,13 +226,13 @@ public:
virtual void flyUp();
virtual void flyDown();
virtual void startEngineSFX ();
virtual void adjustSpeed (float f);
virtual void increaseMaxSpeed(unsigned int category, float add_speed,
float engine_force, float duration,
float engine_force, float duration,
float fade_out_time);
virtual void setSlowdown(unsigned int category, float max_speed_fraction,
virtual void setSlowdown(unsigned int category, float max_speed_fraction,
float fade_in_time);
virtual float getSpeedIncreaseTimeLeft(unsigned int category) const;
virtual void collectedItem(Item *item, int random_attachment);
@ -242,7 +242,7 @@ public:
virtual float getTerrainPitch(float heading) const;
virtual void reset ();
virtual void handleZipper (const Material *m=NULL,
virtual void handleZipper (const Material *m=NULL,
bool play_sound=false);
virtual void setSquash (float time, float slowdown);
@ -298,11 +298,11 @@ public:
// ------------------------------------------------------------------------
/** Sets that the view is blocked by a plunger. The duration depends on
* the difficulty, see KartPorperties getPlungerInFaceTime. */
virtual void blockViewWithPlunger()
{
virtual void blockViewWithPlunger()
{
// Avoid that a plunger extends the plunger time
if(m_view_blocked_by_plunger<=0)
m_view_blocked_by_plunger =
m_view_blocked_by_plunger =
m_kart_properties->getPlungerInFaceTime();
} // blockViewWithPlunger
// -------------------------------------------------------------------------
@ -312,14 +312,14 @@ public:
virtual btTransform getAlignedTransform(const float customPitch=-1);
// -------------------------------------------------------------------------
/** Returns the color used for this kart. */
const video::SColor &getColor() const
const video::SColor &getColor() const
{return m_kart_properties->getColor();}
// ------------------------------------------------------------------------
/** Returns the time till full steering is reached for this kart.
* \param steer Current steer value (must be >=0), on which the time till
* full steer depends. */
virtual float getTimeFullSteer(float steer) const
{
virtual float getTimeFullSteer(float steer) const
{
return m_kart_properties->getTimeFullSteer(steer);
} // getTimeFullSteer
// ------------------------------------------------------------------------
@ -340,7 +340,7 @@ public:
virtual btKart *getVehicle () const {return m_vehicle; }
// ------------------------------------------------------------------------
/** Returns the upright constraint for this kart. */
virtual btUprightConstraint *getUprightConstraint() const
virtual btUprightConstraint *getUprightConstraint() const
{return m_uprightConstraint;}
// ------------------------------------------------------------------------
/** Returns the speed of the kart in meters/second. */

View File

@ -19,7 +19,7 @@
#ifndef HEADER_KART_GFX_HPP
#define HEADER_KART_GFX_HPP
/** \defgroup karts
/** \defgroup karts
* This class implements all particle effects for a kart. */
#include <vector>
@ -33,9 +33,9 @@ class Vec3;
class KartGFX
{
public:
/** All particle effects supported by this object.
/** All particle effects supported by this object.
* Nitro, zipper, terrain, and skidding effects. Two different
* skid types are supported, but only one emitter node will be
* skid types are supported, but only one emitter node will be
* created. So KGFX_SKID1/2 store the two types, and KGFX_SKID
* = KGFX_SKID1 stores the actual emitter node. KGFX_COUNT
* is the number of entries and must therefore be last. */
@ -66,7 +66,7 @@ private:
/** Used to alternate particle effects from the rear wheels. */
int m_wheel_toggle;
void addEffect(KartGFXType type, const std::string &file_name,
void addEffect(KartGFXType type, const std::string &file_name,
const Vec3 &position);
public:

View File

@ -24,7 +24,7 @@
#include <IAnimatedMeshSceneNode.h>
namespace irr
{
namespace scene { class IAnimatedMesh; class IMesh;
namespace scene { class IAnimatedMesh; class IMesh;
class ISceneNode; class IMeshSceneNode; }
}
using namespace irr;
@ -41,7 +41,7 @@ class XMLNode;
* It takes especially care of attaching
* the wheels, which are loaded as separate objects. The wheels can turn
* and (for the front wheels) rotate. The implementation is dependent on the
* OpenGL library used.
* OpenGL library used.
* Note that this object is copied using the default copy function. See
* kart.cpp.
* \ingroup karts
@ -63,7 +63,7 @@ public:
AF_WIN_START, // Begin of win animation
AF_WIN_LOOP_START, // Begin of win loop animation
AF_WIN_END, // End of win animation
AF_END=AF_WIN_END, // Last animation frame
AF_END=AF_WIN_END, // Last animation frame
AF_COUNT}; // Number of entries here
private:
/** Which frame number starts/end which animation. */
@ -107,9 +107,9 @@ private:
/** The position of all four wheels in the 3d model. */
Vec3 m_wheel_graphics_position[4];
/** The position of the wheels for the physics, which can be different
/** The position of the wheels for the physics, which can be different
* from the graphical position. */
Vec3 m_wheel_physics_position[4];
Vec3 m_wheel_physics_position[4];
/** Radius of the graphical wheels. */
float m_wheel_graphics_radius[4];
@ -139,14 +139,14 @@ private:
* anything attached to it etc. */
bool m_is_master;
void loadWheelInfo(const XMLNode &node,
void loadWheelInfo(const XMLNode &node,
const std::string &wheel_name, int index);
void OnAnimationEnd(scene::IAnimatedMeshSceneNode *node);
/** Pointer to the kart object belonging to this kart model. */
AbstractKart* m_kart;
public:
KartModel(bool is_master);
~KartModel();
@ -154,45 +154,45 @@ public:
void reset();
void loadInfo(const XMLNode &node);
bool loadModels(const KartProperties &kart_properties);
void update(float rotation_dt, float steer,
void update(float rotation_dt, float steer,
const float suspension[4]);
void setDefaultPhysicsPosition(const Vec3 &center_shift,
void setDefaultPhysicsPosition(const Vec3 &center_shift,
float wheel_radius);
void finishedRace();
scene::ISceneNode*
attachModel(bool animatedModels);
// ------------------------------------------------------------------------
/** Returns the animated mesh of this kart model. */
scene::IAnimatedMesh*
scene::IAnimatedMesh*
getModel() const { return m_mesh; }
// ------------------------------------------------------------------------
/** Returns the mesh of the wheel for this kart. */
scene::IMesh* getWheelModel(const int i) const
scene::IMesh* getWheelModel(const int i) const
{ assert(i>=0 && i<4); return m_wheel_model[i]; }
// ------------------------------------------------------------------------
/** Since karts might be animated, we might need to know which base frame
/** Since karts might be animated, we might need to know which base frame
* to use. */
int getBaseFrame() const { return m_animation_frame[AF_STRAIGHT]; }
// ------------------------------------------------------------------------
/** Returns the position of a wheel relative to the kart.
* \param i Index of the wheel: 0=front right, 1 = front left, 2 = rear
/** Returns the position of a wheel relative to the kart.
* \param i Index of the wheel: 0=front right, 1 = front left, 2 = rear
* right, 3 = rear left. */
const Vec3& getWheelGraphicsPosition(int i) const
const Vec3& getWheelGraphicsPosition(int i) const
{assert(i>=0 && i<4); return m_wheel_graphics_position[i];}
// ------------------------------------------------------------------------
/** Returns the position of a wheel relative to the kart for the physics.
* The physics wheels can be attached at a different place to make the
* The physics wheels can be attached at a different place to make the
* karts more stable.
* \param i Index of the wheel: 0=front right, 1 = front left, 2 = rear
* \param i Index of the wheel: 0=front right, 1 = front left, 2 = rear
* right, 3 = rear left. */
const Vec3& getWheelPhysicsPosition(int i) const
const Vec3& getWheelPhysicsPosition(int i) const
{assert(i>=0 && i<4); return m_wheel_physics_position[i];}
// ------------------------------------------------------------------------
/** Returns the radius of the graphical wheels.
* \param i Index of the wheel: 0=front right, 1 = front left, 2 = rear
* \param i Index of the wheel: 0=front right, 1 = front left, 2 = rear
* right, 3 = rear left. */
float getWheelGraphicsRadius(int i) const
float getWheelGraphicsRadius(int i) const
{assert(i>=0 && i<4); return m_wheel_graphics_radius[i]; }
// ------------------------------------------------------------------------
/** Returns the length of the kart model. */
@ -205,7 +205,7 @@ public:
float getHeight () const {return m_kart_height; }
// ------------------------------------------------------------------------
/** Enables- or disables the end animation. */
void setAnimation(AnimationFrameType type);
void setAnimation(AnimationFrameType type);
// ------------------------------------------------------------------------
/** Sets the kart this model is currently used for */
void setKart(AbstractKart* k) { m_kart = k; }
@ -215,6 +215,6 @@ public:
// ------------------------------------------------------------------------
/** Returns the array of wheel nodes. */
scene::ISceneNode** getWheelNodes() { return m_wheel_node; }
}; // KartModel
#endif

View File

@ -42,12 +42,12 @@ class Material;
class SkiddingProperties;
class XMLNode;
/**
/**
* \brief This class stores the properties of a kart.
* This includes size, name, identifier, physical properties etc.
* It is atm also the base class for STKConfig, which stores the default values
* for all physics constants.
* Note that KartProperies is copied (when setting the default values from
* Note that KartProperies is copied (when setting the default values from
* stk_config.
*
* \ingroup karts
@ -160,16 +160,16 @@ private:
/** Duration a zipper is active. */
float m_zipper_time;
/** Fade out time for a zipper. */
float m_zipper_fade_out_time;
/** Additional force added to the acceleration. */
float m_zipper_force;
/** Initial one time speed gain. */
float m_zipper_speed_gain;
/** Absolute increase of the kart's maximum speed (in m/s). */
float m_zipper_max_speed_increase;
@ -207,10 +207,10 @@ private:
float m_nitro_max_speed_increase;
/** Additional engine force to affect the kart. */
float m_nitro_engine_force;
/** How long the increased nitro max speed will be valid after
/** How long the increased nitro max speed will be valid after
* the kart stops using nitro (and the fade-out-time starts). */
float m_nitro_duration;
/** Duration during which the increased maximum speed
/** Duration during which the increased maximum speed
* due to nitro fades out. */
float m_nitro_fade_out_time;
/** Maximum nitro a kart can collect. */
@ -245,7 +245,7 @@ private:
* &p=21240&hilit=vehicle#p21240 */
float m_downward_impulse_factor;
/** Artifical acceleration that pulls a kart down onto the track if one
/** Artifical acceleration that pulls a kart down onto the track if one
* axis loses contact with the track. */
float m_track_connection_accel;
@ -278,7 +278,7 @@ public:
* driveline. The later works nice as long as the kart is driving
* on the main track, but can work very bad if the kart is drivling
* off-track (and a wrong driveline is selected). */
enum TerrainImpulseType {IMPULSE_NONE, IMPULSE_NORMAL,
enum TerrainImpulseType {IMPULSE_NONE, IMPULSE_NORMAL,
IMPULSE_TO_DRIVELINE};
private:
TerrainImpulseType m_terrain_impulse_type;
@ -286,7 +286,7 @@ private:
/** An additional impulse to push a kart away if it hits terrain */
float m_collision_terrain_impulse;
/** An additiojnal artificial impulse that pushes two karts in a
/** An additiojnal artificial impulse that pushes two karts in a
* side-side collision away from each other. */
float m_collision_impulse;
@ -311,7 +311,7 @@ private:
float m_slipstream_add_power;
/** Minimum speed for slipstream to take effect. */
float m_slipstream_min_speed;
/** How much the speed of the kart might exceed its
/** How much the speed of the kart might exceed its
* normal maximum speed. */
float m_slipstream_max_speed_increase;
/** How long the higher speed lasts after slipstream stopped working. */
@ -322,11 +322,11 @@ private:
/** Distance of normal camera from kart. */
float m_camera_distance;
/** Up angle of the camera in relation to the pitch of the kart when
/** Up angle of the camera in relation to the pitch of the kart when
* driving forwards. */
float m_camera_forward_up_angle;
/** Up angle of the camera in relation to the pitch of the kart when
/** Up angle of the camera in relation to the pitch of the kart when
* driving backwards. */
float m_camera_backward_up_angle;
@ -339,7 +339,7 @@ private:
m_gear_switch_ratio). */
std::vector<float> m_gear_power_increase;
/** If the kart starts within the specified time at index I after 'go',
/** If the kart starts within the specified time at index I after 'go',
* it receives the speed boost from m_startup_boost[I]. */
std::vector<float> m_startup_times;
@ -360,7 +360,7 @@ public:
float getStartupBoost () const;
// ------------------------------------------------------------------------
/** Returns the (maximum) speed for a given turn radius.
/** Returns the (maximum) speed for a given turn radius.
* \param radius The radius for which the speed needs to be computed. */
float getSpeedForTurnRadius(float radius) const {
float angle = sin(m_wheel_base / radius);
@ -368,7 +368,7 @@ public:
} // getSpeedForTurnRadius
// ------------------------------------------------------------------------
/** Returns the maximum steering angle (depending on speed). */
float getMaxSteerAngle(float speed) const {
float getMaxSteerAngle(float speed) const {
return m_turn_angle_at_speed.get(speed);
} // getMaxSteerAngle
@ -382,7 +382,7 @@ public:
// ------------------------------------------------------------------------
/** Returns a pointer to the KartModel object. */
KartModel* getKartModelCopy () const
KartModel* getKartModelCopy () const
{return m_kart_model->makeCopy(); }
// ------------------------------------------------------------------------
@ -391,12 +391,12 @@ public:
const KartModel& getMasterKartModel() const {return *m_kart_model; }
// ------------------------------------------------------------------------
/** Returns the name of this kart.
/** Returns the name of this kart.
\note Pass it through fridibi as needed, this is the LTR name
*/
const wchar_t* getName() const
const wchar_t* getName() const
{
return translations->w_gettext(m_name.c_str());
return translations->w_gettext(m_name.c_str());
}
// ------------------------------------------------------------------------
@ -416,7 +416,7 @@ public:
// ------------------------------------------------------------------------
/** Returns custom sound effects for this kart. */
const int getCustomSfxId (SFXManager::CustomSFX type)
const int getCustomSfxId (SFXManager::CustomSFX type)
const {return m_custom_sfx_id[type]; }
// ------------------------------------------------------------------------
@ -441,17 +441,17 @@ public:
float getMass () const {return m_mass; }
// ------------------------------------------------------------------------
/** Returns the maximum engine power depending on difficulty. */
float getMaxPower () const
float getMaxPower () const
{return m_engine_power[race_manager->getDifficulty()];}
// ------------------------------------------------------------------------
/** Returns the time the kart needs to fully steer in one direction from
/** Returns the time the kart needs to fully steer in one direction from
* steering straight depending on the current steering value.
* \param steer Current steering value, must be >=0. */
float getTimeFullSteer(float steer) const
float getTimeFullSteer(float steer) const
{
assert(steer>=0);
return m_time_full_steer.get(steer);
return m_time_full_steer.get(steer);
} // getTimeFullSteer
// ------------------------------------------------------------------------
@ -464,7 +464,7 @@ public:
// ------------------------------------------------------------------------
/** Get maximum reverse speed ratio. */
float getMaxSpeedReverseRatio () const
float getMaxSpeedReverseRatio () const
{return m_max_speed_reverse_ratio; }
// ------------------------------------------------------------------------
@ -478,12 +478,12 @@ public:
// ------------------------------------------------------------------------
/** Returns damping relaxation. */
float getWheelDampingRelaxation () const
float getWheelDampingRelaxation () const
{return m_wheel_damping_relaxation; }
// ------------------------------------------------------------------------
/** Returns the wheel damping compression. */
float getWheelDampingCompression() const
float getWheelDampingCompression() const
{return m_wheel_damping_compression;}
// ------------------------------------------------------------------------
@ -512,7 +512,7 @@ public:
// ------------------------------------------------------------------------
/** Returns angular damping of chassis. */
float getChassisAngularDamping () const
float getChassisAngularDamping () const
{return m_chassis_angular_damping; }
// ------------------------------------------------------------------------
@ -542,7 +542,7 @@ public:
// ------------------------------------------------------------------------
/** Returns the increase of maximum speed due to nitro. */
float getNitroMaxSpeedIncrease () const
float getNitroMaxSpeedIncrease () const
{return m_nitro_max_speed_increase; }
// ------------------------------------------------------------------------
@ -553,7 +553,7 @@ public:
float getNitroDuration () const {return m_nitro_duration; }
// ------------------------------------------------------------------------
/** Returns the duration during which the increased maximum speed
/** Returns the duration during which the increased maximum speed
* due to nitro fades out. */
float getNitroFadeOutTime () const {return m_nitro_fade_out_time; }
@ -562,7 +562,7 @@ public:
float getNitroMax () const {return m_nitro_max; }
// ------------------------------------------------------------------------
/** Returns a shift of the center of mass (lowering the center of mass
/** Returns a shift of the center of mass (lowering the center of mass
* makes the karts more stable. */
const Vec3&getGravityCenterShift() const {return m_gravity_center_shift; }
@ -579,9 +579,9 @@ public:
bool getExpSpringResponse() const {return m_exp_spring_response; }
// ------------------------------------------------------------------------
/** Returns an artificial impulse to push karts away from the terrain
/** Returns an artificial impulse to push karts away from the terrain
* it hits. */
float getCollisionTerrainImpulse() const
float getCollisionTerrainImpulse() const
{return m_collision_terrain_impulse;}
// ------------------------------------------------------------------------
@ -624,9 +624,9 @@ public:
float getExplosionRadius () const {return m_explosion_radius; }
// ------------------------------------------------------------------------
/** Returns how long a kart is invulnerable after being hit by an
/** Returns how long a kart is invulnerable after being hit by an
explosion. */
float getExplosionInvulnerabilityTime() const
float getExplosionInvulnerabilityTime() const
{ return m_explosion_invulnerability_time; }
// ------------------------------------------------------------------------
@ -651,23 +651,23 @@ public:
float getRubberBandDuration () const {return m_rubber_band_duration; }
// ------------------------------------------------------------------------
/** Returns the increase of maximum speed while a rubber band is
/** Returns the increase of maximum speed while a rubber band is
* pulling. */
float getRubberBandSpeedIncrease() const
float getRubberBandSpeedIncrease() const
{
return m_rubber_band_speed_increase;
}
// ------------------------------------------------------------------------
/** Return the fade out time once a rubber band is removed. */
float getRubberBandFadeOutTime() const
float getRubberBandFadeOutTime() const
{
return m_rubber_band_fade_out_time;
}
// ------------------------------------------------------------------------
/** Returns duration of a plunger in your face. */
float getPlungerInFaceTime () const
float getPlungerInFaceTime () const
{return m_plunger_in_face_duration[race_manager->getDifficulty()];}
// ------------------------------------------------------------------------
@ -687,9 +687,9 @@ public:
float getZipperSpeedGain () const { return m_zipper_speed_gain; }
// ------------------------------------------------------------------------
/** Returns the increase of the maximum speed of the kart
/** Returns the increase of the maximum speed of the kart
* if a zipper is active. */
float getZipperMaxSpeedIncrease () const
float getZipperMaxSpeedIncrease () const
{ return m_zipper_max_speed_increase;}
// ------------------------------------------------------------------------
@ -702,7 +702,7 @@ public:
// ------------------------------------------------------------------------
/** Returns time after which slipstream has maximum effect. */
float getSlipstreamCollectTime () const
float getSlipstreamCollectTime () const
{return m_slipstream_collect_time; }
// ------------------------------------------------------------------------
@ -718,44 +718,44 @@ public:
float getSlipstreamMinSpeed () const {return m_slipstream_min_speed; }
// ------------------------------------------------------------------------
/** Returns the increase of the maximum speed of a kart
/** Returns the increase of the maximum speed of a kart
* due to slipstream. */
float getSlipstreamMaxSpeedIncrease() const
float getSlipstreamMaxSpeedIncrease() const
{ return m_slipstream_max_speed_increase; }
// ------------------------------------------------------------------------
/** Returns how long the higher speed lasts after slipstream
/** Returns how long the higher speed lasts after slipstream
* stopped working. */
float getSlipstreamDuration () const { return m_slipstream_duration; }
// ------------------------------------------------------------------------
/** Returns how long the slip stream speed increase will gradually
/** Returns how long the slip stream speed increase will gradually
* be reduced. */
float getSlipstreamFadeOutTime () const
float getSlipstreamFadeOutTime () const
{ return m_slipstream_fade_out_time; }
// ------------------------------------------------------------------------
/** Returns the scale factor by which the shadow plane
* had to be set. */
float getShadowScale () const {return m_shadow_scale; }
// ------------------------------------------------------------------------
/** Returns the scale factor by which the shadow plane
* had to be set. */
float getShadowXOffset () const {return m_shadow_x_offset; }
// ------------------------------------------------------------------------
/** Returns the scale factor by which the shadow plane
* had to be set. */
float getShadowYOffset () const {return m_shadow_y_offset; }
// ------------------------------------------------------------------------
/** Returns a pointer to the skidding properties. */
const SkiddingProperties *getSkiddingProperties() const
const SkiddingProperties *getSkiddingProperties() const
{ return m_skidding_properties; }
// ------------------------------------------------------------------------
/** Returns a pointer to the AI properties. */
const AIProperties *getAIPropertiesForDifficulty() const
const AIProperties *getAIPropertiesForDifficulty() const
{
return m_ai_properties[race_manager->getDifficulty()];
} // getAIProperties
@ -777,12 +777,12 @@ public:
// ------------------------------------------------------------------------
/** Returns the angle the camera has relative to the pitch of the kart. */
float getCameraForwardUpAngle () const
float getCameraForwardUpAngle () const
{return m_camera_forward_up_angle; }
// ------------------------------------------------------------------------
/** Returns the angle the camera has relative to the pitch of the kart. */
float getCameraBackwardUpAngle () const
float getCameraBackwardUpAngle () const
{return m_camera_backward_up_angle; }
// ------------------------------------------------------------------------
@ -790,7 +790,7 @@ public:
const std::string& getKartDir () const {return m_root; }
// ------------------------------------------------------------------------
/** Returns the square of the maximum distance at which a swatter
/** Returns the square of the maximum distance at which a swatter
* can hit karts. */
float getSwatterDistance2() const { return m_swatter_distance2; }

View File

@ -70,9 +70,9 @@ public:
const KartProperties* getKartById (int i) const;
const KartProperties* getKart(const std::string &ident) const;
const int getKartId(const std::string &ident) const;
int getKartByGroup(const std::string& group,
int getKartByGroup(const std::string& group,
int i) const;
bool loadKart (const std::string &dir);
void loadAllKarts (bool loading_icon = true);
void unloadAllKarts ();
@ -84,7 +84,7 @@ public:
void setUnavailableKarts(std::vector<std::string>);
void selectKartName(const std::string &kart_name);
bool testAndSetKart(int kartid);
void getRandomKartList(int count,
void getRandomKartList(int count,
RemoteKartInfoList& existing_karts,
std::vector<std::string> *ai_list);
// ------------------------------------------------------------------------
@ -104,7 +104,7 @@ public:
void selectKart(int kartid) { m_selected_karts.push_back(kartid); }
// ------------------------------------------------------------------------
/** Returns all directories from which karts were loaded. */
const std::vector<std::string>* getAllKartDirs() const
const std::vector<std::string>* getAllKartDirs() const
{ return &m_all_kart_dirs; }
// ------------------------------------------------------------------------
/** Returns the number of karts. */

View File

@ -71,7 +71,7 @@ private:
float m_skidding_time;
public:
KartWithStats(const std::string& ident,
KartWithStats(const std::string& ident,
unsigned int world_kart_id,
int position,
const btTransform& init_transform);

View File

@ -30,8 +30,8 @@ public:
* Increase due to zipper, slipstream, nitro, rubber band,
* skidding usage. */
enum {MS_INCREASE_MIN,
MS_INCREASE_ZIPPER = MS_INCREASE_MIN,
MS_INCREASE_SLIPSTREAM,
MS_INCREASE_ZIPPER = MS_INCREASE_MIN,
MS_INCREASE_SLIPSTREAM,
MS_INCREASE_NITRO,
MS_INCREASE_RUBBER,
MS_INCREASE_SKIDDING,
@ -40,8 +40,8 @@ public:
/** The categories to use for decreasing the speed of a kart:
* Decrease due to terrain, different AI levels and end controller. */
enum {MS_DECREASE_MIN,
MS_DECREASE_TERRAIN = MS_DECREASE_MIN,
MS_DECREASE_AI,
MS_DECREASE_TERRAIN = MS_DECREASE_MIN,
MS_DECREASE_AI,
MS_DECREASE_SQUASH,
MS_DECREASE_MAX};
@ -64,7 +64,7 @@ private:
float m_max_add_speed;
/** How long this speed will apply. This is used as a timer internally,
* to the duration will be decreased. When the duration is <0, the
* fade out time starts, and duration will go down to
* fade out time starts, and duration will go down to
* -m_fade_out_time before this speed increase stops. */
float m_duration;
/** The fadeout time. */
@ -74,7 +74,7 @@ private:
/** Additional engine force. */
float m_engine_force;
/** The constructor initialised the values with a no-increase
/** The constructor initialised the values with a no-increase
* entry, i.e. an entry that does affect top speed at all. */
SpeedIncrease()
{
@ -96,8 +96,8 @@ private:
float getTimeLeft() const {return m_duration; }
// --------------------------------------------------------------------
/** Returns the additional engine force for this speed increase. */
float getEngineForce() const
{
float getEngineForce() const
{
return m_duration > 0 ? m_engine_force : 0;
}
}; // SpeedIncrease
@ -111,7 +111,7 @@ private:
float m_max_speed_fraction;
/** How long it should take for the full slowdown to take effect. */
float m_fade_in_time;
/** The current slowdown fraction, taking the fade-in time
/** The current slowdown fraction, taking the fade-in time
* into account. */
float m_current_fraction;
@ -125,31 +125,31 @@ private:
} // SpeedDecrease
void update(float dt);
// --------------------------------------------------------------------
/** Returns the current slowdown fracftion, taking a 'fade in'
/** Returns the current slowdown fracftion, taking a 'fade in'
* into account. */
float getSlowdownFraction() const {return m_current_fraction;}
}; // SpeedDecrease
// ------------------------------------------------------------------------
/** Stores all speed decrease related information
/** Stores all speed decrease related information
* for each possible category. */
SpeedDecrease m_speed_decrease[MS_DECREASE_MAX];
/** Stores all speed increase related information
/** Stores all speed increase related information
* for each possible category. */
SpeedIncrease m_speed_increase[MS_INCREASE_MAX];
public:
MaxSpeed(AbstractKart *kart);
void increaseMaxSpeed(unsigned int category, float add_speed,
float engine_force, float duration,
float fade_out_time);
void instantSpeedIncrease(unsigned int category,
void instantSpeedIncrease(unsigned int category,
float add_speed, float speed_boost,
float engine_force, float duration,
float engine_force, float duration,
float fade_out_time/*=1.0f*/);
void setSlowdown(unsigned int category, float max_speed_fraction,
void setSlowdown(unsigned int category, float max_speed_fraction,
float fade_in_time);
float getSpeedIncreaseTimeLeft(unsigned int category);
void update(float dt);

View File

@ -60,10 +60,10 @@ public:
Moveable();
virtual ~Moveable();
/** Returns the scene node of this moveable. */
scene::ISceneNode
scene::ISceneNode
*getNode() const { return m_node; }
void setNode(scene::ISceneNode *n);
virtual const btVector3
virtual const btVector3
&getVelocity() const {return m_body->getLinearVelocity();}
const btVector3
&getVelocityLC() const {return m_velocityLC; }
@ -75,16 +75,16 @@ public:
float getPitch() const {return m_pitch; }
/** Returns the roll of the kart between -pi and pi. */
float getRoll() const {return m_roll; }
const btQuaternion
const btQuaternion
getRotation() const {return m_transform.getRotation(); }
/** Enter flying mode */
virtual void flyUp();
virtual void flyDown();
virtual void stopFlying();
/** Sets the XYZ coordinates of the moveable. */
void setXYZ(const Vec3& a)
void setXYZ(const Vec3& a)
{
m_transform.setOrigin(a);
if(m_motion_state)
@ -99,15 +99,15 @@ public:
m_motion_state->setWorldTransform(m_transform);
}
// ------------------------------------------------------------------------
virtual void updateGraphics(float dt, const Vec3& off_xyz,
virtual void updateGraphics(float dt, const Vec3& off_xyz,
const btQuaternion& off_rotation);
virtual void reset();
virtual void update(float dt) ;
btRigidBody *getBody() const {return m_body; }
void createBody(float mass, btTransform& trans,
void createBody(float mass, btTransform& trans,
btCollisionShape *shape,
float restitution);
const btTransform
const btTransform
&getTrans() const {return m_transform;}
void setTrans(const btTransform& t);
}

Some files were not shown because too many files have changed in this diff Show More