Add param2 field for ores, some minor fixes and misc. code cleanup

This commit is contained in:
kwolekr 2013-04-07 21:21:17 -04:00
parent 4468ea84e6
commit 7c0e707cf1
5 changed files with 33 additions and 48 deletions

View File

@ -94,7 +94,7 @@ void Ore::resolveNodeNames(INodeDefManager *ndef) {
} }
void OreScatter::generate(Mapgen *mg, u32 blockseed, v3s16 nmin, v3s16 nmax) { void Ore::placeOre(Mapgen *mg, u32 blockseed, v3s16 nmin, v3s16 nmax) {
int in_range = 0; int in_range = 0;
in_range |= (nmin.Y <= height_max && nmax.Y >= height_min); in_range |= (nmin.Y <= height_max && nmax.Y >= height_min);
@ -105,9 +105,6 @@ void OreScatter::generate(Mapgen *mg, u32 blockseed, v3s16 nmin, v3s16 nmax) {
resolveNodeNames(mg->ndef); resolveNodeNames(mg->ndef);
MapNode n_ore(ore);
ManualMapVoxelManipulator *vm = mg->vm;
PseudoRandom pr(blockseed);
int ymin, ymax; int ymin, ymax;
if (in_range & ORE_RANGE_MIRROR) { if (in_range & ORE_RANGE_MIRROR) {
@ -120,6 +117,17 @@ void OreScatter::generate(Mapgen *mg, u32 blockseed, v3s16 nmin, v3s16 nmax) {
if (clust_size >= ymax - ymin + 1) if (clust_size >= ymax - ymin + 1)
return; return;
nmin.Y = ymin;
nmax.Y = ymax;
generate(mg->vm, mg->seed, blockseed, nmin, nmax);
}
void OreScatter::generate(ManualMapVoxelManipulator *vm, int seed,
u32 blockseed, v3s16 nmin, v3s16 nmax) {
PseudoRandom pr(blockseed);
MapNode n_ore(ore, 0, ore_param2);
int volume = (nmax.X - nmin.X + 1) * int volume = (nmax.X - nmin.X + 1) *
(nmax.Y - nmin.Y + 1) * (nmax.Y - nmin.Y + 1) *
(nmax.Z - nmin.Z + 1); (nmax.Z - nmin.Z + 1);
@ -129,10 +137,10 @@ void OreScatter::generate(Mapgen *mg, u32 blockseed, v3s16 nmin, v3s16 nmax) {
for (int i = 0; i != nclusters; i++) { for (int i = 0; i != nclusters; i++) {
int x0 = pr.range(nmin.X, nmax.X - csize + 1); int x0 = pr.range(nmin.X, nmax.X - csize + 1);
int y0 = pr.range(ymin, ymax - csize + 1); int y0 = pr.range(nmin.Y, nmax.Y - csize + 1);
int z0 = pr.range(nmin.Z, nmax.Z - csize + 1); int z0 = pr.range(nmin.Z, nmax.Z - csize + 1);
if (np && (NoisePerlin3D(np, x0, y0, z0, mg->seed) < nthresh)) if (np && (NoisePerlin3D(np, x0, y0, z0, seed) < nthresh))
continue; continue;
for (int z1 = 0; z1 != csize; z1++) for (int z1 = 0; z1 != csize; z1++)
@ -149,53 +157,25 @@ void OreScatter::generate(Mapgen *mg, u32 blockseed, v3s16 nmin, v3s16 nmax) {
} }
void OreSheet::generate(Mapgen *mg, u32 blockseed, v3s16 nmin, v3s16 nmax) { void OreSheet::generate(ManualMapVoxelManipulator *vm, int seed,
int in_range = 0; u32 blockseed, v3s16 nmin, v3s16 nmax) {
in_range |= (nmin.Y <= height_max && nmax.Y >= height_min);
if (flags & OREFLAG_ABSHEIGHT)
in_range |= (nmin.Y >= -height_max && nmax.Y <= -height_min) << 1;
if (!in_range)
return;
resolveNodeNames(mg->ndef);
MapNode n_ore(ore);
ManualMapVoxelManipulator *vm = mg->vm;
PseudoRandom pr(blockseed + 4234); PseudoRandom pr(blockseed + 4234);
int ymin, ymax; MapNode n_ore(ore, 0, ore_param2);
if (in_range & ORE_RANGE_MIRROR) {
ymin = MYMAX(nmin.Y, -height_max);
ymax = MYMIN(nmax.Y, -height_min);
} else {
ymin = MYMAX(nmin.Y, height_min);
ymax = MYMIN(nmax.Y, height_max);
}
if (clust_size >= ymax - ymin + 1)
return;
int x0 = nmin.X;
int z0 = nmin.Z;
int x1 = nmax.X;
int z1 = nmax.Z;
int max_height = clust_size; int max_height = clust_size;
int y_start = pr.range(ymin, ymax - max_height); int y_start = pr.range(nmin.Y, nmax.Y - max_height);
if (!noise) { if (!noise) {
int sx = nmax.X - nmin.X + 1; int sx = nmax.X - nmin.X + 1;
int sz = nmax.Z - nmin.Z + 1; int sz = nmax.Z - nmin.Z + 1;
noise = new Noise(np, 0, sx, sz); noise = new Noise(np, 0, sx, sz);
} }
noise->seed = mg->seed + y_start; noise->seed = seed + y_start;
noise->perlinMap2D(x0, z0); noise->perlinMap2D(nmin.X, nmin.Z);
int index = 0; int index = 0;
for (int z = z0; z != z1; z++) for (int z = nmin.Z; z <= nmax.Z; z++)
for (int x = x0; x != x1; x++) { for (int x = nmin.X; x <= nmax.X; x++) {
float noiseval = noise->result[index++]; float noiseval = noise->result[index++];
if (noiseval < nthresh) if (noiseval < nthresh)
continue; continue;

View File

@ -120,7 +120,6 @@ class Ore {
public: public:
std::string ore_name; std::string ore_name;
std::string wherein_name; std::string wherein_name;
content_t ore; content_t ore;
content_t wherein; // the node to be replaced content_t wherein; // the node to be replaced
u32 clust_scarcity; // ore cluster has a 1-in-clust_scarcity chance of appearing at a node u32 clust_scarcity; // ore cluster has a 1-in-clust_scarcity chance of appearing at a node
@ -128,6 +127,7 @@ public:
s16 clust_size; // how large (in nodes) a chunk of ore is s16 clust_size; // how large (in nodes) a chunk of ore is
s16 height_min; s16 height_min;
s16 height_max; s16 height_max;
u8 ore_param2; // to set node-specific attributes
u32 flags; // attributes for this ore u32 flags; // attributes for this ore
float nthresh; // threshhold for noise at which an ore is placed float nthresh; // threshhold for noise at which an ore is placed
NoiseParams *np; // noise for distribution of clusters (NULL for uniform scattering) NoiseParams *np; // noise for distribution of clusters (NULL for uniform scattering)
@ -141,15 +141,19 @@ public:
} }
void resolveNodeNames(INodeDefManager *ndef); void resolveNodeNames(INodeDefManager *ndef);
virtual void generate(Mapgen *mg, u32 blockseed, v3s16 nmin, v3s16 nmax) = 0; void placeOre(Mapgen *mg, u32 blockseed, v3s16 nmin, v3s16 nmax);
virtual void generate(ManualMapVoxelManipulator *vm, int seed,
u32 blockseed, v3s16 nmin, v3s16 nmax) = 0;
}; };
class OreScatter : public Ore { class OreScatter : public Ore {
void generate(Mapgen *mg, u32 blockseed, v3s16 nmin, v3s16 nmax); virtual void generate(ManualMapVoxelManipulator *vm, int seed,
u32 blockseed, v3s16 nmin, v3s16 nmax);
}; };
class OreSheet : public Ore { class OreSheet : public Ore {
void generate(Mapgen *mg, u32 blockseed, v3s16 nmin, v3s16 nmax); virtual void generate(ManualMapVoxelManipulator *vm, int seed,
u32 blockseed, v3s16 nmin, v3s16 nmax);
}; };
Ore *createOre(OreType type); Ore *createOre(OreType type);

View File

@ -467,7 +467,7 @@ void MapgenV6::makeChunk(BlockMakeData *data) {
// Generate the registered ores // Generate the registered ores
for (unsigned int i = 0; i != emerge->ores.size(); i++) { for (unsigned int i = 0; i != emerge->ores.size(); i++) {
Ore *ore = emerge->ores[i]; Ore *ore = emerge->ores[i];
ore->generate(this, blockseed + i, node_min, node_max); ore->placeOre(this, blockseed + i, node_min, node_max);
} }
// Calculate lighting // Calculate lighting

View File

@ -180,7 +180,7 @@ void MapgenV7::makeChunk(BlockMakeData *data) {
for (size_t i = 0; i != emerge->ores.size(); i++) { for (size_t i = 0; i != emerge->ores.size(); i++) {
Ore *ore = emerge->ores[i]; Ore *ore = emerge->ores[i];
ore->generate(this, blockseed + i, node_min, node_max); ore->placeOre(this, blockseed + i, node_min, node_max);
} }
//printf("makeChunk: %dms\n", t.stop()); //printf("makeChunk: %dms\n", t.stop());

View File

@ -670,6 +670,7 @@ static int l_register_ore(lua_State *L)
} }
ore->ore_name = getstringfield_default(L, index, "ore", ""); ore->ore_name = getstringfield_default(L, index, "ore", "");
ore->ore_param2 = (u8)getintfield_default(L, index, "ore_param2", 0);
ore->wherein_name = getstringfield_default(L, index, "wherein", ""); ore->wherein_name = getstringfield_default(L, index, "wherein", "");
ore->clust_scarcity = getintfield_default(L, index, "clust_scarcity", 1); ore->clust_scarcity = getintfield_default(L, index, "clust_scarcity", 1);
ore->clust_num_ores = getintfield_default(L, index, "clust_num_ores", 1); ore->clust_num_ores = getintfield_default(L, index, "clust_num_ores", 1);