#include <NetworkIDGenerator.h>
Inheritance diagram for NetworkIDGenerator:
Public Member Functions | |
NetworkIDGenerator () | |
Constructor. NetworkIDs, if IsNetworkIDAuthority() is true, are created here. | |
virtual | ~NetworkIDGenerator () |
Destructor. Used NetworkIDs, if any, are freed here. | |
virtual NetworkID | GetNetworkID (void) |
virtual void | SetNetworkID (NetworkID id) |
virtual void | SetParent (void *_parent) |
virtual void * | GetParent (void) const |
virtual bool | IsNetworkIDAuthority (void) const =0 |
virtual bool | RequiresSetParent (void) const |
Static Public Member Functions | |
static unsigned short | GetStaticNetworkID (void) |
static void | SetStaticNetworkID (unsigned short i) |
static void | SetExternalPlayerID (PlayerID playerId) |
static PlayerID | GetExternalPlayerID (void) |
static void * | GET_BASE_OBJECT_FROM_ID (NetworkID x) |
If you use a parent, returns this instance rather than the parent object. | |
static void * | GET_OBJECT_FROM_ID (NetworkID x) |
Returns the parent object, or this instance if you don't use a parent. | |
Static Public Attributes | |
static DataStructures::AVLBalancedBinarySearchTree< NetworkIDNode > | IDTree |
This AVL tree holds the pointer to NetworkID mappings. | |
Protected Member Functions | |
void | GenerateID (void) |
Internal function to generate an ID when needed. This is deferred until needed and is not called from the constructor. | |
Protected Attributes | |
NetworkID | networkID |
The network ID of this object. | |
void * | parent |
The parent set by SetParent(). | |
bool | callGenerationCode |
This is crap but is necessary because virtual functions don't work in the constructor. | |
Static Private Attributes | |
static PlayerID | externalPlayerId = UNASSIGNED_PLAYER_ID |
static unsigned short | staticItemID = 0 |
A class you can derive from to make it easier to represent every networked object with an integer. This way you can refer to objects over the network. One system should return true for IsNetworkIDAuthority() and the rest should return false. When an object needs to be created, have the the one system create the object. Then have that system send a message to all other systems, and include the value returned from GetNetworkID() in that packet. All other systems should then create the same class of object, and call SetNetworkID() on that class with the NetworkID in the packet.
|
Returns the NetworkID that you can use to refer to this object over the network.
|
|
Return what was passed to SetParent
|
|
These function is only meant to be used when saving games as you should save the HIGHEST value staticItemID has achieved upon save and reload it upon load. Save AFTER you've created all the items derived from this class you are going to create.
|
|
For every group of systems, one system needs to be responsible for creating unique IDs for all objects created on all systems. This way, systems can send that id in packets to refer to objects (you can't send pointers because the memory allocations may be different). In a client/server enviroment, the system that creates unique IDs would be the server. return true if this system is responsible for creating unique IDs (probably the server), return true. Otherwise return false. |
|
Overload this function and return true if you require that SetParent is called before this object is used. This is a safety check you should do this if you want this to be a member object of another class rather than derive from this class. |
|
Necessary for peer to peer, as NetworkIDs are then composed of your external player Id (doesn't matter which, as long as unique) plus the usual object ID number. Get this from RakPeer::GetExternalPlayerID) one time, the first time you make a connection.
|
|
Sets the NetworkID for this instance. Usually this is called by the clients and determined from the servers. However, if you save multiplayer games you would likely use This on load as well. |
|
Your class does not have to derive from NetworkIDGenerator, although that is the easiest way to implement this. If you want this to be a member object of another class, rather than inherit, then call SetParent() with a pointer to the parent class instance. GET_OBJECT_FROM_ID will then return the parent rather than this instance. |
|
These function is only meant to be used when loading games. Load BEFORE you create any new objects that are not SetIDed based on the save data.
|