mirror of
https://github.com/sys4-fr/server-nalc.git
synced 2025-10-24 19:05:22 +02:00
Updated homedecor mod
This commit is contained in:
@@ -100,7 +100,7 @@ minetest.register_craft({
|
|||||||
{'group:stick', '', 'group:stick'},
|
{'group:stick', '', 'group:stick'},
|
||||||
{'', 'group:stick', ''},
|
{'', 'group:stick', ''},
|
||||||
{'group:stick', '', 'group:stick'},
|
{'group:stick', '', 'group:stick'},
|
||||||
}
|
} -- MODIFICATION MADE FOR MFF ^
|
||||||
})
|
})
|
||||||
|
|
||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
|
@@ -72,7 +72,7 @@ minetest.register_node("chains:chain_top_brass", {
|
|||||||
minetest.register_node("chains:chandelier", {
|
minetest.register_node("chains:chandelier", {
|
||||||
description = "Chandelier (wrought iron)",
|
description = "Chandelier (wrought iron)",
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
light_source = default.LIGHT_MAX-2,
|
light_source = LIGHT_MAX-2,
|
||||||
walkable = false,
|
walkable = false,
|
||||||
climbable = true,
|
climbable = true,
|
||||||
sunlight_propagates = true,
|
sunlight_propagates = true,
|
||||||
@@ -87,7 +87,7 @@ minetest.register_node("chains:chandelier", {
|
|||||||
minetest.register_node("chains:chandelier_brass", {
|
minetest.register_node("chains:chandelier_brass", {
|
||||||
description = "Chandelier (brass)",
|
description = "Chandelier (brass)",
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
light_source = default.LIGHT_MAX-2,
|
light_source = LIGHT_MAX-2,
|
||||||
walkable = false,
|
walkable = false,
|
||||||
climbable = true,
|
climbable = true,
|
||||||
sunlight_propagates = true,
|
sunlight_propagates = true,
|
||||||
|
@@ -1,37 +1,3 @@
|
|||||||
--[[
|
|
||||||
|
|
||||||
The 'Fake-Fire' mod was originally created by Semmett9.
|
|
||||||
|
|
||||||
URL to the 'Fake-Fire' thread on Minetest.net:
|
|
||||||
http://forum.minetest.net/viewtopic.php?id=6145
|
|
||||||
|
|
||||||
I've customized it a bit. Please see the changelog.txt file for more details.
|
|
||||||
|
|
||||||
~ LazyJ, 2014_03_15
|
|
||||||
|
|
||||||
--]]
|
|
||||||
|
|
||||||
dofile(minetest.get_modpath("fake_fire").."/modfiles/nodes.lua")
|
dofile(minetest.get_modpath("fake_fire").."/modfiles/nodes.lua")
|
||||||
dofile(minetest.get_modpath("fake_fire").."/modfiles/crafts.lua")
|
dofile(minetest.get_modpath("fake_fire").."/modfiles/crafts.lua")
|
||||||
dofile(minetest.get_modpath("fake_fire").."/modfiles/abms.lua")
|
dofile(minetest.get_modpath("fake_fire").."/modfiles/abms.lua")
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
--[[
|
|
||||||
|
|
||||||
The lines below, at the end, are from the original author, Semmett9.
|
|
||||||
|
|
||||||
Thanks for a nice mod, Semmett9. ;)
|
|
||||||
|
|
||||||
~ LazyJ, 2014_03_14
|
|
||||||
|
|
||||||
--]]
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- Thanks-
|
|
||||||
|
|
||||||
-- Many thanks for addi for his help in coding. --
|
|
||||||
|
|
||||||
-- Many thanks for the players on the King Arthur's land server for giving --
|
|
||||||
-- me support, ideas and allowing me to add the mod to the server itself. --
|
|
||||||
|
@@ -1,52 +1,3 @@
|
|||||||
--[[
|
|
||||||
|
|
||||||
I commented out this part because:
|
|
||||||
1. water and lava buckets are disabled on some servers,
|
|
||||||
2. putting out fire with water and especially lava would only make
|
|
||||||
a big mess, and...
|
|
||||||
|
|
||||||
As for 'realism':
|
|
||||||
* C'mon... This is *fake* fire.
|
|
||||||
* Torches have long been impervious to water.
|
|
||||||
* Minetest creates surreal worlds so it's OK if some things aren't
|
|
||||||
perfectly realistic.
|
|
||||||
|
|
||||||
Besides, the fake-fire can be put out by punching it - simple and effective.
|
|
||||||
~ LazyJ, 2014_03_14
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- water and lava puts out fake fire --
|
|
||||||
minetest.register_abm({
|
|
||||||
nodenames = {"fake_fire:fake_fire"},
|
|
||||||
interval = 1,
|
|
||||||
chance = 1,
|
|
||||||
action = function(pos, node)
|
|
||||||
if minetest.env:find_node_near(pos, 1, {"default:water_source",
|
|
||||||
"default:water_flowing","default:lava_source",
|
|
||||||
"default:lava_flowing"}) then
|
|
||||||
minetest.sound_play("fire_extinguish",
|
|
||||||
{gain = 1.0, max_hear_distance = 20,})
|
|
||||||
node.name = "air"
|
|
||||||
minetest.env:set_node(pos, node)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
})
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- ADVISING ABOUT SMOKE PARTICLES SETTINGS
|
|
||||||
|
|
||||||
-- For the best visual result...
|
|
||||||
-- If you increase the particles size,
|
|
||||||
-- you should decrease the particles amount and/or increase the smoke column lenght.
|
|
||||||
-- If you increase the particle time duration and/or particle course,
|
|
||||||
-- you should decrease the particles amount or increase the smoke column lenght.
|
|
||||||
-- Or conversely...
|
|
||||||
-- ~ JP
|
|
||||||
|
|
||||||
--]]
|
|
||||||
|
|
||||||
minetest.register_abm({
|
minetest.register_abm({
|
||||||
nodenames = {
|
nodenames = {
|
||||||
"fake_fire:fake_fire",
|
"fake_fire:fake_fire",
|
||||||
@@ -57,13 +8,11 @@ minetest.register_abm({
|
|||||||
interval = 1,
|
interval = 1,
|
||||||
chance = 2,
|
chance = 2,
|
||||||
action = function(pos, node)
|
action = function(pos, node)
|
||||||
if
|
if minetest.get_node({x=pos.x, y=pos.y+1.0, z=pos.z}).name == "air"
|
||||||
minetest.get_node({x=pos.x, y=pos.y+1.0, z=pos.z}).name == "air" and
|
and minetest.get_node({x=pos.x, y=pos.y+2.0, z=pos.z}).name == "air" then
|
||||||
minetest.get_node({x=pos.x, y=pos.y+2.0, z=pos.z}).name == "air"
|
|
||||||
then
|
|
||||||
local image_number = math.random(4)
|
local image_number = math.random(4)
|
||||||
minetest.add_particlespawner({
|
minetest.add_particlespawner({
|
||||||
amount = 8,
|
amount = 6,
|
||||||
time = 1,
|
time = 1,
|
||||||
minpos = {x=pos.x-0.25, y=pos.y+0.4, z=pos.z-0.25},
|
minpos = {x=pos.x-0.25, y=pos.y+0.4, z=pos.z-0.25},
|
||||||
maxpos = {x=pos.x+0.25, y=pos.y+8, z=pos.z+0.25},
|
maxpos = {x=pos.x+0.25, y=pos.y+8, z=pos.z+0.25},
|
||||||
@@ -81,4 +30,3 @@ minetest.register_abm({
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
})
|
})
|
||||||
|
|
||||||
|
@@ -1,32 +1,3 @@
|
|||||||
--[[
|
|
||||||
|
|
||||||
NEVER-ENDING FLINT and STEEL
|
|
||||||
|
|
||||||
Uncraftable, at the moment, and I'm not sure yet how many wanna-be-firebug
|
|
||||||
griefers are going to litter with fake-fire. Why give them this if it only
|
|
||||||
makes the mess bigger? ~ LazyJ, 2014_03_13
|
|
||||||
|
|
||||||
May add a priv for this later so trusted players can use it.
|
|
||||||
~ LazyJ, 2014_06_19
|
|
||||||
|
|
||||||
minetest.register_craftitem("fake_fire:old_flint_and_steel", {
|
|
||||||
description = "Never ending flint and steel",
|
|
||||||
inventory_image = "flint_and_steel.png",
|
|
||||||
stack_max = 1,
|
|
||||||
liquids_pointable = false,
|
|
||||||
on_use = function(itemstack, user, pointed_thing)
|
|
||||||
n = minetest.env:get_node(pointed_thing)
|
|
||||||
if pointed_thing.type == "node" then
|
|
||||||
minetest.env:add_node(pointed_thing.above,
|
|
||||||
{name="fake_fire:fake_fire"})
|
|
||||||
minetest.sound_play("",
|
|
||||||
{gain = 1.0, max_hear_distance = 20,})
|
|
||||||
end
|
|
||||||
end
|
|
||||||
})
|
|
||||||
--]]
|
|
||||||
|
|
||||||
|
|
||||||
-- RECIPE ITEM - FLINT
|
-- RECIPE ITEM - FLINT
|
||||||
minetest.register_craftitem("fake_fire:flint", {
|
minetest.register_craftitem("fake_fire:flint", {
|
||||||
description = "flint",
|
description = "flint",
|
||||||
@@ -35,8 +6,6 @@ minetest.register_craftitem("fake_fire:flint", {
|
|||||||
liquids_pointable = false,
|
liquids_pointable = false,
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- FLINT
|
-- FLINT
|
||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
type = "shapeless",
|
type = "shapeless",
|
||||||
@@ -47,8 +16,6 @@ minetest.register_craft({
|
|||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- FLINT & STEEL
|
-- FLINT & STEEL
|
||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
type = "shapeless",
|
type = "shapeless",
|
||||||
@@ -59,8 +26,6 @@ minetest.register_craft({
|
|||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- EMBERS
|
-- EMBERS
|
||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
type = "shapeless",
|
type = "shapeless",
|
||||||
@@ -71,14 +36,6 @@ minetest.register_craft({
|
|||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- CHIMNEY TOPS - SMOKELESS
|
|
||||||
|
|
||||||
-- Only the smokeless kind will be craftable and shown in the inventory.
|
|
||||||
-- The nodes are coded to switch to the smoking chimney tops when punched.
|
|
||||||
-- ~ LazyJ
|
|
||||||
|
|
||||||
-- STONE CHIMNEY TOP
|
-- STONE CHIMNEY TOP
|
||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
type = "shapeless",
|
type = "shapeless",
|
||||||
@@ -89,8 +46,6 @@ minetest.register_craft({
|
|||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- SANDSTONE CHIMNEY TOP
|
-- SANDSTONE CHIMNEY TOP
|
||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
type = "shapeless",
|
type = "shapeless",
|
||||||
@@ -101,35 +56,6 @@ minetest.register_craft({
|
|||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- Crafting Chain - Cobble-to-Gravel-to-Sand and Convert Sands
|
|
||||||
|
|
||||||
--[[
|
|
||||||
|
|
||||||
Craft one cobble into one gravel.
|
|
||||||
Craft one gravel into one sand.
|
|
||||||
Convert-craft sand to desert sand and vice-versa.
|
|
||||||
|
|
||||||
This was suggested by klappspaten and it makes sense in both its natural
|
|
||||||
progression and as a practical way for players to get some of the non-
|
|
||||||
renewable resources that they need.
|
|
||||||
|
|
||||||
Because the gravel-to-sand recipe (from one of our other custom mods)
|
|
||||||
conflicted with the Fake Fire mod's flint recipe, the Fake Fire mod's
|
|
||||||
recipe was changed to require 2 gravel.
|
|
||||||
|
|
||||||
I've added the cobble-gravel-sand and convert sands recipes as a bonus and
|
|
||||||
to make-up for the more expensive flint recipe. You can comment-out these
|
|
||||||
recipes because they aren't *required* by this fork of Fake Fire, but they
|
|
||||||
*are* handy recipes to have.
|
|
||||||
|
|
||||||
~ LazyJ
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
--]]
|
|
||||||
|
|
||||||
-- Cobble to Gravel
|
-- Cobble to Gravel
|
||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
output = 'default:gravel',
|
output = 'default:gravel',
|
||||||
@@ -138,8 +64,6 @@ minetest.register_craft({
|
|||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- Gravel to Sand
|
-- Gravel to Sand
|
||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
output = 'default:sand',
|
output = 'default:sand',
|
||||||
@@ -148,8 +72,6 @@ minetest.register_craft({
|
|||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- Desert Sand to Sand
|
-- Desert Sand to Sand
|
||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
output = 'default:sand',
|
output = 'default:sand',
|
||||||
@@ -158,8 +80,6 @@ minetest.register_craft({
|
|||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- Sand to Desert Sand
|
-- Sand to Desert Sand
|
||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
output = 'default:desert_sand',
|
output = 'default:desert_sand',
|
||||||
|
@@ -4,54 +4,41 @@ local function register_fake_fire(name, def)
|
|||||||
assert(name, "local registration called without name")
|
assert(name, "local registration called without name")
|
||||||
assert(def, "local registration called without node definition")
|
assert(def, "local registration called without node definition")
|
||||||
|
|
||||||
-- make sure shared definitions are set
|
|
||||||
def.is_ground_content = true
|
def.is_ground_content = true
|
||||||
def.inventory_image = def.inventory_image or name..".png"
|
def.inventory_image = def.inventory_image or name..".png"
|
||||||
def.drawtype = "plantlike"
|
def.drawtype = "plantlike"
|
||||||
def.waving = 1 -- Waving wasn't an option when this mod was written. ~ LazyJ, 2014_03_13
|
def.waving = 1
|
||||||
def.light_source = def.lightsource or 14
|
def.light_source = def.lightsource or 14
|
||||||
-- Adding sunlight_propagtes and leaving comments as a future reference.
|
|
||||||
-- If true, sunlight will go infinitely through this (no shadow is cast).
|
|
||||||
-- Because fire produces light it should be "true" so fire *doesn't* have
|
|
||||||
-- a shadow.
|
|
||||||
def.sunlight_propagates = true
|
def.sunlight_propagates = true
|
||||||
-- damage_per_second = 2*0.5, -- It's *fake* fire. PvP on our server has
|
|
||||||
-- been disabled for a reason. I don't want griefers lighting players on
|
|
||||||
-- fire or trapping them in blazes. ~ LazyJ, 2014_0_13
|
|
||||||
|
|
||||||
def.groups = def.groups or {
|
def.groups = def.groups or {
|
||||||
oddly_breakable_by_hand=3, dig_immediate=2,
|
oddly_breakable_by_hand=3, dig_immediate=2,
|
||||||
attached_node=1, not_in_creative_inventory=1
|
attached_node=1, not_in_creative_inventory=1
|
||||||
}
|
}
|
||||||
def.paramtype = "light"
|
def.paramtype = "light"
|
||||||
def.walkable = false
|
def.walkable = false
|
||||||
def.drop = "" -- So fire won't return to the inventory. ~ LazyJ
|
def.drop = ""
|
||||||
def.sounds = def.sounds or minetest.sound_play("fire_small", {pos=cp, loop=true})
|
def.sounds = def.sounds or minetest.sound_play("fire_small", {pos=cp, loop=true})
|
||||||
def.buildable_to = true
|
def.buildable_to = true
|
||||||
|
|
||||||
local swap_on_punch = def.swap_on_punch
|
local swap_on_punch = def.swap_on_punch
|
||||||
def.on_punch = def.on_punch or function (pos, node, puncher)
|
def.on_punch = def.on_punch or function (pos, node, puncher)
|
||||||
-- A max_hear_distance of 20 may freak some players out by the "hiss"
|
|
||||||
-- so I reduced it to 5.
|
|
||||||
minetest.sound_play("fire_extinguish", {pos = pos, gain = 1.0, max_hear_distance = 5,})
|
minetest.sound_play("fire_extinguish", {pos = pos, gain = 1.0, max_hear_distance = 5,})
|
||||||
-- swap the node on_punch if def.swap_on_punch is set
|
|
||||||
if swap_on_punch then
|
if swap_on_punch then
|
||||||
minetest.set_node(pos, {name = swap_on_punch})
|
minetest.set_node(pos, {name = swap_on_punch})
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
-- no need to add these to the global registration table
|
|
||||||
def.swap_on_punch = nil
|
def.swap_on_punch = nil
|
||||||
def.smoking = nil
|
def.smoking = nil
|
||||||
minetest.register_node("fake_fire:"..name, def)
|
minetest.register_node("fake_fire:"..name, def)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
-- FLAME TYPES
|
-- FLAME TYPES
|
||||||
register_fake_fire("fake_fire", {
|
register_fake_fire("fake_fire", {
|
||||||
description = "Smokey, Fake Fire",
|
description = "Smokey, Fake Fire",
|
||||||
tiles = {
|
tiles = {
|
||||||
{name="fake_fire_animated.png", animation={type="vertical_frames",
|
{name="fake_fire_animated.png", animation={type="vertical_frames", aspect_w=16, aspect_h=16, length=1.5}},
|
||||||
aspect_w=16, aspect_h=16, length=1.5}},
|
|
||||||
},
|
},
|
||||||
swap_on_punch = "fake_fire:smokeless_fire",
|
swap_on_punch = "fake_fire:smokeless_fire",
|
||||||
})
|
})
|
||||||
@@ -59,8 +46,7 @@ register_fake_fire("fake_fire", {
|
|||||||
register_fake_fire("smokeless_fire", {
|
register_fake_fire("smokeless_fire", {
|
||||||
description = "Smokeless, Fake Fire",
|
description = "Smokeless, Fake Fire",
|
||||||
tiles = {
|
tiles = {
|
||||||
{name="fake_fire_animated.png", animation={type="vertical_frames",
|
{name="fake_fire_animated.png", animation={type="vertical_frames", aspect_w=16, aspect_h=16, length=1.5}},
|
||||||
aspect_w=16, aspect_h=16, length=1.5}},
|
|
||||||
},
|
},
|
||||||
inventory_image = 'fake_fire.png',
|
inventory_image = 'fake_fire.png',
|
||||||
swap_on_punch = "fake_fire:fake_fire",
|
swap_on_punch = "fake_fire:fake_fire",
|
||||||
@@ -69,8 +55,7 @@ register_fake_fire("smokeless_fire", {
|
|||||||
register_fake_fire("ice_fire", {
|
register_fake_fire("ice_fire", {
|
||||||
description = "Smoky, Fake, Ice Fire",
|
description = "Smoky, Fake, Ice Fire",
|
||||||
tiles = {
|
tiles = {
|
||||||
{name="ice_fire_animated.png", animation={type="vertical_frames",
|
{name="ice_fire_animated.png", animation={type="vertical_frames", aspect_w=16, aspect_h=16, length=1.5}},
|
||||||
aspect_w=16, aspect_h=16, length=1.5}},
|
|
||||||
},
|
},
|
||||||
swap_on_punch = "fake_fire:smokeless_ice_fire",
|
swap_on_punch = "fake_fire:smokeless_ice_fire",
|
||||||
})
|
})
|
||||||
@@ -78,13 +63,13 @@ register_fake_fire("ice_fire", {
|
|||||||
register_fake_fire("smokeless_ice_fire", {
|
register_fake_fire("smokeless_ice_fire", {
|
||||||
description = "Smokeless, Fake, Ice Fire",
|
description = "Smokeless, Fake, Ice Fire",
|
||||||
tiles = {
|
tiles = {
|
||||||
{name="ice_fire_animated.png", animation={type="vertical_frames",
|
{name="ice_fire_animated.png", animation={type="vertical_frames", aspect_w=16, aspect_h=16, length=1.5}},
|
||||||
aspect_w=16, aspect_h=16, length=1.5}},
|
|
||||||
},
|
},
|
||||||
inventory_image = 'ice_fire.png',
|
inventory_image = 'ice_fire.png',
|
||||||
swap_on_punch = "fake_fire:ice_fire",
|
swap_on_punch = "fake_fire:ice_fire",
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
-- FLINT and STEEL
|
-- FLINT and STEEL
|
||||||
minetest.register_tool("fake_fire:flint_and_steel", {
|
minetest.register_tool("fake_fire:flint_and_steel", {
|
||||||
description = "Flint and steel",
|
description = "Flint and steel",
|
||||||
@@ -98,138 +83,40 @@ minetest.register_tool("fake_fire:flint_and_steel", {
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
on_use = function(itemstack, user, pointed_thing)
|
on_use = function(itemstack, user, pointed_thing)
|
||||||
-- This next section took me a lot of keyboard bashing to figure out.
|
|
||||||
-- The lua documentation and examples for Minetest are terrible.
|
|
||||||
-- ~ LazyJ, 2014_06_23
|
|
||||||
|
|
||||||
local snow_ice_list = {"snow", "ice",}
|
local snow_ice_list = {"snow", "ice",}
|
||||||
|
|
||||||
for _, which_one_is_it in pairs(snow_ice_list) do
|
for _, which_one_is_it in pairs(snow_ice_list) do
|
||||||
local snow_ice = which_one_is_it
|
local snow_ice = which_one_is_it
|
||||||
|
|
||||||
if
|
if pointed_thing.type == "node"
|
||||||
-- A *node*, not a player or sprite. ~ LazyJ
|
and not string.find(minetest.get_node(pointed_thing.under).name, "snow")
|
||||||
pointed_thing.type == "node"
|
and not string.find(minetest.get_node(pointed_thing.under).name, "ice")
|
||||||
|
and minetest.get_node(pointed_thing.above).name == "air"
|
||||||
--[[
|
|
||||||
These next two "and nots" tell Minetest not to put the
|
|
||||||
red flame on snow and ice stuff. This "string" bit was
|
|
||||||
the workable solution that took many hours, over
|
|
||||||
several days, to finally come around to. It's a search
|
|
||||||
for any node name that contains whatever is between the
|
|
||||||
double-quotes, ie. "snow" or "ice". I had been trying
|
|
||||||
to identify the nodes by their group properties and I
|
|
||||||
couldn't figure out how to do it. The clue for the
|
|
||||||
"string"came from Blockmen's "Landscape" mod.
|
|
||||||
|
|
||||||
Another quirk is that the "string" doesn't work well
|
|
||||||
with variable lists (see "snow_ice_list") when using
|
|
||||||
"and not". Ice-fire would light on snow but when I
|
|
||||||
clicked on ice, the regular flame appeared. I couldn't
|
|
||||||
understand what was happening until I mentally changed
|
|
||||||
the wording "and not" to "is not" and spoke out-loud
|
|
||||||
each thing that line of code was to accomplish:
|
|
||||||
|
|
||||||
"Is not snow, then make fake-fire."
|
|
||||||
"Is not ice, then make fake-fire."
|
|
||||||
|
|
||||||
That's when I caught the problem.
|
|
||||||
|
|
||||||
Ice *is not* snow, so Minetest was correctly following
|
|
||||||
the instruction, "Is not snow, then make fake-fire."
|
|
||||||
and that is why fake-fire appeared instead of ice-fire
|
|
||||||
when I clicked on ice.
|
|
||||||
|
|
||||||
~ LazyJ
|
|
||||||
--]]
|
|
||||||
|
|
||||||
and not
|
|
||||||
string.find(minetest.get_node(pointed_thing.under).name, "snow")
|
|
||||||
and not
|
|
||||||
string.find(minetest.get_node(pointed_thing.under).name, "ice")
|
|
||||||
and
|
|
||||||
minetest.get_node(pointed_thing.above).name == "air"
|
|
||||||
then
|
then
|
||||||
if not minetest.is_protected(pointed_thing.above, user:get_player_name()) then
|
if not minetest.is_protected(pointed_thing.above, user:get_player_name()) then
|
||||||
minetest.set_node(pointed_thing.above, {name="fake_fire:smokeless_fire"})
|
minetest.set_node(pointed_thing.above, {name="fake_fire:smokeless_fire"})
|
||||||
else
|
else
|
||||||
minetest.chat_send_player(user:get_player_name(), "You can't set a fire in someone else's area!")
|
minetest.chat_send_player(user:get_player_name(), "You can't set a fire in someone else's area!")
|
||||||
end
|
end
|
||||||
elseif
|
elseif pointed_thing.type == "node"
|
||||||
|
and string.find(minetest.get_node(pointed_thing.under).name,snow_ice)
|
||||||
pointed_thing.type == "node"
|
and minetest.get_node(pointed_thing.above).name == "air" then
|
||||||
and
|
|
||||||
-- Split this "string" across several lines because I ran out
|
|
||||||
-- of room while trying to adhere to the 80-column wide rule
|
|
||||||
-- of coding style.
|
|
||||||
string.find(
|
|
||||||
minetest.get_node(pointed_thing.under).name,
|
|
||||||
snow_ice
|
|
||||||
)
|
|
||||||
and
|
|
||||||
minetest.get_node(pointed_thing.above).name == "air"
|
|
||||||
then
|
|
||||||
if not minetest.is_protected(pointed_thing.above, user:get_player_name()) then
|
if not minetest.is_protected(pointed_thing.above, user:get_player_name()) then
|
||||||
minetest.set_node(pointed_thing.above, {name="fake_fire:smokeless_ice_fire"})
|
minetest.set_node(pointed_thing.above, {name="fake_fire:smokeless_ice_fire"})
|
||||||
else
|
else
|
||||||
minetest.chat_send_player(user:get_player_name(), "You can't set a fire in someone else's area!")
|
minetest.chat_send_player(user:get_player_name(), "You can't set a fire in someone else's area!")
|
||||||
end
|
end
|
||||||
end -- Line 210, if
|
end
|
||||||
end -- Line 207, for/do
|
end
|
||||||
|
|
||||||
minetest.sound_play("",
|
minetest.sound_play("", {gain = 1.0, max_hear_distance = 2,})
|
||||||
{gain = 1.0, max_hear_distance = 2,})
|
|
||||||
itemstack:add_wear(65535/65)
|
itemstack:add_wear(65535/65)
|
||||||
return itemstack
|
return itemstack
|
||||||
end
|
end
|
||||||
}) -- Closes the flint and steel tool registration
|
})
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
--[[
|
|
||||||
|
|
||||||
SOME LESSONS LEARNED (and keeping this because I'll forget)
|
|
||||||
|
|
||||||
flint_and_steel is registered as a tool. Tools do not materialize something
|
|
||||||
like placing a block (on_construct) makes that block appear. Tools are
|
|
||||||
*used* so "on_use" works but not "on_construct".
|
|
||||||
|
|
||||||
on_rightclick is meant for the code of the thing being clicked on, not the
|
|
||||||
code of the thing doing the clicking.
|
|
||||||
|
|
||||||
~ LazyJ
|
|
||||||
|
|
||||||
--]]
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- ANIMATED, RISING, DISPAPPEARING SMOKE
|
|
||||||
|
|
||||||
--[[
|
|
||||||
|
|
||||||
These next two sections of code are a real bonus that I figured out how
|
|
||||||
to pull-off. ;)
|
|
||||||
|
|
||||||
The first section creates animated smoke. Trying to figure out how to make
|
|
||||||
the animation appear to go upward was a headache.
|
|
||||||
|
|
||||||
The second section places the animated smoke *only* above the fake-fire
|
|
||||||
*if* there is nothing but air straight above the fake-fire. I also made
|
|
||||||
the smoke skip a space so it looks more like puffs of smoke and made it
|
|
||||||
stretch high enough to be used in chimneys. For large builds, a second
|
|
||||||
fake-fire will have to be hidden close to the top of the chimney so the
|
|
||||||
smoke will be visible. The smoke also emmits a low-level light.
|
|
||||||
|
|
||||||
Yup, I'm proud of this little addition I've made to Semmett9's mod. :D
|
|
||||||
|
|
||||||
~ LazyJ, 2014_03_15
|
|
||||||
|
|
||||||
--]]
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- EMBERS
|
-- EMBERS
|
||||||
|
|
||||||
minetest.register_node("fake_fire:embers", {
|
minetest.register_node("fake_fire:embers", {
|
||||||
description = "Glowing Embers",
|
description = "Glowing Embers",
|
||||||
tiles = {
|
tiles = {
|
||||||
@@ -239,30 +126,15 @@ minetest.register_node("fake_fire:embers", {
|
|||||||
inventory_image = minetest.inventorycube('fake_fire_embers.png'),
|
inventory_image = minetest.inventorycube('fake_fire_embers.png'),
|
||||||
is_ground_content = true,
|
is_ground_content = true,
|
||||||
light_source = 9,
|
light_source = 9,
|
||||||
-- Adding sunlight_propagtes and leaving comments as a future reference.
|
|
||||||
-- If true, sunlight will go infinitely through this (no shadow is cast).
|
|
||||||
-- Because embers produce some light it should be somewhat "true" but this
|
|
||||||
-- is an area where Minetest lacks in subtlety so I'm opting for 100% that
|
|
||||||
-- embers *don't* have a shadow.
|
|
||||||
sunlight_propagates = true,
|
sunlight_propagates = true,
|
||||||
-- It's almost soft, brittle charcoal. ~ LazyJ
|
|
||||||
groups = {choppy=3, crumbly=3, oddly_breakable_by_hand=3},
|
groups = {choppy=3, crumbly=3, oddly_breakable_by_hand=3},
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
-- You never know when a creative builder may use the screwdriver or
|
|
||||||
-- position to create a subtle effect that makes their creation just
|
|
||||||
-- that little bit nicer looking. ~ Lazyj
|
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
walkable = true,
|
walkable = true,
|
||||||
sounds = minetest.sound_play("fire_small", {pos=cp, loop=true}),
|
sounds = minetest.sound_play("fire_small", {pos=cp, loop=true}),
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- CHIMNEY TOPS
|
|
||||||
|
|
||||||
-- Stone (cool tone) to go with cool colors.
|
|
||||||
-- Sandstone (warm tone) to go with warm colors.
|
|
||||||
|
|
||||||
-- CHIMNEY TOP - STONE
|
-- CHIMNEY TOP - STONE
|
||||||
minetest.register_node("fake_fire:chimney_top_stone", {
|
minetest.register_node("fake_fire:chimney_top_stone", {
|
||||||
description = "Chimney Top - Stone",
|
description = "Chimney Top - Stone",
|
||||||
@@ -278,14 +150,11 @@ minetest.register_node("fake_fire:chimney_top_stone", {
|
|||||||
fixed = {-0.5, -0.5, -0.5, 0.5, 0, 0.5},
|
fixed = {-0.5, -0.5, -0.5, 0.5, 0, 0.5},
|
||||||
},
|
},
|
||||||
on_punch = function (pos,node,puncher)
|
on_punch = function (pos,node,puncher)
|
||||||
-- This swaps the smokeless version with the smoky version when punched.
|
|
||||||
-- ~ LazyJ
|
|
||||||
minetest.set_node(pos, {name = "fake_fire:smokeless_chimney_top_stone"})
|
minetest.set_node(pos, {name = "fake_fire:smokeless_chimney_top_stone"})
|
||||||
end
|
end
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- CHIMNEY TOP - SANDSTONE
|
-- CHIMNEY TOP - SANDSTONE
|
||||||
minetest.register_node("fake_fire:chimney_top_sandstone", {
|
minetest.register_node("fake_fire:chimney_top_sandstone", {
|
||||||
description = "Chimney Top - Sandstone",
|
description = "Chimney Top - Sandstone",
|
||||||
@@ -301,22 +170,11 @@ minetest.register_node("fake_fire:chimney_top_sandstone", {
|
|||||||
fixed = {-0.5, -0.5, -0.5, 0.5, 0, 0.5},
|
fixed = {-0.5, -0.5, -0.5, 0.5, 0, 0.5},
|
||||||
},
|
},
|
||||||
on_punch = function (pos,node,puncher)
|
on_punch = function (pos,node,puncher)
|
||||||
-- This swaps the smokeless version with the smoky version when punched.
|
minetest.set_node(pos, {name = "fake_fire:smokeless_chimney_top_sandstone"})
|
||||||
-- ~ LazyJ
|
|
||||||
minetest.set_node(pos,
|
|
||||||
{name = "fake_fire:smokeless_chimney_top_sandstone"})
|
|
||||||
end
|
end
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- SMOKELESS CHIMNEY TOPS
|
|
||||||
|
|
||||||
-- Some players may want a chimney top *without* smoke. This is the node
|
|
||||||
-- that will be craftable. To get the smoking variety, simply punch the
|
|
||||||
-- node. Same approach is used with the smoking and non-smoking flames.
|
|
||||||
-- ~ LazyJ
|
|
||||||
|
|
||||||
-- SMOKELESS CHIMNEY TOP - STONE
|
-- SMOKELESS CHIMNEY TOP - STONE
|
||||||
minetest.register_node("fake_fire:smokeless_chimney_top_stone", {
|
minetest.register_node("fake_fire:smokeless_chimney_top_stone", {
|
||||||
description = "Chimney Top - Stone",
|
description = "Chimney Top - Stone",
|
||||||
@@ -331,14 +189,11 @@ minetest.register_node("fake_fire:smokeless_chimney_top_stone", {
|
|||||||
fixed = {-0.5, -0.5, -0.5, 0.5, 0, 0.5},
|
fixed = {-0.5, -0.5, -0.5, 0.5, 0, 0.5},
|
||||||
},
|
},
|
||||||
on_punch = function (pos,node,puncher)
|
on_punch = function (pos,node,puncher)
|
||||||
-- This swaps the smokeless version with the smoky version when punched.
|
|
||||||
-- ~ LazyJ
|
|
||||||
minetest.set_node(pos, {name = "fake_fire:chimney_top_stone"})
|
minetest.set_node(pos, {name = "fake_fire:chimney_top_stone"})
|
||||||
end
|
end
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- SMOKELESS CHIMNEY TOP - SANDSTONE
|
-- SMOKELESS CHIMNEY TOP - SANDSTONE
|
||||||
minetest.register_node("fake_fire:smokeless_chimney_top_sandstone", {
|
minetest.register_node("fake_fire:smokeless_chimney_top_sandstone", {
|
||||||
description = "Chimney Top - Sandstone",
|
description = "Chimney Top - Sandstone",
|
||||||
@@ -353,8 +208,6 @@ minetest.register_node("fake_fire:smokeless_chimney_top_sandstone", {
|
|||||||
fixed = {-0.5, -0.5, -0.5, 0.5, 0, 0.5},
|
fixed = {-0.5, -0.5, -0.5, 0.5, 0, 0.5},
|
||||||
},
|
},
|
||||||
on_punch = function (pos,node,puncher)
|
on_punch = function (pos,node,puncher)
|
||||||
-- This swaps the smokeless version with the smoky version when punched.
|
|
||||||
-- ~ LazyJ
|
|
||||||
minetest.set_node(pos, {name = "fake_fire:chimney_top_sandstone"})
|
minetest.set_node(pos, {name = "fake_fire:chimney_top_sandstone"})
|
||||||
end
|
end
|
||||||
})
|
})
|
||||||
|
@@ -122,7 +122,7 @@ homedecor.register("ceiling_fan", {
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
groups = { snappy = 3 },
|
groups = { snappy = 3 },
|
||||||
light_source = default.LIGHT_MAX-1,
|
light_source = LIGHT_MAX-1,
|
||||||
sounds = default.node_sound_wood_defaults(),
|
sounds = default.node_sound_wood_defaults(),
|
||||||
})
|
})
|
||||||
|
|
||||||
|
@@ -2544,7 +2544,7 @@ minetest.register_craft( {
|
|||||||
{ "", "farming:string", "" },
|
{ "", "farming:string", "" },
|
||||||
{ "farming:string", "farming:string", "farming:string" }, -- craft changé pour éviter conflit avec le "Spider Cobweb" du mod "mobs"
|
{ "farming:string", "farming:string", "farming:string" }, -- craft changé pour éviter conflit avec le "Spider Cobweb" du mod "mobs"
|
||||||
{ "", "farming:string", "" }
|
{ "", "farming:string", "" }
|
||||||
},
|
}, -- MODIFICATION MADE FOR MFF ^
|
||||||
})
|
})
|
||||||
|
|
||||||
minetest.register_craft( {
|
minetest.register_craft( {
|
||||||
|
@@ -417,7 +417,7 @@ function homedecor.flip_door(pos, node, player, name, side, isClosed)
|
|||||||
gain = 2,
|
gain = 2,
|
||||||
})
|
})
|
||||||
-- XXX: does the top half have to remember open/closed too?
|
-- XXX: does the top half have to remember open/closed too?
|
||||||
minetest.add_node({x=pos.x, y=pos.y+1, z=pos.z}, { name = "homedecor:door_"..name.."_top_"..rside, param2=nfdir})
|
minetest.set_node({x=pos.x, y=pos.y+1, z=pos.z}, { name = "homedecor:door_"..name.."_top_"..rside, param2=nfdir})
|
||||||
|
|
||||||
addDoorNode(pos,{ name = "homedecor:door_"..name.."_bottom_"..rside, param2=nfdir },isClosed)
|
addDoorNode(pos,{ name = "homedecor:door_"..name.."_bottom_"..rside, param2=nfdir },isClosed)
|
||||||
end
|
end
|
||||||
|
@@ -80,7 +80,7 @@ homedecor.register("television", {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
light_source = default.LIGHT_MAX - 1,
|
light_source = LIGHT_MAX - 1,
|
||||||
groups = { snappy = 3 },
|
groups = { snappy = 3 },
|
||||||
sounds = default.node_sound_wood_defaults(),
|
sounds = default.node_sound_wood_defaults(),
|
||||||
})
|
})
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
local S = homedecor.gettext
|
local S = homedecor.gettext
|
||||||
|
|
||||||
local function sit(pos, node, clicker)
|
function homedecor.sit(pos, node, clicker)
|
||||||
local name = clicker:get_player_name()
|
local name = clicker:get_player_name()
|
||||||
local meta = minetest:get_meta(pos)
|
local meta = minetest:get_meta(pos)
|
||||||
local param2 = node.param2
|
local param2 = node.param2
|
||||||
@@ -35,10 +35,10 @@ function homedecor.sit_exec(pos, node, clicker) -- don't move these functions in
|
|||||||
or clicker:get_player_control().left == true or clicker:get_player_control().right == true
|
or clicker:get_player_control().left == true or clicker:get_player_control().right == true
|
||||||
or clicker:get_player_control().jump == true then -- make sure that the player is immobile.
|
or clicker:get_player_control().jump == true then -- make sure that the player is immobile.
|
||||||
return end
|
return end
|
||||||
sit(pos, node, clicker)
|
homedecor.sit(pos, node, clicker)
|
||||||
clicker:setpos(pos)
|
clicker:setpos(pos)
|
||||||
default.player_set_animation(clicker, "sit", 30)
|
default.player_set_animation(clicker, "sit", 30)
|
||||||
]]
|
]] -- MODIFICATION MODE FOR MFF ^
|
||||||
end
|
end
|
||||||
|
|
||||||
local table_colors = { "", "mahogany", "white" }
|
local table_colors = { "", "mahogany", "white" }
|
||||||
@@ -383,232 +383,6 @@ homedecor.register("wardrobe_bottom", {
|
|||||||
},
|
},
|
||||||
})
|
})
|
||||||
|
|
||||||
homedecor.register("simple_bench", {
|
|
||||||
tiles = {
|
|
||||||
"homedecor_generic_wood.png",
|
|
||||||
"homedecor_generic_wood.png",
|
|
||||||
"homedecor_generic_wood.png",
|
|
||||||
"homedecor_generic_wood.png",
|
|
||||||
"homedecor_bench_large_2_left_back.png",
|
|
||||||
"homedecor_bench_large_2_left_back.png^[transformFX"
|
|
||||||
},
|
|
||||||
description = "Simple Bench",
|
|
||||||
groups = {snappy=3},
|
|
||||||
node_box = {
|
|
||||||
type = "fixed",
|
|
||||||
fixed = {
|
|
||||||
{-0.5, -0.15, 0, 0.5, -0.05, 0.4},
|
|
||||||
{-0.4, -0.5, 0.1, -0.3, -0.15, 0.3},
|
|
||||||
{ 0.3, -0.5, 0.1, 0.4, -0.15, 0.3},
|
|
||||||
}
|
|
||||||
},
|
|
||||||
on_rightclick = function(pos, node, clicker)
|
|
||||||
pos.y = pos.y-0 -- player's sit position.
|
|
||||||
homedecor.sit_exec(pos, node, clicker)
|
|
||||||
end,
|
|
||||||
})
|
|
||||||
|
|
||||||
homedecor.register("bench_large_1_left", {
|
|
||||||
description = "Garden Bench (style 1)",
|
|
||||||
tiles = {
|
|
||||||
"homedecor_bench_large_1_left_top.png",
|
|
||||||
"homedecor_bench_large_1_left_bottom.png",
|
|
||||||
"homedecor_bench_large_1_ends.png^[transformFX",
|
|
||||||
"homedecor_bench_large_1_ends.png",
|
|
||||||
"homedecor_bench_large_1_left_back.png",
|
|
||||||
"homedecor_bench_large_1_left_front.png"
|
|
||||||
},
|
|
||||||
inventory_image = "homedecor_bench_large_1_inv.png",
|
|
||||||
groups = {snappy=3},
|
|
||||||
node_box = {
|
|
||||||
type = "fixed",
|
|
||||||
fixed = {
|
|
||||||
{-0.5, 0.25, 0.375, 0.5, 0.4375, 0.4375}, -- NodeBox1
|
|
||||||
{-0.5, 0, 0.375, 0.5, 0.1875, 0.4375}, -- NodeBox2
|
|
||||||
{-0.5, -0.125, 0.115, 0.5, -0.0625, 0.35}, -- NodeBox3
|
|
||||||
{-0.5, -0.125, -0.0872, 0.5, -0.0625, 0.079}, -- NodeBox4
|
|
||||||
{-0.3125, -0.5, 0.4375, -0.25, 0.375, 0.5}, -- NodeBox5
|
|
||||||
{-0.3125, -0.25, -0.0625, -0.25, -0.125, 0.4375}, -- NodeBox6
|
|
||||||
{-0.3125, -0.5, -0.0625, -0.25, -0.25, 0}, -- NodeBox7
|
|
||||||
}
|
|
||||||
},
|
|
||||||
selection_box = {
|
|
||||||
type = "fixed",
|
|
||||||
fixed = { -0.5, -0.5, -0.09375, 1.5, 0.5, 0.5 }
|
|
||||||
},
|
|
||||||
expand = { right="homedecor:bench_large_1_right" },
|
|
||||||
on_rightclick = function(pos, node, clicker)
|
|
||||||
pos.y = pos.y-0 -- player's sit position.
|
|
||||||
homedecor.sit_exec(pos, node, clicker)
|
|
||||||
end,
|
|
||||||
})
|
|
||||||
|
|
||||||
homedecor.register("bench_large_1_right", {
|
|
||||||
tiles = {
|
|
||||||
"homedecor_bench_large_1_left_top.png^[transformFX",
|
|
||||||
"homedecor_bench_large_1_left_bottom.png^[transformFX",
|
|
||||||
"homedecor_bench_large_1_ends.png^[transformFX",
|
|
||||||
"homedecor_bench_large_1_ends.png",
|
|
||||||
"homedecor_bench_large_1_left_back.png^[transformFX",
|
|
||||||
"homedecor_bench_large_1_left_front.png^[transformFX"
|
|
||||||
},
|
|
||||||
groups = {snappy=3},
|
|
||||||
node_box = {
|
|
||||||
type = "fixed",
|
|
||||||
fixed = {
|
|
||||||
{-0.5, 0.25, 0.375, 0.5, 0.4375, 0.4375}, -- NodeBox1
|
|
||||||
{-0.5, 0, 0.375, 0.5, 0.1875, 0.4375}, -- NodeBox2
|
|
||||||
{-0.5, -0.125, 0.115, 0.5, -0.0625, 0.35}, -- NodeBox3
|
|
||||||
{-0.5, -0.125, -0.0872, 0.5, -0.0625, 0.079}, -- NodeBox4
|
|
||||||
{0.25, -0.5, 0.4375, 0.3125, 0.375, 0.5}, -- NodeBox5
|
|
||||||
{0.25, -0.25, -0.0625, 0.3125, -0.125, 0.5}, -- NodeBox6
|
|
||||||
{0.25, -0.5, -0.0625, 0.3125, -0.25, 0}, -- NodeBox7
|
|
||||||
}
|
|
||||||
},
|
|
||||||
selection_box = homedecor.nodebox.null,
|
|
||||||
})
|
|
||||||
|
|
||||||
|
|
||||||
homedecor.register("bench_large_2_left", {
|
|
||||||
description = "Garden Bench (style 2)",
|
|
||||||
tiles = {
|
|
||||||
"homedecor_generic_wood.png",
|
|
||||||
"homedecor_generic_wood.png",
|
|
||||||
"homedecor_generic_wood.png",
|
|
||||||
"homedecor_generic_wood.png",
|
|
||||||
"homedecor_bench_large_2_left_back.png",
|
|
||||||
"homedecor_bench_large_2_left_back.png^[transformFX"
|
|
||||||
},
|
|
||||||
inventory_image = "homedecor_bench_large_2_inv.png",
|
|
||||||
groups = {snappy=3},
|
|
||||||
node_box = {
|
|
||||||
type = "fixed",
|
|
||||||
fixed = {
|
|
||||||
{-0.5, -0.5, 0.375, -0.375, 0.5, 0.5}, -- NodeBox1
|
|
||||||
{-0.375, 0.3125, 0.4375, 0.5, 0.4375, 0.5}, -- NodeBox2
|
|
||||||
{-0.375, -0.0625, 0.4375, 0.5, 0.0625, 0.5}, -- NodeBox3
|
|
||||||
{-0.3125, 0.0625, 0.45, -0.25, 0.3125, 0.48}, -- NodeBox4
|
|
||||||
{-0.1875, 0.0625, 0.45, -0.125, 0.3125, 0.48}, -- NodeBox5
|
|
||||||
{-0.0625, 0.0625, 0.45, 0, 0.3125, 0.48}, -- NodeBox6
|
|
||||||
{0.0625, 0.0625, 0.45, 0.125, 0.3125, 0.48}, -- NodeBox7
|
|
||||||
{0.1875, 0.0625, 0.45, 0.25, 0.3125, 0.48}, -- NodeBox8
|
|
||||||
{0.3125, 0.0625, 0.45, 0.375, 0.3125, 0.48}, -- NodeBox9
|
|
||||||
{0.4375, 0.0625, 0.45, 0.5, 0.3125, 0.48}, -- NodeBox10
|
|
||||||
{-0.5, 0.0625, -0.145362, -0.375, 0.125, 0.375}, -- NodeBox11
|
|
||||||
{-0.5, -0.5, -0.0625, -0.375, 0.0625, 0.0625}, -- NodeBox12
|
|
||||||
{-0.4375, -0.125, -0.0625, 0.5, -0.0911603, 0.4375}, -- NodeBox13
|
|
||||||
{-0.4375, -0.4375, 0.0625, -0.375, -0.3125, 0.375}, -- NodeBox14
|
|
||||||
{-0.375, -0.342324, 0.25, 0.5, -0.4375, 0.1875}, -- NodeBox15
|
|
||||||
{-0.5, -0.25, -0.0290173, 0.5, -0.125, 0.0125346}, -- NodeBox16
|
|
||||||
}
|
|
||||||
},
|
|
||||||
selection_box = {
|
|
||||||
type = "fixed",
|
|
||||||
fixed = { -0.5, -0.5, -0.15625, 1.5, 0.5, 0.5 }
|
|
||||||
},
|
|
||||||
expand = { right="homedecor:bench_large_2_right" },
|
|
||||||
on_rightclick = function(pos, node, clicker)
|
|
||||||
pos.y = pos.y-0 -- player's sit position.
|
|
||||||
homedecor.sit_exec(pos, node, clicker)
|
|
||||||
end,
|
|
||||||
})
|
|
||||||
|
|
||||||
homedecor.register("bench_large_2_right", {
|
|
||||||
tiles = {
|
|
||||||
"homedecor_generic_wood.png",
|
|
||||||
"homedecor_generic_wood.png",
|
|
||||||
"homedecor_generic_wood.png",
|
|
||||||
"homedecor_generic_wood.png",
|
|
||||||
"homedecor_bench_large_2_right_back.png",
|
|
||||||
"homedecor_bench_large_2_right_back.png^[transformFX"
|
|
||||||
},
|
|
||||||
groups = {snappy=3},
|
|
||||||
node_box = {
|
|
||||||
type = "fixed",
|
|
||||||
fixed = {
|
|
||||||
{0.375, -0.5, 0.375, 0.5, 0.5, 0.5}, -- NodeBox1
|
|
||||||
{-0.5, 0.3125, 0.4375, 0.375, 0.4375, 0.5}, -- NodeBox2
|
|
||||||
{-0.5, -0.0625, 0.4375, 0.375, 0.0625, 0.5}, -- NodeBox3
|
|
||||||
{-0.5, 0.0625, 0.45, -0.4375, 0.3125, 0.48}, -- NodeBox4
|
|
||||||
{-0.375, 0.0625, 0.45, -0.3125, 0.3125, 0.48}, -- NodeBox5
|
|
||||||
{-0.25, 0.0625, 0.45, -0.1875, 0.3125, 0.48}, -- NodeBox6
|
|
||||||
{-0.125, 0.0625, 0.45, -0.0625, 0.3125, 0.48}, -- NodeBox7
|
|
||||||
{0, 0.0625, 0.45, 0.0625, 0.3125, 0.48}, -- NodeBox8
|
|
||||||
{0.125, 0.0625, 0.45, 0.1875, 0.3125, 0.48}, -- NodeBox9
|
|
||||||
{0.25, 0.0625, 0.45, 0.3125, 0.3125, 0.48}, -- NodeBox10
|
|
||||||
{0.375, 0.0625, -0.145362, 0.5, 0.125, 0.375}, -- NodeBox11
|
|
||||||
{0.375, -0.5, -0.0625, 0.5, 0.125, 0.0625}, -- NodeBox12
|
|
||||||
{0.375, -0.4375, 0.0625, 0.4375, -0.3125, 0.375}, -- NodeBox13
|
|
||||||
{-0.5, -0.4375, 0.1875, 0.375, -0.342324, 0.25}, -- NodeBox14
|
|
||||||
{-0.5, -0.125, -0.0625, 0.4375, -0.0911603, 0.4375}, -- NodeBox15
|
|
||||||
{-0.5, -0.25, -0.0290173, 0.5, -0.125, 0.0125346}, -- NodeBox16
|
|
||||||
}
|
|
||||||
},
|
|
||||||
selection_box = homedecor.nodebox.null,
|
|
||||||
})
|
|
||||||
|
|
||||||
homedecor.register("deckchair_head", {
|
|
||||||
tiles = {
|
|
||||||
"homedecor_deckchair_top_c1.png",
|
|
||||||
"homedecor_deckchair_sides.png",
|
|
||||||
"homedecor_deckchair_sides.png",
|
|
||||||
"homedecor_deckchair_sides.png^[transformFX",
|
|
||||||
"homedecor_deckchair_sides.png",
|
|
||||||
"homedecor_deckchair_front.png"
|
|
||||||
},
|
|
||||||
groups = { snappy = 3, not_in_creative_inventory = 1 },
|
|
||||||
node_box = {
|
|
||||||
type = "fixed",
|
|
||||||
fixed = {
|
|
||||||
{-0.375, -0.3125, -0.0625, 0.375, -0.25, 0}, -- NodeBox1
|
|
||||||
{-0.375, -0.25, 0, 0.375, -0.1875, 0.0625}, -- NodeBox2
|
|
||||||
{-0.375, -0.1875, 0.0625, 0.375, -0.125, 0.125}, -- NodeBox3
|
|
||||||
{-0.375, -0.125, 0.125, 0.375, -0.0625, 0.1875}, -- NodeBox4
|
|
||||||
{-0.375, -0.0625, 0.1875, 0.375, 0, 0.25}, -- NodeBox5
|
|
||||||
{-0.375, 0, 0.25, 0.375, 0.0625, 0.3125}, -- NodeBox6
|
|
||||||
{-0.375, 0.0625, 0.3125, 0.375, 0.125, 0.375}, -- NodeBox7
|
|
||||||
{-0.375, 0.125, 0.375, 0.375, 0.1875, 0.4375}, -- NodeBox8
|
|
||||||
{-0.375, 0.1875, 0.4375, 0.375, 0.25, 0.5}, -- NodeBox9
|
|
||||||
{-0.375, -0.375, -0.5, 0.375, -0.3125, 0.0625}, -- NodeBox10
|
|
||||||
{0.3125, -0.1875, -0.5, 0.4375, -0.1575, 0.0625}, -- NodeBox11
|
|
||||||
{-0.4375, -0.1875, -0.5, -0.3125, -0.1575, 0.0625}, -- NodeBox12
|
|
||||||
{0.3125, -0.5, 0, 0.375, -0.25, 0.0625}, -- NodeBox13
|
|
||||||
{-0.375, -0.5, 0, -0.3125, -0.25, 0.0625}, -- NodeBox14
|
|
||||||
}
|
|
||||||
},
|
|
||||||
selection_box = homedecor.nodebox.null
|
|
||||||
})
|
|
||||||
|
|
||||||
homedecor.register("deckchair_foot", {
|
|
||||||
tiles = {
|
|
||||||
"homedecor_deckchair_top_c2.png",
|
|
||||||
"homedecor_deckchair_sides.png",
|
|
||||||
"homedecor_deckchair_sides.png",
|
|
||||||
"homedecor_deckchair_sides.png^[transformFX",
|
|
||||||
"homedecor_deckchair_front.png"
|
|
||||||
},
|
|
||||||
description = "Deck chair",
|
|
||||||
inventory_image = "homedecor_deckchair_inv.png",
|
|
||||||
groups = { snappy = 3 },
|
|
||||||
node_box = {
|
|
||||||
type = "fixed",
|
|
||||||
fixed = {
|
|
||||||
{-0.375, -0.375, -0.5, 0.375, -0.3125, 0.5}, -- NodeBox1
|
|
||||||
{0.3125, -0.5, -0.5, 0.375, -0.375, -0.4375}, -- NodeBox2
|
|
||||||
{-0.375, -0.5, -0.5, -0.3125, -0.375, -0.4375}, -- NodeBox3
|
|
||||||
{0.3125, -0.1875, 0.3, 0.4375, -0.1575, 0.5}, -- NodeBox4
|
|
||||||
{-0.4375, -0.1875, 0.3, -0.3125, -0.1575, 0.5}, -- NodeBox5
|
|
||||||
{-0.365, -0.3125, 0.32, -0.3225, -0.1875, 0.4375}, -- NodeBox6
|
|
||||||
{0.3225, -0.3125, 0.32, 0.365, -0.1875, 0.4375}, -- NodeBox7
|
|
||||||
}
|
|
||||||
},
|
|
||||||
selection_box = {
|
|
||||||
type = "fixed",
|
|
||||||
fixed = { -0.45, -0.5, -0.5, 0.45, 0.35, 1.5 }
|
|
||||||
},
|
|
||||||
expand = { forward="homedecor:deckchair_head" },
|
|
||||||
})
|
|
||||||
|
|
||||||
homedecor.register("wall_shelf", {
|
homedecor.register("wall_shelf", {
|
||||||
description = "Wall Shelf",
|
description = "Wall Shelf",
|
||||||
tiles = {
|
tiles = {
|
||||||
|
@@ -50,6 +50,8 @@ end
|
|||||||
-- leave the last argument nil if it's one 2m high node
|
-- leave the last argument nil if it's one 2m high node
|
||||||
function homedecor.stack_vertically(itemstack, placer, pointed_thing, node1, node2)
|
function homedecor.stack_vertically(itemstack, placer, pointed_thing, node1, node2)
|
||||||
local pos, def = select_node(pointed_thing)
|
local pos, def = select_node(pointed_thing)
|
||||||
|
if not def then return end -- rare corner case, but happened in #205
|
||||||
|
|
||||||
if def.on_rightclick then
|
if def.on_rightclick then
|
||||||
return def.on_rightclick(pointed_thing.under, minetest.get_node(pos), placer, itemstack)
|
return def.on_rightclick(pointed_thing.under, minetest.get_node(pos), placer, itemstack)
|
||||||
end
|
end
|
||||||
@@ -69,6 +71,8 @@ local fdir_to_left = {
|
|||||||
}
|
}
|
||||||
function homedecor.stack_wing(itemstack, placer, pointed_thing, node1, node2, node1_right, node2_right)
|
function homedecor.stack_wing(itemstack, placer, pointed_thing, node1, node2, node1_right, node2_right)
|
||||||
local pos, def = select_node(pointed_thing)
|
local pos, def = select_node(pointed_thing)
|
||||||
|
if not def then return end -- rare corner case, but happened in #205
|
||||||
|
|
||||||
if def.on_rightclick then
|
if def.on_rightclick then
|
||||||
return def.on_rightclick(pointed_thing.under, minetest.get_node(pos), placer, itemstack)
|
return def.on_rightclick(pointed_thing.under, minetest.get_node(pos), placer, itemstack)
|
||||||
end
|
end
|
||||||
@@ -102,6 +106,8 @@ homedecor.fdir_to_fwd = {
|
|||||||
|
|
||||||
function homedecor.stack_sideways(itemstack, placer, pointed_thing, node1, node2, dir)
|
function homedecor.stack_sideways(itemstack, placer, pointed_thing, node1, node2, dir)
|
||||||
local pos, def = select_node(pointed_thing)
|
local pos, def = select_node(pointed_thing)
|
||||||
|
if not def then return end -- rare corner case, but happened in #205
|
||||||
|
|
||||||
if def.on_rightclick then
|
if def.on_rightclick then
|
||||||
return def.on_rightclick(pointed_thing.under, minetest.get_node(pos), placer, itemstack)
|
return def.on_rightclick(pointed_thing.under, minetest.get_node(pos), placer, itemstack)
|
||||||
end
|
end
|
||||||
|
@@ -16,7 +16,7 @@ for i in ipairs(colors) do
|
|||||||
interval = 1,
|
interval = 1,
|
||||||
chance = 1,
|
chance = 1,
|
||||||
action = function(pos, node, active_object_count, active_object_count_wider)
|
action = function(pos, node, active_object_count, active_object_count_wider)
|
||||||
minetest.add_node(pos, {name = "homedecor:glowlight_quarter_"..color, param2 = 20})
|
minetest.set_node(pos, {name = "homedecor:glowlight_quarter_"..color, param2 = 20})
|
||||||
end,
|
end,
|
||||||
})
|
})
|
||||||
|
|
||||||
@@ -25,7 +25,7 @@ for i in ipairs(colors) do
|
|||||||
interval = 1,
|
interval = 1,
|
||||||
chance = 1,
|
chance = 1,
|
||||||
action = function(pos, node, active_object_count, active_object_count_wider)
|
action = function(pos, node, active_object_count, active_object_count_wider)
|
||||||
minetest.add_node(pos, {name = "homedecor:glowlight_half_"..color, param2 = 20})
|
minetest.set_node(pos, {name = "homedecor:glowlight_half_"..color, param2 = 20})
|
||||||
end,
|
end,
|
||||||
})
|
})
|
||||||
|
|
||||||
@@ -36,7 +36,7 @@ for i in ipairs(colors) do
|
|||||||
action = function(pos, node, active_object_count, active_object_count_wider)
|
action = function(pos, node, active_object_count, active_object_count_wider)
|
||||||
local fdir = node.param2 or 0
|
local fdir = node.param2 or 0
|
||||||
local nfdir = dirs2[fdir+1]
|
local nfdir = dirs2[fdir+1]
|
||||||
minetest.add_node(pos, {name = "homedecor:glowlight_quarter_"..color, param2 = nfdir})
|
minetest.set_node(pos, {name = "homedecor:glowlight_quarter_"..color, param2 = nfdir})
|
||||||
end,
|
end,
|
||||||
})
|
})
|
||||||
|
|
||||||
@@ -47,7 +47,7 @@ for i in ipairs(colors) do
|
|||||||
action = function(pos, node, active_object_count, active_object_count_wider)
|
action = function(pos, node, active_object_count, active_object_count_wider)
|
||||||
local fdir = node.param2 or 0
|
local fdir = node.param2 or 0
|
||||||
local nfdir = dirs2[fdir+1]
|
local nfdir = dirs2[fdir+1]
|
||||||
minetest.add_node(pos, {name = "homedecor:glowlight_half_"..color, param2 = nfdir})
|
minetest.set_node(pos, {name = "homedecor:glowlight_half_"..color, param2 = nfdir})
|
||||||
end,
|
end,
|
||||||
})
|
})
|
||||||
|
|
||||||
@@ -56,7 +56,7 @@ for i in ipairs(colors) do
|
|||||||
interval = 1,
|
interval = 1,
|
||||||
chance = 1,
|
chance = 1,
|
||||||
action = function(pos, node, active_object_count, active_object_count_wider)
|
action = function(pos, node, active_object_count, active_object_count_wider)
|
||||||
minetest.add_node(pos, {name = "homedecor:glowlight_small_cube_"..color, param2 = 20})
|
minetest.set_node(pos, {name = "homedecor:glowlight_small_cube_"..color, param2 = 20})
|
||||||
end,
|
end,
|
||||||
})
|
})
|
||||||
|
|
||||||
@@ -82,7 +82,7 @@ homedecor.register("glowlight_half_"..color, {
|
|||||||
selection_box = glowlight_nodebox.half,
|
selection_box = glowlight_nodebox.half,
|
||||||
node_box = glowlight_nodebox.half,
|
node_box = glowlight_nodebox.half,
|
||||||
groups = { snappy = 3 },
|
groups = { snappy = 3 },
|
||||||
light_source = default.LIGHT_MAX,
|
light_source = LIGHT_MAX,
|
||||||
sounds = default.node_sound_wood_defaults(),
|
sounds = default.node_sound_wood_defaults(),
|
||||||
on_place = minetest.rotate_node
|
on_place = minetest.rotate_node
|
||||||
})
|
})
|
||||||
@@ -100,7 +100,7 @@ homedecor.register("glowlight_quarter_"..color, {
|
|||||||
selection_box = glowlight_nodebox.quarter,
|
selection_box = glowlight_nodebox.quarter,
|
||||||
node_box = glowlight_nodebox.quarter,
|
node_box = glowlight_nodebox.quarter,
|
||||||
groups = { snappy = 3 },
|
groups = { snappy = 3 },
|
||||||
light_source = default.LIGHT_MAX-1,
|
light_source = LIGHT_MAX-1,
|
||||||
sounds = default.node_sound_wood_defaults(),
|
sounds = default.node_sound_wood_defaults(),
|
||||||
on_place = minetest.rotate_node
|
on_place = minetest.rotate_node
|
||||||
})
|
})
|
||||||
@@ -120,7 +120,7 @@ homedecor.register("glowlight_small_cube_"..color, {
|
|||||||
selection_box = glowlight_nodebox.small_cube,
|
selection_box = glowlight_nodebox.small_cube,
|
||||||
node_box = glowlight_nodebox.small_cube,
|
node_box = glowlight_nodebox.small_cube,
|
||||||
groups = { snappy = 3 },
|
groups = { snappy = 3 },
|
||||||
light_source = default.LIGHT_MAX-1,
|
light_source = LIGHT_MAX-1,
|
||||||
sounds = default.node_sound_wood_defaults(),
|
sounds = default.node_sound_wood_defaults(),
|
||||||
on_place = minetest.rotate_node
|
on_place = minetest.rotate_node
|
||||||
})
|
})
|
||||||
@@ -138,7 +138,7 @@ homedecor.register("plasma_lamp", {
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
-- use_texture_alpha = true,
|
-- use_texture_alpha = true,
|
||||||
light_source = default.LIGHT_MAX - 1,
|
light_source = LIGHT_MAX - 1,
|
||||||
sunlight_propagates = true,
|
sunlight_propagates = true,
|
||||||
groups = {cracky=3,oddly_breakable_by_hand=3},
|
groups = {cracky=3,oddly_breakable_by_hand=3},
|
||||||
sounds = default.node_sound_glass_defaults(),
|
sounds = default.node_sound_glass_defaults(),
|
||||||
@@ -170,7 +170,7 @@ homedecor.register("candle", {
|
|||||||
},
|
},
|
||||||
sunlight_propagates = true,
|
sunlight_propagates = true,
|
||||||
groups = { snappy = 3 },
|
groups = { snappy = 3 },
|
||||||
light_source = default.LIGHT_MAX-4,
|
light_source = LIGHT_MAX-4,
|
||||||
sounds = default.node_sound_wood_defaults(),
|
sounds = default.node_sound_wood_defaults(),
|
||||||
})
|
})
|
||||||
|
|
||||||
@@ -190,7 +190,7 @@ homedecor.register("candle_thin", {
|
|||||||
sunlight_propagates = true,
|
sunlight_propagates = true,
|
||||||
walkable = false,
|
walkable = false,
|
||||||
groups = { snappy = 3 },
|
groups = { snappy = 3 },
|
||||||
light_source = default.LIGHT_MAX-4,
|
light_source = LIGHT_MAX-4,
|
||||||
})
|
})
|
||||||
|
|
||||||
homedecor.register("oil_lamp", {
|
homedecor.register("oil_lamp", {
|
||||||
@@ -206,7 +206,7 @@ homedecor.register("oil_lamp", {
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
groups = { snappy = 3 },
|
groups = { snappy = 3 },
|
||||||
light_source = default.LIGHT_MAX-4,
|
light_source = LIGHT_MAX-4,
|
||||||
sounds = default.node_sound_wood_defaults(),
|
sounds = default.node_sound_wood_defaults(),
|
||||||
})
|
})
|
||||||
|
|
||||||
@@ -250,7 +250,7 @@ homedecor.register("lattice_lantern_large", {
|
|||||||
description = S("Lattice lantern (large)"),
|
description = S("Lattice lantern (large)"),
|
||||||
tiles = { 'homedecor_lattice_lantern_large.png' },
|
tiles = { 'homedecor_lattice_lantern_large.png' },
|
||||||
groups = { snappy = 3 },
|
groups = { snappy = 3 },
|
||||||
light_source = default.LIGHT_MAX - 1,
|
light_source = LIGHT_MAX,
|
||||||
sounds = default.node_sound_wood_defaults(),
|
sounds = default.node_sound_wood_defaults(),
|
||||||
})
|
})
|
||||||
|
|
||||||
@@ -270,7 +270,7 @@ homedecor.register("lattice_lantern_small", {
|
|||||||
fixed = { -0.25, -0.5, -0.25, 0.25, 0, 0.25 }
|
fixed = { -0.25, -0.5, -0.25, 0.25, 0, 0.25 }
|
||||||
},
|
},
|
||||||
groups = { snappy = 3 },
|
groups = { snappy = 3 },
|
||||||
light_source = default.LIGHT_MAX-1,
|
light_source = LIGHT_MAX-1,
|
||||||
sounds = default.node_sound_wood_defaults(),
|
sounds = default.node_sound_wood_defaults(),
|
||||||
on_place = minetest.rotate_node
|
on_place = minetest.rotate_node
|
||||||
})
|
})
|
||||||
|
@@ -110,7 +110,7 @@ minetest.register_abm({
|
|||||||
action = function(pos, node, active_object_count, active_object_count_wider)
|
action = function(pos, node, active_object_count, active_object_count_wider)
|
||||||
local newnode = string.sub(node.name, 1, -3) -- strip the "_s" from the name
|
local newnode = string.sub(node.name, 1, -3) -- strip the "_s" from the name
|
||||||
local fdir = node.param2 or 0
|
local fdir = node.param2 or 0
|
||||||
minetest.add_node(pos, {name = newnode, param2 = dirs2[fdir+1]})
|
minetest.set_node(pos, {name = newnode, param2 = dirs2[fdir+1]})
|
||||||
end
|
end
|
||||||
})
|
})
|
||||||
|
|
||||||
|
Binary file not shown.
Before Width: | Height: | Size: 943 B |
Reference in New Issue
Block a user