1
0
Fork 0
mirror of https://github.com/OpenMW/openmw.git synced 2025-10-25 14:56:37 +00:00

don't create terrain if there is no land data, also fixes a water disappearing issue and a sound exception if cells with no region

This commit is contained in:
scrawl 2012-05-17 19:54:09 +02:00
parent 375c198ebd
commit c9aa0ca1f4
3 changed files with 29 additions and 32 deletions

View file

@ -11,6 +11,7 @@
#include "../mwworld/world.hpp" // these includes can be removed once the static-hack is gone #include "../mwworld/world.hpp" // these includes can be removed once the static-hack is gone
#include "../mwworld/ptr.hpp" #include "../mwworld/ptr.hpp"
#include "../mwbase/environment.hpp"
#include <components/esm/loadstat.hpp> #include <components/esm/loadstat.hpp>
#include <components/settings/settings.hpp> #include <components/settings/settings.hpp>
@ -229,7 +230,10 @@ void RenderingManager::update (float duration){
mWater->update(); mWater->update();
} }
void RenderingManager::waterAdded (MWWorld::Ptr::CellStore *store){ void RenderingManager::waterAdded (MWWorld::Ptr::CellStore *store){
if(store->cell->data.flags & store->cell->HasWater){ if(store->cell->data.flags & store->cell->HasWater
|| ((!(store->cell->data.flags & ESM::Cell::Interior))
&& !MWBase::Environment::get().getWorld()->getStore().lands.search(store->cell->data.gridX,store->cell->data.gridY) )) // always use water, if the cell does not have land.
{
if(mWater == 0) if(mWater == 0)
mWater = new MWRender::Water(mRendering.getCamera(), mSkyManager, store->cell); mWater = new MWRender::Water(mRendering.getCamera(), mSkyManager, store->cell);
else else
@ -238,7 +242,6 @@ void RenderingManager::waterAdded (MWWorld::Ptr::CellStore *store){
} }
else else
removeWater(); removeWater();
} }
void RenderingManager::setWaterHeight(const float height) void RenderingManager::setWaterHeight(const float height)

View file

@ -110,12 +110,12 @@ namespace MWRender
const int cellY = store->cell->getGridY(); const int cellY = store->cell->getGridY();
ESM::Land* land = MWBase::Environment::get().getWorld()->getStore().lands.search(cellX, cellY); ESM::Land* land = MWBase::Environment::get().getWorld()->getStore().lands.search(cellX, cellY);
if ( land != NULL ) if (land == NULL) // no land data means we're not going to create any terrain.
return;
if (!land->dataLoaded)
{ {
if (!land->dataLoaded) land->loadData();
{
land->loadData();
}
} }
//split the cell terrain into four segments //split the cell terrain into four segments
@ -138,25 +138,18 @@ namespace MWRender
mLandSize*mLandSize, mLandSize*mLandSize,
MEMCATEGORY_GEOMETRY); MEMCATEGORY_GEOMETRY);
if ( land != NULL ) //copy the height data row by row
for ( int terrainCopyY = 0; terrainCopyY < mLandSize; terrainCopyY++ )
{ {
//copy the height data row by row //the offset of the current segment
for ( int terrainCopyY = 0; terrainCopyY < mLandSize; terrainCopyY++ ) const size_t yOffset = y * (mLandSize-1) * ESM::Land::LAND_SIZE +
{ //offset of the row
//the offset of the current segment terrainCopyY * ESM::Land::LAND_SIZE;
const size_t yOffset = y * (mLandSize-1) * ESM::Land::LAND_SIZE + const size_t xOffset = x * (mLandSize-1);
//offset of the row
terrainCopyY * ESM::Land::LAND_SIZE;
const size_t xOffset = x * (mLandSize-1);
memcpy(&terrainData.inputFloat[terrainCopyY*mLandSize], memcpy(&terrainData.inputFloat[terrainCopyY*mLandSize],
&land->landData->heights[yOffset + xOffset], &land->landData->heights[yOffset + xOffset],
mLandSize*sizeof(float)); mLandSize*sizeof(float));
}
}
else
{
memset(terrainData.inputFloat, 0, mLandSize*mLandSize*sizeof(float));
} }
std::map<uint16_t, int> indexes; std::map<uint16_t, int> indexes;
@ -179,7 +172,7 @@ namespace MWRender
terrain->setVisibilityFlags(RV_Terrain); terrain->setVisibilityFlags(RV_Terrain);
terrain->setRenderQueueGroup(RQG_Main); terrain->setRenderQueueGroup(RQG_Main);
if ( land && land->landData->usingColours ) if ( land->landData->usingColours )
{ {
// disable or enable global colour map (depends on available vertex colours) // disable or enable global colour map (depends on available vertex colours)
mActiveProfile->setGlobalColourMapEnabled(true); mActiveProfile->setGlobalColourMapEnabled(true);
@ -196,10 +189,6 @@ namespace MWRender
//mat = terrain->_getCompositeMapMaterial(); //mat = terrain->_getCompositeMapMaterial();
//mat->getTechnique(0)->getPass(0)->getTextureUnitState(1)->setTextureName( vertex->getName() ); //mat->getTechnique(0)->getPass(0)->getTextureUnitState(1)->setTextureName( vertex->getName() );
} }
else
{
mActiveProfile->setGlobalColourMapEnabled(false);
}
} }
} }
} }
@ -215,8 +204,10 @@ namespace MWRender
{ {
for ( int y = 0; y < 2; y++ ) for ( int y = 0; y < 2; y++ )
{ {
mTerrainGroup.unloadTerrain(store->cell->getGridX() * 2 + x, int terrainX = store->cell->getGridX() * 2 + x;
store->cell->getGridY() * 2 + y); int terrainY = store->cell->getGridY() * 2 + y;
if (mTerrainGroup.getTerrain(terrainX, terrainY) != NULL)
mTerrainGroup.unloadTerrain(terrainX, terrainY);
} }
} }
} }

View file

@ -433,7 +433,10 @@ namespace MWSound
total = 0; total = 0;
} }
const ESM::Region *regn = MWBase::Environment::get().getWorld()->getStore().regions.find(regionName); const ESM::Region *regn = MWBase::Environment::get().getWorld()->getStore().regions.search(regionName);
if (regn == NULL)
return;
std::vector<ESM::Region::SoundRef>::const_iterator soundIter; std::vector<ESM::Region::SoundRef>::const_iterator soundIter;
if(total == 0) if(total == 0)
{ {