This commit is contained in:
Aria 2025-03-21 22:23:30 +11:00
commit 9c94d113d3
Signed by untrusted user who does not match committer: aria
GPG key ID: 19AB7AA462B8AB3B
10260 changed files with 1237388 additions and 0 deletions

View file

@ -0,0 +1,35 @@
#include "StarRidgeBlocksSelector.hpp"
#include "StarRandom.hpp"
namespace Star {
char const* const RidgeBlocksSelector::Name = "ridgeblocks";
RidgeBlocksSelector::RidgeBlocksSelector(Json const& config, TerrainSelectorParameters const& parameters)
: TerrainSelector(Name, config, parameters) {
commonality = parameters.commonality;
amplitude = config.getFloat("amplitude");
frequency = config.getFloat("frequency");
bias = config.getFloat("bias");
noiseAmplitude = config.getFloat("noiseAmplitude");
noiseFrequency = config.getFloat("noiseFrequency");
RandomSource random(parameters.seed);
ridgePerlin1 = PerlinF(PerlinType::RidgedMulti, 2, frequency, amplitude, 0, 2.0f, 2.0f, random.randu64());
ridgePerlin2 = PerlinF(PerlinType::RidgedMulti, 2, frequency, amplitude, 0, 2.0f, 2.0f, random.randu64());
noisePerlin = PerlinF(1, noiseFrequency, noiseAmplitude, 0, 1.0f, 2.0f, random.randu64());
}
float RidgeBlocksSelector::get(int x, int y) const {
if (commonality <= 0.0f) {
return 0.0f;
} else {
x += noisePerlin.get(x, y);
y += noisePerlin.get(y, x);
return (ridgePerlin1.get(x, y) - ridgePerlin2.get(x, y)) * commonality + bias;
}
}
}