mirror of
https://github.com/mangosfour/server.git
synced 2025-12-17 16:37:00 +00:00
[8546] implement battleground bonusweekends call to arms
This commit is contained in:
parent
b30fed45de
commit
0208c54bc9
7 changed files with 29 additions and 8 deletions
|
|
@ -21,7 +21,8 @@
|
||||||
#include "BattleGround.h"
|
#include "BattleGround.h"
|
||||||
#include "BattleGroundAB.h"
|
#include "BattleGroundAB.h"
|
||||||
#include "Creature.h"
|
#include "Creature.h"
|
||||||
#include "ObjectMgr.h"
|
#include "GameObject.h"
|
||||||
|
#include "BattleGroundMgr.h"
|
||||||
#include "Language.h"
|
#include "Language.h"
|
||||||
#include "Util.h"
|
#include "Util.h"
|
||||||
#include "WorldPacket.h"
|
#include "WorldPacket.h"
|
||||||
|
|
@ -580,7 +581,7 @@ void BattleGroundAB::Reset()
|
||||||
m_ReputationScoreTics[BG_TEAM_ALLIANCE] = 0;
|
m_ReputationScoreTics[BG_TEAM_ALLIANCE] = 0;
|
||||||
m_ReputationScoreTics[BG_TEAM_HORDE] = 0;
|
m_ReputationScoreTics[BG_TEAM_HORDE] = 0;
|
||||||
m_IsInformedNearVictory = false;
|
m_IsInformedNearVictory = false;
|
||||||
bool isBGWeekend = false; //TODO FIXME - call sBattleGroundMgr.IsBGWeekend(m_TypeID); - you must also implement that call!
|
bool isBGWeekend = sBattleGroundMgr.IsBGWeekend(GetTypeID());
|
||||||
m_HonorTics = (isBGWeekend) ? BG_AB_ABBGWeekendHonorTicks : BG_AB_NotABBGWeekendHonorTicks;
|
m_HonorTics = (isBGWeekend) ? BG_AB_ABBGWeekendHonorTicks : BG_AB_NotABBGWeekendHonorTicks;
|
||||||
m_ReputationTics = (isBGWeekend) ? BG_AB_ABBGWeekendReputationTicks : BG_AB_NotABBGWeekendReputationTicks;
|
m_ReputationTics = (isBGWeekend) ? BG_AB_ABBGWeekendReputationTicks : BG_AB_NotABBGWeekendReputationTicks;
|
||||||
m_TeamScores500Disadvantage[BG_TEAM_ALLIANCE] = false;
|
m_TeamScores500Disadvantage[BG_TEAM_ALLIANCE] = false;
|
||||||
|
|
|
||||||
|
|
@ -22,6 +22,7 @@
|
||||||
#include "BattleGroundEY.h"
|
#include "BattleGroundEY.h"
|
||||||
#include "Creature.h"
|
#include "Creature.h"
|
||||||
#include "ObjectMgr.h"
|
#include "ObjectMgr.h"
|
||||||
|
#include "BattleGroundMgr.h"
|
||||||
#include "Language.h"
|
#include "Language.h"
|
||||||
#include "WorldPacket.h"
|
#include "WorldPacket.h"
|
||||||
#include "Util.h"
|
#include "Util.h"
|
||||||
|
|
@ -519,7 +520,7 @@ void BattleGroundEY::Reset()
|
||||||
m_DroppedFlagGUID = 0;
|
m_DroppedFlagGUID = 0;
|
||||||
m_PointAddingTimer = 0;
|
m_PointAddingTimer = 0;
|
||||||
m_TowerCapCheckTimer = 0;
|
m_TowerCapCheckTimer = 0;
|
||||||
bool isBGWeekend = false; //TODO FIXME - call sBattleGroundMgr.IsBGWeekend(m_TypeID); - you must also implement that call!
|
bool isBGWeekend = sBattleGroundMgr.IsBGWeekend(GetTypeID());
|
||||||
m_HonorTics = (isBGWeekend) ? BG_EY_EYWeekendHonorTicks : BG_EY_NotEYWeekendHonorTicks;
|
m_HonorTics = (isBGWeekend) ? BG_EY_EYWeekendHonorTicks : BG_EY_NotEYWeekendHonorTicks;
|
||||||
|
|
||||||
for(uint8 i = 0; i < EY_POINTS_MAX; ++i)
|
for(uint8 i = 0; i < EY_POINTS_MAX; ++i)
|
||||||
|
|
|
||||||
|
|
@ -40,7 +40,7 @@
|
||||||
#include "ArenaTeam.h"
|
#include "ArenaTeam.h"
|
||||||
#include "World.h"
|
#include "World.h"
|
||||||
#include "WorldPacket.h"
|
#include "WorldPacket.h"
|
||||||
#include "ProgressBar.h"
|
#include "GameEventMgr.h"
|
||||||
|
|
||||||
#include "Policies/SingletonImp.h"
|
#include "Policies/SingletonImp.h"
|
||||||
|
|
||||||
|
|
@ -2082,3 +2082,19 @@ void BattleGroundMgr::LoadBattleMastersEntry()
|
||||||
sLog.outString( ">> Loaded %u battlemaster entries", count );
|
sLog.outString( ">> Loaded %u battlemaster entries", count );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool BattleGroundMgr::IsBGWeekend(BattleGroundTypeId bgTypeId)
|
||||||
|
{
|
||||||
|
switch (bgTypeId)
|
||||||
|
{
|
||||||
|
case BATTLEGROUND_AV:
|
||||||
|
return IsHolidayActive(HOLIDAY_CALL_TO_ARMS_AV);
|
||||||
|
case BATTLEGROUND_EY:
|
||||||
|
return IsHolidayActive(HOLIDAY_CALL_TO_ARMS_EY);
|
||||||
|
case BATTLEGROUND_WS:
|
||||||
|
return IsHolidayActive(HOLIDAY_CALL_TO_ARMS_WS);
|
||||||
|
case BATTLEGROUND_SA:
|
||||||
|
return IsHolidayActive(HOLIDAY_CALL_TO_ARMS_SA);
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
||||||
|
|
@ -244,6 +244,8 @@ class BattleGroundMgr
|
||||||
static BattleGroundQueueTypeId BGQueueTypeId(BattleGroundTypeId bgTypeId, uint8 arenaType);
|
static BattleGroundQueueTypeId BGQueueTypeId(BattleGroundTypeId bgTypeId, uint8 arenaType);
|
||||||
static BattleGroundTypeId BGTemplateId(BattleGroundQueueTypeId bgQueueTypeId);
|
static BattleGroundTypeId BGTemplateId(BattleGroundQueueTypeId bgQueueTypeId);
|
||||||
static uint8 BGArenaType(BattleGroundQueueTypeId bgQueueTypeId);
|
static uint8 BGArenaType(BattleGroundQueueTypeId bgQueueTypeId);
|
||||||
|
|
||||||
|
static bool IsBGWeekend(BattleGroundTypeId bgTypeId);
|
||||||
private:
|
private:
|
||||||
BattleMastersMap mBattleMastersMap;
|
BattleMastersMap mBattleMastersMap;
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -23,6 +23,7 @@
|
||||||
#include "Creature.h"
|
#include "Creature.h"
|
||||||
#include "GameObject.h"
|
#include "GameObject.h"
|
||||||
#include "ObjectMgr.h"
|
#include "ObjectMgr.h"
|
||||||
|
#include "BattleGroundMgr.h"
|
||||||
#include "WorldPacket.h"
|
#include "WorldPacket.h"
|
||||||
#include "Language.h"
|
#include "Language.h"
|
||||||
|
|
||||||
|
|
@ -591,7 +592,7 @@ void BattleGroundWS::Reset()
|
||||||
m_FlagState[BG_TEAM_HORDE] = BG_WS_FLAG_STATE_ON_BASE;
|
m_FlagState[BG_TEAM_HORDE] = BG_WS_FLAG_STATE_ON_BASE;
|
||||||
m_TeamScores[BG_TEAM_ALLIANCE] = 0;
|
m_TeamScores[BG_TEAM_ALLIANCE] = 0;
|
||||||
m_TeamScores[BG_TEAM_HORDE] = 0;
|
m_TeamScores[BG_TEAM_HORDE] = 0;
|
||||||
bool isBGWeekend = false; //TODO FIXME - call sBattleGroundMgr.IsBGWeekend(m_TypeID); - you must also implement that call!
|
bool isBGWeekend = sBattleGroundMgr.IsBGWeekend(GetTypeID());
|
||||||
m_ReputationCapture = (isBGWeekend) ? 45 : 35;
|
m_ReputationCapture = (isBGWeekend) ? 45 : 35;
|
||||||
m_HonorWinKills = (isBGWeekend) ? 3 : 1;
|
m_HonorWinKills = (isBGWeekend) ? 3 : 1;
|
||||||
m_HonorEndKills = (isBGWeekend) ? 4 : 2;
|
m_HonorEndKills = (isBGWeekend) ? 4 : 2;
|
||||||
|
|
|
||||||
|
|
@ -1899,7 +1899,7 @@ enum HolidayIds
|
||||||
HOLIDAY_NOBLEGARDEN = 181,
|
HOLIDAY_NOBLEGARDEN = 181,
|
||||||
HOLIDAY_CHILDRENS_WEEK = 201,
|
HOLIDAY_CHILDRENS_WEEK = 201,
|
||||||
HOLIDAY_CALL_TO_ARMS_AV = 283,
|
HOLIDAY_CALL_TO_ARMS_AV = 283,
|
||||||
HOLIDAY_CALL_TO_ARMS_WG = 284,
|
HOLIDAY_CALL_TO_ARMS_WS = 284,
|
||||||
HOLIDAY_CALL_TO_ARMS_AB = 285,
|
HOLIDAY_CALL_TO_ARMS_AB = 285,
|
||||||
HOLIDAY_FISHING_EXTRAVAGANZA = 301,
|
HOLIDAY_FISHING_EXTRAVAGANZA = 301,
|
||||||
HOLIDAY_HARVEST_FESTIVAL = 321,
|
HOLIDAY_HARVEST_FESTIVAL = 321,
|
||||||
|
|
@ -1907,7 +1907,7 @@ enum HolidayIds
|
||||||
HOLIDAY_LUNAR_FESTIVAL = 327,
|
HOLIDAY_LUNAR_FESTIVAL = 327,
|
||||||
HOLIDAY_LOVE_IS_IN_THE_AIR = 335,
|
HOLIDAY_LOVE_IS_IN_THE_AIR = 335,
|
||||||
HOLIDAY_FIRE_FESTIVAL = 341,
|
HOLIDAY_FIRE_FESTIVAL = 341,
|
||||||
HOLIDAY_CALL_TO_ARMS_ES = 353,
|
HOLIDAY_CALL_TO_ARMS_EY = 353,
|
||||||
HOLIDAY_BREWFEST = 372,
|
HOLIDAY_BREWFEST = 372,
|
||||||
HOLIDAY_DARKMOON_FAIRE_ELWYNN = 374,
|
HOLIDAY_DARKMOON_FAIRE_ELWYNN = 374,
|
||||||
HOLIDAY_DARKMOON_FAIRE_THUNDER = 375,
|
HOLIDAY_DARKMOON_FAIRE_THUNDER = 375,
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
#ifndef __REVISION_NR_H__
|
#ifndef __REVISION_NR_H__
|
||||||
#define __REVISION_NR_H__
|
#define __REVISION_NR_H__
|
||||||
#define REVISION_NR "8545"
|
#define REVISION_NR "8546"
|
||||||
#endif // __REVISION_NR_H__
|
#endif // __REVISION_NR_H__
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue