mirror of
				https://github.com/FaceDeer/dfcaverns.git
				synced 2025-10-25 14:25:43 +02:00 
			
		
		
		
	add giant mycelium to mapgen
This commit is contained in:
		| @@ -5,6 +5,7 @@ end | |||||||
| local c_orb = minetest.get_content_id("df_primordial_items:glow_orb_hanging") | local c_orb = minetest.get_content_id("df_primordial_items:glow_orb_hanging") | ||||||
| local c_mycelial_dirt = minetest.get_content_id("df_primordial_items:dirt_with_mycelium") | local c_mycelial_dirt = minetest.get_content_id("df_primordial_items:dirt_with_mycelium") | ||||||
| local c_dirt = minetest.get_content_id("default:dirt") | local c_dirt = minetest.get_content_id("default:dirt") | ||||||
|  | local c_giant_mycelium = minetest.get_content_id("df_primordial_items:giant_hypha_apical_mapgen") | ||||||
|  |  | ||||||
| ----------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------- | ||||||
|  |  | ||||||
| @@ -47,7 +48,9 @@ local mushroom_cavern_floor = function(abs_cracks, humidity, vi, area, data, dat | |||||||
| 	end | 	end | ||||||
|  |  | ||||||
| 	local rand = math.random() * math.min(abs_cracks, 1) * humidityfactor | 	local rand = math.random() * math.min(abs_cracks, 1) * humidityfactor | ||||||
| 	if rand < 0.01 then | 	if rand < 0.001 then | ||||||
|  | 		data[vi+ystride] = c_giant_mycelium | ||||||
|  | 	elseif rand < 0.01 then | ||||||
| 		local schematic = df_primordial_items.get_primordial_mushroom() | 		local schematic = df_primordial_items.get_primordial_mushroom() | ||||||
| 		local rotation = (math.random(1,4)-1)*90 | 		local rotation = (math.random(1,4)-1)*90 | ||||||
| 		mapgen_helper.place_schematic_on_data_if_it_fits(data, data_param2, area, area:position(vi+ystride), schematic, rotation) | 		mapgen_helper.place_schematic_on_data_if_it_fits(data, data_param2, area, area:position(vi+ystride), schematic, rotation) | ||||||
| @@ -65,7 +68,9 @@ local mushroom_cavern_ceiling = function(abs_cracks, humidity, vi, area, data, d | |||||||
| 		data[vi] = c_mycelial_dirt | 		data[vi] = c_mycelial_dirt | ||||||
| 		if abs_cracks < 0.3 then | 		if abs_cracks < 0.3 then | ||||||
| 			local rand = math.random() * humidityfactor | 			local rand = math.random() * humidityfactor | ||||||
| 			if rand < 0.03 then | 			if rand < 0.003 then | ||||||
|  | 				data[vi-ystride] = c_giant_mycelium | ||||||
|  | 			elseif rand < 0.03 then | ||||||
| 				df_primordial_items.spawn_ceiling_spire_vm(vi, area, data) | 				df_primordial_items.spawn_ceiling_spire_vm(vi, area, data) | ||||||
| 			elseif rand < 0.2 then | 			elseif rand < 0.2 then | ||||||
| 				data[vi-ystride] = c_orb | 				data[vi-ystride] = c_orb | ||||||
| @@ -81,7 +86,10 @@ local mushroom_warren_ceiling = function(abs_cracks, vi, area, data, data_param2 | |||||||
| 	if abs_cracks < 0.3 then | 	if abs_cracks < 0.3 then | ||||||
| 		data[vi] = c_mycelial_dirt | 		data[vi] = c_mycelial_dirt | ||||||
| 		if abs_cracks < 0.2 then | 		if abs_cracks < 0.2 then | ||||||
| 			if math.random() < 0.2 then | 			local rand = math.random() | ||||||
|  | 			if rand < 0.003 then | ||||||
|  | 				data[vi-ystride] = c_giant_mycelium | ||||||
|  | 			elseif rand < 0.2 then | ||||||
| 				data[vi-ystride] = c_orb | 				data[vi-ystride] = c_orb | ||||||
| 				data_param2[vi-ystride] = math.random(0,179) | 				data_param2[vi-ystride] = math.random(0,179) | ||||||
| 			end | 			end | ||||||
| @@ -97,7 +105,9 @@ local mushroom_warren_floor = function(abs_cracks, vi, area, data, data_param2) | |||||||
| 		data[vi] = c_dirt | 		data[vi] = c_dirt | ||||||
| 	end | 	end | ||||||
| 	local rand = math.random() * math.min(abs_cracks, 1) | 	local rand = math.random() * math.min(abs_cracks, 1) | ||||||
| 	if rand < 0.03 then | 	if rand < 0.001 then | ||||||
|  | 		data[vi+ystride] = c_giant_mycelium | ||||||
|  | 	elseif rand < 0.03 then | ||||||
| 		data[vi+ystride] = plants[math.random(1,5)] | 		data[vi+ystride] = plants[math.random(1,5)] | ||||||
| 	end | 	end | ||||||
| end | end | ||||||
|   | |||||||
| @@ -38,7 +38,7 @@ minetest.register_node("df_primordial_items:glow_orb_hanging", { | |||||||
| 	tiles = {"dfcaverns_mush_orb_vert.png"}, | 	tiles = {"dfcaverns_mush_orb_vert.png"}, | ||||||
| 	inventory_image = "dfcaverns_mush_orb_vert.png", | 	inventory_image = "dfcaverns_mush_orb_vert.png", | ||||||
| 	wield_image = "dfcaverns_mush_orb_vert.png", | 	wield_image = "dfcaverns_mush_orb_vert.png", | ||||||
| 	groups = {snappy = 3, flora = 1, attached_node = 1, flammable = 1}, | 	groups = {snappy = 3, flora = 1, flammable = 1}, | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	paramtype2 = "degrotate", | 	paramtype2 = "degrotate", | ||||||
| 	drawtype = "plantlike", | 	drawtype = "plantlike", | ||||||
|   | |||||||
| @@ -2,30 +2,32 @@ | |||||||
| local MP = minetest.get_modpath(minetest.get_current_modname()) | local MP = minetest.get_modpath(minetest.get_current_modname()) | ||||||
| local S, NS = dofile(MP.."/intllib.lua") | local S, NS = dofile(MP.."/intllib.lua") | ||||||
|  |  | ||||||
| local hub_thickness = 0.1875--0.25 | -- hub_thickness -- the bit in the middle that's seen at the ends and corners of long hypha runs | ||||||
| local connector_thickness = 0.25--0.375 | -- connector_thickness | ||||||
| local node_box = { | local get_node_box = function(hub_thickness, connector_thickness) | ||||||
| 	type = "connected", | 	return { | ||||||
| 	fixed = {-hub_thickness,-hub_thickness,-hub_thickness,hub_thickness,hub_thickness,hub_thickness}, | 		type = "connected", | ||||||
| 	connect_top = {-connector_thickness, 0, -connector_thickness, connector_thickness, 0.5, connector_thickness}, | 		fixed = {-hub_thickness,-hub_thickness,-hub_thickness,hub_thickness,hub_thickness,hub_thickness}, | ||||||
| 	connect_bottom = {-connector_thickness, -0.5, -connector_thickness, connector_thickness, 0, connector_thickness}, | 		connect_top = {-connector_thickness, 0, -connector_thickness, connector_thickness, 0.5, connector_thickness}, | ||||||
| 	connect_back = {-connector_thickness, -connector_thickness, 0, connector_thickness, connector_thickness, 0.5}, | 		connect_bottom = {-connector_thickness, -0.5, -connector_thickness, connector_thickness, 0, connector_thickness}, | ||||||
| 	connect_right = {0, -connector_thickness, -connector_thickness, 0.5, connector_thickness, connector_thickness}, | 		connect_back = {-connector_thickness, -connector_thickness, 0, connector_thickness, connector_thickness, 0.5}, | ||||||
| 	connect_front = {-connector_thickness, -connector_thickness, -0.5, connector_thickness, connector_thickness, 0}, | 		connect_right = {0, -connector_thickness, -connector_thickness, 0.5, connector_thickness, connector_thickness}, | ||||||
| 	connect_left = {-0.5, -connector_thickness, -connector_thickness, 0, connector_thickness, connector_thickness}, | 		connect_front = {-connector_thickness, -connector_thickness, -0.5, connector_thickness, connector_thickness, 0}, | ||||||
| 	disconnected = {-connector_thickness,-connector_thickness,-connector_thickness,connector_thickness,connector_thickness,connector_thickness}, | 		connect_left = {-0.5, -connector_thickness, -connector_thickness, 0, connector_thickness, connector_thickness}, | ||||||
| } | 		disconnected = {-connector_thickness,-connector_thickness,-connector_thickness,connector_thickness,connector_thickness,connector_thickness}, | ||||||
|  | 	} | ||||||
|  | end | ||||||
|  |  | ||||||
|  |  | ||||||
| minetest.register_node("df_primordial_items:giant_hypha_root", { | minetest.register_node("df_primordial_items:giant_hypha_root", { | ||||||
| 	description = S("Giant Hypha"), | 	description = S("Giant Hypha"), | ||||||
| 	tiles = { | 	tiles = { | ||||||
| 		{name="dfcaverns_mush_stalk_side.png"}, | 		{name="dfcaverns_mush_giant_hypha.png"}, | ||||||
| 	}, | 	}, | ||||||
|     connects_to = {"group:soil", "group:hypha"}, |     connects_to = {"group:soil", "group:hypha"}, | ||||||
|     connect_sides = { "top", "bottom", "front", "left", "back", "right" }, |     connect_sides = { "top", "bottom", "front", "left", "back", "right" }, | ||||||
| 	drawtype = "nodebox", | 	drawtype = "nodebox", | ||||||
| 	node_box = node_box, | 	node_box = get_node_box(0.1875, 0.25), | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	light_source = 2, | 	light_source = 2, | ||||||
| 	is_ground_content = false, | 	is_ground_content = false, | ||||||
| @@ -35,12 +37,12 @@ minetest.register_node("df_primordial_items:giant_hypha_root", { | |||||||
| minetest.register_node("df_primordial_items:giant_hypha", { | minetest.register_node("df_primordial_items:giant_hypha", { | ||||||
| 	description = S("Giant Hypha"), | 	description = S("Giant Hypha"), | ||||||
| 	tiles = { | 	tiles = { | ||||||
| 		{name="dfcaverns_mush_stalk_side.png"}, | 		{name="dfcaverns_mush_giant_hypha.png"}, | ||||||
| 	}, | 	}, | ||||||
|     connects_to = {"group:hypha"}, |     connects_to = {"group:hypha"}, | ||||||
|     connect_sides = { "top", "bottom", "front", "left", "back", "right" }, |     connect_sides = { "top", "bottom", "front", "left", "back", "right" }, | ||||||
| 	drawtype = "nodebox", | 	drawtype = "nodebox", | ||||||
| 	node_box = node_box, | 	node_box = get_node_box(0.1875, 0.25), | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	light_source = 2, | 	light_source = 2, | ||||||
| 	is_ground_content = false, | 	is_ground_content = false, | ||||||
| @@ -48,23 +50,25 @@ minetest.register_node("df_primordial_items:giant_hypha", { | |||||||
| 	sounds = default.node_sound_wood_defaults(), | 	sounds = default.node_sound_wood_defaults(), | ||||||
| }) | }) | ||||||
|  |  | ||||||
| local grow_mycelium = function(pos) | local find_mycelium_growth_targets = function(pos) | ||||||
| 	local nodes = {} | 	local nodes = {} | ||||||
| 	for x = -1, 1 do | 	for x = -1, 1 do | ||||||
| 		nodes[x] = {} | 		nodes[x] = {} | ||||||
| 		for y = -1, 1 do | 		for y = -1, 1 do | ||||||
| 			nodes[x][y] = {} | 			nodes[x][y] = {} | ||||||
| 			for z = -1, 1 do | 			for z = -1, 1 do | ||||||
| 				local node = minetest.get_node({x=pos.x+x, y=pos.y+y, z=pos.z+z}) | 				if not (x == y and y == z) then -- we don't care about the diagonals or the center node | ||||||
| 				local state = {} | 					local node = minetest.get_node({x=pos.x+x, y=pos.y+y, z=pos.z+z}) | ||||||
| 				if minetest.get_item_group(node.name, "soil") > 0 then | 					local state = {} | ||||||
| 					state.soil = true | 					if minetest.get_item_group(node.name, "soil") > 0 then | ||||||
| 				elseif minetest.get_item_group(node.name, "hypha") > 0 then | 						state.soil = true | ||||||
| 					state.hypha = true | 					elseif minetest.get_item_group(node.name, "hypha") > 0 then | ||||||
| 				elseif minetest.registered_nodes[node.name] and minetest.registered_nodes[node.name].buildable_to then | 						state.hypha = true | ||||||
| 					state.buildable = true | 					elseif minetest.registered_nodes[node.name] and minetest.registered_nodes[node.name].buildable_to then | ||||||
|  | 						state.buildable = true | ||||||
|  | 					end | ||||||
|  | 					nodes[x][y][z] = state | ||||||
| 				end | 				end | ||||||
| 				nodes[x][y][z] = state |  | ||||||
| 			end | 			end | ||||||
| 		end | 		end | ||||||
| 	end | 	end | ||||||
| @@ -73,179 +77,215 @@ local grow_mycelium = function(pos) | |||||||
| 	--copy and pasting is easy and nobody's going to decide whether to hire or fire me based on this | 	--copy and pasting is easy and nobody's going to decide whether to hire or fire me based on this | ||||||
| 	--particular snippet of code so what the hell. I'll fix it later when that clever way comes to me. | 	--particular snippet of code so what the hell. I'll fix it later when that clever way comes to me. | ||||||
| 	local valid_targets = {} | 	local valid_targets = {} | ||||||
| 	if nodes[-1][0][0].buildable then | 	if nodes[-1][0][0].buildable and | ||||||
| 		if  | 		-- test for soil to directly support new growth | ||||||
| 			-- test for soil to directly support new growth | 		(nodes[-1][-1][0].soil or | ||||||
| 			(nodes[-1][-1][0].soil or | 		nodes[-1][1][0].soil or | ||||||
| 			nodes[-1][1][0].soil or | 		nodes[-1][0][-1].soil or | ||||||
| 			nodes[-1][0][-1].soil or | 		nodes[-1][0][1].soil or | ||||||
| 			nodes[-1][0][1].soil or | 		-- test for soil "around the corner" to allow for growth over an edge | ||||||
| 			-- test for soil "around the corner" to allow for growth over an edge | 		nodes[0][-1][0].soil or | ||||||
| 			nodes[0][-1][0].soil or | 		nodes[0][1][0].soil or | ||||||
| 			nodes[0][1][0].soil or | 		nodes[0][0][-1].soil or | ||||||
| 			nodes[0][0][-1].soil or | 		nodes[0][0][1].soil) | ||||||
| 			nodes[0][0][1].soil) | 		and not -- no adjacent hypha | ||||||
| 			and not -- no adjacent hypha | 		(nodes[-1][-1][0].hypha or | ||||||
| 			(nodes[-1][-1][0].hypha or | 		nodes[-1][1][0].hypha or | ||||||
| 			nodes[-1][1][0].hypha or | 		nodes[-1][0][-1].hypha or | ||||||
| 			nodes[-1][0][-1].hypha or | 		nodes[-1][0][1].hypha) | ||||||
| 			nodes[-1][0][1].hypha) | 	then | ||||||
| 		then | 		table.insert(valid_targets, {x=pos.x-1, y=pos.y, z=pos.z}) | ||||||
| 			table.insert(valid_targets, {x=pos.x-1, y=pos.y, z=pos.z}) |  | ||||||
| 		end |  | ||||||
| 	end | 	end | ||||||
| 	if nodes[1][0][0].buildable then | 	if nodes[1][0][0].buildable and | ||||||
| 		if  | 		-- test for soil to directly support new growth | ||||||
| 			-- test for soil to directly support new growth | 		(nodes[1][-1][0].soil or | ||||||
| 			(nodes[1][-1][0].soil or | 		nodes[1][1][0].soil or | ||||||
| 			nodes[1][1][0].soil or | 		nodes[1][0][-1].soil or | ||||||
| 			nodes[1][0][-1].soil or | 		nodes[1][0][1].soil or | ||||||
| 			nodes[1][0][1].soil or | 		-- test for soil "around the corner" to allow for growth over an edge | ||||||
| 			-- test for soil "around the corner" to allow for growth over an edge | 		nodes[0][-1][0].soil or | ||||||
| 			nodes[0][-1][0].soil or | 		nodes[0][1][0].soil or | ||||||
| 			nodes[0][1][0].soil or | 		nodes[0][0][-1].soil or | ||||||
| 			nodes[0][0][-1].soil or | 		nodes[0][0][1].soil) | ||||||
| 			nodes[0][0][1].soil) | 		and not -- no adjacent hypha | ||||||
| 			and not -- no adjacent hypha | 		(nodes[1][-1][0].hypha or | ||||||
| 			(nodes[1][-1][0].hypha or | 		nodes[1][1][0].hypha or | ||||||
| 			nodes[1][1][0].hypha or | 		nodes[1][0][-1].hypha or | ||||||
| 			nodes[1][0][-1].hypha or | 		nodes[1][0][1].hypha) | ||||||
| 			nodes[1][0][1].hypha) | 	then | ||||||
| 		then | 		table.insert(valid_targets, {x=pos.x+1, y=pos.y, z=pos.z}) | ||||||
| 			table.insert(valid_targets, {x=pos.x+1, y=pos.y, z=pos.z}) |  | ||||||
| 		end |  | ||||||
| 	end | 	end | ||||||
| 	if nodes[0][-1][0].buildable then | 	if nodes[0][-1][0].buildable and | ||||||
| 			if  | 		-- test for soil to directly support new growth | ||||||
| 			-- test for soil to directly support new growth | 		(nodes[-1][-1][0].soil or | ||||||
| 			(nodes[-1][-1][0].soil or | 		nodes[1][-1][0].soil or | ||||||
| 			nodes[1][-1][0].soil or | 		nodes[0][-1][-1].soil or | ||||||
| 			nodes[0][-1][-1].soil or | 		nodes[0][-1][1].soil or | ||||||
| 			nodes[0][-1][1].soil or | 		-- test for soil "around the corner" to allow for growth over an edge | ||||||
| 			-- test for soil "around the corner" to allow for growth over an edge | 		nodes[-1][0][0].soil or | ||||||
| 			nodes[-1][0][0].soil or | 		nodes[1][0][0].soil or | ||||||
| 			nodes[1][0][0].soil or | 		nodes[0][0][-1].soil or | ||||||
| 			nodes[0][0][-1].soil or | 		nodes[0][0][1].soil) | ||||||
| 			nodes[0][0][1].soil) | 		and not -- no adjacent hypha | ||||||
| 			and not -- no adjacent hypha | 		(nodes[-1][-1][0].hypha or | ||||||
| 			(nodes[-1][-1][0].hypha or | 		nodes[1][-1][0].hypha or | ||||||
| 			nodes[1][-1][0].hypha or | 		nodes[0][-1][-1].hypha or | ||||||
| 			nodes[0][-1][-1].hypha or | 		nodes[0][-1][1].hypha) | ||||||
| 			nodes[0][-1][1].hypha) | 	then | ||||||
| 		then | 		table.insert(valid_targets, {x=pos.x, y=pos.y-1, z=pos.z}) | ||||||
| 			table.insert(valid_targets, {x=pos.x, y=pos.y-1, z=pos.z}) |  | ||||||
| 		end |  | ||||||
| 	end | 	end | ||||||
| 	if nodes[0][1][0].buildable then | 	if nodes[0][1][0].buildable and | ||||||
| 			if  | 		-- test for soil to directly support new growth | ||||||
| 			-- test for soil to directly support new growth | 		(nodes[-1][1][0].soil or | ||||||
| 			(nodes[-1][1][0].soil or | 		nodes[1][1][0].soil or | ||||||
| 			nodes[1][1][0].soil or | 		nodes[0][1][-1].soil or | ||||||
| 			nodes[0][1][-1].soil or | 		nodes[0][1][1].soil or | ||||||
| 			nodes[0][1][1].soil or | 		-- test for soil "around the corner" to allow for growth over an edge | ||||||
| 			-- test for soil "around the corner" to allow for growth over an edge | 		nodes[-1][0][0].soil or | ||||||
| 			nodes[-1][0][0].soil or | 		nodes[1][0][0].soil or | ||||||
| 			nodes[1][0][0].soil or | 		nodes[0][0][-1].soil or | ||||||
| 			nodes[0][0][-1].soil or | 		nodes[0][0][1].soil) | ||||||
| 			nodes[0][0][1].soil) | 		and not -- no adjacent hypha | ||||||
| 			and not -- no adjacent hypha | 		(nodes[-1][1][0].hypha or | ||||||
| 			(nodes[-1][1][0].hypha or | 		nodes[1][1][0].hypha or | ||||||
| 			nodes[1][1][0].hypha or | 		nodes[0][1][-1].hypha or | ||||||
| 			nodes[0][1][-1].hypha or | 		nodes[0][1][1].hypha) | ||||||
| 			nodes[0][1][1].hypha) | 	then | ||||||
| 		then | 		table.insert(valid_targets, {x=pos.x, y=pos.y+1, z=pos.z}) | ||||||
| 			table.insert(valid_targets, {x=pos.x, y=pos.y+1, z=pos.z}) |  | ||||||
| 		end |  | ||||||
| 	end | 	end | ||||||
| 	if nodes[0][0][-1].buildable then | 	if nodes[0][0][-1].buildable and | ||||||
| 		if  | 		-- test for soil to directly support new growth | ||||||
| 			-- test for soil to directly support new growth | 		(nodes[-1][0][-1].soil or | ||||||
| 			(nodes[-1][0][-1].soil or | 		nodes[1][0][-1].soil or | ||||||
| 			nodes[1][0][-1].soil or | 		nodes[0][-1][-1].soil or | ||||||
| 			nodes[0][-1][-1].soil or | 		nodes[0][1][-1].soil or | ||||||
| 			nodes[0][1][-1].soil or | 		-- test for soil "around the corner" to allow for growth over an edge | ||||||
| 			-- test for soil "around the corner" to allow for growth over an edge | 		nodes[-1][0][0].soil or | ||||||
| 			nodes[-1][0][0].soil or | 		nodes[1][0][0].soil or | ||||||
| 			nodes[1][0][0].soil or | 		nodes[0][-1][0].soil or | ||||||
| 			nodes[0][-1][0].soil or | 		nodes[0][1][0].soil) | ||||||
| 			nodes[0][1][0].soil) | 		and not -- no adjacent hypha | ||||||
| 			and not -- no adjacent hypha | 		(nodes[-1][0][-1].hypha or | ||||||
| 			(nodes[-1][0][-1].hypha or | 		nodes[1][0][-1].hypha or | ||||||
| 			nodes[1][0][-1].hypha or | 		nodes[0][-1][-1].hypha or | ||||||
| 			nodes[0][-1][-1].hypha or | 		nodes[0][1][-1].hypha) | ||||||
| 			nodes[0][1][-1].hypha) | 	then | ||||||
| 		then | 		table.insert(valid_targets, {x=pos.x, y=pos.y, z=pos.z-1}) | ||||||
| 			table.insert(valid_targets, {x=pos.x, y=pos.y, z=pos.z-1}) |  | ||||||
| 		end |  | ||||||
| 	end | 	end | ||||||
| 	if nodes[0][0][1].buildable then | 	if nodes[0][0][1].buildable and | ||||||
| 		if  | 		-- test for soil to directly support new growth | ||||||
| 			-- test for soil to directly support new growth | 		(nodes[-1][0][1].soil or | ||||||
| 			(nodes[-1][0][1].soil or | 		nodes[1][0][1].soil or | ||||||
| 			nodes[1][0][1].soil or | 		nodes[0][-1][1].soil or | ||||||
| 			nodes[0][-1][1].soil or | 		nodes[0][1][1].soil or | ||||||
| 			nodes[0][1][1].soil or | 		-- test for soil "around the corner" to allow for growth over an edge | ||||||
| 			-- test for soil "around the corner" to allow for growth over an edge | 		nodes[-1][0][0].soil or | ||||||
| 			nodes[-1][0][0].soil or | 		nodes[1][0][0].soil or | ||||||
| 			nodes[1][0][0].soil or | 		nodes[0][-1][0].soil or | ||||||
| 			nodes[0][-1][0].soil or | 		nodes[0][1][0].soil) | ||||||
| 			nodes[0][1][0].soil) | 		and not -- no adjacent hypha | ||||||
| 			and not -- no adjacent hypha | 		(nodes[-1][0][1].hypha or | ||||||
| 			(nodes[-1][0][1].hypha or | 		nodes[1][0][1].hypha or | ||||||
| 			nodes[1][0][1].hypha or | 		nodes[0][-1][1].hypha or | ||||||
| 			nodes[0][-1][1].hypha or | 		nodes[0][1][1].hypha) | ||||||
| 			nodes[0][1][1].hypha) | 	then | ||||||
| 		then | 		table.insert(valid_targets, {x=pos.x, y=pos.y, z=pos.z+1}) | ||||||
| 			table.insert(valid_targets, {x=pos.x, y=pos.y, z=pos.z+1}) |  | ||||||
| 		end		 |  | ||||||
| 	end | 	end | ||||||
| 	 | 	 | ||||||
| 	return valid_targets | 	return valid_targets | ||||||
| end | end | ||||||
|  |  | ||||||
|  | local grow_mycelium = function(pos, meristem_name) | ||||||
|  | 	local new_meristems = {} | ||||||
|  | 	-- Can we grow? If so, pick a random direction and add a new meristem there | ||||||
|  | 	local targets = find_mycelium_growth_targets(pos) | ||||||
|  | 	local target_count = #targets | ||||||
|  | 	if target_count > 0 then | ||||||
|  | 		local target = targets[math.random(1,target_count)] | ||||||
|  | 		minetest.set_node(target, {name=meristem_name}) | ||||||
|  | 		table.insert(new_meristems, target) | ||||||
|  | 	else | ||||||
|  | 		--nowhere to grow, turn into a rooted hypha and we're done | ||||||
|  | 		minetest.set_node(pos, {name="df_primordial_items:giant_hypha_root"}) | ||||||
|  | 		return new_meristems | ||||||
|  | 	end | ||||||
|  |  | ||||||
|  | 	if math.random() < 0.05 then | ||||||
|  | 	-- Split - try again from here next time | ||||||
|  | 		table.insert(new_meristems, pos) | ||||||
|  | 	-- Otherwise, just turn into a hypha and we're done | ||||||
|  | 	elseif math.random() < 0.333 then | ||||||
|  | 		minetest.set_node(pos, {name="df_primordial_items:giant_hypha_root"}) | ||||||
|  | 	else | ||||||
|  | 		minetest.set_node(pos, {name="df_primordial_items:giant_hypha"}) | ||||||
|  | 	end | ||||||
|  | 	return new_meristems | ||||||
|  | end | ||||||
|  |  | ||||||
|  | local min_growth_delay = minetest.settings:get_key("dfcaverns_mycelium_min_growth_delay") or 240 | ||||||
|  | local max_growth_delay = minetest.settings:get_key("dfcaverns_mycelium_max_growth_delay") or 400 | ||||||
|  |  | ||||||
| minetest.register_node("df_primordial_items:giant_hypha_apical_meristem", { | minetest.register_node("df_primordial_items:giant_hypha_apical_meristem", { | ||||||
| 	description = S("Giant Hypha Apical Meristem"), | 	description = S("Giant Hypha Apical Meristem"), | ||||||
| 	tiles = { | 	tiles = { | ||||||
| 		{name="dfcaverns_mush_stalk_side.png^[brighten"}, | 		{name="dfcaverns_mush_giant_hypha.png^[brighten"}, | ||||||
| 	}, | 	}, | ||||||
|     connects_to = {"group:hypha"}, |     connects_to = {"group:hypha"}, | ||||||
|     connect_sides = { "top", "bottom", "front", "left", "back", "right" }, |     connect_sides = { "top", "bottom", "front", "left", "back", "right" }, | ||||||
| 	drawtype = "nodebox", | 	drawtype = "nodebox", | ||||||
| 	light_source = 6, | 	light_source = 6, | ||||||
| 	node_box = { | 	node_box = get_node_box(0.25, 0.375), | ||||||
|         type = "connected", |  | ||||||
|         fixed = {-0.25,-0.25,-0.25,0.25,0.25,0.25}, |  | ||||||
|         connect_top = {-0.375, 0, -0.375, 0.375, 0.5, 0.375}, |  | ||||||
|         connect_bottom = {-0.375, -0.5, -0.375, 0.375, 0, 0.375}, |  | ||||||
|         connect_back = {-0.375, -0.375, 0, 0.375, 0.375, 0.5}, |  | ||||||
|         connect_right = {0, -0.375, -0.375, 0.5, 0.375, 0.375}, |  | ||||||
|         connect_front = {-0.375, -0.375, -0.5, 0.375, 0.375, 0}, |  | ||||||
|         connect_left = {-0.5, -0.375, -0.375, 0, 0.375, 0.375}, |  | ||||||
|         disconnected = {-0.375,-0.375,-0.375,0.375,0.375,0.375}, |  | ||||||
|     }, |  | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
|  |  | ||||||
| 	is_ground_content = false, | 	is_ground_content = false, | ||||||
| 	groups = {oddly_breakable_by_hand = 1, choppy = 2, hypha =1}, | 	groups = {oddly_breakable_by_hand = 1, choppy = 2, hypha = 1, light_sensitive_fungus = 13}, | ||||||
| 	sounds = default.node_sound_wood_defaults(), | 	sounds = default.node_sound_wood_defaults(), | ||||||
| 	on_construct = function(pos) | 	on_construct = function(pos) | ||||||
| 		minetest.get_node_timer(pos):start(1.0) | 		minetest.get_node_timer(pos):start(math.random(min_growth_delay,max_growth_delay)) | ||||||
| 	end, | 	end, | ||||||
| 	on_timer = function(pos, elapsed) | 	on_timer = function(pos, elapsed) | ||||||
| 		--if math.random() < 0.99 then | 		local new_meristems = grow_mycelium(pos, "df_primordial_items:giant_hypha_apical_meristem") | ||||||
| 			local targets = grow_mycelium(pos) | 		for _, newpos in ipairs(new_meristems) do | ||||||
| 			local target_count = #targets | 			minetest.get_node_timer(newpos):start(math.random(min_growth_delay,max_growth_delay)) | ||||||
| 			if target_count > 0 then |  | ||||||
| 				minetest.set_node(targets[math.random(1,target_count)], {name="df_primordial_items:giant_hypha_apical_meristem"}) |  | ||||||
| 			end |  | ||||||
| 		--end |  | ||||||
| 		if math.random() < 0.05 then |  | ||||||
| 			minetest.get_node_timer(pos):start(1.0) -- branch |  | ||||||
| 		elseif math.random() < 0.5 then |  | ||||||
| 			minetest.set_node(pos, {name="df_primordial_items:giant_hypha_root"}) |  | ||||||
| 		else |  | ||||||
| 			minetest.set_node(pos, {name="df_primordial_items:giant_hypha"}) |  | ||||||
| 		end | 		end | ||||||
| 	end, | 	end, | ||||||
| }) | }) | ||||||
|  |  | ||||||
|  | -- this version grows instantly via ABM, is meant for mapgen usage | ||||||
|  | minetest.register_node("df_primordial_items:giant_hypha_apical_mapgen", { | ||||||
|  | 	description = S("Giant Hypha Apical Meristem"), | ||||||
|  | 	tiles = { | ||||||
|  | 		{name="dfcaverns_mush_giant_hypha.png^[brighten"}, | ||||||
|  | 	}, | ||||||
|  |     connects_to = {"group:hypha"}, | ||||||
|  |     connect_sides = { "top", "bottom", "front", "left", "back", "right" }, | ||||||
|  | 	drawtype = "nodebox", | ||||||
|  | 	light_source = 6, | ||||||
|  | 	node_box = get_node_box(0.25, 0.375), | ||||||
|  | 	paramtype = "light", | ||||||
|  |  | ||||||
|  | 	is_ground_content = false, | ||||||
|  | 	groups = {oddly_breakable_by_hand = 1, choppy = 2, hypha = 1, light_sensitive_fungus = 13}, | ||||||
|  | 	sounds = default.node_sound_wood_defaults(), | ||||||
|  | }) | ||||||
|  |  | ||||||
|  | df_primordial_items.grow_mycelium_immediately = function(pos) | ||||||
|  | 	local stack = {pos} | ||||||
|  | 	while #stack > 0 do | ||||||
|  | 		local pos = table.remove(stack) | ||||||
|  | 		local new_poses = grow_mycelium(pos, "df_primordial_items:giant_hypha_apical_meristem") | ||||||
|  | 		for _, new_pos in ipairs(new_poses) do | ||||||
|  | 			table.insert(stack, new_pos) | ||||||
|  | 		end | ||||||
|  | 	end	 | ||||||
|  | end | ||||||
|  |  | ||||||
|  | minetest.register_abm({ | ||||||
|  | 	label = "Mycelium mapgen growth", | ||||||
|  | 	nodenames = {"df_primordial_items:giant_hypha_apical_mapgen"}, | ||||||
|  | 	interval = 1.0, | ||||||
|  | 	chance = 1, | ||||||
|  | 	action = function(pos, node, active_object_count, active_object_count_wider) | ||||||
|  | 		df_primordial_items.grow_mycelium_immediately(pos) | ||||||
|  | 	end | ||||||
|  | }) | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								df_primordial_items/settingtypes.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								df_primordial_items/settingtypes.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,2 @@ | |||||||
|  | dfcaverns_mycelium_min_growth_delay (Minimum mycelium growth delay) int 240 | ||||||
|  | dfcaverns_mycelium_max_growth_delay (Maximum mycelium growth delay) int 400 | ||||||
							
								
								
									
										
											BIN
										
									
								
								df_primordial_items/textures/dfcaverns_mush_giant_hypha.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								df_primordial_items/textures/dfcaverns_mush_giant_hypha.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 570 B | 
		Reference in New Issue
	
	Block a user