summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/heightmap.cpp38
-rw-r--r--src/heightmap.h15
2 files changed, 33 insertions, 20 deletions
diff --git a/src/heightmap.cpp b/src/heightmap.cpp
index 6e785fcc5..2f7ecc4dc 100644
--- a/src/heightmap.cpp
+++ b/src/heightmap.cpp
@@ -248,8 +248,7 @@ void FixedHeightmap::generateContinued(f32 randmax, f32 randfactor,
s16 a = m_blocksize;
// Check that a is a power of two
- if((a & (a-1)) != 0)
- throw;
+ assert((a & (a-1)) == 0);
// Overwrite with GROUNDHEIGHT_NOTFOUND_SETVALUE
for(s16 y=0; y<=a; y++){
@@ -263,7 +262,7 @@ void FixedHeightmap::generateContinued(f32 randmax, f32 randfactor,
Seed borders from master heightmap
NOTE: Does this actually have any effect on the output?
*/
- struct SeedSpec
+ /*struct SeedSpec
{
v2s16 neighbour_start;
v2s16 heightmap_start;
@@ -307,7 +306,7 @@ void FixedHeightmap::generateContinued(f32 randmax, f32 randfactor,
hpos += seeds[i].dir;
npos += seeds[i].dir;
}
- }
+ }*/
/*dstream<<"borders seeded:"<<std::endl;
print();*/
@@ -548,13 +547,28 @@ FixedHeightmap * UnlimitedHeightmap::getHeightmap(v2s16 p_from, bool generate)
FixedHeightmap *heightmap = new FixedHeightmap(this, p, m_blocksize);
m_heightmaps.insert(p, heightmap);
+
+ f32 corners[4];
- f32 corners[4] = {
- m_base_generator->getValue(p+v2s16(0,0)),
- m_base_generator->getValue(p+v2s16(1,0)),
- m_base_generator->getValue(p+v2s16(1,1)),
- m_base_generator->getValue(p+v2s16(0,1)),
- };
+ if(m_palist)
+ {
+ //TODO: palist must be taken into account in generateContinued.
+ // It is almost useless in here.
+ s32 div = 2 * 16;
+ Settings *attr = m_palist->getNearAttr(p / div);
+ assert(attr);
+ corners[0] = attr->getFloat("baseheight");
+ corners[1] = attr->getFloat("baseheight");
+ corners[2] = attr->getFloat("baseheight");
+ corners[3] = attr->getFloat("baseheight");
+ }
+ else
+ {
+ corners[0] = m_base_generator->getValue(p+v2s16(0,0));
+ corners[1] = m_base_generator->getValue(p+v2s16(1,0));
+ corners[2] = m_base_generator->getValue(p+v2s16(1,1));
+ corners[3] = m_base_generator->getValue(p+v2s16(0,1));
+ }
f32 randmax = m_randmax_generator->getValue(p);
f32 randfactor = m_randfactor_generator->getValue(p);
@@ -829,7 +843,7 @@ UnlimitedHeightmap * UnlimitedHeightmap::deSerialize(std::istream &is)
ValueGenerator *basegen = new ConstantGenerator(basevalue);
UnlimitedHeightmap *hm = new UnlimitedHeightmap
- (blocksize, maxgen, factorgen, basegen);
+ (blocksize, maxgen, factorgen, basegen, NULL);
for(u32 i=0; i<heightmap_count; i++)
{
@@ -866,7 +880,7 @@ UnlimitedHeightmap * UnlimitedHeightmap::deSerialize(std::istream &is)
FixedHeightmap::serializedLength(version, blocksize);
UnlimitedHeightmap *hm = new UnlimitedHeightmap
- (blocksize, maxgen, factorgen, basegen);
+ (blocksize, maxgen, factorgen, basegen, NULL);
for(u32 i=0; i<heightmap_count; i++)
{
diff --git a/src/heightmap.h b/src/heightmap.h
index 71e152d5c..fe0a7f405 100644
--- a/src/heightmap.h
+++ b/src/heightmap.h
@@ -502,22 +502,27 @@ private:
core::map<v2s16, FixedHeightmap*> m_heightmaps;
s16 m_blocksize;
+ // TODO: Remove ValueGenerators
ValueGenerator *m_randmax_generator;
ValueGenerator *m_randfactor_generator;
ValueGenerator *m_base_generator;
+ PointAttributeList *m_palist;
+
public:
UnlimitedHeightmap(
s16 blocksize,
ValueGenerator *randmax_generator,
ValueGenerator *randfactor_generator,
- ValueGenerator *base_generator
+ ValueGenerator *base_generator,
+ PointAttributeList *palist=NULL
):
m_blocksize(blocksize),
m_randmax_generator(randmax_generator),
m_randfactor_generator(randfactor_generator),
- m_base_generator(base_generator)
+ m_base_generator(base_generator),
+ m_palist(palist)
{
assert(m_randmax_generator != NULL);
assert(m_randfactor_generator != NULL);
@@ -538,12 +543,6 @@ public:
delete m_base_generator;
}
- /*void setParams(f32 randmax, f32 randfactor)
- {
- m_randmax = randmax;
- m_randfactor = randfactor;
- }*/
-
void print();
v2s16 getNodeHeightmapPos(v2s16 p)