Difference between revisions of "ID System"
From SWGANH Wiki
(New page: All ids are 64bit values, first 4 bytes determine category, last 4 is the objects id categories: 0x00000000 - // static objects, currently used(buildings,cells,terminals,chairs,...) |
|||
Line 1: | Line 1: | ||
All ids are 64bit values, first 4 bytes determine category, last 4 is the objects id | All ids are 64bit values, first 4 bytes determine category, last 4 is the objects id | ||
− | + | <pre> | |
categories: | categories: | ||
Line 145: | Line 145: | ||
No containment msgs are sent, when entering/leaving a cell while in game | No containment msgs are sent, when entering/leaving a cell while in game | ||
So this needs further testing.. | So this needs further testing.. | ||
+ | </pre> |
Revision as of 23:51, 17 April 2007
All ids are 64bit values, first 4 bytes determine category, last 4 is the objects id
categories: 0x00000000 - // static objects, currently used(buildings,cells,terminals,chairs,bazzar,..) 0x00000000000C3500 // Additional Planets Static Buildings START 0x00000001 // travel terminals and for future expansion (LAST ID USED --> 4294967567) groups: 0x000000010xxxxxxx // terminals 0x000000011xxxxxxx // ticket collectors (DONE!) 0x000000012xxxxxxx // crafting stations 0x00000002 - // characters, todo: see how much to reserve for each(increment) 0x00000003 0x00000004 - // player vendors 0x00000006 0x00000007 - // player mounts 0x00000008 0x00000009 - // player ships 0x0000000A 0x0000000B // static npcs(trainers,junk vendors) groups: 0x0000000B0xxxxxxx // trainers, increment by 2(object,inventory) 0x0000000B1xxxxxxx // filler NPCs, increment by 2(object,inventory) 0x0000000B2xxxxxxx // shuttles, increment by 2(object,inventory) 0x0000000B3xxxxxxx // junk vendors, increment by 2(object,inventory) 0x0000000C // guilds 0x0000000D - // mails 0x0000000E 0x0000000F // unused 0x00000010 - // missions 0x0000001A 0x0000001b - // quests, todo: check, probably those are fixed ids 0x0000001f 0x00000020 - // waypoints 0x0000002f 0x00000030 - // auctions 0x000000ff 0x00000100 // resource containers 0x00000200 // resources 0x00000201 - // dynamic structures(buildings,cells) 0x00000fff groups: 0x00000201xxxxxxxx // tutorial stations 0x00001000 // lairs 0x00001001 - // dynamic npc 0x00001fff 0x00002000 - // space objects(jtl) 0x0000ffff 0x00010000 - // tangible objects(items) 0x000fffff groups: 0x0001xxxxxxxxxxxx - 0x0002xxxxxxxxxxxx // wearables 0x0003xxxxxxxxxxxx - 0x0004xxxxxxxxxxxx // foods 0x0005xxxxxxxxxxxx - 0x0006xxxxxxxxxxxx // furniture 0x00070xxxxxxxxxxx // tickets 0x00071xxxxxxxxxxx // crafting tools 0x00072xxxxxxxxxxx // survey tools 0x00100000 // persistent chatrooms 0x00100001 // temporary chatrooms(groups) 0x00100002 // guild chatrooms 0x00100003 // other user chatrooms 0xXXXXXXXXXXXXXXXX // draft schematics, first for byte of the id are the crc of the schematicobject, so they shouldnt be smaller than 0x0xxxxxxx , last 4 byte represent the linked resourceweights batch object ids: on static objects: category 0x00000000 - starts with 2 - inrement by 1, e.g. by 1 + cellcount for structures Most are already ripped from the snapshots, you can find em in the static_objects tables. So there are big holes, probably need to fill up that stuff with ids for chairs and other stuff from the ilf files. Unfortunately those arent id'd and so can only be identified by their position. category 0x00000001 - start with 1 - inrement by 1, e.g. by 1 + cellcount for structures To sum it up. Use linear id'ing for: static_objects,characters,vendors,trainers,mounts,ships,static npc,guilds,mails, draft schematics,resources,skills,player structures,chatrooms use random number id'ing for missions,auctions,lairs,dynamic npc,items, On Character/NPC id'ing, from what i understand right now, plz correct me. 1. the character id would be the creature object id, so the main objects id, which we send with createobject(). 2. with a containment msg this creature object is put into a player object, which id, lets say is a fixed offset from that creatureobject id 3. from there on we send updates to the client, creature specific(CREOs), referencing this creatureobject id and player specific(PLAYs), referencing the offset player id 4. procedure would be the same for npc 5. non npc -> creatures, dont need PLAY updates 6. we have an inventory object, which is set off from the creatureobject id 7. we have a mission_bag object, which is set off from the creatureobject id 8. we have a weaponslot object, which is set off from the creatureobject id 9. we have a hair object which is set off from the creatureobject id On Object <-> cell linking Currently it seems, we only need to send a containment msg when we want to load in to a cell. The linked id would be the creatureobject id. Linktype would be 0xffffffff. No containment msgs are sent, when entering/leaving a cell while in game So this needs further testing..