diff options
author | megamage <none@none> | 2009-05-30 15:05:54 -0500 |
---|---|---|
committer | megamage <none@none> | 2009-05-30 15:05:54 -0500 |
commit | 76d0498aae83914b3321039e605e198abe383ac4 (patch) | |
tree | 8311480f218268e60e4b466a4eace66b76678a7d /src/game/ObjectMgr.cpp | |
parent | 790181add08642fc18954c6d165f08ac4aa2c1e9 (diff) |
*Allow to spawn correct npc for defender/attacker in wintergrasp based on game event. Now only xxx Champion is spawned based on faction for test. Other npc and gameobjects requires DB support (now in db the defender is always horde and attacker always alliance, and the data of counterpart is missing)
*Fix defenders' portal (now only useable for horde)
*Display random model if the model id in creature table is one of those in creature_template table (in this case they should be 0 actually).
--HG--
branch : trunk
Diffstat (limited to 'src/game/ObjectMgr.cpp')
-rw-r--r-- | src/game/ObjectMgr.cpp | 27 |
1 files changed, 26 insertions, 1 deletions
diff --git a/src/game/ObjectMgr.cpp b/src/game/ObjectMgr.cpp index 52a06ed7e57..7232da67103 100644 --- a/src/game/ObjectMgr.cpp +++ b/src/game/ObjectMgr.cpp @@ -892,7 +892,15 @@ uint32 ObjectMgr::ChooseDisplayId(uint32 team, const CreatureInfo *cinfo, const if (!data || data->displayid == 0) // use defaults from the template { display_id = cinfo->GetRandomValidModelId(); - } else display_id = data->displayid; // overwritten from creature data + } + else + { + display_id = data->displayid; // overwritten from creature data + // I do not know why but in db most display id are not zero + if(display_id == cinfo->Modelid_A1 || display_id == cinfo->Modelid_A2 + || display_id == cinfo->Modelid_H1 || display_id == cinfo->Modelid_H2) + display_id = cinfo->GetRandomValidModelId(); + } return display_id; } @@ -1059,6 +1067,9 @@ void ObjectMgr::LoadCreatures() if(cInfo->HeroicEntry) heroicCreatures.insert(cInfo->HeroicEntry); + //TODO: remove this + gameeventmgr.mGameEventCreatureGuids.resize(52*2-1); + barGoLink bar(result->GetRowCount()); do @@ -1160,6 +1171,20 @@ void ObjectMgr::LoadCreatures() data.phaseMask = 1; } + //if(entry == 32307 || entry == 32308) + if(entry == 30739 || entry == 30740) + { + gameEvent = 51; + uint32 guid2 = objmgr.GenerateLowGuid(HIGHGUID_UNIT); + CreatureData& data2 = mCreatureDataMap[guid2]; + data2 = data; +// data2.id = (entry == 32307 ? 32308 : 32307); + data2.id = (entry == 30739 ? 30740 : 30739); + data2.displayid = 0; + gameeventmgr.mGameEventCreatureGuids[51+51].push_back(guid); + gameeventmgr.mGameEventCreatureGuids[51+50].push_back(guid2); + } + if (gameEvent==0 && PoolId==0) // if not this is to be managed by GameEvent System or Pool system AddCreatureToGrid(guid, &data); |