forked from mtcontrib/homedecor_modpack
		
	Merge remote-tracking branch 'upstream/master' into nalc-1.2-dev
This commit is contained in:
		| @@ -1,4 +1,3 @@ | |||||||
|  |  | ||||||
| local S = homedecor.gettext | local S = homedecor.gettext | ||||||
|  |  | ||||||
| local shapes = { | local shapes = { | ||||||
| @@ -220,10 +219,10 @@ local function step(pos, fields) | |||||||
| 	if fields then | 	if fields then | ||||||
| 		if fields.new then | 		if fields.new then | ||||||
| 			new_game(pos) | 			new_game(pos) | ||||||
| 		else | 		elseif t then | ||||||
| 			key(fields) | 			key(fields) | ||||||
| 		end | 		end | ||||||
| 	else | 	elseif t then | ||||||
| 		run = tick() | 		run = tick() | ||||||
| 	end | 	end | ||||||
|  |  | ||||||
|   | |||||||
| @@ -3,7 +3,80 @@ local S = homedecor.gettext | |||||||
|  |  | ||||||
| screwdriver = screwdriver or {} | screwdriver = screwdriver or {} | ||||||
|  |  | ||||||
| local function start_smoke(pos, node, clicker, chimney) | local function fire_particles_on(pos) -- 3 layers of fire | ||||||
|  | 	local meta = minetest.get_meta(pos) | ||||||
|  | 	local id = minetest.add_particlespawner({ -- 1 layer big particles fire | ||||||
|  | 		amount = 9, | ||||||
|  | 		time = 0, | ||||||
|  | 		minpos = {x = pos.x - 0.2, y = pos.y - 0.4, z = pos.z - 0.2}, | ||||||
|  | 		maxpos = {x = pos.x + 0.2, y = pos.y - 0.1, z = pos.z + 0.2}, | ||||||
|  | 		minvel = {x= 0, y= 0, z= 0}, | ||||||
|  | 		maxvel = {x= 0, y= 0.1, z= 0}, | ||||||
|  | 		minacc = {x= 0, y= 0, z= 0}, | ||||||
|  | 		maxacc = {x= 0, y= 0.7, z= 0}, | ||||||
|  | 		minexptime = 0.5, | ||||||
|  | 		maxexptime = 0.7, | ||||||
|  | 		minsize = 2, | ||||||
|  | 		maxsize = 5, | ||||||
|  | 		collisiondetection = false, | ||||||
|  | 		vertical = true, | ||||||
|  | 		texture = "fake_fire_particle_anim_fire.png", | ||||||
|  | 		animation = {type="vertical_frames", aspect_w=16, aspect_h=16, length = 0.8,}, | ||||||
|  | 	}) | ||||||
|  | 	meta:set_int("layer_1", id) | ||||||
|  |  | ||||||
|  | 	local id = minetest.add_particlespawner({ -- 2 layer smol particles fire | ||||||
|  | 		amount = 1, | ||||||
|  | 		time = 0, | ||||||
|  | 		minpos = {x = pos.x - 0.1, y = pos.y, z = pos.z - 0.1}, | ||||||
|  | 		maxpos = {x = pos.x + 0.1, y = pos.y + 0.4, z = pos.z + 0.1}, | ||||||
|  | 		minvel = {x= 0, y= 0, z= 0}, | ||||||
|  | 		maxvel = {x= 0, y= 0.1, z= 0}, | ||||||
|  | 		minacc = {x= 0, y= 0, z= 0}, | ||||||
|  | 		maxacc = {x= 0, y= 1, z= 0}, | ||||||
|  | 		minexptime = 0.4, | ||||||
|  | 		maxexptime = 0.6, | ||||||
|  | 		minsize = 0.5, | ||||||
|  | 		maxsize = 0.7, | ||||||
|  | 		collisiondetection = false, | ||||||
|  | 		vertical = true, | ||||||
|  | 		texture = "fake_fire_particle_anim_fire.png", | ||||||
|  | 		animation = {type="vertical_frames", aspect_w=16, aspect_h=16, length = 0.7,}, | ||||||
|  | 	}) | ||||||
|  | 	meta:set_int("layer_2", id) | ||||||
|  |  | ||||||
|  | 	local id = minetest.add_particlespawner({ --3 layer smoke | ||||||
|  | 		amount = 1, | ||||||
|  | 		time = 0, | ||||||
|  | 		minpos = {x = pos.x - 0.1, y = pos.y - 0.2, z = pos.z - 0.1}, | ||||||
|  | 		maxpos = {x = pos.x + 0.2, y = pos.y + 0.4, z = pos.z + 0.2}, | ||||||
|  | 		minvel = {x= 0, y= 0, z= 0}, | ||||||
|  | 		maxvel = {x= 0, y= 0.1, z= 0}, | ||||||
|  | 		minacc = {x= 0, y= 0, z= 0}, | ||||||
|  | 		maxacc = {x= 0, y= 1, z= 0}, | ||||||
|  | 		minexptime = 0.6, | ||||||
|  | 		maxexptime = 0.8, | ||||||
|  | 		minsize = 2, | ||||||
|  | 		maxsize = 4, | ||||||
|  | 		collisiondetection = true, | ||||||
|  | 		vertical = true, | ||||||
|  | 		texture = "fake_fire_particle_anim_smoke.png", | ||||||
|  | 		animation = {type="vertical_frames", aspect_w=16, aspect_h=16, length = 0.9,}, | ||||||
|  | 	}) | ||||||
|  | 	meta:set_int("layer_3", id) | ||||||
|  | end | ||||||
|  |  | ||||||
|  | local function fire_particles_off(pos) | ||||||
|  | 	local meta = minetest.get_meta(pos) | ||||||
|  | 	local id_1 = meta:get_int("layer_1"); | ||||||
|  | 	local id_2 = meta:get_int("layer_2"); | ||||||
|  | 	local id_3 = meta:get_int("layer_3"); | ||||||
|  | 	minetest.delete_particlespawner(id_1) | ||||||
|  | 	minetest.delete_particlespawner(id_2) | ||||||
|  | 	minetest.delete_particlespawner(id_3) | ||||||
|  | end | ||||||
|  |  | ||||||
|  | local function start_fire_effects(pos, node, clicker, chimney) | ||||||
| 	local this_spawner_meta = minetest.get_meta(pos) | 	local this_spawner_meta = minetest.get_meta(pos) | ||||||
| 	local id = this_spawner_meta:get_int("smoky") | 	local id = this_spawner_meta:get_int("smoky") | ||||||
| 	local s_handle = this_spawner_meta:get_int("sound") | 	local s_handle = this_spawner_meta:get_int("sound") | ||||||
| @@ -41,7 +114,7 @@ local function start_smoke(pos, node, clicker, chimney) | |||||||
| 				max_hear_distance = 5, | 				max_hear_distance = 5, | ||||||
| 				loop = true | 				loop = true | ||||||
| 			}) | 			}) | ||||||
| 			this_spawner_meta:set_int("smoky", id) | 			fire_particles_on(pos) | ||||||
| 			this_spawner_meta:set_int("sound", s_handle) | 			this_spawner_meta:set_int("sound", s_handle) | ||||||
| 		end | 		end | ||||||
| 	end | 	end | ||||||
| @@ -83,7 +156,7 @@ minetest.register_node("fake_fire:ice_fire", { | |||||||
| 		aspect_w=16, aspect_h=16, length=1.5}}, | 		aspect_w=16, aspect_h=16, length=1.5}}, | ||||||
| 	}, | 	}, | ||||||
| 	on_rightclick = function(pos, node, clicker, itemstack, pointed_thing) | 	on_rightclick = function(pos, node, clicker, itemstack, pointed_thing) | ||||||
| 		start_smoke(pos, node, clicker) | 		start_fire_effects(pos, node, clicker) | ||||||
| 		return itemstack | 		return itemstack | ||||||
| 	end, | 	end, | ||||||
| 	on_destruct = function (pos) | 	on_destruct = function (pos) | ||||||
| @@ -97,6 +170,11 @@ minetest.register_node("fake_fire:ice_fire", { | |||||||
|  |  | ||||||
| minetest.register_alias("fake_fire:fake_fire", "fire:permanent_flame") | minetest.register_alias("fake_fire:fake_fire", "fire:permanent_flame") | ||||||
|  |  | ||||||
|  | local sbox = { | ||||||
|  | 	type = 'fixed', | ||||||
|  | 	fixed = { -8/16, -8/16, -8/16, 8/16, -6/16, 8/16}, | ||||||
|  | } | ||||||
|  |  | ||||||
| minetest.register_node("fake_fire:fancy_fire", { | minetest.register_node("fake_fire:fancy_fire", { | ||||||
| 	inventory_image = "fancy_fire_inv.png", | 	inventory_image = "fancy_fire_inv.png", | ||||||
| 	description = S("Fancy Fire"), | 	description = S("Fancy Fire"), | ||||||
| @@ -104,21 +182,28 @@ minetest.register_node("fake_fire:fancy_fire", { | |||||||
| 	mesh = "fancy_fire.obj", | 	mesh = "fancy_fire.obj", | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	paramtype2 = "facedir", | 	paramtype2 = "facedir", | ||||||
| 		groups = {dig_immediate=3}, | 	groups = {oddly_breakable_by_hand=3, flammable=0}, | ||||||
| 	sunlight_propagates = true, | 	sunlight_propagates = true, | ||||||
| 		light_source = 14, | 	light_source = 13, | ||||||
| 	walkable = false, | 	walkable = false, | ||||||
| 		damage_per_second = 4, | 	buildable_to = false, | ||||||
| 		on_rotate = screwdriver.rotate_simple, | 	damage_per_second = 3, | ||||||
|  | 	selection_box = sbox, | ||||||
| 	tiles = { | 	tiles = { | ||||||
| 		{name="fake_fire_animated.png", | 		"basic_materials_concrete_block.png", | ||||||
| 		animation={type='vertical_frames', aspect_w=16, aspect_h=16, length=1}}, {name='fake_fire_logs.png'}}, | 		"default_junglewood.png", | ||||||
|  | 		"fake_fire_empty_tile.png" | ||||||
|  | 	}, | ||||||
| 	on_rightclick = function(pos, node, clicker, itemstack, pointed_thing) | 	on_rightclick = function(pos, node, clicker, itemstack, pointed_thing) | ||||||
| 			start_smoke(pos, node, clicker) | 		fire_particles_on(pos) | ||||||
| 		return itemstack | 		return itemstack | ||||||
| 	end, | 	end, | ||||||
| 		on_destruct = function (pos) | 	on_construct = function(pos) | ||||||
| 			stop_smoke(pos) | 		local meta = minetest.get_meta(pos) | ||||||
|  | 		fire_particles_on(pos) | ||||||
|  | 	end, | ||||||
|  | 	on_destruct = function(pos, oldnode, oldmetadata, digger) | ||||||
|  | 		fire_particles_off(pos) | ||||||
| 		minetest.sound_play("fire_extinguish", { | 		minetest.sound_play("fire_extinguish", { | ||||||
| 			pos = pos, max_hear_distance = 5 | 			pos = pos, max_hear_distance = 5 | ||||||
| 		}) | 		}) | ||||||
| @@ -132,7 +217,7 @@ minetest.register_node("fake_fire:fancy_fire", { | |||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 	}) | }) | ||||||
|  |  | ||||||
| -- EMBERS | -- EMBERS | ||||||
| minetest.register_node("fake_fire:embers", { | minetest.register_node("fake_fire:embers", { | ||||||
| @@ -168,7 +253,7 @@ for _, mat in ipairs(materials) do | |||||||
| 		}, | 		}, | ||||||
| 		on_rightclick = function(pos, node, clicker, itemstack, pointed_thing) | 		on_rightclick = function(pos, node, clicker, itemstack, pointed_thing) | ||||||
| 			local chimney = 1 | 			local chimney = 1 | ||||||
| 			start_smoke(pos, node, clicker, chimney) | 			start_fire_effects(pos, node, clicker, chimney) | ||||||
| 			return itemstack | 			return itemstack | ||||||
| 		end, | 		end, | ||||||
| 		on_destruct = function (pos) | 		on_destruct = function (pos) | ||||||
| @@ -209,10 +294,24 @@ minetest.register_craft({ | |||||||
| }) | }) | ||||||
|  |  | ||||||
| -- ALIASES | -- ALIASES | ||||||
|  |  | ||||||
| minetest.register_alias("fake_fire:smokeless_fire", "fake_fire:fake_fire") | minetest.register_alias("fake_fire:smokeless_fire", "fake_fire:fake_fire") | ||||||
| minetest.register_alias("fake_fire:smokeless_ice_fire", "fake_fire:ice_fire") | minetest.register_alias("fake_fire:smokeless_ice_fire", "fake_fire:ice_fire") | ||||||
| minetest.register_alias("fake_fire:smokeless_chimney_top_stone", "fake_fire:chimney_top_stone") | minetest.register_alias("fake_fire:smokeless_chimney_top_stone", "fake_fire:chimney_top_stone") | ||||||
| minetest.register_alias("fake_fire:smokeless_chimney_top_sandstone", "fake_fire:chimney_top_sandstone") | minetest.register_alias("fake_fire:smokeless_chimney_top_sandstone", "fake_fire:chimney_top_sandstone") | ||||||
| minetest.register_alias("fake_fire:flint", "fake_fire:flint_and_steel") | minetest.register_alias("fake_fire:flint", "fake_fire:flint_and_steel") | ||||||
|  |  | ||||||
|  | -- OTHER | ||||||
|  |  | ||||||
|  | minetest.register_lbm({ | ||||||
|  | 	name = "fake_fire:reload_particles", | ||||||
|  | 	label = "restart fire particles on reload", | ||||||
|  | 	nodenames = {"fake_fire:fancy_fire"}, | ||||||
|  | 	run_at_every_load = true, | ||||||
|  | 	action = function(pos, node) | ||||||
|  | 		fire_particles_off(pos) | ||||||
|  | 		fire_particles_on(pos) | ||||||
|  | 	end | ||||||
|  | }) | ||||||
|  |  | ||||||
| minetest.log("action", "[fake_fire] loaded.") | minetest.log("action", "[fake_fire] loaded.") | ||||||
|   | |||||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								fake_fire/textures/fake_fire_empty_tile.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								fake_fire/textures/fake_fire_empty_tile.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 68 B | 
										
											Binary file not shown.
										
									
								
							| Before Width: | Height: | Size: 2.0 KiB | 
							
								
								
									
										
											BIN
										
									
								
								fake_fire/textures/fake_fire_particle_anim_fire.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								fake_fire/textures/fake_fire_particle_anim_fire.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 251 B | 
							
								
								
									
										
											BIN
										
									
								
								fake_fire/textures/fake_fire_particle_anim_smoke.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								fake_fire/textures/fake_fire_particle_anim_smoke.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 275 B | 
| Before Width: | Height: | Size: 591 B After Width: | Height: | Size: 591 B | 
							
								
								
									
										0
									
								
								homedecor_common/tools/updatepo.sh
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							
							
						
						
									
										0
									
								
								homedecor_common/tools/updatepo.sh
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							| @@ -2,6 +2,7 @@ homedecor_common | |||||||
| default | default | ||||||
| dye | dye | ||||||
| creative | creative | ||||||
|  | basic_materials | ||||||
| moreblocks? | moreblocks? | ||||||
| building_blocks? | building_blocks? | ||||||
| bucket? | bucket? | ||||||
|   | |||||||
| @@ -349,7 +349,7 @@ minetest.register_craft({ | |||||||
| 	recipe = { | 	recipe = { | ||||||
| 		{ "","homedecor:fence_chainlink","" }, | 		{ "","homedecor:fence_chainlink","" }, | ||||||
| 		{ "default:steel_ingot","fake_fire:embers","default:steel_ingot" }, | 		{ "default:steel_ingot","fake_fire:embers","default:steel_ingot" }, | ||||||
| 		{ "homedecor:pole_wrought_iron","default:steel_ingot","homedecor:pole_wrought_iron" } | 		{ "basic_materials:steel_bar","default:steel_ingot","basic_materials:steel_bar" } | ||||||
| 	}, | 	}, | ||||||
| }) | }) | ||||||
|  |  | ||||||
|   | |||||||
| @@ -920,7 +920,7 @@ minetest.register_craft({ | |||||||
| minetest.register_craft({ | minetest.register_craft({ | ||||||
| 	output = "homedecor:sportbench", | 	output = "homedecor:sportbench", | ||||||
| 	recipe = { | 	recipe = { | ||||||
| 		{ "stairs:slab_steelblock","homedecor:pole_wrought_iron","stairs:slab_steelblock" }, | 		{ "stairs:slab_steelblock","basic_materials:steel_bar","stairs:slab_steelblock" }, | ||||||
| 		{ "default:steel_ingot","wool:black","default:steel_ingot" }, | 		{ "default:steel_ingot","wool:black","default:steel_ingot" }, | ||||||
| 		{ "default:steel_ingot","wool:black","default:steel_ingot" } | 		{ "default:steel_ingot","wool:black","default:steel_ingot" } | ||||||
| 	}, | 	}, | ||||||
|   | |||||||
| @@ -2,3 +2,4 @@ default | |||||||
| wool | wool | ||||||
| homedecor_common | homedecor_common | ||||||
| unifieddyes | unifieddyes | ||||||
|  | basic_materials | ||||||
|   | |||||||
| @@ -212,7 +212,7 @@ minetest.register_craft( { | |||||||
|         recipe = { |         recipe = { | ||||||
| 			{ "group:wood", "group:wood", "group:wood" }, | 			{ "group:wood", "group:wood", "group:wood" }, | ||||||
| 			{ "group:wood", "group:wood", "group:wood" }, | 			{ "group:wood", "group:wood", "group:wood" }, | ||||||
| 			{ "homedecor:pole_wrought_iron", "", "homedecor:pole_wrought_iron" } | 			{ "basic_materials:steel_bar", "", "basic_materials:steel_bar" } | ||||||
|         }, |         }, | ||||||
| }) | }) | ||||||
|  |  | ||||||
| @@ -316,7 +316,7 @@ minetest.register_craft({ | |||||||
| 	recipe = { | 	recipe = { | ||||||
| 		{ "", "", "wool:black" }, | 		{ "", "", "wool:black" }, | ||||||
| 		{ "", "wool:black", "default:steel_ingot" }, | 		{ "", "wool:black", "default:steel_ingot" }, | ||||||
| 		{ "group:stick", "homedecor:pole_wrought_iron", "group:stick" } | 		{ "group:stick", "basic_materials:steel_bar", "group:stick" } | ||||||
| 	}, | 	}, | ||||||
| }) | }) | ||||||
|  |  | ||||||
| @@ -325,7 +325,7 @@ minetest.register_craft({ | |||||||
| 	recipe = { | 	recipe = { | ||||||
| 		{ "dye:black", "building_blocks:sticks", "group:wool" }, | 		{ "dye:black", "building_blocks:sticks", "group:wool" }, | ||||||
| 		{ "basic_materials:plastic_sheet", "group:wool", "default:steel_ingot" }, | 		{ "basic_materials:plastic_sheet", "group:wool", "default:steel_ingot" }, | ||||||
| 		{ "building_blocks:sticks", "homedecor:pole_wrought_iron", "building_blocks:sticks" } | 		{ "building_blocks:sticks", "basic_materials:steel_bar", "building_blocks:sticks" } | ||||||
| 	}, | 	}, | ||||||
| }) | }) | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										1
									
								
								modpack.conf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								modpack.conf
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | min_minetest_version = 5.2.0 | ||||||
		Reference in New Issue
	
	Block a user