#11 Distort geodes

This commit is contained in:
kay27 2022-02-05 04:56:17 +04:00
parent e828757fae
commit 6be95762bc
1 changed files with 26 additions and 9 deletions

View File

@ -24,15 +24,32 @@ local function round(v)
end end
local function place(pos, rotation, pr) local function place(pos, rotation, pr)
local radius = pr:next(radius_min, radius_max) local radius1 = vector.new(
local pos = vector.add(pos, radius) -pr:next(radius_min, radius_max),
for x = pos.x - radius, pos.x + radius do -pr:next(radius_min, radius_max),
for y = pos.y - radius, pos.y + radius do -pr:next(radius_min, radius_max)
for z = pos.z - radius, pos.z + radius do )
local node_pos = vector.new(x, y, z) local radius2 = vector.new(
local inverted_layer = round(vector.distance(node_pos, pos)) pr:next(radius_min, radius_max),
if inverted_layer <= radius then pr:next(radius_min, radius_max),
local layer = math.min(radius - inverted_layer + 1, #layers) pr:next(radius_min, radius_max)
)
local layer_radius = pr:next(radius_min, radius_max)
local radius1_normalized = vector.normalize(radius1)
local radius2_normalized = vector.normalize(radius2)
local pos = vector.subtract(pos, radius1)
for x = radius1.x, radius2.x do
local max_x = (x < 0) and radius1.x or radius2.x
for y = radius1.y, radius2.y do
local max_y = (y < 0) and radius1.y or radius2.y
for z = radius1.z, radius2.z do
local max_z = (z < 0) and radius1.z or radius2.z
local normal_abs = vector.new(x / max_x, y / max_y, z / max_z)
local inverted_layer = round(vector.length(normal_abs) * layer_radius)
if inverted_layer <= layer_radius then
local layer = math.min(math.max(1, layer_radius - inverted_layer + 1), #layers)
local offset = vector.new(x, y, z)
local node_pos = pos + offset
local node_candidates = layers[layer] local node_candidates = layers[layer]
local node_name local node_name
local chance_index = pr:next(1, 100) local chance_index = pr:next(1, 100)