From 123ab76e4f19f336f660f683ce6f470336144386 Mon Sep 17 00:00:00 2001 From: paramat Date: Tue, 22 Apr 2014 14:21:21 +0100 Subject: [PATCH] Craft 8 lights at once. Mid colour blend water. Flatter lowlands: terblen exponent, vary canexp, canamp. Grassy sides on mod grass --- README.txt | 2 +- functions.lua | 14 ++-- init.lua | 45 +++++++----- nodes.lua | 92 +++++++++++++++++++++--- textures/watershed_mixwater.png | Bin 0 -> 716 bytes textures/watershed_mixwateranim.png | Bin 0 -> 4935 bytes textures/watershed_mixwaterflowanim.png | Bin 0 -> 5851 bytes 7 files changed, 121 insertions(+), 32 deletions(-) create mode 100644 textures/watershed_mixwater.png create mode 100644 textures/watershed_mixwateranim.png create mode 100644 textures/watershed_mixwaterflowanim.png diff --git a/README.txt b/README.txt index b7cafee..d5b5b54 100644 --- a/README.txt +++ b/README.txt @@ -1,4 +1,4 @@ -watershed 0.3.13 by paramat +watershed 0.3.14 by paramat For latest stable Minetest back to 0.4.8 Depends default bucket Licenses: code WTFPL, textures CC BY-SA diff --git a/functions.lua b/functions.lua index 6d24300..8888d68 100644 --- a/functions.lua +++ b/functions.lua @@ -229,8 +229,8 @@ if SINGLENODE then local ATANAMP = 1.1 -- Arctan function amplitude, smaller = more and larger floatlands above ridges local XLSAMP = 0.2 -- Extra large scale height variation amplitude local BASAMP = 0.4 -- Base terrain amplitude - local CANAMP = 0.4 -- Canyon terrain amplitude - local CANEXP = 1.33 -- Canyon shape exponent + local CANAMP = 0.4 -- Canyon terrain maximum amplitude + local BLENEXP = 2 -- Terrain blend exponent local xsp local ysp local zsp @@ -271,7 +271,7 @@ if SINGLENODE then scale = 1, spread = {x=4096, y=4096, z=4096}, seed = 8890, - octaves = 4, + octaves = 3, persist = 0.33 } local np_xlscale = { @@ -280,7 +280,7 @@ if SINGLENODE then spread = {x=8192, y=8192, z=8192}, seed = -72, octaves = 3, - persist = 0.4 + persist = 0.33 } for chunk = 1, 64 do print ("[watershed] searching for spawn "..chunk) @@ -317,10 +317,12 @@ if SINGLENODE then local n_xlscale = nvals_xlscale[nixz] local grad = math.atan((TERCEN - y) / TERSCA) * ATANAMP local densitybase = (1 - math.abs(n_base)) * BASAMP + n_xlscale * XLSAMP + grad - local terblen = math.max(1 - math.abs(n_base), 0) + local terblen = (math.max(1 - math.abs(n_base), 0)) ^ BLENEXP + local canexp = 0.5 + terblen + local canamp = 0.03 + terblen * CANAMP local density = densitybase + math.abs((n_rough + n_roughalt) * 0.5 * terblen + - (n_smooth + n_smoothalt) * 0.25 * (1 - terblen)) ^ CANEXP * CANAMP + (n_smooth + n_smoothalt) * 0.5 * (1 - terblen)) ^ canexp * canamp if y >= 1 and density > -0.01 and density < 0 then ysp = y + 1 xsp = x diff --git a/init.lua b/init.lua index 10a1129..85ce8b4 100644 --- a/init.lua +++ b/init.lua @@ -1,10 +1,13 @@ --- watershed 0.3.13 by paramat +-- watershed 0.3.14 by paramat -- For latest stable Minetest and back to 0.4.8 -- Depends default bucket -- License: code WTFPL, textures CC BY-SA -- Red cobble texture CC BY-SA by brunob.santos --- y = 47 bugfix: add snowblocks in chunk above +-- light crafting gives 8 lights +-- mid colour water at y == 2 +-- flatter lowlands: terblen exponent, vary canexp, canamp +-- grassy sides on mod grass -- Parameters @@ -20,9 +23,9 @@ local CLOUDS = true -- Mod clouds? local TERSCA = 512 -- Vertical terrain scale local XLSAMP = 0.2 -- Extra large scale height variation amplitude local BASAMP = 0.4 -- Base terrain amplitude -local CANAMP = 0.4 -- Canyon terrain amplitude -local CANEXP = 1.33 -- Canyon shape exponent +local CANAMP = 0.4 -- Canyon terrain maximum amplitude local ATANAMP = 1.1 -- Arctan function amplitude, smaller = more and larger floatlands above ridges +local BLENEXP = 2 -- Terrain blend exponent local TSTONE = 0.02 -- Density threshold for stone, depth of soil at TERCEN local TRIV = -0.02 -- Maximum densitybase threshold for river water @@ -160,7 +163,7 @@ local np_base = { scale = 1, spread = {x=4096, y=4096, z=4096}, seed = 8890, - octaves = 4, + octaves = 3, persist = 0.33 } @@ -172,7 +175,7 @@ local np_xlscale = { spread = {x=8192, y=8192, z=8192}, seed = -72, octaves = 3, - persist = 0.4 + persist = 0.33 } -- 2D noise for magma surface @@ -242,6 +245,7 @@ minetest.register_on_generated(function(minp, maxp, seed) local c_obsidian = minetest.get_content_id("default:obsidian") local c_wsfreshwater = minetest.get_content_id("watershed:freshwater") + local c_wsmixwater = minetest.get_content_id("watershed:mixwater") local c_wsstone = minetest.get_content_id("watershed:stone") local c_wsredstone = minetest.get_content_id("watershed:redstone") local c_wsgrass = minetest.get_content_id("watershed:grass") @@ -304,12 +308,14 @@ minetest.register_on_generated(function(minp, maxp, seed) local n_xlscale = nvals_xlscale[nixz] local n_magma = nvals_magma[nixz] -- get densitybase and density - local grad = math.atan((TERCEN - y) / TERSCA) * ATANAMP -- vertical density gradient - local densitybase = (1 - math.abs(n_base)) * BASAMP + n_xlscale * XLSAMP + grad -- base terrain - local terblen = math.max(1 - math.abs(n_base), 0) -- canyon terrain blend of rough and smooth - local density = densitybase + -- add canyon terrain + local grad = math.atan((TERCEN - y) / TERSCA) * ATANAMP + local densitybase = (1 - math.abs(n_base)) * BASAMP + n_xlscale * XLSAMP + grad + local terblen = (math.max(1 - math.abs(n_base), 0)) ^ BLENEXP + local canexp = 0.5 + terblen + local canamp = 0.03 + terblen * CANAMP + local density = densitybase + math.abs((n_rough + n_roughalt) * 0.5 * terblen + - (n_smooth + n_smoothalt) * 0.25 * (1 - terblen)) ^ CANEXP * CANAMP + (n_smooth + n_smoothalt) * 0.5 * (1 - terblen)) ^ canexp * canamp -- other values local triv = TRIV * (1 - terblen) -- river threshold local tsand = TSAND * (1 - terblen) -- sand threshold @@ -396,8 +402,8 @@ minetest.register_on_generated(function(minp, maxp, seed) stable[si] = 1 under[si] = 0 elseif density >= tstone and nofis -- stone cut by fissures - or (density >= tstone and density < TSTONE * 2 and y <= YWAT) -- stone around water - or (density >= tstone and density < TSTONE * 2 and densitybase >= triv ) then -- stone around river + or (density >= tstone and density < TSTONE * 1.5 and y <= YWAT) -- stone around water + or (density >= tstone and density < TSTONE * 1.5 and densitybase >= triv ) then -- stone around river local densitystr = n_strata * 0.25 + (TERCEN - y) / TERSCA local densityper = densitystr - math.floor(densitystr) -- periodic strata 'density' if (densityper >= 0.05 and densityper <= 0.09) -- sandstone strata @@ -408,7 +414,7 @@ minetest.register_on_generated(function(minp, maxp, seed) or (densityper >= 0.84 and densityper <= 0.87) or (densityper >= 0.95 and densityper <= 0.98) then data[vi] = c_sandstone - elseif biome == 7 and density < TSTONE * 4 then -- desert stone as surface layer + elseif biome == 7 and density < TSTONE * 3 then -- desert stone as surface layer data[vi] = c_wsredstone elseif math.abs(n_seam) < SEAMT then if densityper >= 0 and densityper <= ORETHI * 4 then -- ore seams @@ -491,7 +497,7 @@ minetest.register_on_generated(function(minp, maxp, seed) stable[si] = 0 under[si] = 0 end - elseif y >= YWAT - bergdep and y <= YWAT + bergdep / 8 and n_temp < ICETET -- iceberg + elseif y >= YWAT - bergdep and y <= YWAT + bergdep / 8 and n_temp < ICETET -- icesheet and density < tstone and math.abs(n_fissure) > 0.01 then data[vi] = c_ice under[si] = 12 @@ -504,7 +510,11 @@ minetest.register_on_generated(function(minp, maxp, seed) if n_temp < ICETET then data[vi] = c_wsfreshice else - data[vi] = c_wsfreshwater + if y == YWAT + 1 then + data[vi] = c_wsmixwater + else + data[vi] = c_wsfreshwater + end end stable[si] = 0 under[si] = 0 @@ -598,7 +608,8 @@ minetest.register_on_generated(function(minp, maxp, seed) if math.random(PAPCHA) == 2 then watershed_papyrus(x, y, z, area, data) end - elseif under[si] == 12 and n_humid > LOHUT then -- snowy iceberg + elseif under[si] == 12 + and n_humid > LOHUT + (math.random() - 0.5) * BLEND then -- snowy iceberg data[vi] = c_snowblock end end diff --git a/nodes.lua b/nodes.lua index 4e53fd5..705472e 100644 --- a/nodes.lua +++ b/nodes.lua @@ -85,7 +85,7 @@ minetest.register_node("watershed:icydirt", { minetest.register_node("watershed:grass", { description = "WS Grass", - tiles = {"default_grass.png", "default_dirt.png", "default_dirt.png^default_grass_side.png"}, + tiles = {"default_grass.png", "default_dirt.png", "default_grass.png"}, is_ground_content = false, groups = {crumbly=3,soil=1}, drop = "default:dirt", @@ -278,8 +278,8 @@ minetest.register_node("watershed:freshwater", { liquid_alternative_source = "watershed:freshwater", liquid_viscosity = WATER_VISC, liquid_renewable = false, - liquid_range = 2, - post_effect_color = {a=64, r=100, g=100, b=200}, + liquid_range = 4, + post_effect_color = {a=64, r=100, g=150, b=200}, groups = {water=3, liquid=3, puts_out_fire=1}, }) @@ -315,8 +315,8 @@ minetest.register_node("watershed:freshwaterflow", { liquid_alternative_source = "watershed:freshwater", liquid_viscosity = WATER_VISC, liquid_renewable = false, - liquid_range = 2, - post_effect_color = {a=64, r=100, g=100, b=200}, + liquid_range = 4, + post_effect_color = {a=64, r=100, g=150, b=200}, groups = {water=3, liquid=3, puts_out_fire=1, not_in_creative_inventory=1}, }) @@ -395,6 +395,81 @@ minetest.register_node("watershed:lavaflow", { groups = {lava=3, liquid=2, hot=3, igniter=1, not_in_creative_inventory=1}, }) +minetest.register_node("watershed:mixwater", { + description = "WS Mixed Water Source", + inventory_image = minetest.inventorycube("watershed_mixwater.png"), + drawtype = "liquid", + tiles = { + { + name="watershed_mixwateranim.png", + animation={type="vertical_frames", + aspect_w=16, aspect_h=16, length=2.0} + } + }, + special_tiles = { + { + name="watershed_mixwateranim.png", + animation={type="vertical_frames", + aspect_w=16, aspect_h=16, length=2.0}, + backface_culling = false, + } + }, + alpha = WATER_ALPHA, + paramtype = "light", + is_ground_content = false, + walkable = false, + pointable = false, + diggable = false, + buildable_to = true, + drop = "", + drowning = 1, + liquidtype = "source", + liquid_alternative_flowing = "watershed:mixwaterflow", + liquid_alternative_source = "watershed:mixwater", + liquid_viscosity = WATER_VISC, + liquid_renewable = false, + liquid_range = 4, + post_effect_color = {a=64, r=100, g=120, b=200}, + groups = {water=3, liquid=3, puts_out_fire=1}, +}) + +minetest.register_node("watershed:mixwaterflow", { + description = "WS Flowing Mixed Water", + inventory_image = minetest.inventorycube("watershed_mixwater.png"), + drawtype = "flowingliquid", + tiles = {"watershed_mixwater.png"}, + special_tiles = { + { + image="watershed_mixwaterflowanim.png", + backface_culling=false, + animation={type="vertical_frames", aspect_w=16, aspect_h=16, length=0.8} + }, + { + image="watershed_mixwaterflowanim.png", + backface_culling=true, + animation={type="vertical_frames", aspect_w=16, aspect_h=16, length=0.8} + }, + }, + alpha = WATER_ALPHA, + paramtype = "light", + paramtype2 = "flowingliquid", + is_ground_content = false, + walkable = false, + pointable = false, + diggable = false, + buildable_to = true, + drop = "", + drowning = 1, + liquidtype = "flowing", + liquid_alternative_flowing = "watershed:mixwaterflow", + liquid_alternative_source = "watershed:mixwater", + liquid_viscosity = WATER_VISC, + liquid_renewable = false, + liquid_range = 4, + post_effect_color = {a=64, r=100, g=120, b=200}, + groups = {water=3, liquid=3, puts_out_fire=1, not_in_creative_inventory=1}, +}) + -- Items minetest.register_craftitem("watershed:luxcrystal", { @@ -411,10 +486,11 @@ minetest.register_craft({ }) minetest.register_craft({ - output = "watershed:light", + output = "watershed:light 8", recipe = { - {"default:glass"}, - {"watershed:luxcrystal"}, + {"default:glass", "default:glass", "default:glass"}, + {"default:glass", "watershed:luxcrystal", "default:glass"}, + {"default:glass", "default:glass", "default:glass"}, }, }) diff --git a/textures/watershed_mixwater.png b/textures/watershed_mixwater.png new file mode 100644 index 0000000000000000000000000000000000000000..3b55c5f66f1f1ef780a89dedbd9f9e6a454626e1 GIT binary patch literal 716 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 J)|vYg{tMfXn)Uzy literal 0 HcmV?d00001 diff --git a/textures/watershed_mixwaterflowanim.png b/textures/watershed_mixwaterflowanim.png new file mode 100644 index 0000000000000000000000000000000000000000..536acc535b695c3d493e202c81c057964dc176b6 GIT binary patch literal 5851 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 literal 0 HcmV?d00001