From 441d1c78733b210c1cacbf3b4cd2a4d12651076d Mon Sep 17 00:00:00 2001 From: Chris N Date: Sun, 8 Mar 2015 17:33:29 -1000 Subject: [PATCH] Make tower automatically scale to rift size Tower now decides its width by the width of the world's fracture, via a global variable. Also cleaned up three files by changing content-id holding variables to use the c_ prefix. --- mods/blastradius/init.lua | 10 +++++----- mods/fracturerift/init.lua | 17 ++++++++++------- mods/worldstonetower/init.lua | 28 ++++++++++++++-------------- 3 files changed, 29 insertions(+), 26 deletions(-) diff --git a/mods/blastradius/init.lua b/mods/blastradius/init.lua index e5867d4..22cc41f 100644 --- a/mods/blastradius/init.lua +++ b/mods/blastradius/init.lua @@ -11,7 +11,7 @@ local blastrad_radius=100 --how wide should the blast radius be aro local blastrad_scatter=0.25 local blastrad_top=100 --don't bother blasting higher than this local blastrad_bot=-20 --don't bother blasting lower than this. -local blastrad_material=minetest.get_content_id("default:dry_dirt") +local c_blastmat = minetest.get_content_id("default:dry_dirt") --caclulated constants @@ -72,20 +72,20 @@ minetest.register_on_generated(function(minp, maxp, seed) --check if we are in the last scatter% of the blast radius if dist/blastrad_radius < blastrad_noscatter then --if not, change this node and the next node down to dry dirt - data[vi]=blastrad_material --hit surface, change to dry dirt + data[vi] = c_blastmat --hit surface, change to dry dirt changed=true if y > ymin then local vi = area:index(x, y-1, z) - data[vi]=blastrad_material --make it 2 deep + data[vi] = c_blastmat --make it 2 deep end --if y > ymin elseif math.random() < 1-(((dist/blastrad_radius)-blastrad_noscatter)/blastrad_scatter) then --but if we are in the last scatter% only change one deep randomly. - data[vi]=blastrad_material --change to dry dirt + data[vi] = c_blastmat --change to dry dirt changed=true end -- dist/blastrad_radius < blastrad_noscatter end --if not air y=y-1 - until y < y0 or data[vi] == blastrad_material + until y < y0 or data[vi] == c_blastmat end -- if in blast area end -- end 'x' loop end -- end 'z' loop diff --git a/mods/fracturerift/init.lua b/mods/fracturerift/init.lua index 4391373..6e2cd0e 100644 --- a/mods/fracturerift/init.lua +++ b/mods/fracturerift/init.lua @@ -1,22 +1,25 @@ -- mods/default/mapgen.lua +fracturerift = {} --Global container for variables accessed by other mods + --- --- constants --- -local fracrift_width=80 --how wide the rift will be +fracturerift.width = 80 --how wide the rift will be --fracrift. prefix added so that it can be referenced by other mods (e.g. worldstonetower) + local fracrift_depth_air=33000 --how deep before the water local fracrift_depth_water=20 --how deep the water will be local fracrift_top=100 --max height to scan for land to remove local fracrift_bottomsmooth=0.995 --odds of bottom being smooth local fracrift_waterfallchance=0.997 --odds of NOT having a waterfall hole in wall -local fracrift_material=minetest.get_content_id("default:sandstone") -- Makes more sense, no? +local c_fracrift_material=minetest.get_content_id("default:sandstone") -- Makes more sense, no? minetest.get_content_id("default:sandstone") --calculated constants -local fracrift_half=fracrift_width/2 -local fracrift_edge=fracrift_half+1 -local fracrift_depth=-(fracrift_depth_air+fracrift_depth_water) +local fracrift_half = fracturerift.width/2 +local fracrift_edge = fracrift_half+1 +local fracrift_depth = -(fracrift_depth_air+fracrift_depth_water) local fracrift_waterstart=-(fracrift_depth_air+1) --grab content IDs -- You need these to efficiently access and set node data. get_node() works, but is far slower @@ -88,7 +91,7 @@ minetest.register_on_generated(function(minp, maxp, seed) else if (x < -fracrift_edge/3 or x > fracrift_edge/3) then -- Put limits in to make sure the chasm always stays at least some ways open if data[vi] == c_water then -- If there's water, make it wall material so as not to drain the oceans :P - data[vi] = fracrift_material + data[vi] = c_fracrift_material end else if (x > -fracrift_edge/3 or x < fracrift_edge/3) then -- In the limits, always hollow this @@ -101,7 +104,7 @@ minetest.register_on_generated(function(minp, maxp, seed) if x == -fracrift_edge or x == fracrift_edge then -- x is on edge if data[vi] == c_water and math.random() < fracrift_waterfallchance and (math.abs(nvals_walls[nixyz]) - grad) > -0.1 then - data[vi]=fracrift_material + data[vi]=c_fracrift_material changed=true end -- change water to stone on edge end -- if x == -fracrift_edge or x == fracrift_edge diff --git a/mods/worldstonetower/init.lua b/mods/worldstonetower/init.lua index 5a9bcf1..b61a83c 100644 --- a/mods/worldstonetower/init.lua +++ b/mods/worldstonetower/init.lua @@ -5,16 +5,16 @@ --- local wst_pos={x=0,y=0,z=0} local wst_radius=15 -local wst_length=100 +local wst_length = fracturerift.width + 20 local wst_floorheight=8 local wst_shrinkheight=20 local wst_floorholeodds=0.1 local wst_wallholeodds=0.01 -local wst_material_wall = minetest.get_content_id("default:obsidianbrick") -local wst_material_floor = minetest.get_content_id("default:desert_stonebrick") -local wst_material_stair = minetest.get_content_id("stairs:stair_obsidianbrick") +local c_wall = minetest.get_content_id("default:obsidianbrick") +local c_floor = minetest.get_content_id("default:desert_stonebrick") +local c_stair = minetest.get_content_id("stairs:stair_obsidianbrick") --local wst_start={x=0,y=0,z=0} --where to start trying to put the tower. --local wst_lookdist=100 --distance to look for starting point. @@ -41,13 +41,13 @@ local np_dmg = { offset = 0, scale = 1, --spread = {x=192, y=512, z=512}, -- squashed 2:1 - --spread = {x=200, y=80, z=80}, - spread = {x=15, y=5, z=5}, - seed = 133742, --a LEET answer to life, the universe, and everything + --spread = {x=200, y=80, z=80}, + spread = {x=15, y=8, z=8}, + seed = 314159, --everyone loves pi(e) octaves = 3, persist = 0.67 } -local wst_dmg_lvl=0.7 +local wst_dmg_lvl=0.7 --threshold for holes in the tower. Smaller means larger holes @@ -110,21 +110,21 @@ minetest.register_on_generated(function(minp, maxp, seed) radius=wst_radius-(math.floor(xdist/wst_shrinkheight)) if yzdist==radius then if math.abs(nvals_dmg[nixyz]) > wst_dmg_lvl then - data[vi] = c_air + data[vi] = c_air else - data[vi]=wst_material_wall + data[vi] = c_wall end elseif yzdist=wst_min.x - nixyz = nixyz + 1 - vi = vi + 1 + nixyz = nixyz + 1 + vi = vi + 1 end -- end 'x' loop end -- end 'y' loop end -- end 'z' loop