2004-07-27 23:00:53 +02:00
|
|
|
#include "precompiled.h"
|
|
|
|
|
|
|
|
#include "CStr.h"
|
|
|
|
#include "CLogger.h"
|
2005-01-07 01:47:44 +01:00
|
|
|
#include "ps/Errors.h"
|
2004-07-27 23:00:53 +02:00
|
|
|
|
|
|
|
#include "World.h"
|
|
|
|
#include "MapReader.h"
|
|
|
|
#include "Game.h"
|
2005-07-03 18:25:48 +02:00
|
|
|
#include "GameAttributes.h"
|
2004-07-27 23:00:53 +02:00
|
|
|
#include "Terrain.h"
|
2004-07-31 17:57:18 +02:00
|
|
|
#include "LightEnv.h"
|
|
|
|
#include "BaseEntityCollection.h"
|
2004-08-05 15:07:51 +02:00
|
|
|
#include "EntityManager.h"
|
2005-03-18 23:02:20 +01:00
|
|
|
#include "timer.h"
|
2005-03-22 03:17:55 +01:00
|
|
|
#include "Loader.h"
|
2005-03-22 22:00:56 +01:00
|
|
|
#include "LoaderThunks.h"
|
2005-08-15 01:34:37 +02:00
|
|
|
#include "graphics/MapWriter.h"
|
2005-09-30 02:59:42 +02:00
|
|
|
#include "UnitManager.h"
|
|
|
|
#include "EntityManager.h"
|
|
|
|
#include "Projectile.h"
|
2005-10-09 05:43:03 +02:00
|
|
|
#include "LOSManager.h"
|
2006-03-21 21:55:45 +01:00
|
|
|
#include "graphics/GameView.h"
|
2004-07-27 23:00:53 +02:00
|
|
|
|
2004-08-15 22:57:31 +02:00
|
|
|
#define LOG_CATEGORY "world"
|
|
|
|
|
2005-08-15 01:34:37 +02:00
|
|
|
// global light settings. this is not a member of CWorld because it is
|
|
|
|
// passed to the renderer before CWorld exists.
|
2004-10-23 16:39:28 +02:00
|
|
|
CLightEnv g_LightEnv;
|
2004-07-27 23:00:53 +02:00
|
|
|
|
2005-09-30 02:59:42 +02:00
|
|
|
|
|
|
|
CWorld::CWorld(CGame *pGame):
|
|
|
|
m_pGame(pGame),
|
|
|
|
m_Terrain(),
|
2006-03-21 21:55:45 +01:00
|
|
|
m_UnitManager(&g_UnitMan),
|
|
|
|
m_EntityManager(new CEntityManager()),
|
|
|
|
m_ProjectileManager(new CProjectileManager()),
|
|
|
|
m_LOSManager(new CLOSManager())
|
2005-09-30 02:59:42 +02:00
|
|
|
{}
|
|
|
|
|
2004-07-27 23:00:53 +02:00
|
|
|
void CWorld::Initialize(CGameAttributes *pAttribs)
|
|
|
|
{
|
2005-02-21 00:55:07 +01:00
|
|
|
// TODO: Find a better way of handling these global things
|
2006-03-18 22:25:03 +01:00
|
|
|
ONCE(RegMemFun(CBaseEntityCollection::GetSingletonPtr(), &CBaseEntityCollection::loadTemplates, L"LoadTemplates", 15));
|
2004-07-31 17:57:18 +02:00
|
|
|
|
2005-02-11 13:57:19 +01:00
|
|
|
// Load the map, if one was specified
|
|
|
|
if (pAttribs->m_MapFile.Length())
|
|
|
|
{
|
|
|
|
CStr mapfilename("maps/scenarios/");
|
|
|
|
|
|
|
|
mapfilename += (CStr)pAttribs->m_MapFile;
|
|
|
|
|
2005-03-22 22:00:56 +01:00
|
|
|
CMapReader* reader = 0;
|
2005-03-30 18:14:19 +02:00
|
|
|
|
2005-02-11 13:57:19 +01:00
|
|
|
try {
|
2005-03-22 22:00:56 +01:00
|
|
|
reader = new CMapReader;
|
2006-03-21 21:55:45 +01:00
|
|
|
reader->LoadMap(mapfilename, &m_Terrain, m_UnitManager, &g_LightEnv, m_pGame->GetView()->GetCamera());
|
2005-03-22 22:00:56 +01:00
|
|
|
// fails immediately, or registers for delay loading
|
2005-10-30 22:30:52 +01:00
|
|
|
} catch (CFileUnpacker::CError) {
|
2005-03-22 22:00:56 +01:00
|
|
|
delete reader;
|
2005-02-11 13:57:19 +01:00
|
|
|
LOG(ERROR, LOG_CATEGORY, "Failed to load map %s", mapfilename.c_str());
|
|
|
|
throw PSERROR_Game_World_MapLoadFailed();
|
|
|
|
}
|
2004-07-27 23:00:53 +02:00
|
|
|
}
|
|
|
|
}
|
2004-08-05 15:07:51 +02:00
|
|
|
|
2005-03-22 03:17:55 +01:00
|
|
|
|
|
|
|
void CWorld::RegisterInit(CGameAttributes *pAttribs)
|
|
|
|
{
|
2005-03-22 22:00:56 +01:00
|
|
|
Initialize(pAttribs);
|
2005-03-22 03:17:55 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2004-08-05 15:07:51 +02:00
|
|
|
CWorld::~CWorld()
|
|
|
|
{
|
2006-03-21 21:55:45 +01:00
|
|
|
delete m_EntityManager;
|
|
|
|
delete m_ProjectileManager;
|
|
|
|
delete m_LOSManager;
|
2004-08-05 15:07:51 +02:00
|
|
|
}
|
2005-08-15 01:34:37 +02:00
|
|
|
|
|
|
|
|
|
|
|
void CWorld::RewriteMap()
|
|
|
|
{
|
2006-03-21 21:55:45 +01:00
|
|
|
CMapWriter::RewriteAllMaps(&m_Terrain, m_UnitManager, &g_LightEnv, m_pGame->GetView()->GetCamera());
|
2005-08-16 21:51:18 +02:00
|
|
|
}
|