From 30d5f9ce969235a342dda2f504f3862bca77168e Mon Sep 17 00:00:00 2001 From: Duane Date: Sat, 11 Jun 2016 23:26:07 -0500 Subject: [PATCH] Add flora and fauna to clouds. --- cloudgen.lua | 92 ++++++++++++++++++++++++------ deco.lua | 41 +++++++++++++ deco_clouds.lua | 86 +++++++++++++++++++++++++++- deco_plants.lua | 16 ++++++ decogen.lua | 79 +------------------------ mapgen.lua | 74 +++++++++++++++++++++++- mobs.lua | 22 +++++++ nodes.lua | 6 +- textures/fun_caves_cloud.png | Bin 0 -> 1608 bytes textures/fun_caves_moon_weed.png | Bin 0 -> 2545 bytes textures/fun_caves_white_wolf.png | Bin 0 -> 1041 bytes textures/fun_caves_wisp.png | Bin 0 -> 5766 bytes textures/vmg_moon_weed.png | Bin 21426 -> 0 bytes 13 files changed, 316 insertions(+), 100 deletions(-) create mode 100644 textures/fun_caves_cloud.png create mode 100644 textures/fun_caves_moon_weed.png create mode 100644 textures/fun_caves_white_wolf.png create mode 100644 textures/fun_caves_wisp.png delete mode 100644 textures/vmg_moon_weed.png diff --git a/cloudgen.lua b/cloudgen.lua index 559509d..f0f6c44 100644 --- a/cloudgen.lua +++ b/cloudgen.lua @@ -5,21 +5,29 @@ local rand = math.random local min = math.min local floor = math.floor local ceil = math.ceil -local abs = math.ceil -local map_max = 31000 +local abs = math.abs +local max_depth = 31000 -local cloud_noise_1 = {offset = 10, scale = 10, seed = 3721, spread = {x = 120, y = 120, z = 120}, octaves = 3, persist = 1, lacunarity = 2} +local cloud_noise_1 = {offset = 10, scale = 10, seed = 4877, spread = {x = 120, y = 120, z = 120}, octaves = 3, persist = 1, lacunarity = 2} +local cloud_noise_2 = {offset = 0, scale = 1, seed = 5748, spread = {x = 40, y = 10, z = 40}, octaves = 3, persist = 1, lacunarity = 2} +local plant_noise = {offset = 0.0, scale = 1.0, spread = {x = 200, y = 200, z = 200}, seed = -2525, octaves = 3, persist = 0.7, lacunarity = 2.0} +local biome_noise = {offset = 0.0, scale = 1.0, spread = {x = 400, y = 400, z = 400}, seed = -1471, octaves = 3, persist = 0.5, lacunarity = 2.0} -fun_caves.cloudgen = function(minp, maxp, data, area, node) - local clouds = ceil(minp.y / floor(map_max / 7)) - if abs(clouds * floor(map_max / 7) - minp.y) > 80 then +fun_caves.cloudgen = function(minp, maxp, data, p2data, area, node) + local clouds = ceil(minp.y / floor(max_depth / 7)) + if abs(clouds * floor(max_depth / 7) - minp.y) > 80 then return end local csize = vector.add(vector.subtract(maxp, minp), 1) + local map_max = {x = csize.x, y = csize.y, z = csize.z} + local map_min = {x = minp.x, y = minp.y, z = minp.z} local cloud_1 = minetest.get_perlin_map(cloud_noise_1, {x=csize.x, y=csize.z}):get2dMap_flat({x=minp.x, y=minp.z}) + local cloud_2 = minetest.get_perlin_map(cloud_noise_2, map_max):get3dMap_flat(map_min) + local plant_n = minetest.get_perlin_map(plant_noise, {x=csize.x, y=csize.z}):get2dMap_flat({x=minp.x, y=minp.z}) + local biome_n = minetest.get_perlin_map(biome_noise, {x=csize.x, y=csize.z}):get2dMap_flat({x=minp.x, y=minp.z}) local write = false @@ -28,25 +36,43 @@ fun_caves.cloudgen = function(minp, maxp, data, area, node) for z = minp.z, maxp.z do for x = minp.x, maxp.x do index = index + 1 - --index3d = noise_area:index(x, minp.y-1, z) - index3d = (z - minp.z) * (csize.y + 2) * csize.x + (x - minp.x) + 1 - --local height = cloud_1[index] + minp.y + 32 - local ivm = area:index(x, minp.y-1, z) + index3d = (z - minp.z) * (csize.y) * csize.x + (x - minp.x) + 1 + local ivm = area:index(x, minp.y, z) + local cloud + if biome_n[index] < 0 then + cloud = 'storm_cloud' + else + cloud = 'cloud' + end + + cloud_1[index] = floor(cloud_1[index] + 0.5) if cloud_1[index] > 0 then for y = minp.y, maxp.y do local dy = y - minp.y - if dy > 32 and cloud_1[index] > 15 then - if dy < 47 then - if dy < 47 - (cloud_1[index] - 15) then - data[ivm] = node['fun_caves:cloud'] - else - data[ivm] = node['default:water_source'] - end + if dy > 32 and cloud_1[index] > 15 and dy < 47 then + if dy < 47 - (cloud_1[index] - 15) then + data[ivm] = node['fun_caves:'..cloud] + else + data[ivm] = node['default:water_source'] write = true end - elseif dy >= 32 - cloud_1[index] and dy <= 32 + cloud_1[index] then - data[ivm] = node['fun_caves:cloud'] + elseif (dy <= 32 or cloud_1[index] <= 15) and dy >= 32 - cloud_1[index] and dy <= 32 + cloud_1[index] then + data[ivm] = node['fun_caves:'..cloud] + write = true + elseif data[ivm - area.ystride] == node['fun_caves:'..cloud] and data[ivm] == node['air'] then + if rand(30) == 1 and plant_n[index] > 0.5 then + data[ivm] = node['fun_caves:moon_weed'] + write = true + elseif rand(60) == 1 and plant_n[index] > 0.5 then + fun_caves.place_schematic(minp, maxp, data, p2data, area, node, {x=x,y=y-1,z=z}, fun_caves.schematics['lumin_tree'], true) + write = true + elseif rand(10) == 1 then + data[ivm] = node['default:grass_'..rand(4)] + write = true + end + elseif data[ivm] == node['air'] and (dy < 29 - cloud_1[index] or dy > 35 + cloud_1[index]) and cloud_2[index3d] > abs((dy - 40) / 20) then + data[ivm] = node['fun_caves:wispy_cloud'] write = true end @@ -57,5 +83,33 @@ fun_caves.cloudgen = function(minp, maxp, data, area, node) end end + local index = 0 + local index3d = 0 + for z = minp.z, maxp.z do + for x = minp.x, maxp.x do + index = index + 1 + local ivm = area:index(x, minp.y, z) + + local cloud + if biome_n[index] < 0 then + cloud = 'storm_cloud' + else + cloud = 'cloud' + end + + cloud_1[index] = floor(cloud_1[index] + 0.5) + if cloud_1[index] > 0 then + for y = minp.y, maxp.y do + local dy = y - minp.y + if data[ivm] == node['fun_caves:'..cloud] and data[ivm + area.ystride] == node['default:water_source'] and rand(30) == 1 and fun_caves.surround(node, data, area, ivm) then + data[ivm] = node['fun_caves:water_plant_1_water_'..cloud] + end + + ivm = ivm + area.ystride + end + end + end + end + return write end diff --git a/deco.lua b/deco.lua index 56f99b3..ced67cd 100644 --- a/deco.lua +++ b/deco.lua @@ -182,6 +182,47 @@ do fun_caves.schematics['decaying_tree'] = s end +do + local w, h, d = 5, 8, 5 + local s = fun_caves.schematic_array(w, h, d) + + for y = 0, math.floor(h/2)-1 do + s.data[2*d*h + y*d + 2 + 1].name = 'fun_caves:lumin_tree' + s.data[2*d*h + y*d + 2 + 1].param1 = 255 + end + + for z = 0, d-1 do + for y = math.floor(h/2), h-1 do + for x = 0, w-1 do + if y < h - 1 or (x ~= 0 and x ~= w-1 and z ~= 0 and z ~= d-1) then + s.data[z*d*h + y*d + x + 1].name = 'fun_caves:leaves_lumin' + + if y == h-1 or x == 0 or x == w-1 or z == 0 or z == d-1 then + s.data[z*d*h + y*d + x + 1].param1 = 150 + else + s.data[z*d*h + y*d + x + 1].param1 = 225 + end + end + end + end + end + + for z = math.floor(d/2)-1, math.floor(d/2)+1, 2 do + for x = math.floor(w/2)-1, math.floor(w/2)+1, 2 do + s.data[z*d*h + math.floor(h/2)*d + x + 1].name = 'fun_caves:lumin_tree' + s.data[z*d*h + math.floor(h/2)*d + x + 1].param1 = 150 + end + end + + for y = 0, h-1 do + if y / 3 == math.floor(y / 3) then + s.yslice_prob[#s.yslice_prob+1] = {ypos=y,prob=170} + end + end + + fun_caves.schematics['lumin_tree'] = s +end + dofile(fun_caves.path .. "/deco_caves.lua") --dofile(fun_caves.path.."/deco_dirt.lua") diff --git a/deco_clouds.lua b/deco_clouds.lua index efc6dff..37abb10 100644 --- a/deco_clouds.lua +++ b/deco_clouds.lua @@ -1,6 +1,90 @@ local newnode = fun_caves.clone_node("default:dirt") newnode.description = "Cloud" -newnode.tiles = {'fun_caves_storm_cloud.png'} +newnode.tiles = {'fun_caves_cloud.png'} newnode.sunlight_propagates = true minetest.register_node("fun_caves:cloud", newnode) + +newnode = fun_caves.clone_node("default:dirt") +newnode.description = "Storm Cloud" +newnode.tiles = {'fun_caves_storm_cloud.png'} +--newnode.sunlight_propagates = true +minetest.register_node("fun_caves:storm_cloud", newnode) + +newnode = fun_caves.clone_node("default:dirt") +newnode.description = "Wispy Cloud" +newnode.tiles = {'fun_caves_wisp.png'} +newnode.sunlight_propagates = true +newnode.use_texture_alpha = true +newnode.walkable = false +newnode.buildable_to = true +newnode.pointable = false +minetest.register_node("fun_caves:wispy_cloud", newnode) + +minetest.register_node("fun_caves:moon_weed", { + description = "Moon Weed", + drawtype = "plantlike", + tiles = {"fun_caves_moon_weed.png"}, + inventory_image = "fun_caves_moon_weed.png", + waving = false, + sunlight_propagates = true, + paramtype = "light", + light_source = 8, + walkable = false, + groups = {snappy=3,flammable=2,flora=1,attached_node=1}, + sounds = default.node_sound_leaves_defaults(), + selection_box = { + type = "fixed", + fixed = {-0.5, -0.5, -0.5, 0.5, -5/16, 0.5}, + }, +}) + +minetest.register_node("fun_caves:leaves_lumin", { + description = "Leaves", + drawtype = "allfaces_optional", + waving = 1, + visual_scale = 1.3, + tiles = {"default_leaves.png^[colorize:#FFDF00:150"}, + special_tiles = {"default_leaves_simple.png^[colorize:#FFDF00:150"}, + paramtype = "light", + is_ground_content = false, + light_source = 8, + groups = {snappy = 3, leafdecay = 4, flammable = 2, leaves = 1}, + drop = { + max_items = 1, + items = { + --{ + -- -- player will get sapling with 1/20 chance + -- items = {'default:sapling'}, + -- rarity = 20, + --}, + { + -- player will get leaves only if he get no saplings, + -- this is because max_items is 1 + items = {'fun_caves:leaves_lumin'}, + } + } + }, + sounds = default.node_sound_leaves_defaults(), + + after_place_node = default.after_place_leaves, +}) + +minetest.register_node("fun_caves:lumin_tree", { + description = "Lumin Tree", + tiles = { + "default_tree_top.png", "default_tree_top.png", "fun_caves_lumin_tree.png" + }, + paramtype = "light", + drawtype = "nodebox", + node_box = { + type = "fixed", + fixed = { {-0.25, -0.5, -0.25, 0.25, 0.5, 0.25}, } + }, + paramtype2 = "facedir", + is_ground_content = false, + groups = {tree = 1, choppy = 2, oddly_breakable_by_hand = 1, flammable = 2}, + sounds = default.node_sound_wood_defaults(), + + on_place = minetest.rotate_node +}) diff --git a/deco_plants.lua b/deco_plants.lua index 17f7c60..a0c5913 100644 --- a/deco_plants.lua +++ b/deco_plants.lua @@ -134,6 +134,14 @@ for _, plant in ipairs(fun_caves.plantlist) do def2.tiles = { "default_dirt.png", "fun_caves_"..plant.name..".png",} def2.drop = {max_items=2, items={{items={"fun_caves:"..plant.name}, rarity=1}, {items={"default:dirt"}, rarity=1}}} minetest.register_node("fun_caves:"..plant.name.."_water_soil", def2) + def2 = table.copy(def) + def2.tiles = { "fun_caves_cloud.png", "fun_caves_"..plant.name..".png",} + def2.drop = {max_items=2, items={{items={"fun_caves:"..plant.name}, rarity=1}, {items={"fun_caves:cloud"}, rarity=1}}} + minetest.register_node("fun_caves:"..plant.name.."_water_cloud", def2) + def2 = table.copy(def) + def2.tiles = { "fun_caves_storm_cloud.png", "fun_caves_"..plant.name..".png",} + def2.drop = {max_items=2, items={{items={"fun_caves:"..plant.name}, rarity=1}, {items={"fun_caves:storm_cloud"}, rarity=1}}} + minetest.register_node("fun_caves:"..plant.name.."_water_storm_cloud", def2) end end @@ -199,9 +207,17 @@ do local water_plant_1_def_soil = table.copy(water_plant_1_def_sand) water_plant_1_def_soil.place_on = {"group:soil"} water_plant_1_def_soil.decoration = {"fun_caves:water_plant_1_water_soil",} + local water_plant_1_def_cloud = table.copy(water_plant_1_def_sand) + water_plant_1_def_cloud.place_on = {"group:cloud"} + water_plant_1_def_cloud.decoration = {"fun_caves:water_plant_1_water_cloud",} + local water_plant_1_def_storm_cloud = table.copy(water_plant_1_def_sand) + water_plant_1_def_storm_cloud.place_on = {"group:cloud"} + water_plant_1_def_storm_cloud.decoration = {"fun_caves:water_plant_1_water_storm_cloud",} register_water_plant(water_plant_1_def_sand) register_water_plant(water_plant_1_def_soil) + register_water_plant(water_plant_1_def_cloud) + register_water_plant(water_plant_1_def_storm_cloud) end diff --git a/decogen.lua b/decogen.lua index 998cd95..4119e98 100644 --- a/decogen.lua +++ b/decogen.lua @@ -26,79 +26,6 @@ local csize local node_match_cache = {} -local function place_schematic(minp, maxp, data, p2data, area, node, pos, schem, center) - local rot = rand(4) - 1 - local yslice = {} - if schem.yslice_prob then - for _, ys in pairs(schem.yslice_prob) do - yslice[ys.ypos] = ys.prob - end - end - - if center then - pos.x = pos.x - floor(schem.size.x / 2) - pos.z = pos.z - floor(schem.size.z / 2) - end - - for z1 = 0, schem.size.z - 1 do - for x1 = 0, schem.size.x - 1 do - local x, z - if rot == 0 then - x, z = x1, z1 - elseif rot == 1 then - x, z = schem.size.z - z1 - 1, x1 - elseif rot == 2 then - x, z = schem.size.x - x1 - 1, schem.size.z - z1 - 1 - elseif rot == 3 then - x, z = z1, schem.size.x - x1 - 1 - end - local dz = pos.z - minp.z + z - local dx = pos.x - minp.x + x - if pos.x + x > minp.x and pos.x + x < maxp.x and pos.z + z > minp.z and pos.z + z < maxp.z then - local ivm = area:index(pos.x + x, pos.y, pos.z + z) - local isch = z1 * schem.size.y * schem.size.x + x1 + 1 - for y = 0, schem.size.y - 1 do - local dy = pos.y - minp.y + y - --if math.min(dx, csize.x - dx) + math.min(dy, csize.y - dy) + math.min(dz, csize.z - dz) > bevel then - if yslice[y] or 255 >= rand(255) then - local prob = schem.data[isch].prob or schem.data[isch].param1 or 255 - if prob >= rand(255) and schem.data[isch].name ~= "air" then - data[ivm] = node[schem.data[isch].name] - end - local param2 = schem.data[isch].param2 or 0 - p2data[ivm] = param2 - end - --end - - ivm = ivm + area.ystride - isch = isch + schem.size.x - end - end - end - end -end - -local function surround(node, data, area, ivm) - -- Check to make sure that a plant root is fully surrounded. - -- This is due to the kludgy way you have to make water plants - -- in minetest, to avoid bubbles. - for x1 = -1,1,2 do - local n = data[ivm+x1] - if n == node["default:river_water_source"] or n == node["default:water_source"] or n == node["air"] then - return false - end - end - for z1 = -area.zstride,area.zstride,2*area.zstride do - local n = data[ivm+z1] - if n == node["default:river_water_source"] or n == node["default:water_source"] or n == node["air"] then - return false - end - end - - return true -end - - local biome_noise = {offset = 0.0, scale = 1.0, spread = {x = 400, y = 400, z = 400}, seed = 903, octaves = 3, persist = 0.5, lacunarity = 2.0} local plant_noise = {offset = 0.0, scale = 1.0, spread = {x = 200, y = 200, z = 200}, seed = 33, octaves = 3, persist = 0.7, lacunarity = 2.0} @@ -308,7 +235,7 @@ fun_caves.decogen = function(minp, maxp, data, p2data, area, node, heightmap, bi end end if air_count > 6 then - place_schematic(minp, maxp, data, p2data, area, node, {x=x,y=y,z=z}, fun_caves.schematics['decaying_tree'], true) + fun_caves.place_schematic(minp, maxp, data, p2data, area, node, {x=x,y=y,z=z}, fun_caves.schematics['decaying_tree'], true) end end elseif node_below == node["default:dirt"] and biome and biome.fungi then @@ -380,7 +307,7 @@ fun_caves.decogen = function(minp, maxp, data, p2data, area, node, heightmap, bi local node_below = data[ivm - area.ystride] local node_above = data[ivm + area.ystride] - if y < water_level and data[ivm] == node["default:sand"] and node_above == node["default:water_source"] and data[ivm + area.ystride * 2] == node["default:water_source"] and coral_biomes[biome] and pn < -0.1 and rand(5) == 1 and surround(node, data, area, ivm) then + if y < water_level and data[ivm] == node["default:sand"] and node_above == node["default:water_source"] and data[ivm + area.ystride * 2] == node["default:water_source"] and coral_biomes[biome] and pn < -0.1 and rand(5) == 1 and fun_caves.surround(node, data, area, ivm) then if rand(100) == 1 then data[ivm] = node["fun_caves:precious_coral_water_sand"] else @@ -404,7 +331,7 @@ fun_caves.decogen = function(minp, maxp, data, p2data, area, node, heightmap, bi end elseif x < maxp.x and y < maxp.y and z < maxp.z and x > minp.x and y > minp.y and z > minp.z and (node_above == node["default:water_source"] or node_above == node["default:river_water_source"]) and (data[ivm] == node["default:sand"] or data[ivm] == node["default:dirt"]) then -- Check the biomes and plant water plants, if called for. - if not surround(node, data, area, ivm) then + if not fun_caves.surround(node, data, area, ivm) then break end diff --git a/mapgen.lua b/mapgen.lua index 838d3af..e3d1822 100644 --- a/mapgen.lua +++ b/mapgen.lua @@ -74,6 +74,78 @@ fun_caves.is_fortress = function(pos, cs, debug) return false end +fun_caves.place_schematic = function(minp, maxp, data, p2data, area, node, pos, schem, center) + local rot = rand(4) - 1 + local yslice = {} + if schem.yslice_prob then + for _, ys in pairs(schem.yslice_prob) do + yslice[ys.ypos] = ys.prob + end + end + + if center then + pos.x = pos.x - floor(schem.size.x / 2) + pos.z = pos.z - floor(schem.size.z / 2) + end + + for z1 = 0, schem.size.z - 1 do + for x1 = 0, schem.size.x - 1 do + local x, z + if rot == 0 then + x, z = x1, z1 + elseif rot == 1 then + x, z = schem.size.z - z1 - 1, x1 + elseif rot == 2 then + x, z = schem.size.x - x1 - 1, schem.size.z - z1 - 1 + elseif rot == 3 then + x, z = z1, schem.size.x - x1 - 1 + end + local dz = pos.z - minp.z + z + local dx = pos.x - minp.x + x + if pos.x + x > minp.x and pos.x + x < maxp.x and pos.z + z > minp.z and pos.z + z < maxp.z then + local ivm = area:index(pos.x + x, pos.y, pos.z + z) + local isch = z1 * schem.size.y * schem.size.x + x1 + 1 + for y = 0, schem.size.y - 1 do + local dy = pos.y - minp.y + y + --if math.min(dx, csize.x - dx) + math.min(dy, csize.y - dy) + math.min(dz, csize.z - dz) > bevel then + if yslice[y] or 255 >= rand(255) then + local prob = schem.data[isch].prob or schem.data[isch].param1 or 255 + if prob >= rand(255) and schem.data[isch].name ~= "air" then + data[ivm] = node[schem.data[isch].name] + end + local param2 = schem.data[isch].param2 or 0 + p2data[ivm] = param2 + end + --end + + ivm = ivm + area.ystride + isch = isch + schem.size.x + end + end + end + end +end + +fun_caves.surround = function(node, data, area, ivm) + -- Check to make sure that a plant root is fully surrounded. + -- This is due to the kludgy way you have to make water plants + -- in minetest, to avoid bubbles. + for x1 = -1,1,2 do + local n = data[ivm+x1] + if n == node["default:river_water_source"] or n == node["default:water_source"] or n == node["air"] then + return false + end + end + for z1 = -area.zstride,area.zstride,2*area.zstride do + local n = data[ivm+z1] + if n == node["default:river_water_source"] or n == node["default:water_source"] or n == node["air"] then + return false + end + end + + return true +end + fun_caves.underzones = { Caina = { @@ -303,7 +375,7 @@ local function generate(p_minp, p_maxp, seed) end if minp.y > 3000 then - write = fun_caves.cloudgen(minp, maxp, data, area, node) + write = fun_caves.cloudgen(minp, maxp, data, p2data, area, node) elseif not underzone and fun_caves.is_fortress(minp, csize) then --if not underzone then fun_caves.fortress(minp, maxp, data, area, node) diff --git a/mobs.lua b/mobs.lua index f109be9..4700583 100644 --- a/mobs.lua +++ b/mobs.lua @@ -75,6 +75,28 @@ fun_caves.custom_ready = function(self) end +if minetest.registered_entities["kpgmobs:wolf"] then + local m = table.copy(minetest.registered_entities["kpgmobs:wolf"]) + m.textures = { {"fun_caves_white_wolf.png"}, } + m.base_texture = m.textures[1] + + minetest.registered_entities["fun_caves:white_wolf"] = m + mobs.spawning_mobs["fun_caves:white_wolf"] = true + + mobs:register_spawn("fun_caves:white_wolf", {"default:dirt_with_snow", "fun_caves:cloud", "fun_caves:storm_cloud"}, 20, -1, 11000, 3, 31000) + mobs:register_egg("fun_caves:white_wolf", "White Wolf", "wool_white.png", 1) +end + +if minetest.registered_entities["kpgmobs:horse2"] then + mobs:register_spawn("kpgmobs:horse2", {"fun_caves:cloud", "fun_caves:storm_cloud"}, 20, 8, 11000, 1, 31000) +end + +if minetest.registered_entities["mobs_fish:clownfish"] then + --local l_spawn_near = {"default:sand","default:dirt","group:seaplants","group:seacoral"} + mobs:spawn_specific("mobs_fish:clownfish", {"default:water_source", "default:water_flowing"}, {"default:sand","default:dirt", "fun_caves:cloud", "fun_caves:storm_cloud","group:seaplants","group:seacoral"}, 5, 20, 30, 10000, 1, 4000, 31000) + mobs:spawn_specific("mobs_fish:tropical", {"default:water_source", "default:water_flowing"}, {"default:sand","default:dirt", "fun_caves:cloud", "fun_caves:storm_cloud","group:seaplants","group:seacoral"}, 5, 20, 30, 10000, 1, 4000, 31000) +end + if minetest.registered_entities["mobs_monster:spider"] then -- Deep spider local m = table.copy(minetest.registered_entities["mobs_monster:spider"]) diff --git a/nodes.lua b/nodes.lua index 8d69383..bafd191 100644 --- a/nodes.lua +++ b/nodes.lua @@ -1,6 +1,6 @@ local get_node_or_nil = minetest.get_node_or_nil local get_item_group = minetest.get_item_group -local map_max = 31000 +local max_depth = 31000 local old_is_protected = minetest.is_protected function minetest.is_protected(pos, name) @@ -143,7 +143,7 @@ local function teleporter(user, area, power) else local newpos if area == 'overworld' then - newpos = {x=(math.random(2)*2-3)*(math.random(math.floor(map_max/6))+power*math.floor(map_max/6)), y=120, z=(math.random(2)*2-3)*(math.random(math.floor(map_max/6))+power*math.floor(map_max/6))} + newpos = {x=(math.random(2)*2-3)*(math.random(math.floor(max_depth/6))+power*math.floor(max_depth/6)), y=120, z=(math.random(2)*2-3)*(math.random(math.floor(max_depth/6))+power*math.floor(max_depth/6))} elseif area == 'hell' then newpos = {x=pos.x, y=fun_caves.underzones[({'Caina','Phlegethos','Dis','Minauros','Styx'})[power+1]].ceiling-30, z=pos.z} else @@ -467,7 +467,7 @@ newnode.on_rightclick = function(pos, node, clicker, itemstack, pointed_thing) local meta = minetest.get_meta(pos) local ready = meta:get_string('formspec') if ready == '' then - local level = math.max(6, math.ceil(pos.y / math.floor(map_max / 6))) + local level = math.max(6, math.ceil(pos.y / math.floor(max_depth / 6))) local big_item = treasures[level][math.random(#treasures[level])] meta:set_string("formspec", chest_formspec) local inv = meta:get_inventory() diff --git a/textures/fun_caves_cloud.png b/textures/fun_caves_cloud.png new file mode 100644 index 0000000000000000000000000000000000000000..1e4124d8663f86f94d8b8fe38520f88e43368cac GIT binary patch literal 1608 zcmaKseNfT|7{}3Gd_w~@Lm&+}OHxV99Olb>!B8wk?VA1;rWlJPOGQ&l^5yWQQp_Sv z53o#f-o)K1EYq|Jp^ckiG1wv{!(tw5WaJdB9R9bzcF#SZ?>*oDp69;zoTns_oE_ng zAP~qoA)c6O)op8SztKw8nKK`)vXPcZB7#=e>iWa(D^|xLKR$y60y(*@wGF7953`zf zMF|Ju>|SjI+adz57GsD9@hcav^$97t3k$0iYX3TY!CPkX z50AHiUgK@(JKT2CVsP(~2Y*Vqw%4GPLvp%I5vcViHGbmJ=G_DC zZ|S#;;g=I zotAyEcjci9v*oC;~i^2;yQI%{yYivxmQz&>AsvPDphK9BSh(IaG)P$#{fkRmC2Z;GJX#(NQk{>AKb$ z^`nxl@^l7-Hfug-mol!=SJek{F(ToWqNz|Sb8`))P{eX!I#)CuBFo_yT^|pd_CM!L zZiGH2a0v!TGwTfrZP?$l0Xh@ZAcHU@Xm5=J(_eDPdh1~p2QtU5d##Gbd5ZVox95t3 z;nO9soYHVFBYPi1C=F#5RyvAX3 z5w*@YI#=v(Zm5?7PUP&y=uDgv&4C<&6L!;_svx${i{ku#C2+f6Gm0jl{|F{RBfqYo zdjFQ3di05Iw=6)?GL(bp%PsYDk|^>`l(KzCv#Sz?juIoB~; zdm3Q+`gG~HJskQJv5NzvkndN#g!rh`_Nc7J?Dku&iH@YmFAhOI*NI9X?TF#Pa}Ear zt83=D01<3(qZ)2}kdk|YH%dp=rN zHtqSlgV84`M2=xkn8NzmdV(u?eGYhf@o?s7I}Rg<^#{D--&EJ8c8gN?Bgbssxu3*# zzw6T=$PPN4?$grz`Ek!I5ptGa@b}%%=1>e7YfXhOfvYcWZ7XZ@9IG-6@gq-ORm0i3 z8TKZ}UVIntr=*b(J9Ik_t+>4nNMnjj5&GXToero=EV}kI#n}P>p*%9hcX|3wAL8y6 z(~2=Ojsy73#i#498QK(tXBL+n4t?r=lG|bv;(K`@xYTr9GXJ@p*5D(Hw>NkQc7vt) z+YN)^759>_v7JhFsLm&rM;TI9<~7_FAa8Zd40+b`QN3g_Z{pc|YYOr#pV%-H>3oWjvi}kMEScFIdUam2k_Ip{uShur!M5&|KJ4uOtLl wKR)FD=SbpQ*xK6T+BFU-%q1(F|4_CHnl5TX#zpyGwElchLR=EDFD9${UmC;rL;wH) literal 0 HcmV?d00001 diff --git a/textures/fun_caves_moon_weed.png b/textures/fun_caves_moon_weed.png new file mode 100644 index 0000000000000000000000000000000000000000..8445b7f873a6c1290337aae821b1788261c5c55e GIT binary patch literal 2545 zcmV13QOi|AYVl34TdL zK~z}7wU=v<6x9{S|M$_|)6>(l^V*%=+4r)$?DAN7xgcQJfG8p?8ceCtl#zraMPkaT zBxO?hpk-1iOF!gOQnAnvSV^T&u{4SiOi;5>fGt!;U^ zaw9*f#bl>!iKAt-JXt!Ne+0nJ>(NQR>_A&5LH{Xt#fNh5q}7C9&k@?r-ufgvi-kB`6VK+Sa#? zB@Hiu3@sMRgc4V{b*OeZNiN$8?Ar{nO>U$QlXpeSavkUPj$EGymaMP*aamez9^B1J zRA{JRQjIE9saIfS47eX>TsP||`MGUSPmBsmN!A(9Y?4ITRS|Ta4o0*Fri2Ig{9))P zbqP-6wNxBFSiUxZn<>aa0eRc~bt|&j575z|NvO8&-)UXi&#jin{23TVl;2z9NdBidf+E+L znpxgDb)s-!D(%TD?R+7?aLU01fT&uKN)Dp7nvs3~^!iz2Y?;NvE#p<1R)|t4rUoMl zOxqqR@)Cj0dX$qB#5Dl7AixX{qQ*dJT1J}_eBRjE(#~rFXk4r#GvY#-6JWBti5=N7 zDFDE@IdD&*+3q$x0d3Gmm6k`bLWA@RjFt(ag#yZo2VTM8#2K)-0l~Tu3XVuvm!`6< zjXt$~g?_9)H)<9!@$5asyb^R8be^Q5bX0qP&(r9&ZnDr(Jp+rqxf=Ty~N-k zKpU272+jm%f2)cEKyISA;L^qXZ#sH|$7VeclkF>;560^wzbvN44sl-^CW^#q^dSHV z%3RQ(4YbYz=OF}+jUyjXp*UQmUmyH;MV26Z^b#DO0`JU-l)|;8L&^Zq*9X+y;s-NK zLXsZ~glp(iwTmkMk!THU4n)+&{zSAIWt&WlW?n!2;#ilzGg!xCZm&${iDRfRa%C_d z!1Ergu_WZNF+h`;h!K=62ec&OH0ONRBkl%gBrn8xfl|xc7i;#n_^R{;ss7R%*=gV8jCb0h-sQEH84!lBiVK5-!A+bfQWRIpCy*lDE)-G)f$wW=R@Ch z0VP)f9WDzBMh2I3Ai8`7n(n=Ya8kzj2g8Rh?kKE^)WA?Hm1Sy$R!`^D#G`X67P@(B zq~)IK<4 zEmEyq1}FuQ-d+~0L&AuK?$3-*$r6`v{62Pid$JY);vE!LQbJ{(Oug^Er_EqLlO}@2 z{V8CoG?{$)z1@Wu&OGk4@i8<5-PIdnbd&&_u3v4V~0L@GJP!+<`T-C0+P~` zck}ZS8XSY1C_XebF3#63K$q3Qh0^kDK zAsaMRCQb=25df&|X5WFvpBw43wJ-ZVeGz_>5~jNpzu22P;ob{?x3AGNsTS_DTB@l$ zHv)84dhW5*N%#3&7XTRFt2jbit7gY9j46(;KyqEW1LdNfVciq}qRn#KNT02>E#bUn zg^oK{`aWmaoXdEii>=|!@+j#fQ5g_*01&JpO9PsmE)6LkQRxX9F~L-wVZiw*UvDVJ zt$yzA&2Mr*6er7JPfB=}CtRqLQ+vigqKO4Q9N#WvY&J#ze%GC8oA}$F64ovYYipN< zKO>Nm5Lec+AcfBa33O=l>v~mDrp%hi$-Fr}eL@}?p$%(p7csLv?=V}v6DCMBZ57ocV9n3an) z2NlN?!PI#EM_#4!`-+D)Aan5|CLTRN0tONzwXyiuIDz>qGjq+yK{eD?ni`y69XUewKzHc|&rb++?i(uyEvTK0>08o2B zdG32&T1fyP+~EK6n(#^qcM<4e0^k zjws9Tn)2}fl7@xq9ES8E)s>>t^$H*Q$rzi1Ci4Q3S#jP^g1yA82Zb zygu}aje4MzE|B5=66`3Eb5~$6H>GT8 zn(3=fq|ph{N-+`Hz*^9+0k1Fxy_*!T3LzvoCDi3UyTOkWw$TY&gjm_gN1WEXs;G$4-yQ zoYrmp{!Cv{eq{jE$6&Sg%4RET_`jwS00@C%_{8|3iCo@0xXSdj(~}!BqqdoybhVP@ zCa#(TloG-jh3g3jAwd9002(8poI(-_;Q_8IKtLcsK%@jC1e(sF1VGp4^27AW44GcFlcBfTb(ksA1Z$OFH!JzrZ2b-r2?)?K*%QmH8%zTXg&@}B-Dae z3a&T)DirEXy_)?-i4ctu0>Y%!HBNH{PeMq+s3ZcETnX?Wi(XMIelLmV00000NkvXX Hu0mjf2Wr0B literal 0 HcmV?d00001 diff --git a/textures/fun_caves_white_wolf.png b/textures/fun_caves_white_wolf.png new file mode 100644 index 0000000000000000000000000000000000000000..b659f19eeea8d1ead9bca34d4ebec104a7cad2c4 GIT binary patch literal 1041 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 RQ62yQ002ovPDHLkV1hu`y%_)i