diff options
| author | Sokomine <wegwerf@anarres.dyndns.org> | 2015-07-25 23:48:07 +0200 | 
|---|---|---|
| committer | Sokomine <wegwerf@anarres.dyndns.org> | 2015-07-25 23:48:07 +0200 | 
| commit | 42521c5f2b2943a2f656d2fdfdcb3be3c76fb8de (patch) | |
| tree | 5ec3d0c9c3121b54c918761f81cbfe1e7f78a8da /nodes_doorlike.lua | |
| parent | 46c6a4c47e1bbb0ad3cdbceab79a07ebd96d3d4f (diff) | |
added the files in the same state as they where in on random_buildings/cottages
Diffstat (limited to 'nodes_doorlike.lua')
| -rw-r--r-- | nodes_doorlike.lua | 443 | 
1 files changed, 443 insertions, 0 deletions
| diff --git a/nodes_doorlike.lua b/nodes_doorlike.lua new file mode 100644 index 0000000..78f27e4 --- /dev/null +++ b/nodes_doorlike.lua @@ -0,0 +1,443 @@ + +----------------------------------------------------------------------------------------------------------- +-- These nodes are all like doors in a way: +--  * window shutters (they open on right-click and when it turns day; they close at night) +--  * a half-door where the top part can be opened seperately from the bottom part +--  * a gate that drops to the floor when opened +-- +----------------------------------------------------------------------------------------------------------- +-- IMPORTANT NOTICE: If you have a very slow computer, it might be wise to increase the rate at which the +--                   abm that opens/closes the window shutters is called. Anything less than 10 minutes +--                   (600 seconds) ought to be ok. +----------------------------------------------------------------------------------------------------------- +-- Boilerplate to support localized strings if intllib mod is installed. +local S +if intllib then +  S = intllib.Getter() +else +  S = function(s) return s end +end + +----------------------------------------------------------------------------------------------------------- +-- small window shutters for single-node-windows; they open at day and close at night if the abm is working +----------------------------------------------------------------------------------------------------------- + +-- propagate shutting/closing of window shutters to window shutters below/above this one +cottages_window_sutter_operate = function( pos, old_node_state_name, new_node_state_name ) +    +   local offsets   = {-1,1,-2,2,-3,3}; +   local stop_up   = 0; +   local stop_down = 0; + +   for i,v in ipairs(offsets) do + +      local node = minetest.env:get_node_or_nil( {x=pos.x, y=(pos.y+v), z=pos.z } ); +      if( node and node.name and node.name==old_node_state_name  +        and ( (v > 0 and stop_up   == 0 )  +           or (v < 0 and stop_down == 0 ))) then + +         minetest.env:add_node({x=pos.x, y=(pos.y+v), z=pos.z }, {name = new_node_state_name, param2 = node.param2}) + +      -- found a diffrent node - no need to search further up +      elseif( v > 0 and stop_up   == 0 ) then +         stop_up   = 1;  + +      elseif( v < 0 and stop_down == 0 ) then +         stop_down = 1;  +      end +   end +end + +-- window shutters - they cover half a node to each side +minetest.register_node("cottages:window_shutter_open", { +		description = S("opened window shutters"), +		drawtype = "nodebox", +                -- top, bottom, side1, side2, inner, outer +		tiles = {"cottages_minimal_wood.png"}, +		paramtype = "light", +		paramtype2 = "facedir", +		groups = {snappy=2,choppy=2,oddly_breakable_by_hand=2}, +                -- larger than one node but slightly smaller than a half node so that wallmounted torches pose no problem +		node_box = { +			type = "fixed", +			fixed = { +				{-0.90, -0.5,  0.4, -0.45, 0.5,  0.5}, +				{ 0.45, -0.5,  0.4,  0.9, 0.5,  0.5}, +			}, +		}, +		selection_box = { +			type = "fixed", +			fixed = { +				{-0.9, -0.5,  0.4,  0.9, 0.5,  0.5}, +			}, +		}, +                on_rightclick = function(pos, node, puncher) +                    minetest.env:add_node(pos, {name = "cottages:window_shutter_closed", param2 = node.param2}) +                    cottages_window_sutter_operate( pos, "cottages:window_shutter_open", "cottages:window_shutter_closed" ); +                end, +		is_ground_content = false, +}) + +minetest.register_node("cottages:window_shutter_closed", { +		description = S("closed window shutters"), +		drawtype = "nodebox", +                -- top, bottom, side1, side2, inner, outer +		tiles = {"cottages_minimal_wood.png"}, +		paramtype = "light", +		paramtype2 = "facedir", +		groups = {snappy=2,choppy=2,oddly_breakable_by_hand=2,not_in_creative_inventory=1}, +		node_box = { +			type = "fixed", +			fixed = { +				{-0.5,  -0.5,  0.4, -0.05, 0.5,  0.5}, +				{ 0.05, -0.5,  0.4,  0.5,  0.5,  0.5}, +			}, +		}, +		selection_box = { +			type = "fixed", +			fixed = { +				{-0.5, -0.5,  0.4,  0.5, 0.5,  0.5}, +			}, +		}, +                on_rightclick = function(pos, node, puncher) +                    minetest.env:add_node(pos, {name = "cottages:window_shutter_open", param2 = node.param2}) +                    cottages_window_sutter_operate( pos, "cottages:window_shutter_closed", "cottages:window_shutter_open" ); +                end, +		is_ground_content = false, +		drop = "cottages:window_shutter_open", +}) + + +-- open shutters in the morning +minetest.register_abm({ +   nodenames = {"cottages:window_shutter_closed"}, +   interval = 20, -- change this to 600 if your machine is too slow +   chance = 3, -- not all people wake up at the same time! +   action = function(pos) + +        -- at this time, sleeping in a bed is not possible +        if( not(minetest.env:get_timeofday() < 0.2 or minetest.env:get_timeofday() > 0.805)) then +           local old_node = minetest.env:get_node( pos ); +           minetest.env:add_node(pos, {name = "cottages:window_shutter_open", param2 = old_node.param2}) +           cottages_window_sutter_operate( pos, "cottages:window_shutter_closed", "cottages:window_shutter_open" ); +       end +   end +}) + + +-- close them at night +minetest.register_abm({ +   nodenames = {"cottages:window_shutter_open"}, +   interval = 20, -- change this to 600 if your machine is too slow +   chance = 2, +   action = function(pos) + +        -- same time at which sleeping is allowed in beds +        if( minetest.env:get_timeofday() < 0.2 or minetest.env:get_timeofday() > 0.805) then +           local old_node = minetest.env:get_node( pos ); +           minetest.env:add_node(pos, {name = "cottages:window_shutter_closed", param2 = old_node.param2}) +           cottages_window_sutter_operate( pos, "cottages:window_shutter_open", "cottages:window_shutter_closed" ); +        end +   end +}) + + +------------------------------------------------------------------------------------------------------------------------------ +-- a half door; can be combined to a full door where the upper part can be operated seperately; usually found in barns/stables +------------------------------------------------------------------------------------------------------------------------------ +minetest.register_node("cottages:half_door", { +		description = S("half door"), +		drawtype = "nodebox", +                -- top, bottom, side1, side2, inner, outer +		tiles = {"cottages_minimal_wood.png"}, +		paramtype = "light", +		paramtype2 = "facedir", +		groups = {snappy=2,choppy=2,oddly_breakable_by_hand=2}, +		node_box = { +			type = "fixed", +			fixed = { +				{-0.5, -0.5,  0.4,  0.48, 0.5,  0.5}, +			}, +		}, +		selection_box = { +			type = "fixed", +			fixed = { +				{-0.5, -0.5,  0.4,  0.48, 0.5,  0.5}, +			}, +		}, +                on_rightclick = function(pos, node, puncher) +                    local node2 = minetest.env:get_node( {x=pos.x,y=(pos.y+1),z=pos.z}); + +                    local param2 = node.param2; +                    if(     param2%4 == 1) then param2 = param2+1; --2; +                    elseif( param2%4 == 2) then param2 = param2-1; --1; +                    elseif( param2%4 == 3) then param2 = param2-3; --0; +                    elseif( param2%4 == 0) then param2 = param2+3; --3; +                    end; +                    minetest.env:add_node(pos, {name = "cottages:half_door", param2 = param2}) +                    -- if the node above consists of a door of the same type, open it as well +                    -- Note: doors beneath this one are not opened! It is a special feature of these doors that they can be opend partly +                    if( node2 ~= nil and node2.name == node.name and node2.param2==node.param2) then +                       minetest.env:add_node( {x=pos.x,y=(pos.y+1),z=pos.z}, {name = "cottages:half_door", param2 = param2}) +                    end +                end, +		is_ground_content = false, +}) + + + +minetest.register_node("cottages:half_door_inverted", { +		description = S("half door inverted"), +		drawtype = "nodebox", +                -- top, bottom, side1, side2, inner, outer +		tiles = {"cottages_minimal_wood.png"}, +		paramtype = "light", +		paramtype2 = "facedir", +		groups = {snappy=2,choppy=2,oddly_breakable_by_hand=2}, +		node_box = { +			type = "fixed", +			fixed = { +				{-0.5, -0.5, -0.5,  0.48, 0.5, -0.4}, +			}, +		}, +		selection_box = { +			type = "fixed", +			fixed = { +				{-0.5, -0.5, -0.5,  0.48, 0.5, -0.4}, +			}, +		}, +                on_rightclick = function(pos, node, puncher) +                    local node2 = minetest.env:get_node( {x=pos.x,y=(pos.y+1),z=pos.z}); + +                    local param2 = node.param2; +                    if(     param2%4 == 1) then param2 = param2-1; --0; +                    elseif( param2%4 == 0) then param2 = param2+1; --1; +                    elseif( param2%4 == 2) then param2 = param2+1; --3; +                    elseif( param2%4 == 3) then param2 = param2-1; --2; +                    end; +                    minetest.env:add_node(pos, {name = "cottages:half_door_inverted", param2 = param2}) +                    -- open upper parts of this door (if there are any) +                    if( node2 ~= nil and node2.name == node.name and node2.param2==node.param2) then +                       minetest.env:add_node( {x=pos.x,y=(pos.y+1),z=pos.z}, {name = "cottages:half_door_inverted", param2 = param2}) +                    end +                end, +		is_ground_content = false, +}) + + + + +------------------------------------------------------------------------------------------------------------------------------ +-- this gate for fences solves the "where to store the opened gate" problem by dropping it to the floor in optened state +------------------------------------------------------------------------------------------------------------------------------ +minetest.register_node("cottages:gate_closed", { +		description = S("closed fence gate"), +		drawtype = "nodebox", +                -- top, bottom, side1, side2, inner, outer +		tiles = {"default_wood.png"}, +		paramtype = "light", +		paramtype2 = "facedir", +		groups = {snappy=2,choppy=2,oddly_breakable_by_hand=2}, +		node_box = { +			type = "fixed", +			fixed = { +				{ -0.85, -0.25, -0.02,  0.85, -0.05,  0.02}, +				{ -0.85,  0.15, -0.02,  0.85,  0.35,  0.02}, + +				{ -0.80, -0.05, -0.02, -0.60,  0.15,  0.02}, +				{  0.60, -0.05, -0.02,  0.80,  0.15,  0.02}, +				{ -0.15, -0.05, -0.02,  0.15,  0.15,  0.02}, +			}, +		}, +		selection_box = { +			type = "fixed", +			fixed = { +				{ -0.85, -0.25, -0.1,  0.85,  0.35,  0.1}, +			}, +		}, +                on_rightclick = function(pos, node, puncher) +                    minetest.env:add_node(pos, {name = "cottages:gate_open", param2 = node.param2}) +                end, +		is_ground_content = false, +}) + + +minetest.register_node("cottages:gate_open", { +		description = S("opened fence gate"), +		drawtype = "nodebox", +                -- top, bottom, side1, side2, inner, outer +		tiles = {"default_wood.png"}, +		paramtype = "light", +		paramtype2 = "facedir", +		drop = "cottages:gate_closed", +		groups = {snappy=2,choppy=2,oddly_breakable_by_hand=2,not_in_creative_inventory=1}, +		node_box = { +			type = "fixed", +			fixed = { +				{ -0.85, -0.5, -0.25,  0.85, -0.46, -0.05}, +				{ -0.85, -0.5,  0.15,  0.85, -0.46,  0.35}, + +				{ -0.80, -0.5, -0.05, -0.60, -0.46,  0.15}, +				{  0.60, -0.5, -0.05,  0.80, -0.46,  0.15}, +				{ -0.15, -0.5, -0.05,  0.15, -0.46,  0.15}, + +			}, +		}, +		selection_box = { +			type = "fixed", +			fixed = { +				{ -0.85, -0.5, -0.25, 0.85, -0.3, 0.35}, +			}, +		}, +                on_rightclick = function(pos, node, puncher) +                    minetest.env:add_node(pos, {name = "cottages:gate_closed", param2 = node.param2}) +                end, +		is_ground_content = false, +		drop = "cottages:gate_closed", +}) + + + +----------------------------------------------------------------------------------------------------------- +-- a hatch; nodebox definition taken from realtest +----------------------------------------------------------------------------------------------------------- + +-- hatches rotate around their axis +--  old facedir:  0, 1, 2, 3, 4, 5, 6, 7, 8, 9,10,11,12,13,14,15,16,17,18,19,20,21,22,23 +new_facedirs = { 10,19, 4,13, 2,18,22,14,20,16, 0,12,11, 3, 7,21, 9,23, 5, 1, 8,15, 6,17}; + + +cottages.register_hatch = function( nodename, description, texture, receipe_item ) + +	minetest.register_node( nodename, { +		description = S(description), -- not that there are any other... +		drawtype = "nodebox", +                -- top, bottom, side1, side2, inner, outer +		tiles = { texture },  +		paramtype = "light", +		paramtype2 = "facedir", +		groups = {snappy=2,choppy=2,oddly_breakable_by_hand=2}, + +                node_box = { +                        type = "fixed", +                        fixed = { +                                {-0.49, -0.55, -0.49, -0.3, -0.45, 0.45}, +--                                {-0.5, -0.55, 0.3, 0.3, -0.45, 0.5}, +                                {0.3, -0.55, -0.3, 0.49, -0.45, 0.45}, +                                {0.49, -0.55, -0.49, -0.3, -0.45, -0.3}, +                                {-0.075, -0.55, -0.3, 0.075, -0.45, 0.3}, +                                {-0.3, -0.55, -0.075, -0.075, -0.45, 0.075}, +                                {0.075, -0.55, -0.075, 0.3, -0.45, 0.075}, + +                                {-0.3, -0.55, 0.3, 0.3, -0.45, 0.45}, + +				-- hinges +      				{-0.45,-0.530, 0.45, -0.15,-0.470, 0.525},  +      				{ 0.15,-0.530, 0.45,  0.45,-0.470, 0.525},  + +				-- handle +      				{-0.05,-0.60,-0.35, 0.05,-0.40,-0.45},  +                        }, +                }, +                selection_box = { +                        type = "fixed", +                        fixed = {-0.5, -0.55, -0.5, 0.5, -0.45, 0.5}, +                }, +                on_rightclick = function(pos, node, puncher) + +                    minetest.env:add_node(pos, {name = node.name, param2 = new_facedirs[ node.param2+1 ]}) +                end, +		is_ground_content = false, +		on_place = minetest.rotate_node, +	}) + +	minetest.register_craft({ +		output = nodename, +		recipe = { +			{ '',           '',              receipe_item }, +			{ receipe_item, 'default:stick', ''           }, +			{ '',           '',              ''           }, +		} +	}) +end + + +-- further alternate hatch materials: wood, tree, copper_block +cottages.register_hatch( 'cottages:hatch_wood',  'wooden hatch', 'cottages_minimal_wood.png', 'stairs:slab_wood' ); +cottages.register_hatch( 'cottages:hatch_steel', 'metal hatch',  'default_steel_block.png',   'default:steel_ingot' ); + + + + +----------------------------------------------------------------------------------------------------------- +-- and now the crafting receipes: +----------------------------------------------------------------------------------------------------------- + +-- transform opend and closed shutters into each other for convenience +minetest.register_craft({ +	output = "cottages:window_shutter_open", +	recipe = { +		{"cottages:window_shutter_closed" }, +	} +}) + +minetest.register_craft({ +	output = "cottages:window_shutter_closed", +	recipe = { +		{"cottages:window_shutter_open" }, +	} +}) + +minetest.register_craft({ +	output = "cottages:window_shutter_open", +	recipe = { +		{"default:wood", "", "default:wood" }, +	} +}) + +-- transform one half door into another +minetest.register_craft({ +	output = "cottages:half_door", +	recipe = { +		{"cottages:half_door_inverted" }, +	} +}) + +minetest.register_craft({ +	output = "cottages:half_door_inverted", +	recipe = { +		{"cottages:half_door" }, +	} +}) + +minetest.register_craft({ +	output = "cottages:half_door 2", +	recipe = { +		{"", "default:wood", "" }, +		{"", "doors:door_wood", "" }, +	} +}) + + +-- transform open and closed versions into into another for convenience +minetest.register_craft({ +	output = "cottages:gate_closed", +	recipe = { +		{"cottages:gate_open" }, +	} +}) + +minetest.register_craft({ +	output = "cottages:gate_open", +	recipe = { +		{"cottages:gate_closed"}, +	} +}) + +minetest.register_craft({ +	output = "cottages:gate_closed", +	recipe = { +		{"default:stick", "default:stick", "default:wood" }, +	} +}) + | 
