Compare commits

...

2 Commits
main ... dev

24 changed files with 2427 additions and 2505 deletions

View File

@ -1,19 +1,18 @@
local Ombrellone_n_list = {
{ "Red Ombrellone_n", "red"},
{ "Orange Ombrellone_n", "orange"},
{ "Black Ombrellone_n", "black"},
{ "Yellow Ombrellone_n", "yellow"},
{ "Green Ombrellone_n", "green"},
{ "Blue Ombrellone_n", "blue"},
{ "Violet Ombrellone_n", "violet"},
{ "White Ombrellone_n", "white"},
{ "Red Ombrellone_n", "red" },
{ "Orange Ombrellone_n", "orange" },
{ "Black Ombrellone_n", "black" },
{ "Yellow Ombrellone_n", "yellow" },
{ "Green Ombrellone_n", "green" },
{ "Blue Ombrellone_n", "blue" },
{ "Violet Ombrellone_n", "violet" },
{ "White Ombrellone_n", "white" },
}
for i in ipairs(Ombrellone_n_list) do
local Ombrellone_ndesc = Ombrellone_n_list[i][1]
local colour = Ombrellone_n_list[i][2]
minetest.register_alias_force("summer:Ombrellone_n_"..colour.."", "summer:ombrellone_n_"..colour.."")
minetest.register_alias_force("summer:Ombrellone_n_"..colour.."_ch", "summer:ombrellone_n_"..colour.."_ch")
minetest.register_alias_force("summer:Ombrellone_n_" .. colour .. "", "summer:ombrellone_n_" .. colour .. "")
minetest.register_alias_force("summer:Ombrellone_n_" .. colour .. "_ch", "summer:ombrellone_n_" .. colour .. "_ch")
end

View File

@ -1,77 +1,66 @@
local Asciugamano_list = {
{ "Red Asciugamano", "red"},
{ "Orange Asciugamano", "orange"},
{ "Black Asciugamano", "black"},
{ "Yellow Asciugamano", "yellow"},
{ "Green Asciugamano", "green"},
{ "Blue Asciugamano", "blue"},
{ "Violet Asciugamano", "violet"},
local Asciugamano_list = {
{ "Red Asciugamano", "red" },
{ "Orange Asciugamano", "orange" },
{ "Black Asciugamano", "black" },
{ "Yellow Asciugamano", "yellow" },
{ "Green Asciugamano", "green" },
{ "Blue Asciugamano", "blue" },
{ "Violet Asciugamano", "violet" },
}
for i in ipairs(Asciugamano_list) do
local asciugamanodesc = Asciugamano_list[i][1]
local colour = Asciugamano_list[i][2]
minetest.register_node("summer:asciugamano_"..colour.."", {
description = asciugamanodesc.."",
minetest.register_node("summer:asciugamano_" .. colour .. "", {
description = asciugamanodesc .. "",
drawtype = "mesh",
mesh = "asciugamano.obj",
tiles = {"asciugsmano_"..colour..".png",
tiles = { "asciugsmano_" .. colour .. ".png",
},
inventory_image = "asciugsmano_a_"..colour..".png",
inventory_image = "asciugsmano_a_" .. colour .. ".png",
wield_image = "asciugsmano_a_"..colour..".png",
wield_image = "asciugsmano_a_" .. colour .. ".png",
paramtype = "light",
paramtype2 = "facedir",
sunlight_propagates = true,
walkable = false,
selection_box = {
type = "fixed",
fixed = { -1.0, -0.5,-0.5, 1.0,-0.49, 0.5 },
fixed = { -1.0, -0.5, -0.5, 1.0, -0.49, 0.5 },
},
groups = {snappy=2,cracky=3,oddly_breakable_by_hand=3,not_in_creative_inventory=0},
groups = { snappy = 2, cracky = 3, oddly_breakable_by_hand = 3, not_in_creative_inventory = 0 },
--sounds = default.node_sound_wood_defaults(),
drop = "summer:asciugamano_"..colour.."",
drop = "summer:asciugamano_" .. colour .. "",
on_rightclick = function(pos, node, clicker, itemstack, pointed_thing)
return minetest.sleep_in_asciugamano( pos, node, clicker, itemstack, pointed_thing );
return minetest.sleep_in_asciugamano(pos, node, clicker, itemstack, pointed_thing);
end
})
minetest.allow_sit = function( player )
minetest.allow_sit = function(player)
-- no check possible
if( not( player.get_player_velocity )) then
if (not (player.get_player_velocity)) then
return true;
end
local velo = player:get_player_velocity();
if( not( velo )) then
if (not (velo)) then
return false;
end
local max_velo = 0.0010;
if( math.abs(velo.x) < max_velo
if (math.abs(velo.x) < max_velo
and math.abs(velo.y) < max_velo
and math.abs(velo.z) < max_velo ) then
and math.abs(velo.z) < max_velo) then
return true;
end
return false;
end
end
minetest.sleep_in_asciugamano = function( pos, node, clicker, itemstack, pointed_thing )
if( not( clicker ) or not( node ) or not( node.name ) or not( pos ) or not( minetest.allow_sit( clicker))) then
minetest.sleep_in_asciugamano = function(pos, node, clicker, itemstack, pointed_thing)
if (not (clicker) or not (node) or not (node.name) or not (pos) or not (minetest.allow_sit(clicker))) then
return;
end
local animation = default.player_get_animation( clicker );
local animation = default.player_get_animation(clicker);
local pname = clicker:get_player_name();
local place_name = 'place';
@ -81,134 +70,130 @@ minetest.sleep_in_asciugamano = function( pos, node, clicker, itemstack, pointed
local new_animation = 'lay';
-- let players get back up
if( animation and animation.animation=="lay" ) then
if (animation and animation.animation == "lay") then
default.player_attached[pname] = false
clicker:setpos({x=pos.x,y=pos.y-0.5,z=pos.z})
clicker:set_eye_offset({x=0,y=0,z=0}, {x=0,y=0,z=0})
clicker:set_physics_override({1, 1, 1})
clicker:setpos({ x = pos.x, y = pos.y - 0.5, z = pos.z })
clicker:set_eye_offset({ x = 0, y = 0, z = 0 }, { x = 0, y = 0, z = 0 })
clicker:set_physics_override({ 1, 1, 1 })
default.player_set_animation(clicker, "stand", 30)
minetest.chat_send_player( pname, 'That was enough sleep for now. You stand up again.');
minetest.chat_send_player(pname, 'That was enough sleep for now. You stand up again.');
return;
end
local second_node_pos = {x=pos.x, y=pos.y, z=pos.z};
local second_node_pos = { x = pos.x, y = pos.y, z = pos.z };
-- the node that will contain the head of the player
local p = {x=pos.x, y=pos.y, z=pos.z};
local p = { x = pos.x, y = pos.y, z = pos.z };
-- the player's head is pointing in this direction
local dir = node.param2;
-- it would be odd to sleep in half a asciugamano
if( node.name=="summer:asciugamano_"..colour.."" ) then
if( node.param2==0 ) then
second_node_pos.z = pos.z-1;
elseif( node.param2==1) then
second_node_pos.x = pos.x-1;
elseif( node.param2==2) then
second_node_pos.z = pos.z+1;
elseif( node.param2==3) then
second_node_pos.x = pos.x+1;
if (node.name == "summer:asciugamano_" .. colour .. "") then
if (node.param2 == 0) then
second_node_pos.z = pos.z - 1;
elseif (node.param2 == 1) then
second_node_pos.x = pos.x - 1;
elseif (node.param2 == 2) then
second_node_pos.z = pos.z + 1;
elseif (node.param2 == 3) then
second_node_pos.x = pos.x + 1;
end
local node2 = minetest.get_node( second_node_pos );
if( not( node2 ) or not( node2.param2 ) or not( node.param2 )
or node2.name ~= "summer:asciugamano_"..colour..""
or node2.param2 ~= node.param2 ) then
local node2 = minetest.get_node(second_node_pos);
if (not (node2) or not (node2.param2) or not (node.param2)
or node2.name ~= "summer:asciugamano_" .. colour .. ""
or node2.param2 ~= node.param2) then
allow_sleep = false;
else
allow_sleep = true;
end
place_name = "asciugamano_"..colour.."";
place_name = "asciugamano_" .. colour .. "";
-- if the player clicked on the foot of the asciugamano, locate the head
elseif( node.name=='summer:asciugamano' ) then
if( node.param2==2 ) then
second_node_pos.z = pos.z-1;
elseif( node.param2==3) then
second_node_pos.x = pos.x-1;
elseif( node.param2==0) then
second_node_pos.z = pos.z+1;
elseif( node.param2==1) then
second_node_pos.x = pos.x+1;
elseif (node.name == 'summer:asciugamano') then
if (node.param2 == 2) then
second_node_pos.z = pos.z - 1;
elseif (node.param2 == 3) then
second_node_pos.x = pos.x - 1;
elseif (node.param2 == 0) then
second_node_pos.z = pos.z + 1;
elseif (node.param2 == 1) then
second_node_pos.x = pos.x + 1;
end
local node2 = minetest.get_node( second_node_pos );
if( not( node2 ) or not( node2.param2 ) or not( node.param2 )
local node2 = minetest.get_node(second_node_pos);
if (not (node2) or not (node2.param2) or not (node.param2)
or node2.name ~= 'summer:asciugamano'
or node2.param2 ~= node.param2 ) then
or node2.param2 ~= node.param2) then
allow_sleep = false;
else
allow_sleep = true;
end
if( allow_sleep==true ) then
p = {x=second_node_pos.x, y=second_node_pos.y, z=second_node_pos.z};
if (allow_sleep == true) then
p = { x = second_node_pos.x, y = second_node_pos.y, z = second_node_pos.z };
end
place_name = 'asciugamano';
elseif( node.name=='summer:sleeping_mat' or node.name=='summer:straw_mat') then
elseif (node.name == 'summer:sleeping_mat' or node.name == 'summer:straw_mat') then
place_name = 'mat';
dir = node.param2;
allow_sleep = false;
-- search for a second mat right next to this one
local offset = {{x=0,z=-1}, {x=-1,z=0}, {x=0,z=1}, {x=1,z=0}};
for i,off in ipairs( offset ) do
node2 = minetest.get_node( {x=pos.x+off.x, y=pos.y, z=pos.z+off.z} );
if( node2.name == 'summer:sleeping_mat' or node2.name=='summer:straw_mat' ) then
local offset = { { x = 0, z = -1 }, { x = -1, z = 0 }, { x = 0, z = 1 }, { x = 1, z = 0 } };
for i, off in ipairs(offset) do
node2 = minetest.get_node({ x = pos.x + off.x, y = pos.y, z = pos.z + off.z });
if (node2.name == 'summer:sleeping_mat' or node2.name == 'summer:straw_mat') then
-- if a second mat is found, sleeping is possible
allow_sleep = true;
dir = i-1;
dir = i - 1;
end
end
end
-- set the right height for the asciugamano
if( place_name=='asciugamano' ) then
p.y = p.y-0.4;
if (place_name == 'asciugamano') then
p.y = p.y - 0.4;
end
if( allow_sleep==true ) then
if (allow_sleep == true) then
-- set the right position (middle of the asciugamano)
if( dir==0 ) then
p.z = p.z-0.5;
elseif( dir==1 ) then
p.x = p.x-0.5;
elseif( dir==2 ) then
p.z = p.z+0.5;
elseif( dir==3 ) then
p.x = p.x+0.5;
if (dir == 0) then
p.z = p.z - 0.5;
elseif (dir == 1) then
p.x = p.x - 0.5;
elseif (dir == 2) then
p.z = p.z + 0.5;
elseif (dir == 3) then
p.x = p.x + 0.5;
end
end
if( default.player_attached[pname] and animation.animation=="sit") then
if (default.player_attached[pname] and animation.animation == "sit") then
-- just changing the animation...
if( allow_sleep==true ) then
if (allow_sleep == true) then
default.player_set_animation(clicker, "lay", 30)
clicker:set_eye_offset({x=0,y=-14,z=2}, {x=0,y=0,z=0})
minetest.chat_send_player( pname, 'You lie down and take a nap. A right-click will wake you up.');
clicker:set_eye_offset({ x = 0, y = -14, z = 2 }, { x = 0, y = 0, z = 0 })
minetest.chat_send_player(pname, 'You lie down and take a nap. A right-click will wake you up.');
return;
-- no sleeping on this place
else
default.player_attached[pname] = false
clicker:setpos({x=pos.x,y=pos.y-0.5,z=pos.z})
clicker:set_eye_offset({x=0,y=0,z=0}, {x=0,y=0,z=0})
clicker:set_physics_override({1, 1, 1})
clicker:setpos({ x = pos.x, y = pos.y - 0.5, z = pos.z })
clicker:set_eye_offset({ x = 0, y = 0, z = 0 }, { x = 0, y = 0, z = 0 })
clicker:set_physics_override({ 1, 1, 1 })
default.player_set_animation(clicker, "stand", 30)
minetest.chat_send_player( pname, 'That was enough sitting around for now. You stand up again.');
minetest.chat_send_player(pname, 'That was enough sitting around for now. You stand up again.');
return;
end
end
clicker:set_eye_offset({x=0,y=-7,z=2}, {x=0,y=0,z=0})
clicker:setpos( p );
clicker:set_eye_offset({ x = 0, y = -7, z = 2 }, { x = 0, y = 0, z = 0 })
clicker:setpos(p);
default.player_set_animation(clicker, new_animation, 30)
clicker:set_physics_override({0, 0, 0})
clicker:set_physics_override({ 0, 0, 0 })
default.player_attached[pname] = true
if( allow_sleep==true) then
minetest.chat_send_player( pname, 'Aaah! What a comftable '..place_name..'. A second right-click will let you sleep.');
if (allow_sleep == true) then
minetest.chat_send_player(pname,
'Aaah! What a comftable ' .. place_name .. '. A second right-click will let you sleep.');
else
minetest.chat_send_player( pname, 'Comftable, but not good enough for a nap. Right-click again if you want to get back up.');
minetest.chat_send_player(pname,
'Comftable, but not good enough for a nap. Right-click again if you want to get back up.');
end
end
end
end
--state=true: lay, state=false: stand up
--state=true: lay, state=false: stand up

View File

@ -16,7 +16,7 @@ end
local function get_velocity(v, yaw, y)
local x = -math.sin(yaw) * v
local z = math.cos(yaw) * v
return {x = x, y = y, z = z}
return { x = x, y = y, z = z }
end
@ -24,29 +24,28 @@ local function get_v(v)
return math.sqrt(v.x ^ 2 + v.z ^ 2)
end
local function reg_barca(color)
local barca_item_name = "summer:barca_" .. color .. "_item"
local barca_ent_name = "summer:barca_" .. color .. "_entity"
local barca_item_name = "summer:barca_"..color.."_item"
local barca_ent_name = "summer:barca_"..color.."_entity"
--
-- Boat entity
--
--
-- Boat entity
--
local barca = {
local barca = {
physical = true,
collisionbox = {-2.5, -0.5, -2.5, 2.5, 0.3, 2.5},
collisionbox = { -2.5, -0.5, -2.5, 2.5, 0.3, 2.5 },
visual = "mesh",
mesh = "barca.x",--"barcal.obj",
textures = {"barca_"..color..".png" },
mesh = "barca.x", --"barcal.obj",
textures = { "barca_" .. color .. ".png" },
driver = nil,
v = 0,
last_v = 0,
removed = false
}
}
function barca.on_rightclick(self, clicker)
function barca.on_rightclick(self, clicker)
if not clicker or not clicker:is_player() then
return
end
@ -55,9 +54,9 @@ function barca.on_rightclick(self, clicker)
self.driver = nil
clicker:set_detach()
default.player_attached[name] = false
default.player_set_animation(clicker, "stand" , 30)
default.player_set_animation(clicker, "stand", 30)
local pos = clicker:getpos()
pos = {x = pos.x, y = pos.y + 0.2, z = pos.z}
pos = { x = pos.x, y = pos.y + 0.2, z = pos.z }
minetest.after(0.1, function()
clicker:setpos(pos)
end)
@ -72,31 +71,28 @@ function barca.on_rightclick(self, clicker)
end
self.driver = clicker
clicker:set_attach(self.object, "",
{x = 0, y = 11, z = -3}, {x = 0, y = 0, z = 0})
{ x = 0, y = 11, z = -3 }, { x = 0, y = 0, z = 0 })
default.player_attached[name] = true
minetest.after(0.2, function()
default.player_set_animation(clicker, "sit" , 30)
default.player_set_animation(clicker, "sit", 30)
end)
self.object:setyaw(clicker:get_look_yaw() - math.pi / 2)
end
end
end
function barca.on_activate(self, staticdata, dtime_s)
self.object:set_armor_groups({immortal = 1})
function barca.on_activate(self, staticdata, dtime_s)
self.object:set_armor_groups({ immortal = 1 })
if staticdata then
self.v = tonumber(staticdata)
end
self.last_v = self.v
end
end
function barca.get_staticdata(self)
function barca.get_staticdata(self)
return tostring(self.v)
end
end
function barca.on_punch(self, puncher)
function barca.on_punch(self, puncher)
if not puncher or not puncher:is_player() or self.removed then
return
end
@ -113,17 +109,16 @@ function barca.on_punch(self, puncher)
end)
if not minetest.setting_getbool("creative_mode") then
local inv = puncher:get_inventory()
if inv:room_for_item("main", "summer:barca_"..color.."_item") then
inv:add_item("main", "summer:barca_"..color.."_item")
if inv:room_for_item("main", "summer:barca_" .. color .. "_item") then
inv:add_item("main", "summer:barca_" .. color .. "_item")
else
minetest.add_item(self.object:getpos(), barca_item_name)
end
end
end
end
end
function barca.on_step(self, dtime)
function barca.on_step(self, dtime)
self.v = get_v(self.object:getvelocity()) * get_sign(self.v)
if self.driver then
local ctrl = self.driver:get_player_control()
@ -155,7 +150,7 @@ function barca.on_step(self, dtime)
local s = get_sign(self.v)
self.v = self.v - 0.02 * s
if s ~= get_sign(self.v) then
self.object:setvelocity({x = 0, y = 0, z = 0})
self.object:setvelocity({ x = 0, y = 0, z = 0 })
self.v = 0
return
end
@ -165,15 +160,15 @@ function barca.on_step(self, dtime)
local p = self.object:getpos()
p.y = p.y - 0.5
local new_velo = {x = 0, y = 0, z = 0}
local new_acce = {x = 0, y = 0, z = 0}
local new_velo = { x = 0, y = 0, z = 0 }
local new_acce = { x = 0, y = 0, z = 0 }
if not is_water(p) then
local nodedef = minetest.registered_nodes[minetest.get_node(p).name]
if (not nodedef) or nodedef.walkable then
self.v = 0
new_acce = {x = 0, y = 2, z = 0}
new_acce = { x = 0, y = 2, z = 0 }
else
new_acce = {x = 0, y = -1.8, z = 0}
new_acce = { x = 0, y = -1.8, z = 0 }
end
new_velo = get_velocity(self.v, self.object:getyaw(),
self.object:getvelocity().y)
@ -185,14 +180,14 @@ function barca.on_step(self, dtime)
if y >= 7 then
y = 7
elseif y < 0 then
new_acce = {x = 0, y = 50, z = 0}
new_acce = { x = 0, y = 50, z = 0 }
else
new_acce = {x = 0, y = 7, z = 0}
new_acce = { x = 0, y = 7, z = 0 }
end
new_velo = get_velocity(self.v, self.object:getyaw(), y)
self.object:setpos(self.object:getpos())
else
new_acce = {x = 0, y = 0, z = 0}
new_acce = { x = 0, y = 0, z = 0 }
if math.abs(self.object:getvelocity().y) < 1 then
local pos = self.object:getpos()
pos.y = math.floor(pos.y) + 1.
@ -207,17 +202,16 @@ function barca.on_step(self, dtime)
end
self.object:setvelocity(new_velo)
self.object:setacceleration(new_acce)
end
end
minetest.register_entity("summer:barca_" .. color .. "", barca)
minetest.register_entity("summer:barca_"..color.."", barca)
minetest.register_craftitem(barca_item_name, {
description = "Barca ("..color..")",
inventory_image = "barca_"..color.."_inv.png",
wield_image = "barca_"..color.."_inv.png",
wield_scale = {x = 2, y = 2, z = 1},
minetest.register_craftitem(barca_item_name, {
description = "Barca (" .. color .. ")",
inventory_image = "barca_" .. color .. "_inv.png",
wield_image = "barca_" .. color .. "_inv.png",
wield_scale = { x = 2, y = 2, z = 1 },
liquids_pointable = true,
on_place = function(itemstack, placer, pointed_thing)
@ -228,40 +222,38 @@ minetest.register_craftitem(barca_item_name, {
return
end
pointed_thing.under.y = pointed_thing.under.y + 0.5
minetest.add_entity(pointed_thing.under, "summer:barca_"..color.."")
minetest.add_entity(pointed_thing.under, "summer:barca_" .. color .. "")
if not minetest.setting_getbool("creative_mode") then
itemstack:take_item()
end
return itemstack
end,
})
})
if minetest.get_modpath("cannabis") then
minetest.register_craft({
if minetest.get_modpath("cannabis") then
minetest.register_craft({
output = barca_item_name,
recipe = {
{"" , "" , "" },
{"cannabis:canapa_plastic", "wool:"..color, "cannabis:canapa_plastic"},
{"cannabis:canapa_plastic", "cannabis:canapa_plastic", "cannabis:canapa_plastic"},
{ "", "", "" },
{ "cannabis:canapa_plastic", "wool:" .. color, "cannabis:canapa_plastic" },
{ "cannabis:canapa_plastic", "cannabis:canapa_plastic", "cannabis:canapa_plastic" },
},
})
end
minetest.register_craft({
})
end
minetest.register_craft({
output = barca_item_name,
recipe = {
{"" , "" , "" },
{"group:wood", "wool:"..color, "group:wood"},
{"group:wood","group:wood","group:wood"},
{ "", "", "" },
{ "group:wood", "wool:" .. color, "group:wood" },
{ "group:wood", "group:wood", "group:wood" },
},
})
})
end
colors = {
"black", "red", "green", "blue", "yellow", "violet","orange",
"black", "red", "green", "blue", "yellow", "violet", "orange",
}
for _,color in ipairs(colors) do
for _, color in ipairs(colors) do
reg_barca(color)
end

View File

@ -1,8 +1,8 @@
--BRECCIA
minetest.register_node("summer:breccia", {
description = "Breccia",
tiles = {"breccia.png"},
groups = {crumbly = 2, falling_node = 1},
tiles = { "breccia.png" },
groups = { crumbly = 2, falling_node = 1 },
--groups = {cracky = 3, stone = 1},
drop = '"summer:pietra" 9',
--legacy_mineral = true,
@ -13,34 +13,33 @@ minetest.register_node("summer:breccia", {
minetest.register_node("summer:breccia_2", {
description = "BrecciaB ",
tiles = {"breccia2.png"},
groups = {crumbly = 2, falling_node = 1},
tiles = { "breccia2.png" },
groups = { crumbly = 2, falling_node = 1 },
--groups = {cracky = 3, stone = 1},
drop = '"summer:pietraA" 9',
--legacy_mineral = true,
sounds = default.node_sound_gravel_defaults(),
--sounds = default.node_sound_stone_defaults(),
})
minetest.register_node("summer:desert_breccia_2", {
minetest.register_node("summer:desert_breccia_2", {
description = "Red Breccia",
tiles = {"desert_breccia2.png"},
groups = {crumbly = 2, falling_node = 1},
tiles = { "desert_breccia2.png" },
groups = { crumbly = 2, falling_node = 1 },
--groups = {cracky = 3, stone = 1},
drop = '"summer:desert_pietra" 9',
--legacy_mineral = true,
sounds = default.node_sound_gravel_defaults(),
--sounds = default.node_sound_stone_defaults(),
})
minetest.register_node("summer:desert_breccia", {
description = "Desert Breccia",
tiles = {"desert_breccia.png"},
groups = {crumbly = 2, falling_node = 1},
tiles = { "desert_breccia.png" },
groups = { crumbly = 2, falling_node = 1 },
--groups = {cracky = 3, stone = 1},
drop = '"summer:pietraP" 9',
--legacy_mineral = true,
sounds = default.node_sound_gravel_defaults(),
--sounds = default.node_sound_stone_defaults(),
})

View File

@ -1,123 +1,121 @@
if minetest.get_modpath("wool") and minetest.get_modpath("dye")then
local lchest_list = {
{ "Red chest", "red"},
{ "Orange chest", "orange"},
{ "Black ", "black"},
{ "Yellow chest", "yellow"},
{ "Green chest", "green"},
{ "Blue chest", "blue"},
{ "Violet chest", "violet"},
{"white chest", "white"}
}
if minetest.get_modpath("wool") and minetest.get_modpath("dye") then
local lchest_list = {
{ "Red chest", "red" },
{ "Orange chest", "orange" },
{ "Black ", "black" },
{ "Yellow chest", "yellow" },
{ "Green chest", "green" },
{ "Blue chest", "blue" },
{ "Violet chest", "violet" },
{ "white chest", "white" }
}
for i in ipairs(lchest_list) do
for i in ipairs(lchest_list) do
local desc = lchest_list[i][1]
local colour = lchest_list[i][2]
--sdraia
minetest.register_craft({
output = "summer:sdraia_"..colour.."",
--sdraia
minetest.register_craft({
output = "summer:sdraia_" .. colour .. "",
recipe = {
{"", "wool:"..colour, "", },
{"cannabis:canapa_fiber", "cannabis:canapa_plastic", "cannabis:canapa_fiber", },
{"", "cannabis:canapa_fiber", "", }
{ "", "wool:" .. colour, "", },
{ "cannabis:canapa_fiber", "cannabis:canapa_plastic", "cannabis:canapa_fiber", },
{ "", "cannabis:canapa_fiber", "", }
}
})
--portacenere
--portacenere
minetest.register_craft({
output = "summer:Portacenere_"..colour.."",
output = "summer:Portacenere_" .. colour .. "",
recipe = {
{"cannabis:canapa_fiber", "", "cannabis:canapa_fiber" },
{"cannabis:canapa_plastic", "", "cannabis:canapa_plastic" },
{"cannabis:canapa_plastic", "wool:"..colour, "cannabis:canapa_plastic" }
{ "cannabis:canapa_fiber", "", "cannabis:canapa_fiber" },
{ "cannabis:canapa_plastic", "", "cannabis:canapa_plastic" },
{ "cannabis:canapa_plastic", "wool:" .. colour, "cannabis:canapa_plastic" }
}
})
--occhiali
minetest.register_craft({
output = "summer:occhiali_"..colour.."",
recipe = {
{"", "wool:"..colour, "", },
{"", "cannabis:canapa_fiber", "", },
{"cannabis:canapa_plastic", "", "cannabis:canapa_plastic", }
}
})
--porta
--occhiali
minetest.register_craft({
output = "summer:porta_"..colour.."_ch",
output = "summer:occhiali_" .. colour .. "",
recipe = {
{"cannabis:canapa_fiber", "wool:"..colour, "", },
{"wool:"..colour, "cannabis:canapa_fiber", "", },
{"cannabis:canapa_fiber", "cannabis:canapa_fiber", "", }
{ "", "wool:" .. colour, "", },
{ "", "cannabis:canapa_fiber", "", },
{ "cannabis:canapa_plastic", "", "cannabis:canapa_plastic", }
}
})
--________________________________________________________
--asciugamano
--________________________________________________________
minetest.register_craft({
output = "summer:asciugamano_"..colour.."",
recipe = {
{"","","", },
{"wool:"..colour, "", "", },
{"cannabis:canapa_fiber", "cannabis:canapa_fiber", "cannabis:canapa_fiber", }
}
})
--________________________________________________________
--ombrellone
--________________________________________________________
--porta
minetest.register_craft({
output = "summer:ombrellone_"..colour.."",
output = "summer:porta_" .. colour .. "_ch",
recipe = {
{"", "wool:"..colour, "", },
{"", "cannabis:canapa_plastic", "", },
{"", "cannabis:canapa_fiber", "", }
{ "cannabis:canapa_fiber", "wool:" .. colour, "", },
{ "wool:" .. colour, "cannabis:canapa_fiber", "", },
{ "cannabis:canapa_fiber", "cannabis:canapa_fiber", "", }
}
})
--________________________________________________________
--asciugamano
--________________________________________________________
minetest.register_craft({
output = "summer:asciugamano_" .. colour .. "",
recipe = {
{ "", "", "", },
{ "wool:" .. colour, "", "", },
{ "cannabis:canapa_fiber", "cannabis:canapa_fiber", "cannabis:canapa_fiber", }
}
})
--________________________________________________________
--ombrellone
--________________________________________________________
minetest.register_craft({
output = "summer:ombrellone_" .. colour .. "",
recipe = {
{ "", "wool:" .. colour, "", },
{ "", "cannabis:canapa_plastic", "", },
{ "", "cannabis:canapa_fiber", "", }
}
})
minetest.register_craft({
output = "summer:ombrellone_n_"..colour.."",
output = "summer:ombrellone_n_" .. colour .. "",
recipe = {
{"cannabis:canapa_fiber", "wool:"..colour, "cannabis:canapa_fiber" },
{"", "cannabis:canapa_plastic", "" },
{"", "cannabis:canapa_plastic", "" }
{ "cannabis:canapa_fiber", "wool:" .. colour, "cannabis:canapa_fiber" },
{ "", "cannabis:canapa_plastic", "" },
{ "", "cannabis:canapa_plastic", "" }
}
})
--________________________________________________________
--________________________________________________________
--chest
--________________________________________________________
minetest.register_craft({
output = "summer:chest"..colour.."",
--chest
--________________________________________________________
minetest.register_craft({
output = "summer:chest" .. colour .. "",
recipe = {
{"cannabis:canapa_plastic","dye:"..colour.."","cannabis:canapa_plastic"},
{"group:wood","","group:wood"},
{"group:wood","group:wood","group:wood"}
{ "cannabis:canapa_plastic", "dye:" .. colour .. "", "cannabis:canapa_plastic" },
{ "group:wood", "", "group:wood" },
{ "group:wood", "group:wood", "group:wood" }
}
})
minetest.register_craft({
output = "summer:chest_lock"..colour.."",
output = "summer:chest_lock" .. colour .. "",
recipe = {
{"summer:chest"..colour.."","cannabis:high_performance_ingot",""}
{ "summer:chest" .. colour .. "", "cannabis:high_performance_ingot", "" }
--{"","",""},
--{"","",""}
}
})
end
end
end

126
canoa.lua
View File

@ -16,7 +16,7 @@ end
local function get_velocity(v, yaw, y)
local x = -math.sin(yaw) * v
local z = math.cos(yaw) * v
return {x = x, y = y, z = z}
return { x = x, y = y, z = z }
end
@ -24,29 +24,28 @@ local function get_v(v)
return math.sqrt(v.x ^ 2 + v.z ^ 2)
end
local function reg_canoa_(color)
local canoa_item_name = "summer:canoa_" .. color .. "_item"
local canoa_ent_name = "summer:canoa_" .. color .. "_entity"
local canoa_item_name = "summer:canoa_"..color.."_item"
local canoa_ent_name = "summer:canoa_"..color.."_entity"
--
-- Boat entity
--
--
-- Boat entity
--
local canoa_ = {
local canoa_ = {
physical = true,
collisionbox = {-0.5, -0.35, -0.5, 0.5, 0.3, 0.5},
collisionbox = { -0.5, -0.35, -0.5, 0.5, 0.3, 0.5 },
visual = "mesh",
mesh = "canoa.x",
textures = {"canoa_"..color..".png" },
textures = { "canoa_" .. color .. ".png" },
driver = nil,
v = 0,
last_v = 0,
removed = false
}
}
function canoa_.on_rightclick(self, clicker)
function canoa_.on_rightclick(self, clicker)
if not clicker or not clicker:is_player() then
return
end
@ -55,9 +54,9 @@ function canoa_.on_rightclick(self, clicker)
self.driver = nil
clicker:set_detach()
default.player_attached[name] = false
default.player_set_animation(clicker, "stand" , 30)
default.player_set_animation(clicker, "stand", 30)
local pos = clicker:getpos()
pos = {x = pos.x, y = pos.y + 0.2, z = pos.z}
pos = { x = pos.x, y = pos.y + 0.2, z = pos.z }
minetest.after(0.1, function()
clicker:setpos(pos)
end)
@ -72,31 +71,28 @@ function canoa_.on_rightclick(self, clicker)
end
self.driver = clicker
clicker:set_attach(self.object, "",
{x = 0, y = 11, z = -3}, {x = 0, y = 0, z = 0})
{ x = 0, y = 11, z = -3 }, { x = 0, y = 0, z = 0 })
default.player_attached[name] = true
minetest.after(0.2, function()
default.player_set_animation(clicker, "sit" , 30)
default.player_set_animation(clicker, "sit", 30)
end)
self.object:setyaw(clicker:get_look_yaw() - math.pi / 2)
end
end
end
function canoa_.on_activate(self, staticdata, dtime_s)
self.object:set_armor_groups({immortal = 1})
function canoa_.on_activate(self, staticdata, dtime_s)
self.object:set_armor_groups({ immortal = 1 })
if staticdata then
self.v = tonumber(staticdata)
end
self.last_v = self.v
end
end
function canoa_.get_staticdata(self)
function canoa_.get_staticdata(self)
return tostring(self.v)
end
end
function canoa_.on_punch(self, puncher)
function canoa_.on_punch(self, puncher)
if not puncher or not puncher:is_player() or self.removed then
return
end
@ -113,17 +109,16 @@ function canoa_.on_punch(self, puncher)
end)
if not minetest.setting_getbool("creative_mode") then
local inv = puncher:get_inventory()
if inv:room_for_item("main", "summer:canoa_"..color.."_item") then
inv:add_item("main", "summer:canoa_"..color.."_item")
if inv:room_for_item("main", "summer:canoa_" .. color .. "_item") then
inv:add_item("main", "summer:canoa_" .. color .. "_item")
else
minetest.add_item(self.object:getpos(), canoa_item_name)
end
end
end
end
end
function canoa_.on_step(self, dtime)
function canoa_.on_step(self, dtime)
self.v = get_v(self.object:getvelocity()) * get_sign(self.v)
if self.driver then
local ctrl = self.driver:get_player_control()
@ -155,7 +150,7 @@ function canoa_.on_step(self, dtime)
local s = get_sign(self.v)
self.v = self.v - 0.02 * s
if s ~= get_sign(self.v) then
self.object:setvelocity({x = 0, y = 0, z = 0})
self.object:setvelocity({ x = 0, y = 0, z = 0 })
self.v = 0
return
end
@ -165,15 +160,15 @@ function canoa_.on_step(self, dtime)
local p = self.object:getpos()
p.y = p.y - 0.5
local new_velo = {x = 0, y = 0, z = 0}
local new_acce = {x = 0, y = 0, z = 0}
local new_velo = { x = 0, y = 0, z = 0 }
local new_acce = { x = 0, y = 0, z = 0 }
if not is_water(p) then
local nodedef = minetest.registered_nodes[minetest.get_node(p).name]
if (not nodedef) or nodedef.walkable then
self.v = 0
new_acce = {x = 0, y = 1, z = 0}
new_acce = { x = 0, y = 1, z = 0 }
else
new_acce = {x = 0, y = -9.8, z = 0}
new_acce = { x = 0, y = -9.8, z = 0 }
end
new_velo = get_velocity(self.v, self.object:getyaw(),
self.object:getvelocity().y)
@ -185,14 +180,14 @@ function canoa_.on_step(self, dtime)
if y >= 5 then
y = 5
elseif y < 0 then
new_acce = {x = 0, y = 20, z = 0}
new_acce = { x = 0, y = 20, z = 0 }
else
new_acce = {x = 0, y = 5, z = 0}
new_acce = { x = 0, y = 5, z = 0 }
end
new_velo = get_velocity(self.v, self.object:getyaw(), y)
self.object:setpos(self.object:getpos())
else
new_acce = {x = 0, y = 0, z = 0}
new_acce = { x = 0, y = 0, z = 0 }
if math.abs(self.object:getvelocity().y) < 1 then
local pos = self.object:getpos()
pos.y = math.floor(pos.y) + 0.5
@ -207,17 +202,16 @@ function canoa_.on_step(self, dtime)
end
self.object:setvelocity(new_velo)
self.object:setacceleration(new_acce)
end
end
minetest.register_entity("summer:canoa_" .. color .. "", canoa_)
minetest.register_entity("summer:canoa_"..color.."", canoa_)
minetest.register_craftitem(canoa_item_name, {
description = "canoa ("..color..")",
inventory_image = "canoa_"..color.."_inv.png",
wield_image = "canoa_"..color.."_inv.png",
wield_scale = {x = 2, y = 2, z = 1},
minetest.register_craftitem(canoa_item_name, {
description = "canoa (" .. color .. ")",
inventory_image = "canoa_" .. color .. "_inv.png",
wield_image = "canoa_" .. color .. "_inv.png",
wield_scale = { x = 2, y = 2, z = 1 },
liquids_pointable = true,
on_place = function(itemstack, placer, pointed_thing)
@ -228,44 +222,42 @@ minetest.register_craftitem(canoa_item_name, {
return
end
pointed_thing.under.y = pointed_thing.under.y + 0.5
minetest.add_entity(pointed_thing.under, "summer:canoa_"..color.."")
minetest.add_entity(pointed_thing.under, "summer:canoa_" .. color .. "")
if not minetest.setting_getbool("creative_mode") then
itemstack:take_item()
end
return itemstack
end,
})
})
--canoa
minetest.register_craft({
--canoa
minetest.register_craft({
output = canoa_item_name,
recipe = {
{"" , "" , "" },
{"" , "wool:"..color, "" },
{"group:wood","group:wood","group:wood"},
{ "", "", "" },
{ "", "wool:" .. color, "" },
{ "group:wood", "group:wood", "group:wood" },
},
})
})
if minetest.get_modpath("cannabis") then
minetest.register_craft({
if minetest.get_modpath("cannabis") then
minetest.register_craft({
output = canoa_item_name,
recipe = {
{"" , "" , "" },
{"" , "wool:"..color, "" },
{"cannabis:canapa_plastic", "cannabis:canapa_plastic", "cannabis:canapa_plastic"},
{ "", "", "" },
{ "", "wool:" .. color, "" },
{ "cannabis:canapa_plastic", "cannabis:canapa_plastic", "cannabis:canapa_plastic" },
},
})
end
})
end
end
colors = {
"black", "red", "green", "blue", "yellow", "violet","orange"
"black", "red", "green", "blue", "yellow", "violet", "orange"
}
for _,color in ipairs(colors) do
for _, color in ipairs(colors) do
reg_canoa_(color)
end

View File

@ -8,7 +8,7 @@ local chest_formspec =
"list[current_player;main;0,6.09;8,3;8]" ..
"listring[current_name;main]" ..
"listring[current_player;main]" ..
default.get_hotbar_bg(0,4.95)
default.get_hotbar_bg(0, 4.95)
local function get_locked_chest_formspec(pos)
local spos = pos.x .. "," .. pos.y .. "," .. pos.z
@ -22,7 +22,7 @@ local function get_locked_chest_formspec(pos)
"list[current_player;main;0,6.09;8,3;8]" ..
"listring[nodemeta:" .. spos .. ";main]" ..
"listring[current_player;main]" ..
default.get_hotbar_bg(0,4.95)
default.get_hotbar_bg(0, 4.95)
return formspec
end
@ -40,29 +40,29 @@ local function has_locked_chest_privilege(meta, player)
return true
end
local chest_list = {
{ "Red chest", "red"},
{ "Orange chest", "orange"},
{ "Black chest", "black"},
{ "Yellow chest", "yellow"},
{ "Green chest", "green"},
{ "Blue chest", "blue"},
{ "Violet chest", "violet"},
{ "Red chest", "red" },
{ "Orange chest", "orange" },
{ "Black chest", "black" },
{ "Yellow chest", "yellow" },
{ "Green chest", "green" },
{ "Blue chest", "blue" },
{ "Violet chest", "violet" },
}
for i in ipairs(chest_list) do
local chestdesc = chest_list[i][1]
local colour = chest_list[i][2]
minetest.register_node("summer:chest"..colour.."", {
description = chestdesc..colour.."",
tiles = {"chest_top_"..colour..".png", "chest_top_"..colour..".png", "chest_side_"..colour..".png",
"chest_side_"..colour..".png", "chest_side_"..colour..".png", "chest_front_"..colour..".png"},
--inventory_image = "chest_front_"..colour.."_inv.png",
minetest.register_node("summer:chest" .. colour .. "", {
description = chestdesc .. colour .. "",
tiles = { "chest_top_" .. colour .. ".png", "chest_top_" .. colour .. ".png", "chest_side_" .. colour .. ".png",
"chest_side_" .. colour .. ".png", "chest_side_" .. colour .. ".png", "chest_front_" .. colour .. ".png" },
--inventory_image = "chest_front_"..colour.."_inv.png",
--wield_image = {"chest_front_"..colour..".png",
--wield_image = {"chest_front_"..colour..".png",
-- },
paramtype2 = "facedir",
groups = {choppy = 2, oddly_breakable_by_hand = 2,tubedevice = 1, tubedevice_receiver = 1},
groups = { choppy = 2, oddly_breakable_by_hand = 2, tubedevice = 1, tubedevice_receiver = 1 },
tube = {
insert_object = function(pos, node, stack, direction)
local meta = minetest.get_meta(pos)
@ -75,8 +75,8 @@ minetest.register_node("summer:chest"..colour.."", {
return inv:room_for_item("main", stack)
end,
input_inventory = "main",
connect_sides = {left = 1, right = 1, back = 1, front = 1, bottom = 1, top = 1}
},
connect_sides = { left = 1, right = 1, back = 1, front = 1, bottom = 1, top = 1 }
},
legacy_facedir_simple = true,
is_ground_content = false,
sounds = default.node_sound_wood_defaults(),
@ -86,9 +86,9 @@ minetest.register_node("summer:chest"..colour.."", {
meta:set_string("formspec", chest_formspec)
meta:set_string("infotext", "Chest")
local inv = meta:get_inventory()
inv:set_size("main", 16*4)
inv:set_size("main", 16 * 4)
end,
can_dig = function(pos,player)
can_dig = function(pos, player)
local meta = minetest.get_meta(pos);
local inv = meta:get_inventory()
return inv:is_empty("main")
@ -111,35 +111,36 @@ minetest.register_node("summer:chest"..colour.."", {
on_blast = function(pos)
local drops = {}
default.get_inventory_drops(pos, "main", drops)
drops[#drops+1] = "summer:chest"..colour..""
drops[#drops + 1] = "summer:chest" .. colour .. ""
minetest.remove_node(pos)
return drops
end,
})
local lockchest_list = {
{ "Red lockchest", "red"},
{ "Orange lockchest", "orange"},
{ "Black lockchest", "black"},
{ "Yellow lockchest", "yellow"},
{ "Green lockchest", "green"},
{ "Blue lockchest", "blue"},
{ "Violet lockchest", "violet"},
}
})
local lockchest_list = {
{ "Red lockchest", "red" },
{ "Orange lockchest", "orange" },
{ "Black lockchest", "black" },
{ "Yellow lockchest", "yellow" },
{ "Green lockchest", "green" },
{ "Blue lockchest", "blue" },
{ "Violet lockchest", "violet" },
}
for i in ipairs(lockchest_list) do
for i in ipairs(lockchest_list) do
local lockchestdesc = lockchest_list[i][1]
local colour = lockchest_list[i][2]
minetest.register_node("summer:chest_lock"..colour.."", {
description = lockchestdesc.."",
tiles = {"chest_top_"..colour..".png", "chest_top_"..colour..".png", "chest_side_"..colour..".png",
"chest_side_"..colour..".png", "chest_side_"..colour..".png", "chest_lock_"..colour..".png"},
--inventory_image = "chest_lock_"..colour.."_inv.png",
minetest.register_node("summer:chest_lock" .. colour .. "", {
description = lockchestdesc .. "",
tiles = { "chest_top_" .. colour .. ".png", "chest_top_" .. colour .. ".png", "chest_side_" .. colour ..
".png",
"chest_side_" .. colour .. ".png", "chest_side_" .. colour .. ".png", "chest_lock_" .. colour .. ".png" },
--inventory_image = "chest_lock_"..colour.."_inv.png",
--wield_image = {"chest_lock_"..colour.."_inv.png",
--wield_image = {"chest_lock_"..colour.."_inv.png",
-- },
paramtype2 = "facedir",
groups = {choppy = 2, oddly_breakable_by_hand = 2,tubedevice = 1, tubedevice_receiver = 1},
groups = { choppy = 2, oddly_breakable_by_hand = 2, tubedevice = 1, tubedevice_receiver = 1 },
tube = {
insert_object = function(pos, node, stack, direction)
local meta = minetest.get_meta(pos)
@ -152,8 +153,8 @@ for i in ipairs(lockchest_list) do
return inv:room_for_item("main", stack)
end,
input_inventory = "main",
connect_sides = {left = 1, right = 1, back = 1, front = 1, bottom = 1, top = 1}
},
connect_sides = { left = 1, right = 1, back = 1, front = 1, bottom = 1, top = 1 }
},
legacy_facedir_simple = true,
is_ground_content = false,
sounds = default.node_sound_wood_defaults(),
@ -171,7 +172,7 @@ for i in ipairs(lockchest_list) do
local inv = meta:get_inventory()
inv:set_size("main", 16 * 4)
end,
can_dig = function(pos,player)
can_dig = function(pos, player)
local meta = minetest.get_meta(pos);
local inv = meta:get_inventory()
return inv:is_empty("main") and has_locked_chest_privilege(meta, player)
@ -213,12 +214,12 @@ for i in ipairs(lockchest_list) do
if has_locked_chest_privilege(meta, clicker) then
minetest.show_formspec(
clicker:get_player_name(),
"summer:chest_lock"..colour.."",
"summer:chest_lock" .. colour .. "",
get_locked_chest_formspec(pos)
)
end
end,
on_blast = function() end,
})
end
})
end
end

221
craft.lua
View File

@ -1,86 +1,139 @@
if minetest.get_modpath("wool") and minetest.get_modpath("dye")then
local lchest_list = {
{ "Red chest", "red"},
{ "Orange chest", "orange"},
{ "Black ", "black"},
{ "Yellow chest", "yellow"},
{ "Green chest", "green"},
{ "Blue chest", "blue"},
{ "Violet chest", "violet"},
{"white chest", "white"}
}
if minetest.get_modpath("wool") and minetest.get_modpath("dye") then
local lchest_list = {
{ "Red chest", "red" },
{ "Orange chest", "orange" },
{ "Black ", "black" },
{ "Yellow chest", "yellow" },
{ "Green chest", "green" },
{ "Blue chest", "blue" },
{ "Violet chest", "violet" },
{ "white chest", "white" }
}
for i in ipairs(lchest_list) do
for i in ipairs(lchest_list) do
local desc = lchest_list[i][1]
local colour = lchest_list[i][2]
--rake
minetest.register_craft({
output = "summer:rake",
--sdraia
minetest.register_craft({
output = "summer:sdraia_" .. colour .. "",
recipe = {
{"default:stick", "default:steel_ingot", "default:stick", },
{"", "default:stick", "", },
{"", "default:gold_ingot", "", }
}
})
--sdraia
minetest.register_craft({
output = "summer:sdraia_"..colour.."",
recipe = {
{"default:stick", "wool:"..colour, "", },
{"default:paper", "default:paper", "default:paper", },
{"default:stick", "", "default:stick", }
{ "default:stick", "wool:" .. colour, "", },
{ "default:paper", "default:paper", "default:paper", },
{ "default:stick", "", "default:stick", }
}
})
--portacenere
minetest.register_craft({
output = "summer:Portacenere_"..colour.."",
output = "summer:Portacenere_" .. colour .. "",
recipe = {
{"group:wood", "", "group:wood" },
{"default:stick", "default:paper", "default:stick" },
{"default:paper", "wool:"..colour, "default:paper" }
{ "group:wood", "", "group:wood" },
{ "default:stick", "default:paper", "default:stick" },
{ "default:paper", "wool:" .. colour, "default:paper" }
}
})
--porta
--porta
minetest.register_craft({
output = "summer:porta_"..colour.."_ch",
output = "summer:porta_" .. colour .. "_ch",
recipe = {
{"group:wood", "wool:"..colour, "", },
{"wool:"..colour, "group:wood", "", },
{"group:wood", "group:wood", "", }
{ "group:wood", "wool:" .. colour, "", },
{ "wool:" .. colour, "group:wood", "", },
{ "group:wood", "group:wood", "", }
}
})
--occhiali
minetest.register_craft({
output = "summer:occhiali_"..colour.."",
--occhiali
minetest.register_craft({
output = "summer:occhiali_" .. colour .. "",
recipe = {
{"", "wool:"..colour, "", },
{"default:stick", "", "default:stick", },
{"default:glass", "default:stick", "default:glass", }
{ "", "wool:" .. colour, "", },
{ "default:stick", "", "default:stick", },
{ "default:glass", "default:stick", "default:glass", }
}
})
--________________________________________________________
--________________________________________________________
--asciugamano
--________________________________________________________
--asciugamano
--________________________________________________________
minetest.register_craft({
output = "summer:asciugamano_"..colour.."",
minetest.register_craft({
output = "summer:asciugamano_" .. colour .. "",
recipe = {
{"","","", },
{"wool:"..colour, "", "", },
{"default:ladder_wood", "default:ladder_wood", "default:ladder_wood", }
{ "", "", "", },
{ "wool:" .. colour, "", "", },
{ "default:ladder_wood", "default:ladder_wood", "default:ladder_wood", }
}
})
--________________________________________________________
--breccia
--________________________________________________________
--________________________________________________________
--ombrellone
--________________________________________________________
minetest.register_craft({
output = "summer:ombrellone_" .. colour .. "",
recipe = {
{ "default:paper", "wool:" .. colour, "default:paper", },
{ "", "default:stick", "", },
{ "", "default:stick", "", }
}
})
minetest.register_craft({
output = "summer:ombrellone_n_" .. colour .. "",
recipe = {
{ "", "wool:" .. colour, "" },
{ "default:paper", "default:stick", "default:paper" },
{ "", "default:stick", "" }
}
})
--________________________________________________________
--chest
--________________________________________________________
minetest.register_craft({
output = "summer:chest" .. colour .. "",
recipe = {
{ "default:stone", "dye:" .. colour .. "", "default:stone" },
{ "group:wood", "", "group:wood" },
{ "group:wood", "group:wood", "group:wood" }
}
})
minetest.register_craft({
output = "summer:chest_lock" .. colour .. "",
recipe = {
{ "summer:chest" .. colour .. "", "default:diamond", "" }
--{"","",""},
--{"","",""}
}
})
end
--rake
minetest.register_craft({
output = "summer:rake",
recipe = {
{ "default:stick", "default:steel_ingot", "default:stick", },
{ "", "default:stick", "", },
{ "", "default:gold_ingot", "", }
}
})
--________________________________________________________
--breccia
--________________________________________________________
--craft BRECCIA BLOCK
minetest.register_craft({
@ -93,7 +146,7 @@ minetest.register_craft({
})
minetest.register_craft({
output ='"summer:desert_breccia_2" 4',
output = '"summer:desert_breccia_2" 4',
recipe = {
{ "summer:desert_pietra", "summer:desert_pietra", "summer:desert_pietra" },
{ "summer:desert_pietra", "summer:desert_pietra", "summer:desert_pietra" },
@ -124,7 +177,7 @@ minetest.register_craft({
--____________________________________________________
--craft GRANITE
minetest.register_craft({
minetest.register_craft({
output = '"summer:graniteBC" 5',
recipe = {
{ "", "", "" },
@ -172,61 +225,5 @@ minetest.register_craft({
{ "summer:mattoneP", "summer:mattoneP", "summer:mattoneP" },
},
})
--________________________________________________________
--________________________________________________________
--ombrellone
--________________________________________________________
minetest.register_craft({
output = "summer:ombrellone_"..colour.."",
recipe = {
{"default:paper", "wool:"..colour, "default:paper", },
{"", "default:stick", "", },
{"", "default:stick", "", }
}
})
minetest.register_craft({
output = "summer:ombrellone_n_"..colour.."",
recipe = {
{"", "wool:"..colour, "" },
{"default:paper", "default:stick", "default:paper" },
{"", "default:stick", "" }
}
})
--________________________________________________________
--chest
--________________________________________________________
minetest.register_craft({
output = "summer:chest"..colour.."",
recipe = {
{"default:stone","dye:"..colour.."","default:stone"},
{"group:wood","","group:wood"},
{"group:wood","group:wood","group:wood"}
}
})
minetest.register_craft({
output = "summer:chest_lock"..colour.."",
recipe = {
{"summer:chest"..colour.."","default:diamond",""}
--{"","",""},
--{"","",""}
}
})
end
--________________________________________________________
end

View File

@ -1,10 +1,10 @@
local granite = {
{"granite", "Granite grey"},
{"graniteR", "Granite corten"},
{"graniteA", "Granite avory"},
{"graniteP", "Granite pink"},
{"graniteB", "Granite black"},
{"graniteBC", "Granite black center"},
{ "granite", "Granite grey" },
{ "graniteR", "Granite corten" },
{ "graniteA", "Granite avory" },
{ "graniteP", "Granite pink" },
{ "graniteB", "Granite black" },
{ "graniteBC", "Granite black center" },
}
local stairs_mod = minetest.get_modpath("stairs")
@ -12,100 +12,100 @@ local stairsplus_mod = minetest.get_modpath("moreblocks")
and minetest.global_exists("stairsplus")
for _, granite in pairs(granite) do
if stairsplus_mod then
if stairsplus_mod then
stairsplus:register_all("summer", granite[1], "summer:" .. granite[1], {
description = granite[2] .. " Summer",
tiles = {granite[1] .. ".png"},
groups = {cracky = 3},
tiles = { granite[1] .. ".png" },
groups = { cracky = 3 },
sounds = default.node_sound_stone_defaults(),
})
stairsplus:register_alias_all("summer", granite[1], "summer", granite[1])
minetest.register_alias("stairs:slab_summer_".. granite[1], "summer:slab_baked_granite_" .. granite[1])
minetest.register_alias("stairs:stair_summer_".. granite[1], "summer:stair_baked_granite_" .. granite[1])
minetest.register_alias("stairs:slab_summer_" .. granite[1], "summer:slab_baked_granite_" .. granite[1])
minetest.register_alias("stairs:stair_summer_" .. granite[1], "summer:stair_baked_granite_" .. granite[1])
-- register all stair types for stairs redo
elseif stairs_mod and stairs.mod then
stairs.register_all("summer_" .. granite[1], "summer:" .. granite[1],
{cracky = 3},
{granite[1] .. ".png"},
{ cracky = 3 },
{ granite[1] .. ".png" },
granite[2] .. " Summer",
default.node_sound_stone_defaults())
-- register stair and slab using default stairs
elseif stairs_mod then
stairs.register_stair_and_slab("summer_".. granite[1], "summer:".. granite[1],
{cracky = 3},
{granite[1] .. ".png"},
stairs.register_stair_and_slab("summer_" .. granite[1], "summer:" .. granite[1],
{ cracky = 3 },
{ granite[1] .. ".png" },
granite[2] .. " Summer Stair",
granite[2] .. " Summer Slab",
default.node_sound_stone_defaults())
end
end
--GRANITE
--GRANITE
minetest.register_node("summer:granite", {
description = "Granite",
tiles = {"granite.png"},
tiles = { "granite.png" },
--material = minetest.digprop_constanttime(1),
groups = {cracky = 3, stone = 1},
groups = { cracky = 3, stone = 1 },
--drop ='"summer:mattoneG" 9',
stack_max = 9999,
--legacy_mineral = true,
sounds = default.node_sound_stone_defaults(),
})
minetest.register_node("summer:graniteA", {
description = "GraniteA",
tiles = {"graniteA.png"},
tiles = { "graniteA.png" },
--material = minetest.digprop_constanttime(1),
groups = {cracky = 3, stone = 1},
groups = { cracky = 3, stone = 1 },
--drop ='"summer:mattoneA" 9',
stack_max = 9999,
--legacy_mineral = true,
sounds = default.node_sound_stone_defaults(),
})
minetest.register_node("summer:graniteP", {
description = "GraniteP",
tiles = {"graniteP.png"},
tiles = { "graniteP.png" },
--material = minetest.digprop_constanttime(1),
groups = {cracky = 3, stone = 1},
groups = { cracky = 3, stone = 1 },
--drop ='"summer:mattoneP" 9',
stack_max = 9999,
--legacy_mineral = true,
sounds = default.node_sound_stone_defaults(),
})
minetest.register_node("summer:graniteR", {
description = "GraniteR",
tiles = {"graniteR.png"},
tiles = { "graniteR.png" },
--material = minetest.digprop_constanttime(1),
groups = {cracky = 3, stone = 1},
groups = { cracky = 3, stone = 1 },
--drop ='summer:mattoneR 9',
stack_max = 9999,
--legacy_mineral = true,
sounds = default.node_sound_stone_defaults(),
})
minetest.register_node("summer:graniteBC", {
minetest.register_node("summer:graniteBC", {
description = "Granite",
tiles = {"graniteBC.png"},
tiles = { "graniteBC.png" },
--material = minetest.digprop_constanttime(1),
groups = {cracky = 3, stone = 1},
--drop ='"summer:mattoneG" 9',
stack_max = 9999,
--legacy_mineral = true,
sounds = default.node_sound_stone_defaults(),
})
minetest.register_node("summer:graniteB", {
description = "Granite",
tiles = {"graniteB.png"},
--material = minetest.digprop_constanttime(1),
groups = {cracky = 3, stone = 1},
groups = { cracky = 3, stone = 1 },
--drop ='"summer:mattoneG" 9',
stack_max = 9999,
--legacy_mineral = true,
sounds = default.node_sound_stone_defaults(),
})
minetest.register_node("summer:graniteB", {
description = "Granite",
tiles = { "graniteB.png" },
--material = minetest.digprop_constanttime(1),
groups = { cracky = 3, stone = 1 },
--drop ='"summer:mattoneG" 9',
stack_max = 9999,
--legacy_mineral = true,
sounds = default.node_sound_stone_defaults(),
})

View File

@ -1,29 +1,29 @@
local path = minetest.get_modpath("summer")
dofile(path.."/salvag.lua")
dofile(path.."/ombrellone.lua")
dofile(path.."/sdraia.lua")
dofile(path.."/porta.lua")
dofile(path.."/ombrellone_new.lua")
dofile(path.."/materassino.lua")
dofile(path.."/breccia.lua")
dofile(path.."/asciugamano.lua")
dofile(path .. "/salvag.lua")
dofile(path .. "/ombrellone.lua")
dofile(path .. "/sdraia.lua")
dofile(path .. "/porta.lua")
dofile(path .. "/ombrellone_new.lua")
dofile(path .. "/materassino.lua")
dofile(path .. "/breccia.lua")
dofile(path .. "/asciugamano.lua")
if minetest.get_modpath("3d_armor") then
dofile(path.."/occhiali.lua")
dofile(path .. "/occhiali.lua")
end
dofile(path.."/chest.lua")
dofile(path.."/portacenere.lua")
dofile(path.."/summerstair.lua")
dofile(path.."/barche.lua")
dofile(path.."/granite.lua")
dofile(path.."/canoa.lua")
dofile(path.."/craft.lua")
dofile(path.."/vetro.lua")
dofile(path.."/aliases.lua")
dofile(path.."/sabbia.lua")
dofile(path.."/mattone.lua")
--dofile(path.."/pietra.lua")
dofile(path.."/pallone.lua")
dofile(path.."/granite.lua")
dofile(path .. "/chest.lua")
dofile(path .. "/portacenere.lua")
dofile(path .. "/summerstair.lua")
dofile(path .. "/barche.lua")
dofile(path .. "/granite.lua")
dofile(path .. "/canoa.lua")
dofile(path .. "/craft.lua")
dofile(path .. "/vetro.lua")
dofile(path .. "/aliases.lua")
dofile(path .. "/sabbia.lua")
dofile(path .. "/mattone.lua")
dofile(path .. "/pietra.lua")
dofile(path .. "/pallone.lua")
dofile(path .. "/granite.lua")
if minetest.get_modpath("cannabis") then
dofile(path.."/canapa.lua")
dofile(path .. "/canapa.lua")
end

View File

@ -16,7 +16,7 @@ end
local function get_velocity(v, yaw, y)
local x = -math.sin(yaw) * v
local z = math.cos(yaw) * v
return {x = x, y = y, z = z}
return { x = x, y = y, z = z }
end
@ -24,29 +24,28 @@ local function get_v(v)
return math.sqrt(v.x ^ 2 + v.z ^ 2)
end
local function reg_materassino(color)
local materassino_item_name = "summer:materassino_" .. color .. "_item"
local materassino_ent_name = "summer:materassino_" .. color .. "_entity"
local materassino_item_name = "summer:materassino_"..color.."_item"
local materassino_ent_name = "summer:materassino_"..color.."_entity"
--
-- Boat entity
--
--
-- Boat entity
--
local materassino = {
local materassino = {
physical = true,
collisionbox = {-0.5, -0.35, -0.5, 0.5, 0.3, 0.5},
collisionbox = { -0.5, -0.35, -0.5, 0.5, 0.3, 0.5 },
visual = "mesh",
mesh = "materassino.obj",
textures = { "materassino_"..color..".png" },
textures = { "materassino_" .. color .. ".png" },
driver = nil,
v = 0,
last_v = 0,
removed = false
}
}
function materassino.on_rightclick(self, clicker)
function materassino.on_rightclick(self, clicker)
if not clicker or not clicker:is_player() then
return
end
@ -55,9 +54,9 @@ function materassino.on_rightclick(self, clicker)
self.driver = nil
clicker:set_detach()
default.player_attached[name] = false
default.player_set_animation(clicker, "stand" , 30)
default.player_set_animation(clicker, "stand", 30)
local pos = clicker:getpos()
pos = {x = pos.x, y = pos.y + 0.2, z = pos.z}
pos = { x = pos.x, y = pos.y + 0.2, z = pos.z }
minetest.after(0.1, function()
clicker:setpos(pos)
end)
@ -72,31 +71,28 @@ function materassino.on_rightclick(self, clicker)
end
self.driver = clicker
clicker:set_attach(self.object, "",
{x = 0, y = 11, z = -3}, {x = 0, y = 0, z = 0})
{ x = 0, y = 11, z = -3 }, { x = 0, y = 0, z = 0 })
default.player_attached[name] = true
minetest.after(0.2, function()
default.player_set_animation(clicker, "lay" , 30)
default.player_set_animation(clicker, "lay", 30)
end)
self.object:setyaw(clicker:get_look_yaw() - math.pi / 2)
end
end
end
function materassino.on_activate(self, staticdata, dtime_s)
self.object:set_armor_groups({immortal = 1})
function materassino.on_activate(self, staticdata, dtime_s)
self.object:set_armor_groups({ immortal = 1 })
if staticdata then
self.v = tonumber(staticdata)
end
self.last_v = self.v
end
end
function materassino.get_staticdata(self)
function materassino.get_staticdata(self)
return tostring(self.v)
end
end
function materassino.on_punch(self, puncher)
function materassino.on_punch(self, puncher)
if not puncher or not puncher:is_player() or self.removed then
return
end
@ -113,17 +109,16 @@ function materassino.on_punch(self, puncher)
end)
if not minetest.setting_getbool("creative_mode") then
local inv = puncher:get_inventory()
if inv:room_for_item("main", "summer:materassino_"..color.."_item") then
inv:add_item("main", "summer:materassino_"..color.."_item")
if inv:room_for_item("main", "summer:materassino_" .. color .. "_item") then
inv:add_item("main", "summer:materassino_" .. color .. "_item")
else
minetest.add_item(self.object:getpos(), materassino_item_name)
end
end
end
end
end
function materassino.on_step(self, dtime)
function materassino.on_step(self, dtime)
self.v = get_v(self.object:getvelocity()) * get_sign(self.v)
if self.driver then
local ctrl = self.driver:get_player_control()
@ -155,7 +150,7 @@ function materassino.on_step(self, dtime)
local s = get_sign(self.v)
self.v = self.v - 0.02 * s
if s ~= get_sign(self.v) then
self.object:setvelocity({x = 0, y = 0, z = 0})
self.object:setvelocity({ x = 0, y = 0, z = 0 })
self.v = 0
return
end
@ -165,15 +160,15 @@ function materassino.on_step(self, dtime)
local p = self.object:getpos()
p.y = p.y - 0.5
local new_velo = {x = 0, y = 0, z = 0}
local new_acce = {x = 0, y = 0, z = 0}
local new_velo = { x = 0, y = 0, z = 0 }
local new_acce = { x = 0, y = 0, z = 0 }
if not is_water(p) then
local nodedef = minetest.registered_nodes[minetest.get_node(p).name]
if (not nodedef) or nodedef.walkable then
self.v = 0
new_acce = {x = 0, y = 1, z = 0}
new_acce = { x = 0, y = 1, z = 0 }
else
new_acce = {x = 0, y = -9.8, z = 0}
new_acce = { x = 0, y = -9.8, z = 0 }
end
new_velo = get_velocity(self.v, self.object:getyaw(),
self.object:getvelocity().y)
@ -185,14 +180,14 @@ function materassino.on_step(self, dtime)
if y >= 5 then
y = 5
elseif y < 0 then
new_acce = {x = 0, y = 20, z = 0}
new_acce = { x = 0, y = 20, z = 0 }
else
new_acce = {x = 0, y = 5, z = 0}
new_acce = { x = 0, y = 5, z = 0 }
end
new_velo = get_velocity(self.v, self.object:getyaw(), y)
self.object:setpos(self.object:getpos())
else
new_acce = {x = 0, y = 0, z = 0}
new_acce = { x = 0, y = 0, z = 0 }
if math.abs(self.object:getvelocity().y) < 1 then
local pos = self.object:getpos()
pos.y = math.floor(pos.y) + 0.5
@ -207,17 +202,16 @@ function materassino.on_step(self, dtime)
end
self.object:setvelocity(new_velo)
self.object:setacceleration(new_acce)
end
end
minetest.register_entity("summer:materassino_" .. color .. "", materassino)
minetest.register_entity("summer:materassino_"..color.."", materassino)
minetest.register_craftitem(materassino_item_name, {
description = "materassino ("..color..")",
inventory_image = "materassino_"..color.."_inv.png",
wield_image = "materassino_"..color.."_inv.png",
wield_scale = {x = 2, y = 2, z = 1},
minetest.register_craftitem(materassino_item_name, {
description = "materassino (" .. color .. ")",
inventory_image = "materassino_" .. color .. "_inv.png",
wield_image = "materassino_" .. color .. "_inv.png",
wield_scale = { x = 2, y = 2, z = 1 },
liquids_pointable = true,
on_place = function(itemstack, placer, pointed_thing)
@ -228,41 +222,38 @@ minetest.register_craftitem(materassino_item_name, {
return
end
pointed_thing.under.y = pointed_thing.under.y + 0.5
minetest.add_entity(pointed_thing.under, "summer:materassino_"..color.."")
minetest.add_entity(pointed_thing.under, "summer:materassino_" .. color .. "")
if not minetest.setting_getbool("creative_mode") then
itemstack:take_item()
end
return itemstack
end,
})
})
if minetest.get_modpath("cannabis") then
minetest.register_craft({
if minetest.get_modpath("cannabis") then
minetest.register_craft({
output = materassino_item_name,
recipe = {
{"", "" ,""},
{"", "wool:"..color, ""},
{"cannabis:canapa_plastic", "cannabis:canapa_plastic", "cannabis:canapa_plastic"},
{ "", "", "" },
{ "", "wool:" .. color, "" },
{ "cannabis:canapa_plastic", "cannabis:canapa_plastic", "cannabis:canapa_plastic" },
},
})
end
minetest.register_craft({
})
end
minetest.register_craft({
output = materassino_item_name,
recipe = {
{"", "" ,""},
{"", "wool:"..color, ""},
{"wool:"..color, "wool:"..color, "wool:"..color},
{ "", "", "" },
{ "", "wool:" .. color, "" },
{ "wool:" .. color, "wool:" .. color, "wool:" .. color },
},
})
})
end
colors = {
"black", "red", "green", "blue", "yellow", "violet","orange",
"black", "red", "green", "blue", "yellow", "violet", "orange",
}
for _,color in ipairs(colors) do
for _, color in ipairs(colors) do
reg_materassino(color)
end

View File

@ -1,43 +1,45 @@
minetest.register_craftitem("summer:mattoneG", {
description = "Mattone",
inventory_image = "mattone.png",
})
minetest.register_craftitem("summer:mattoneR", {
minetest.register_craftitem("summer:mattoneR", {
description = "MattoneR",
inventory_image = "mattoneR.png",
})
minetest.register_craftitem("summer:mattoneA", {
description = "MattoneA",
inventory_image = "mattoneA.png",
})
minetest.register_craftitem("summer:mattoneP", {
minetest.register_craftitem("summer:mattoneP", {
description = "MattoneP",
inventory_image = "mattoneP.png",
})
--craftMATTONE
--craftMATTONE
minetest.register_craft({
type = 'cooking',
recipe = "summer:pietraA",
cooktime = 2,
output = "summer:mattoneA",
})
minetest.register_craft({
type = 'cooking',
recipe = "summer:pietra",
cooktime = 2,
output = "summer:mattoneG",
})
minetest.register_craft({
type = 'cooking',
recipe = "summer:desert_pietra",
cooktime = 2,
output = "summer:mattoneR",
})
minetest.register_craft({
type = 'cooking',
recipe = "summer:pietraP",

View File

@ -1,21 +1,21 @@
local Occhiali_list = {
{ "Red Occhiali", "red"},
{ "Orange Occhiali", "orange"},
{ "Black Occhiali", "black"},
{ "Yellow Occhiali", "yellow"},
{ "Green Occhiali", "green"},
{ "Blue Occhiali", "blue"},
{ "Jam Occhiali", "jam"},
{ "Violet Occhiali", "violet"},
{ "Red Occhiali", "red" },
{ "Orange Occhiali", "orange" },
{ "Black Occhiali", "black" },
{ "Yellow Occhiali", "yellow" },
{ "Green Occhiali", "green" },
{ "Blue Occhiali", "blue" },
{ "Jam Occhiali", "jam" },
{ "Violet Occhiali", "violet" },
}
for i in ipairs(Occhiali_list) do
local Occhialidesc = Occhiali_list[i][1]
local colour = Occhiali_list[i][2]
minetest.register_alias("occhiali"..colour.."","summer:occhiali"..colour.."")
if minetest.get_modpath("summer") then
minetest.register_alias("occhiali" .. colour .. "", "summer:occhiali" .. colour .. "")
if minetest.get_modpath("summer") then
local stats = {
Occhialidesc = { name=Occhialidesc, armor=1.8, heal=0, use=650 },
Occhialidesc = { name = Occhialidesc, armor = 1.8, heal = 0, use = 650 },
}
--[[local mats = {
@ -25,16 +25,13 @@ if minetest.get_modpath("summer") then
high="cannabis:high_performance_ingot",
}]]
for k, v in pairs(stats) do
minetest.register_tool("summer:occhiali_"..colour.."", {
minetest.register_tool("summer:occhiali_" .. colour .. "", {
description = Occhialidesc,
tiles= "occhiali_"..colour..".png",
inventory_image = "occhiali_"..colour.."_inv.png",
groups = {armor_head=math.floor(5*v.armor), armor_heal=v.heal, armor_use=v.use},
tiles = "occhiali_" .. colour .. ".png",
inventory_image = "occhiali_" .. colour .. "_inv.png",
groups = { armor_head = math.floor(5 * v.armor), armor_heal = v.heal, armor_use = v.use },
wear = 0,
})
end
end
end
end
end

View File

@ -1,70 +1,68 @@
local Ombrellone_list = {
{ "Red Ombrellone", "red"},
{ "White Ombrellone", "white"},
{ "Orange Ombrellone", "orange"},
{ "Black Ombrellone", "black"},
{ "Yellow Ombrellone", "yellow"},
{ "Green Ombrellone", "green"},
{ "Blue Ombrellone", "blue"},
{ "Violet Ombrellone", "violet"},
{ "Red Ombrellone", "red" },
{ "White Ombrellone", "white" },
{ "Orange Ombrellone", "orange" },
{ "Black Ombrellone", "black" },
{ "Yellow Ombrellone", "yellow" },
{ "Green Ombrellone", "green" },
{ "Blue Ombrellone", "blue" },
{ "Violet Ombrellone", "violet" },
}
for i in ipairs(Ombrellone_list) do
local ombrellonedesc = Ombrellone_list[i][1]
local colour = Ombrellone_list[i][2]
minetest.register_node("summer:ombrellone_"..colour.."", {
description = ombrellonedesc.."",
minetest.register_node("summer:ombrellone_" .. colour .. "", {
description = ombrellonedesc .. "",
drawtype = "mesh",
mesh = "omb_o.obj",
tiles = {"ball_"..colour..".png",
tiles = { "ball_" .. colour .. ".png",
},
inventory_image = "ombo_"..colour.."_q.png",
inventory_image = "ombo_" .. colour .. "_q.png",
wield_image = "ombo_"..colour.."_q.png",
wield_image = "ombo_" .. colour .. "_q.png",
paramtype = "light",
paramtype2 = "facedir",
sunlight_propagates = true,
walkable = false,
selection_box = {
type = "fixed",
fixed = { -0.25, -0.5, -0.25, 0.25,0.5, 0.25 },
fixed = { -0.25, -0.5, -0.25, 0.25, 0.5, 0.25 },
},
groups = {snappy=2,cracky=3,oddly_breakable_by_hand=3, not_in_creative_inventory=0},
groups = { snappy = 2, cracky = 3, oddly_breakable_by_hand = 3, not_in_creative_inventory = 0 },
--sounds = default.node_sound_glass_defaults(),
drop = "summer:ombrellone_"..colour.."_ch",
drop = "summer:ombrellone_" .. colour .. "_ch",
on_rightclick = function(pos, node, clicker)
node.name = "summer:ombrellone_"..colour.."_ch"
node.name = "summer:ombrellone_" .. colour .. "_ch"
minetest.set_node(pos, node)
end,
})
minetest.register_node("summer:ombrellone_"..colour.."_ch", {
description = ombrellonedesc.." ch",
minetest.register_node("summer:ombrellone_" .. colour .. "_ch", {
description = ombrellonedesc .. " ch",
drawtype = "mesh",
mesh = "omb_c.obj",
tiles = {"ball_"..colour..".png",
tiles = { "ball_" .. colour .. ".png",
},
inventory_image = "ombc_"..colour.."_q.png",
inventory_image = "ombc_" .. colour .. "_q.png",
wield_image = "ombc_"..colour.."_q.png",
wield_image = "ombc_" .. colour .. "_q.png",
paramtype = "light",
paramtype2 = "facedir",
sunlight_propagates = true,
walkable = false,
selection_box = {
type = "fixed",
fixed = { -0.25, -0.5, -0.25, 0.25,0.5, 0.25 },
fixed = { -0.25, -0.5, -0.25, 0.25, 0.5, 0.25 },
},
groups = {snappy=2,cracky=3,oddly_breakable_by_hand=3, not_in_creative_inventory=0},
groups = { snappy = 2, cracky = 3, oddly_breakable_by_hand = 3, not_in_creative_inventory = 0 },
--sounds = default.node_sound_glass_defaults(),
drop = "summer:ombrellone_"..colour,
drop = "summer:ombrellone_" .. colour,
on_rightclick = function(pos, node, clicker)
node.name = "summer:ombrellone_"..colour..""
node.name = "summer:ombrellone_" .. colour .. ""
minetest.set_node(pos, node)
end,
})
end

View File

@ -1,69 +1,68 @@
local Ombrellone_n_list = {
{ "Red Ombrellone_n", "red"},
{ "Orange Ombrellone_n", "orange"},
{ "Black Ombrellone_n", "black"},
{ "Yellow Ombrellone_n", "yellow"},
{ "Green Ombrellone_n", "green"},
{ "Blue Ombrellone_n", "blue"},
{ "Violet Ombrellone_n", "violet"},
{ "White Ombrellone_n", "white"},
{ "Red Ombrellone_n", "red" },
{ "Orange Ombrellone_n", "orange" },
{ "Black Ombrellone_n", "black" },
{ "Yellow Ombrellone_n", "yellow" },
{ "Green Ombrellone_n", "green" },
{ "Blue Ombrellone_n", "blue" },
{ "Violet Ombrellone_n", "violet" },
{ "White Ombrellone_n", "white" },
}
for i in ipairs(Ombrellone_n_list) do
local Ombrellone_ndesc = Ombrellone_n_list[i][1]
local colour = Ombrellone_n_list[i][2]
minetest.register_node("summer:ombrellone_n_"..colour.."", {
description = Ombrellone_ndesc.."",
minetest.register_node("summer:ombrellone_n_" .. colour .. "", {
description = Ombrellone_ndesc .. "",
drawtype = "mesh",
mesh = "omb_n_o.obj",
tiles = {"Ombrellone_n_"..colour..".png",
tiles = { "Ombrellone_n_" .. colour .. ".png",
},
inventory_image = "ombo_"..colour.."_r.png",
inventory_image = "ombo_" .. colour .. "_r.png",
wield_image = "ombo_"..colour.."_r.png" ,
wield_image = "ombo_" .. colour .. "_r.png",
paramtype = "light",
paramtype2 = "facedir",
sunlight_propagates = true,
walkable = false,
selection_box = {
type = "fixed",
fixed = { -0.25, -0.5, -0.25, 0.25,0.5, 0.25 },
fixed = { -0.25, -0.5, -0.25, 0.25, 0.5, 0.25 },
},
groups = {snappy=2,cracky=3,oddly_breakable_by_hand=3,not_in_creative_inventory = 0},
groups = { snappy = 2, cracky = 3, oddly_breakable_by_hand = 3, not_in_creative_inventory = 0 },
--sounds = default.node_sound_glass_defaults(),
drop = "summer:ombrellone_n_"..colour.."_ch",
drop = "summer:ombrellone_n_" .. colour .. "_ch",
on_rightclick = function(pos, node, clicker)
node.name = "summer:Ombrellone_n_"..colour.."_ch"
node.name = "summer:Ombrellone_n_" .. colour .. "_ch"
minetest.set_node(pos, node)
end,
})
minetest.register_node("summer:ombrellone_n_"..colour.."_ch", {
description = Ombrellone_ndesc.." ch",
minetest.register_node("summer:ombrellone_n_" .. colour .. "_ch", {
description = Ombrellone_ndesc .. " ch",
drawtype = "mesh",
mesh = "omb_n_c.obj",
tiles = {"Ombrellone_n_"..colour..".png",
tiles = { "Ombrellone_n_" .. colour .. ".png",
},
inventory_image = "ombc_"..colour.."_r.png",
inventory_image = "ombc_" .. colour .. "_r.png",
wield_image = "ombc_"..colour.."_r.png",
wield_image = "ombc_" .. colour .. "_r.png",
paramtype = "light",
paramtype2 = "facedir",
sunlight_propagates = true,
walkable = false,
selection_box = {
type = "fixed",
fixed = { -0.25, -0.5, -0.25, 0.25,0.5, 0.25 },
fixed = { -0.25, -0.5, -0.25, 0.25, 0.5, 0.25 },
},
groups = {snappy=2,cracky=3,oddly_breakable_by_hand=3, not_in_creative_inventory=0},
groups = { snappy = 2, cracky = 3, oddly_breakable_by_hand = 3, not_in_creative_inventory = 0 },
--sounds = default.node_sound_glass_defaults(),
drop = "summer:ombrellone_n_"..colour,
drop = "summer:ombrellone_n_" .. colour,
on_rightclick = function(pos, node, clicker)
node.name = "summer:Ombrellone_n_"..colour..""
node.name = "summer:Ombrellone_n_" .. colour .. ""
minetest.set_node(pos, node)
end,
})
end

View File

@ -2,9 +2,8 @@
local CALCIO = 0.1
local function reg_ball(color)
local ball_item_name = "summer:ball_"..color.."_item"
local ball_ent_name = "summer:ball_"..color.."_entity"
local ball_item_name = "summer:ball_" .. color .. "_item"
local ball_ent_name = "summer:ball_" .. color .. "_entity"
minetest.register_entity(ball_ent_name, {
physical = true,
@ -13,7 +12,7 @@ local function reg_ball(color)
hp_max = 1000,
liquids_pointable = true,
groups = { immortal = true },
textures = { "ball_"..color..".png" },
textures = { "ball_" .. color .. ".png" },
collisionbox = { -0.2, -0.2, -0.2, 0.2, 0.2, 0.2 }, --{ -1, -1, -1, 1, 1, 1 },
timer = 0,
@ -21,7 +20,7 @@ local function reg_ball(color)
on_step = function(self, dtime)
self.timer = self.timer + dtime
if self.timer >= CALCIO then
self.object:setacceleration({x=0, y=-10, z=0})
self.object:setacceleration({ x = 0, y = -10, z = 0 })
self.timer = 0
local vel = self.object:getvelocity()
local p = self.object:getpos();
@ -40,8 +39,8 @@ local function reg_ball(color)
local pos = self.object:getpos()
local objs = minetest.env:get_objects_inside_radius(pos, 1)
local player_count = 0
local final_dir = { x=0, y=0, z=0 }
for _,obj in ipairs(objs) do
local final_dir = { x = 0, y = 0, z = 0 }
for _, obj in ipairs(objs) do
if obj:is_player() then
local objdir = obj:get_look_dir()
local mul = 1
@ -84,48 +83,47 @@ local function reg_ball(color)
end,
})
minetest.register_craftitem(ball_item_name,{
description = "Summer Ball ("..color..")",
inventory_image = "summer_ball_"..color.."_inv.png",
minetest.register_craftitem(ball_item_name, {
description = "Summer Ball (" .. color .. ")",
inventory_image = "summer_ball_" .. color .. "_inv.png",
on_place = function(itemstack, placer, pointed_thing)
local pos = pointed_thing.above
--pos = { x=pos.x+0.5, y=pos.y, z=pos.z+0.5 }
local ent = minetest.env:add_entity(pos, ball_ent_name)
ent:setvelocity({x=0, y=-15, z=0})
ent:setvelocity({ x = 0, y = -15, z = 0 })
itemstack:take_item()
return itemstack
end,
})
minetest.register_craft({
minetest.register_craft({
output = ball_item_name,
recipe = {
{ "default:paper", "group:leaves", "default:paper" },
{ "group:leaves", "wool:"..color, "group:leaves" },
{ "group:leaves", "wool:" .. color, "group:leaves" },
{ "default:paper", "group:leaves", "default:paper" },
},
})
if minetest.get_modpath("cannabis") then
if minetest.get_modpath("cannabis") then
minetest.register_craft({
output = ball_item_name,
recipe = {
{ "", "cannabis:canapa_plastic", "" },
{ "cannabis:canapa_plastic", "wool:"..color, "cannabis:canapa_plastic" },
{ "cannabis:canapa_plastic", "wool:" .. color, "cannabis:canapa_plastic" },
{ "", "cannabis:canapa_plastic", "" },
},
})
end
end
end
colors = {
"black", "red", "green", "blue", "yellow", "violet","orange"
"black", "red", "green", "blue", "yellow", "violet", "orange"
}
for _,color in ipairs(colors) do
for _, color in ipairs(colors) do
reg_ball(color)
end

View File

@ -1,27 +1,27 @@
--ROCCIA
minetest.register_alias("desert_roccia_1","desert_roccia")
minetest.register_alias("roccia_1","roccia")
minetest.register_alias("desert_roccia_1", "desert_roccia")
minetest.register_alias("roccia_1", "roccia")
minetest.register_node("summer:roccia_1", {
description = "Roccia",
drawtype = "mesh",
mesh = "roccia.obj",
tiles = {"roccia.png"},
tiles = { "roccia.png" },
paramtype = "light",
paramtype2 = "facedir",
sunlight_propagates = true,
walkable = true,
groups = {cracky = 3, stone = 1},
groups = { cracky = 3, stone = 1 },
drop = '"summer:pietra" 5',
selection_box = {
type = "fixed",
fixed = { -0.5, -0.5,-0.5, 0.5,0.1, 0.5 },
fixed = { -0.5, -0.5, -0.5, 0.5, 0.1, 0.5 },
},
on_place = function(itemstack, placer, pointed_thing)
-- place a random pebble node
local stack = ItemStack("summer:roccia_"..math.random(1,2))
local stack = ItemStack("summer:roccia_" .. math.random(1, 2))
local ret = minetest.item_place(stack, placer, pointed_thing)
return ItemStack("summer:roccia_1 "..itemstack:get_count()-(1-ret:get_count()))
end,--legacy_mineral = true,
return ItemStack("summer:roccia_1 " .. itemstack:get_count() - (1 - ret:get_count()))
end, --legacy_mineral = true,
sounds = default.node_sound_stone_defaults(),
})
@ -30,22 +30,22 @@ minetest.register_node("summer:desert_roccia_1", {
description = "Desert Roccia",
drawtype = "mesh",
mesh = "desert_roccia.obj",
tiles = {"desert_roccia.png"},
tiles = { "desert_roccia.png" },
paramtype = "light",
paramtype2 = "facedir",
sunlight_propagates = true,
walkable = true,
groups = {cracky = 3, stone = 1},
groups = { cracky = 3, stone = 1 },
drop = '"summer:desert_pietra" 5',
selection_box = {
type = "fixed",
fixed = { -0.5, -0.5,-0.5, 0.5,0.1, 0.5 },
fixed = { -0.5, -0.5, -0.5, 0.5, 0.1, 0.5 },
},
on_place = function(itemstack, placer, pointed_thing)
-- place a random pebble node
local stack = ItemStack("summer:desert_roccia_"..math.random(1,2))
local stack = ItemStack("summer:desert_roccia_" .. math.random(1, 2))
local ret = minetest.item_place(stack, placer, pointed_thing)
return ItemStack("summer:desert_roccia_1 "..itemstack:get_count()-(1-ret:get_count()))
return ItemStack("summer:desert_roccia_1 " .. itemstack:get_count() - (1 - ret:get_count()))
end,
--legacy_mineral = true,
sounds = default.node_sound_stone_defaults(),
@ -55,16 +55,16 @@ minetest.register_node("summer:roccia_2", {
description = "Roccia",
drawtype = "mesh",
mesh = "roccia.obj",
tiles = {"roccia.png"},
tiles = { "roccia.png" },
paramtype = "light",
paramtype2 = "facedir",
sunlight_propagates = true,
walkable = true,
groups = {cracky=3, stone=1, not_in_creative_inventory=1},
groups = { cracky = 3, stone = 1, not_in_creative_inventory = 1 },
drop = '"summer:pietra" 5',
selection_box = {
type = "fixed",
fixed = { -0.5, -0.5,-0.5, 0.5,0.1, 0.5 },
fixed = { -0.5, -0.5, -0.5, 0.5, 0.1, 0.5 },
},
--legacy_mineral = true,
sounds = default.node_sound_stone_defaults(),
@ -75,16 +75,16 @@ minetest.register_node("summer:desert_roccia_2", {
description = "Desert Roccia",
drawtype = "mesh",
mesh = "desert_roccia.obj",
tiles = {"desert_roccia.png"},
tiles = { "desert_roccia.png" },
paramtype = "light",
paramtype2 = "facedir",
sunlight_propagates = true,
walkable = true,
groups = {cracky=3, stone=1, not_in_creative_inventory=1},
groups = { cracky = 3, stone = 1, not_in_creative_inventory = 1 },
drop = '"summer:desert_pietra" 5',
selection_box = {
type = "fixed",
fixed = { -0.5, -0.5,-0.5, 0.5,0.1, 0.5 },
fixed = { -0.5, -0.5, -0.5, 0.5, 0.1, 0.5 },
},
--legacy_mineral = true,
sounds = default.node_sound_stone_defaults(),
@ -97,45 +97,49 @@ minetest.register_on_generated(function(minp, maxp, seed)
local perlin1 = minetest.get_perlin(329, 3, 0.6, 100)
-- Assume X and Z lengths are equal
local divlen = 16
local divs = (maxp.x-minp.x)/divlen+1;
for divx=0,divs-1 do
for divz=0,divs-1 do
local x0 = minp.x + math.floor((divx+0)*divlen)
local z0 = minp.z + math.floor((divz+0)*divlen)
local x1 = minp.x + math.floor((divx+1)*divlen)
local z1 = minp.z + math.floor((divz+1)*divlen)
local divs = (maxp.x - minp.x) / divlen + 1;
for divx = 0, divs - 1 do
for divz = 0, divs - 1 do
local x0 = minp.x + math.floor((divx + 0) * divlen)
local z0 = minp.z + math.floor((divz + 0) * divlen)
local x1 = minp.x + math.floor((divx + 1) * divlen)
local z1 = minp.z + math.floor((divz + 1) * divlen)
-- Determine roccia amount from perlin noise
local roccia_amount = math.floor(perlin1:get2d({x=x0, y=z0}) ^ 2 * 2)
local roccia_amount = math.floor(perlin1:get2d({ x = x0, y = z0 }) ^ 2 * 2)
-- Find random positions for roccias based on this random
local pr = PseudoRandom(seed+1)
for i=0,roccia_amount do
local pr = PseudoRandom(seed + 1)
for i = 0, roccia_amount do
local x = pr:next(x0, x1)
local z = pr:next(z0, z1)
-- Find ground level (0...15)
local ground_y = nil
for y=30,0,-1 do
if minetest.get_node({x=x,y=y,z=z}).name ~= "air" then
for y = 30, 0, -1 do
if minetest.get_node({ x = x, y = y, z = z }).name ~= "air" then
ground_y = y
break
end
end
if ground_y then
local p = {x=x,y=ground_y+1,z=z}
local p = { x = x, y = ground_y + 1, z = z }
local nn = minetest.get_node(p).name
-- Check if the node can be replaced
if minetest.registered_nodes[nn] and
minetest.registered_nodes[nn].buildable_to then
nn = minetest.get_node({x=x,y=ground_y,z=z}).name
nn = minetest.get_node({ x = x, y = ground_y, z = z }).name
-- If desert sand, add dry shrub
if nn == "default:dirt_with_grass" then
minetest.set_node(p,{name="summer:roccia_"..pr:next(1,2), param2=math.random(0,3)})
minetest.set_node(p, {
name = "summer:roccia_" .. pr:next(1, 2),
param2 = math.random(0,
3)
})
elseif nn == "default:desert_sand" then
minetest.set_node(p,{name="summer:desert_roccia_"..pr:next(1,2), param2=math.random(0,3)})
minetest.set_node(p,
{ name = "summer:desert_roccia_" .. pr:next(1, 2), param2 = math.random(0, 3) })
end
end
end
end
end
end
@ -147,32 +151,32 @@ end)
--craft PIETRA
minetest.register_craft({
--craft PIETRA
minetest.register_craft({
output = '"summer:pietraA" 2',
recipe = {
{ "", "", "" },
{ "", "", "" },
{ "summer:pietra", "summer:desert_pietra", "" },
},
})
minetest.register_craft({
})
minetest.register_craft({
output = '"summer:pietraP" 2',
recipe = {
{ "", "", "" },
{ "", "", "" },
{ "summer:pietraA", "summer:desert_pietra", "" },
},
})
})
--craftitem PIETRA
--craftitem PIETRA
minetest.register_craftitem("summer:desert_pietra", {
description = "Desert Pietra",
inventory_image = "desert_pietra.png",
})
minetest.register_craftitem("summer:pietraA", {
minetest.register_craftitem("summer:pietraA", {
description = "pietraA",
inventory_image = "pietraA.png",
@ -182,9 +186,9 @@ minetest.register_craftitem("summer:pietra", {
inventory_image = "pietra.png",
})
minetest.register_craftitem("summer:pietraP", {
minetest.register_craftitem("summer:pietraP", {
description = "pietraP",
inventory_image = "pietraP.png",
})
-- craftitem MATTONE
-- craftitem MATTONE

View File

@ -1,12 +1,11 @@
local Porta_list = {
{ "Red Door", "red"},
{ "Orange Door", "orange"},
{ "Black Door", "black"},
{ "Yellow Door", "yellow"},
{ "Green Door", "green"},
{ "Blue Door", "blue"},
{ "Violet Door", "violet"},
{ "Red Door", "red" },
{ "Orange Door", "orange" },
{ "Black Door", "black" },
{ "Yellow Door", "yellow" },
{ "Green Door", "green" },
{ "Blue Door", "blue" },
{ "Violet Door", "violet" },
}
--[[ { S("Red Door"), "red"},
{ S("Orange Door"), "orange"},
@ -20,34 +19,34 @@ for i in ipairs(Porta_list) do
local portadesc = Porta_list[i][1]
local colour = Porta_list[i][2]
minetest.register_node("summer:porta_"..colour.."", {
description = portadesc.."",
minetest.register_node("summer:porta_" .. colour .. "", {
description = portadesc .. "",
drawtype = "mesh",
mesh = "porta_2.obj",
tiles = {"porta_"..colour..".png",
tiles = { "porta_" .. colour .. ".png",
},
inventory_image = "summer_p_"..colour..".png",
inventory_image = "summer_p_" .. colour .. ".png",
wield_image = "summer_p_"..colour..".png",
wield_image = "summer_p_" .. colour .. ".png",
paramtype = "light",
paramtype2 = "facedir",
sunlight_propagates = true,
walkable = true,
selection_box = {
type = "fixed",
fixed = { -0.40, -0.5,-0.5,- 0.5,1.5, 0.5 },
fixed = { -0.40, -0.5, -0.5, -0.5, 1.5, 0.5 },
},
collision_box = {
type = "fixed",
fixed = { -0.40, -0.5,-0.5,- 0.5,1.5, 0.5 },
fixed = { -0.40, -0.5, -0.5, -0.5, 1.5, 0.5 },
},
groups = {snappy=2,cracky=3,oddly_breakable_by_hand=3,not_in_creative_inventory=1},
groups = { snappy = 2, cracky = 3, oddly_breakable_by_hand = 3, not_in_creative_inventory = 1 },
sounds = default.node_sound_wood_defaults(),
--sound_close="summer_porta_ch",
drop = "summer:porta_"..colour.."_ch",
drop = "summer:porta_" .. colour .. "_ch",
on_rightclick = function(pos, node, clicker)
node.name = "summer:porta_"..colour.."_ch"
node.name = "summer:porta_" .. colour .. "_ch"
minetest.set_node(pos, node)
minetest.sound_play("summer_porta_ch", {
@ -60,33 +59,33 @@ for i in ipairs(Porta_list) do
})
minetest.register_node("summer:porta_"..colour.."_ch", {
description = portadesc.." ch",
minetest.register_node("summer:porta_" .. colour .. "_ch", {
description = portadesc .. " ch",
drawtype = "mesh",
mesh = "porta.obj",
tiles = {"porta_"..colour..".png",
tiles = { "porta_" .. colour .. ".png",
},
inventory_image = "summer_p_"..colour..".png",
inventory_image = "summer_p_" .. colour .. ".png",
wield_image = "summer_p_"..colour..".png",
wield_image = "summer_p_" .. colour .. ".png",
paramtype = "light",
paramtype2 = "facedir",
sunlight_propagates = true,
walkable = true,
selection_box = {
type = "fixed",
fixed = { -0.5, -0.5, 0.40, 0.5,1.5, 0.5},
fixed = { -0.5, -0.5, 0.40, 0.5, 1.5, 0.5 },
},
collision_box = {
type = "fixed",
fixed = { -0.5, -0.5, 0.40, 0.5,1.5, 0.5},
fixed = { -0.5, -0.5, 0.40, 0.5, 1.5, 0.5 },
},
groups = {snappy=2,cracky=3,oddly_breakable_by_hand=3, not_in_creative_inventory=0},
groups = { snappy = 2, cracky = 3, oddly_breakable_by_hand = 3, not_in_creative_inventory = 0 },
sounds = default.node_sound_wood_defaults(),
drop = "summer:porta_"..colour.."_ch",
drop = "summer:porta_" .. colour .. "_ch",
on_rightclick = function(pos, node, clicker)
node.name = "summer:porta_"..colour..""
node.name = "summer:porta_" .. colour .. ""
minetest.set_node(pos, node)
minetest.sound_play("summer_porta_op", {
to_player = "",
@ -96,7 +95,4 @@ minetest.register_node("summer:porta_"..colour.."_ch", {
})
end,
})
end

View File

@ -1,23 +1,23 @@
local Portacenere_list = {
{ "Red Portacenere", "red"},
{ "Orange Portacenere", "orange"},
{ "Black Portacenere", "black"},
{ "Yellow Portacenere", "yellow"},
{ "Green Portacenere", "green"},
{ "Blue Portacenere", "blue"},
{ "Violet Portacenere", "violet"},
{ "White Portacenere", "white"},
{ "Red Portacenere", "red" },
{ "Orange Portacenere", "orange" },
{ "Black Portacenere", "black" },
{ "Yellow Portacenere", "yellow" },
{ "Green Portacenere", "green" },
{ "Blue Portacenere", "blue" },
{ "Violet Portacenere", "violet" },
{ "White Portacenere", "white" },
}
for i in ipairs(Portacenere_list) do
local Portaceneredesc = Portacenere_list[i][1]
local colour = Portacenere_list[i][2]
minetest.register_node("summer:Portacenere_"..colour.."", {
description = Portaceneredesc.."",
minetest.register_node("summer:Portacenere_" .. colour .. "", {
description = Portaceneredesc .. "",
drawtype = "mesh",
mesh = "portacenere_o.obj",
tiles = {"portacenere_"..colour..".png",
tiles = { "portacenere_" .. colour .. ".png",
},
-- inventory_image = "summer_ombo_n_"..colour..".png",
@ -29,23 +29,23 @@ for i in ipairs(Portacenere_list) do
walkable = false,
selection_box = {
type = "fixed",
fixed = { -0.130, -0.5, -0.130, 0.25,-0.25, 0},
fixed = { -0.130, -0.5, -0.130, 0.25, -0.25, 0 },
},
groups = {snappy=2,cracky=3,oddly_breakable_by_hand=3,not_in_creative_inventory = 0},
groups = { snappy = 2, cracky = 3, oddly_breakable_by_hand = 3, not_in_creative_inventory = 0 },
--sounds = default.node_sound_glass_defaults(),
drop = "summer:Portacenere_"..colour.."_ch",
drop = "summer:Portacenere_" .. colour .. "_ch",
on_rightclick = function(pos, node, clicker)
node.name = "summer:Portacenere_"..colour.."_ch"
node.name = "summer:Portacenere_" .. colour .. "_ch"
minetest.set_node(pos, node)
end,
})
minetest.register_node("summer:Portacenere_"..colour.."_ch", {
description = Portaceneredesc.." ch",
minetest.register_node("summer:Portacenere_" .. colour .. "_ch", {
description = Portaceneredesc .. " ch",
drawtype = "mesh",
mesh = "portacenere_c.obj",
tiles = {"portacenere_"..colour..".png",
tiles = { "portacenere_" .. colour .. ".png",
},
-- inventory_image = "summer_ombc_n_"..colour..".png",
@ -57,16 +57,14 @@ minetest.register_node("summer:Portacenere_"..colour.."_ch", {
walkable = false,
selection_box = {
type = "fixed",
fixed = { -0.130, -0.5, -0.130, 0.25,-0.25, 0 },
fixed = { -0.130, -0.5, -0.130, 0.25, -0.25, 0 },
},
groups = {snappy=2,cracky=3,oddly_breakable_by_hand=3, not_in_creative_inventory=1},
groups = { snappy = 2, cracky = 3, oddly_breakable_by_hand = 3, not_in_creative_inventory = 1 },
--sounds = default.node_sound_glass_defaults(),
drop = "summer:Portacenere_"..colour.."ch",
drop = "summer:Portacenere_" .. colour .. "ch",
on_rightclick = function(pos, node, clicker)
node.name = "summer:Portacenere_"..colour..""
node.name = "summer:Portacenere_" .. colour .. ""
minetest.set_node(pos, node)
end,
})
end

View File

@ -1,25 +1,19 @@
--_swap tool____________
minetest.register_on_punchnode(function(pos, node, puncher, pointed_thing)
pos.y = pos.y
pos.y = pos.y --Непонятно зачем?
local name = minetest.get_node(pos).name
if name ~= "default:sand"
and name ~= "default:silver_sand"
if name ~= "default:sand" and name ~= "default:silver_sand"
and name ~= "default:desert_sand" then
return
end
pos.y = pos.y
if puncher:get_wielded_item():get_name() == "summer:rake"
then
if puncher:get_wielded_item():get_name() == "summer:rake" then
minetest.remove_node(pos)
node.name = "summer:sabbia_mare"
minetest.set_node(pos, node)
minetest.sound_play("summer_n_swap", {
to_player = "",
gain = 2.0,})
end
end )
minetest.sound_play("summer_n_swap",{pos=pos, max_hear_distance=10})
end
end )
--SABBIA
@ -38,12 +32,4 @@ groups = {crumbly = 3, falling_node = 1, sand = 1},
minetest.register_tool("summer:rake", {
description = "rake",
inventory_image = "rake.png",
[[on_place = function(itemstack, user, pointed_thing)
minetest.sound_play("summer_n_swap_2", {
to_player = user:get_player_name() ,
gain = 2.0
})]]
})

View File

@ -16,7 +16,7 @@ end
local function get_velocity(v, yaw, y)
local x = -math.sin(yaw) * v
local z = math.cos(yaw) * v
return {x = x, y = y, z = z}
return { x = x, y = y, z = z }
end
@ -24,29 +24,28 @@ local function get_v(v)
return math.sqrt(v.x ^ 2 + v.z ^ 2)
end
local function reg_salvag(color)
local salvag_item_name = "summer:salvag_" .. color .. "_item"
local salvag_ent_name = "summer:salvag_" .. color .. "_entity"
local salvag_item_name = "summer:salvag_"..color.."_item"
local salvag_ent_name = "summer:salvag_"..color.."_entity"
--
-- Boat entity
--
--
-- Boat entity
--
local salvag = {
local salvag = {
physical = true,
collisionbox = {-0.5, -0.35, -0.5, 0.5, 0.3, 0.5},
collisionbox = { -0.5, -0.35, -0.5, 0.5, 0.3, 0.5 },
visual = "mesh",
mesh = "salvagl.obj",
textures = {"summer_salvag_"..color..".png" },
textures = { "summer_salvag_" .. color .. ".png" },
driver = nil,
v = 0,
last_v = 0,
removed = false
}
}
function salvag.on_rightclick(self, clicker)
function salvag.on_rightclick(self, clicker)
if not clicker or not clicker:is_player() then
return
end
@ -55,9 +54,9 @@ function salvag.on_rightclick(self, clicker)
self.driver = nil
clicker:set_detach()
default.player_attached[name] = false
default.player_set_animation(clicker, "stand" , 30)
default.player_set_animation(clicker, "stand", 30)
local pos = clicker:getpos()
pos = {x = pos.x, y = pos.y + 0.2, z = pos.z}
pos = { x = pos.x, y = pos.y + 0.2, z = pos.z }
minetest.after(0.1, function()
clicker:setpos(pos)
end)
@ -72,31 +71,28 @@ function salvag.on_rightclick(self, clicker)
end
self.driver = clicker
clicker:set_attach(self.object, "",
{x = 0, y = 11, z = -3}, {x = 0, y = 0, z = 0})
{ x = 0, y = 11, z = -3 }, { x = 0, y = 0, z = 0 })
default.player_attached[name] = true
minetest.after(0.2, function()
default.player_set_animation(clicker, "sit" , 30)
default.player_set_animation(clicker, "sit", 30)
end)
self.object:setyaw(clicker:get_look_yaw() - math.pi / 2)
end
end
end
function salvag.on_activate(self, staticdata, dtime_s)
self.object:set_armor_groups({immortal = 1})
function salvag.on_activate(self, staticdata, dtime_s)
self.object:set_armor_groups({ immortal = 1 })
if staticdata then
self.v = tonumber(staticdata)
end
self.last_v = self.v
end
end
function salvag.get_staticdata(self)
function salvag.get_staticdata(self)
return tostring(self.v)
end
end
function salvag.on_punch(self, puncher)
function salvag.on_punch(self, puncher)
if not puncher or not puncher:is_player() or self.removed then
return
end
@ -113,17 +109,16 @@ function salvag.on_punch(self, puncher)
end)
if not minetest.setting_getbool("creative_mode") then
local inv = puncher:get_inventory()
if inv:room_for_item("main", "summer:salvag_"..color.."_item") then
inv:add_item("main", "summer:salvag_"..color.."_item")
if inv:room_for_item("main", "summer:salvag_" .. color .. "_item") then
inv:add_item("main", "summer:salvag_" .. color .. "_item")
else
minetest.add_item(self.object:getpos(), salvag_item_name)
end
end
end
end
end
function salvag.on_step(self, dtime)
function salvag.on_step(self, dtime)
self.v = get_v(self.object:getvelocity()) * get_sign(self.v)
if self.driver then
local ctrl = self.driver:get_player_control()
@ -155,7 +150,7 @@ function salvag.on_step(self, dtime)
local s = get_sign(self.v)
self.v = self.v - 0.02 * s
if s ~= get_sign(self.v) then
self.object:setvelocity({x = 0, y = 0, z = 0})
self.object:setvelocity({ x = 0, y = 0, z = 0 })
self.v = 0
return
end
@ -165,15 +160,15 @@ function salvag.on_step(self, dtime)
local p = self.object:getpos()
p.y = p.y - 0.5
local new_velo = {x = 0, y = 0, z = 0}
local new_acce = {x = 0, y = 0, z = 0}
local new_velo = { x = 0, y = 0, z = 0 }
local new_acce = { x = 0, y = 0, z = 0 }
if not is_water(p) then
local nodedef = minetest.registered_nodes[minetest.get_node(p).name]
if (not nodedef) or nodedef.walkable then
self.v = 0
new_acce = {x = 0, y = 1, z = 0}
new_acce = { x = 0, y = 1, z = 0 }
else
new_acce = {x = 0, y = -9.8, z = 0}
new_acce = { x = 0, y = -9.8, z = 0 }
end
new_velo = get_velocity(self.v, self.object:getyaw(),
self.object:getvelocity().y)
@ -185,14 +180,14 @@ function salvag.on_step(self, dtime)
if y >= 5 then
y = 5
elseif y < 0 then
new_acce = {x = 0, y = 20, z = 0}
new_acce = { x = 0, y = 20, z = 0 }
else
new_acce = {x = 0, y = 5, z = 0}
new_acce = { x = 0, y = 5, z = 0 }
end
new_velo = get_velocity(self.v, self.object:getyaw(), y)
self.object:setpos(self.object:getpos())
else
new_acce = {x = 0, y = 0, z = 0}
new_acce = { x = 0, y = 0, z = 0 }
if math.abs(self.object:getvelocity().y) < 1 then
local pos = self.object:getpos()
pos.y = math.floor(pos.y) + 0.5
@ -207,17 +202,16 @@ function salvag.on_step(self, dtime)
end
self.object:setvelocity(new_velo)
self.object:setacceleration(new_acce)
end
end
minetest.register_entity("summer:salvag_" .. color .. "", salvag)
minetest.register_entity("summer:salvag_"..color.."", salvag)
minetest.register_craftitem(salvag_item_name, {
description = "salvagente ("..color..")",
inventory_image = "summer_salvag_"..color.."_inv.png",
wield_image = "summer_salvag_"..color.."_inv.png",
wield_scale = {x = 2, y = 2, z = 1},
minetest.register_craftitem(salvag_item_name, {
description = "salvagente (" .. color .. ")",
inventory_image = "summer_salvag_" .. color .. "_inv.png",
wield_image = "summer_salvag_" .. color .. "_inv.png",
wield_scale = { x = 2, y = 2, z = 1 },
liquids_pointable = true,
on_place = function(itemstack, placer, pointed_thing)
@ -228,43 +222,40 @@ minetest.register_craftitem(salvag_item_name, {
return
end
pointed_thing.under.y = pointed_thing.under.y + 0.5
minetest.add_entity(pointed_thing.under, "summer:salvag_"..color.."")
minetest.add_entity(pointed_thing.under, "summer:salvag_" .. color .. "")
if not minetest.setting_getbool("creative_mode") then
itemstack:take_item()
end
return itemstack
end,
})
minetest.register_craft({
})
minetest.register_craft({
output = salvag_item_name,
recipe = {
{"" , "" , "" },
{"group:leaves", "wool:"..color, "group:leaves"},
{"default:paper", "group:leaves", "default:paper"},
{ "", "", "" },
{ "group:leaves", "wool:" .. color, "group:leaves" },
{ "default:paper", "group:leaves", "default:paper" },
},
})
})
if minetest.get_modpath("cannabis") then
minetest.register_craft({
if minetest.get_modpath("cannabis") then
minetest.register_craft({
output = salvag_item_name,
recipe = {
{"" , "" , "" },
{"cannabis:canapa_plastic", "wool:"..color, "cannabis:canapa_plastic"},
{"cannabis:canapa_plastic", "cannabis:canapa_plastic", "cannabis:canapa_plastic"},
{ "", "", "" },
{ "cannabis:canapa_plastic", "wool:" .. color, "cannabis:canapa_plastic" },
{ "cannabis:canapa_plastic", "cannabis:canapa_plastic", "cannabis:canapa_plastic" },
},
})
end
})
end
end
colors = {
"black", "red", "green", "blue", "yellow", "violet","orange",
"black", "red", "green", "blue", "yellow", "violet", "orange",
}
for _,color in ipairs(colors) do
for _, color in ipairs(colors) do
reg_salvag(color)
end

View File

@ -1,23 +1,22 @@
local sdraia_list = {
{ "Red sdraia", "red"},
{ "Orange sdraia", "orange"},
{ "Black sdraia", "black"},
{ "Yellow sdraia", "yellow"},
{ "Green sdraia", "green"},
{ "Blue sdraia", "blue"},
{ "Violet sdraia", "violet"},
local sdraia_list = {
{ "Red sdraia", "red" },
{ "Orange sdraia", "orange" },
{ "Black sdraia", "black" },
{ "Yellow sdraia", "yellow" },
{ "Green sdraia", "green" },
{ "Blue sdraia", "blue" },
{ "Violet sdraia", "violet" },
}
for i in ipairs(sdraia_list) do
local sdraiadesc = sdraia_list[i][1]
local colour = sdraia_list[i][2]
local sleep_in_sdraia = function( pos, node, clicker, itemstack, pointed_thing )
if( not( clicker ) or not( node ) or not( node.name ) or not( pos ) or not( minetest.allow_sit( clicker))) then
local sleep_in_sdraia = function(pos, node, clicker, itemstack, pointed_thing)
if (not (clicker) or not (node) or not (node.name) or not (pos) or not (minetest.allow_sit(clicker))) then
return;
end
local animation = default.player_get_animation( clicker );
local animation = default.player_get_animation(clicker);
local pname = clicker:get_player_name();
local place_name = 'place';
@ -27,176 +26,174 @@ for i in ipairs(sdraia_list) do
local new_animation = 'lay';
-- let players get back up
if( animation and animation.animation=="lay" ) then
if (animation and animation.animation == "lay") then
default.player_attached[pname] = false
clicker:setpos({x=pos.x,y=pos.y-0.5,z=pos.z})
clicker:set_eye_offset({x=0,y=0,z=0}, {x=0,y=0,z=0})
clicker:set_physics_override({1, 1, 1})
clicker:setpos({ x = pos.x, y = pos.y - 0.5, z = pos.z })
clicker:set_eye_offset({ x = 0, y = 0, z = 0 }, { x = 0, y = 0, z = 0 })
clicker:set_physics_override({ 1, 1, 1 })
default.player_set_animation(clicker, "stand", 30)
minetest.chat_send_player( pname, 'You stand up again.');
minetest.chat_send_player(pname, 'You stand up again.');
return;
end
local second_node_pos = {x=pos.x, y=pos.y, z=pos.z};
local second_node_pos = { x = pos.x, y = pos.y, z = pos.z };
-- the node that will contain the head of the player
local p = {x=pos.x, y=pos.y, z=pos.z};
local p = { x = pos.x, y = pos.y, z = pos.z };
-- the player's head is pointing in this direction
local dir = node.param2;
-- it would be odd to sleep in half a sdraia
if( node.name=="summer:sdraia_"..colour.."" ) then
if( node.param2==0 ) then
second_node_pos.z = pos.z-1;
elseif( node.param2==1) then
second_node_pos.x = pos.x-1;
elseif( node.param2==2) then
second_node_pos.z = pos.z+1;
elseif( node.param2==3) then
second_node_pos.x = pos.x+1;
if (node.name == "summer:sdraia_" .. colour .. "") then
if (node.param2 == 0) then
second_node_pos.z = pos.z - 1;
elseif (node.param2 == 1) then
second_node_pos.x = pos.x - 1;
elseif (node.param2 == 2) then
second_node_pos.z = pos.z + 1;
elseif (node.param2 == 3) then
second_node_pos.x = pos.x + 1;
end
local node2 = minetest.get_node( second_node_pos );
if( not( node2 ) or not( node2.param2 ) or not( node.param2 )
or node2.name ~= "summer:sdraia_"..colour..""
or node2.param2 ~= node.param2 ) then
local node2 = minetest.get_node(second_node_pos);
if (not (node2) or not (node2.param2) or not (node.param2)
or node2.name ~= "summer:sdraia_" .. colour .. ""
or node2.param2 ~= node.param2) then
allow_sleep = false;
else
allow_sleep = true;
end
place_name = "sdraia_"..colour.."";
place_name = "sdraia_" .. colour .. "";
-- if the player clicked on the foot of the sdraia, locate the head
elseif( node.name=='summer:sdraia' ) then
if( node.param2==2 ) then
second_node_pos.z = pos.z-1;
elseif( node.param2==3) then
second_node_pos.x = pos.x-1;
elseif( node.param2==0) then
second_node_pos.z = pos.z+1;
elseif( node.param2==1) then
second_node_pos.x = pos.x+1;
elseif (node.name == 'summer:sdraia') then
if (node.param2 == 2) then
second_node_pos.z = pos.z - 1;
elseif (node.param2 == 3) then
second_node_pos.x = pos.x - 1;
elseif (node.param2 == 0) then
second_node_pos.z = pos.z + 1;
elseif (node.param2 == 1) then
second_node_pos.x = pos.x + 1;
end
local node2 = minetest.get_node( second_node_pos );
if( not( node2 ) or not( node2.param2 ) or not( node.param2 )
local node2 = minetest.get_node(second_node_pos);
if (not (node2) or not (node2.param2) or not (node.param2)
or node2.name ~= 'summer:sdraia'
or node2.param2 ~= node.param2 ) then
or node2.param2 ~= node.param2) then
allow_sleep = false;
else
allow_sleep = true;
end
if( allow_sleep==true ) then
p = {x=second_node_pos.x, y=second_node_pos.y, z=second_node_pos.z};
if (allow_sleep == true) then
p = { x = second_node_pos.x, y = second_node_pos.y, z = second_node_pos.z };
end
place_name = 'sdraia';
elseif( node.name=='summer:sleeping_mat' or node.name=='summer:straw_mat') then
elseif (node.name == 'summer:sleeping_mat' or node.name == 'summer:straw_mat') then
place_name = 'mat';
dir = node.param2;
allow_sleep = false;
-- search for a second mat right next to this one
local offset = {{x=0,z=-1}, {x=-1,z=0}, {x=0,z=1}, {x=1,z=0}};
for i,off in ipairs( offset ) do
node2 = minetest.get_node( {x=pos.x+off.x, y=pos.y, z=pos.z+off.z} );
if( node2.name == 'summer:sleeping_mat' or node2.name=='summer:straw_mat' ) then
local offset = { { x = 0, z = -1 }, { x = -1, z = 0 }, { x = 0, z = 1 }, { x = 1, z = 0 } };
for i, off in ipairs(offset) do
node2 = minetest.get_node({ x = pos.x + off.x, y = pos.y, z = pos.z + off.z });
if (node2.name == 'summer:sleeping_mat' or node2.name == 'summer:straw_mat') then
-- if a second mat is found, sleeping is possible
allow_sleep = true;
dir = i-1;
dir = i - 1;
end
end
end
-- set the right height for the sdraia
if( place_name=='sdraia' ) then
p.y = p.y-0.4;
if (place_name == 'sdraia') then
p.y = p.y - 0.4;
end
if( allow_sleep==true ) then
if (allow_sleep == true) then
-- set the right position (middle of the sdraia)
if( dir==0 ) then
p.z = p.z-0.5;
elseif( dir==1 ) then
p.x = p.x-0.5;
elseif( dir==2 ) then
p.z = p.z+0.5;
elseif( dir==3 ) then
p.x = p.x+0.5;
if (dir == 0) then
p.z = p.z - 0.5;
elseif (dir == 1) then
p.x = p.x - 0.5;
elseif (dir == 2) then
p.z = p.z + 0.5;
elseif (dir == 3) then
p.x = p.x + 0.5;
end
end
if( default.player_attached[pname] and animation.animation=="sit") then
if (default.player_attached[pname] and animation.animation == "sit") then
-- just changing the animation...
if( allow_sleep==true ) then
if (allow_sleep == true) then
default.player_set_animation(clicker, "lay", 30)
clicker:set_eye_offset({x=0,y=-14,z=2}, {x=0,y=0,z=0})
minetest.chat_send_player( pname, 'you lay A right-click will wake you up.');
clicker:set_eye_offset({ x = 0, y = -14, z = 2 }, { x = 0, y = 0, z = 0 })
minetest.chat_send_player(pname, 'you lay A right-click will wake you up.');
return;
-- no sleeping on this place
else
default.player_attached[pname] = false
clicker:setpos({x=pos.x,y=pos.y-0.5,z=pos.z})
clicker:set_eye_offset({x=0,y=0,z=0}, {x=0,y=0,z=0})
clicker:set_physics_override({1, 1, 1})
clicker:setpos({ x = pos.x, y = pos.y - 0.5, z = pos.z })
clicker:set_eye_offset({ x = 0, y = 0, z = 0 }, { x = 0, y = 0, z = 0 })
clicker:set_physics_override({ 1, 1, 1 })
default.player_set_animation(clicker, "stand", 30)
minetest.chat_send_player( pname, 'That was enough sitting around for now. You stand up again.');
minetest.chat_send_player(pname, 'That was enough sitting around for now. You stand up again.');
return;
end
end
clicker:set_eye_offset({x=0,y=3,z=2}, {x=0,y=3,z=0})
clicker:setpos( p );
clicker:set_eye_offset({ x = 0, y = 3, z = 2 }, { x = 0, y = 3, z = 0 })
clicker:setpos(p);
default.player_set_animation(clicker, new_animation, 30)
clicker:set_physics_override({0,0,0})
clicker:set_physics_override({ 0, 0, 0 })
default.player_attached[pname] = true
return;
end
minetest.register_node("summer:sdraia_"..colour.."", {
description = sdraiadesc.."",
minetest.register_node("summer:sdraia_" .. colour .. "", {
description = sdraiadesc .. "",
drawtype = "mesh",
mesh = "sdraia.obj",
tiles = {"sdraia_"..colour..".png",
tiles = { "sdraia_" .. colour .. ".png",
},
inventory_image = "sdraia_"..colour.."_inv.png",
inventory_image = "sdraia_" .. colour .. "_inv.png",
wield_image = "sdraia_"..colour..".png" ,
wield_image = "sdraia_" .. colour .. ".png",
paramtype = "light",
paramtype2 = "facedir",
selection_box = {
type = "fixed",
fixed = { 0.4, 0.1,1.0, -0.4,-0.49, -1.0 },
fixed = { 0.4, 0.1, 1.0, -0.4, -0.49, -1.0 },
},
collision_box = {
type = "fixed",
fixed = {
{0.4, 0.1,1.0, -0.4,-0.49, -1.0},
{ 0.4, 0.1, 1.0, -0.4, -0.49, -1.0 },
},
},
is_ground_content = false,
groups = {cracky=3,oddly_breakable_by_hand=3,not_in_creative_inventory=0},
groups = { cracky = 3, oddly_breakable_by_hand = 3, not_in_creative_inventory = 0 },
--sounds = default.node_sound_wood_defaults(),
drop = "summer:sdraia_"..colour.."",
drop = "summer:sdraia_" .. colour .. "",
on_rightclick = function(pos, node, clicker, itemstack, pointed_thing)
return sleep_in_sdraia( pos, node, clicker, itemstack, pointed_thing );
return sleep_in_sdraia(pos, node, clicker, itemstack, pointed_thing);
end
})
minetest.allow_sit = function( player )
minetest.allow_sit = function(player)
-- no check possible
if( not( player.get_player_velocity )) then
if (not (player.get_player_velocity)) then
return true;
end
local velo = player:get_player_velocity();
if( not( velo )) then
if (not (velo)) then
return false;
end
local max_velo = 0.0010;
if( math.abs(velo.x) < max_velo
if (math.abs(velo.x) < max_velo
and math.abs(velo.y) < max_velo
and math.abs(velo.z) < max_velo ) then
and math.abs(velo.z) < max_velo) then
return true;
end
return false;

View File

@ -9,7 +9,7 @@ minetest.register_node("summer:angstairA", {
"graniteA.png",
"graniteA.png"
},
--inventory_image = "s_s_A.png",
--inventory_image = "s_s_A.png",
--wield_image = "s_s_A.png",
drawtype = "nodebox",
paramtype = "light",
@ -17,13 +17,13 @@ minetest.register_node("summer:angstairA", {
node_box = {
type = "fixed",
fixed = {
{-0.5, -0.5, -0.5, 0, 0.5, 0.5}, -- NodeBox1
{-0.5, -0.5, 0, 0.5, 0.5, 0.5}, -- NodeBox2
{-0.5, -0.5, -0.5, 0.5, 0, 0.5}, -- NodeBox3
{ -0.5, -0.5, -0.5, 0, 0.5, 0.5 }, -- NodeBox1
{ -0.5, -0.5, 0, 0.5, 0.5, 0.5 }, -- NodeBox2
{ -0.5, -0.5, -0.5, 0.5, 0, 0.5 }, -- NodeBox3
}
},
--material = minetest.digprop_constanttime(1),
groups = {cracky = 3, stone = 1},
groups = { cracky = 3, stone = 1 },
--drop ='"summer:mattoneA" 7',
--legacy_mineral = true,
sounds = default.node_sound_stone_defaults(),
@ -33,14 +33,14 @@ minetest.register_node("summer:angstairA", {
minetest.register_craft({
output = 'summer:angstairA',
recipe = {
{'summer:mattoneA','summer:mattoneA',' '},
{'summer:mattoneA','summer:mattoneA',' '},
{'summer:mattoneA','summer:mattoneA','summer:mattoneA'},
{ 'summer:mattoneA', 'summer:mattoneA', ' ' },
{ 'summer:mattoneA', 'summer:mattoneA', ' ' },
{ 'summer:mattoneA', 'summer:mattoneA', 'summer:mattoneA' },
}
})
minetest.register_node("summer:angstairA2", {
description = "Spigolo_scala_granito_bianco",
description = "Spigolo_scala_granito_bianco",
tiles = {
"graniteA.png",
"graniteA.png",
@ -55,12 +55,12 @@ description = "Spigolo_scala_granito_bianco",
node_box = {
type = "fixed",
fixed = {
{-0.5, -0.5, 0, 0, 0.5, 0.5}, -- NodeBox2
{-0.5, -0.5, -0.5, 0.5, 0, 0.5}, -- NodeBox3
{ -0.5, -0.5, 0, 0, 0.5, 0.5 }, -- NodeBox2
{ -0.5, -0.5, -0.5, 0.5, 0, 0.5 }, -- NodeBox3
}
},
-- material = minetest.digprop_constanttime(1),
groups = {cracky = 3, stone = 1},
groups = { cracky = 3, stone = 1 },
--drop ='summer:mattoneA 5',
--legacy_mineral = true,
sounds = default.node_sound_stone_defaults(),
@ -69,9 +69,9 @@ description = "Spigolo_scala_granito_bianco",
minetest.register_craft({
output = 'summer:angstairA2',
recipe = {
{' ','summer:mattoneA',' '},
{' ','summer:mattoneA',' '},
{'summer:mattoneA','summer:mattoneA','summer:mattoneA'},
{ ' ', 'summer:mattoneA', ' ' },
{ ' ', 'summer:mattoneA', ' ' },
{ 'summer:mattoneA', 'summer:mattoneA', 'summer:mattoneA' },
}
})
minetest.register_node("summer:stairA", {
@ -90,13 +90,13 @@ minetest.register_node("summer:stairA", {
node_box = {
type = "fixed",
fixed = {
{-0.5, -0.5, -0.5, 0.5, 0, 0.5}, -- Node1
{-0.5, -0.5, 0, 0.5, 0.5, 0.5}, -- Node2
{ -0.5, -0.5, -0.5, 0.5, 0, 0.5 }, -- Node1
{ -0.5, -0.5, 0, 0.5, 0.5, 0.5 }, -- Node2
}
},
-- material = minetest.digprop_constanttime(1),
groups = {cracky = 3, stone = 1},
-- drop ='summer:mattoneA 6',
groups = { cracky = 3, stone = 1 },
-- drop ='summer:mattoneA 6',
--legacy_mineral = true,
sounds = default.node_sound_stone_defaults(),
})
@ -104,13 +104,13 @@ minetest.register_node("summer:stairA", {
minetest.register_craft({
output = 'summer:stairA',
recipe = {
{'summer:mattoneA',' ',' '},
{'summer:mattoneA','summer:mattoneA',' '},
{'summer:mattoneA','summer:mattoneA','summer:mattoneA'},
{ 'summer:mattoneA', ' ', ' ' },
{ 'summer:mattoneA', 'summer:mattoneA', ' ' },
{ 'summer:mattoneA', 'summer:mattoneA', 'summer:mattoneA' },
}
})
minetest.register_node("summer:battiscopaA", {
description = "Battiscopa_granito_bianco",
description = "Battiscopa_granito_bianco",
tiles = {
"graniteA.png",
"graniteA.png",
@ -125,14 +125,14 @@ description = "Battiscopa_granito_bianco",
node_box = {
type = "fixed",
fixed = {
{-0.5, -0.5, -0.5, 0.5, -0.25, 0.5}, -- NodeBox3
{-0.5, -0.5, -0.375, 0.5, 0.25, 0.5}, -- NodeBox4
{-0.5, 0, -0.5, 0.5, 0.5, 0.5}, -- NodeBox5
{ -0.5, -0.5, -0.5, 0.5, -0.25, 0.5 }, -- NodeBox3
{ -0.5, -0.5, -0.375, 0.5, 0.25, 0.5 }, -- NodeBox4
{ -0.5, 0, -0.5, 0.5, 0.5, 0.5 }, -- NodeBox5
}
},
-- material = minetest.digprop_constanttime(1),
groups = {cracky = 3, stone = 1},
-- drop ='summer:mattoneA 8',
groups = { cracky = 3, stone = 1 },
-- drop ='summer:mattoneA 8',
--legacy_mineral = true,
sounds = default.node_sound_stone_defaults(),
})
@ -140,9 +140,9 @@ description = "Battiscopa_granito_bianco",
minetest.register_craft({
output = 'summer:battiscopaA',
recipe = {
{'summer:mattoneA','summer:mattoneA','summer:mattoneA'},
{'summer:mattoneA','summer:mattoneA',' '},
{'summer:mattoneA','summer:mattoneA','summer:mattoneA'},
{ 'summer:mattoneA', 'summer:mattoneA', 'summer:mattoneA' },
{ 'summer:mattoneA', 'summer:mattoneA', ' ' },
{ 'summer:mattoneA', 'summer:mattoneA', 'summer:mattoneA' },
}
})
minetest.register_node("summer:slabA", {
@ -161,13 +161,13 @@ minetest.register_node("summer:slabA", {
node_box = {
type = "fixed",
fixed = {
{-0.5, -0.5, -0.5, 0.5, 0, 0.5}, -- Node1
{ -0.5, -0.5, -0.5, 0.5, 0, 0.5 }, -- Node1
-- {-0.5, -0.5, 0, 0.5, 0.5, 0.5}, -- Node2
}
},
-- material = minetest.digprop_constanttime(1),
groups = {cracky = 3, stone = 1},
-- drop ='summer:mattoneA 6',
groups = { cracky = 3, stone = 1 },
-- drop ='summer:mattoneA 6',
--legacy_mineral = true,
sounds = default.node_sound_stone_defaults(),
})
@ -175,9 +175,9 @@ minetest.register_node("summer:slabA", {
minetest.register_craft({
output = 'summer:slabA',
recipe = {
{' ',' ',' '},
{' ',' ',' '},
{'summer:mattoneA','summer:mattoneA','summer:mattoneA'},
{ ' ', ' ', ' ' },
{ ' ', ' ', ' ' },
{ 'summer:mattoneA', 'summer:mattoneA', 'summer:mattoneA' },
}
})
--P
@ -192,7 +192,7 @@ minetest.register_node("summer:angstairP", {
"graniteP.png",
"graniteP.png"
},
--inventory_image = "s_s_P.png",
--inventory_image = "s_s_P.png",
--wield_image = "s_s_P.png",
drawtype = "nodebox",
paramtype = "light",
@ -200,13 +200,13 @@ minetest.register_node("summer:angstairP", {
node_box = {
type = "fixed",
fixed = {
{-0.5, -0.5, -0.5, 0, 0.5, 0.5}, -- NodeBox1
{-0.5, -0.5, 0, 0.5, 0.5, 0.5}, -- NodeBox2
{-0.5, -0.5, -0.5, 0.5, 0, 0.5}, -- NodeBox3
{ -0.5, -0.5, -0.5, 0, 0.5, 0.5 }, -- NodeBox1
{ -0.5, -0.5, 0, 0.5, 0.5, 0.5 }, -- NodeBox2
{ -0.5, -0.5, -0.5, 0.5, 0, 0.5 }, -- NodeBox3
}
},
-- material = minetest.digprop_constanttime(1),
groups = {cracky = 3, stone = 1},
groups = { cracky = 3, stone = 1 },
--drop ='"summer:mattoneP" 7',
--legacy_mineral = true,
sounds = default.node_sound_stone_defaults(),
@ -216,14 +216,14 @@ minetest.register_node("summer:angstairP", {
minetest.register_craft({
output = 'summer:angstairP',
recipe = {
{'summer:mattoneP','summer:mattoneP',' '},
{'summer:mattoneP','summer:mattoneP',' '},
{'summer:mattoneP','summer:mattoneP','summer:mattoneP'},
{ 'summer:mattoneP', 'summer:mattoneP', ' ' },
{ 'summer:mattoneP', 'summer:mattoneP', ' ' },
{ 'summer:mattoneP', 'summer:mattoneP', 'summer:mattoneP' },
}
})
minetest.register_node("summer:angstairP2", {
description = "Spigolo_scala_granito_rosa",
description = "Spigolo_scala_granito_rosa",
tiles = {
"graniteP.png",
"graniteP.png",
@ -238,13 +238,13 @@ description = "Spigolo_scala_granito_rosa",
node_box = {
type = "fixed",
fixed = {
{-0.5, -0.5, 0, 0, 0.5, 0.5}, -- NodeBox2
{-0.5, -0.5, -0.5, 0.5, 0, 0.5}, -- NodeBox3
{ -0.5, -0.5, 0, 0, 0.5, 0.5 }, -- NodeBox2
{ -0.5, -0.5, -0.5, 0.5, 0, 0.5 }, -- NodeBox3
}
},
-- material = minetest.digprop_constanttime(1),
groups = {cracky = 3, stone = 1},
drop ='summer:mattoneP 5',
groups = { cracky = 3, stone = 1 },
drop = 'summer:mattoneP 5',
--legacy_mineral = true,
sounds = default.node_sound_stone_defaults(),
})
@ -252,9 +252,9 @@ description = "Spigolo_scala_granito_rosa",
minetest.register_craft({
output = 'summer:angstairP2',
recipe = {
{' ','summer:mattoneP',' '},
{' ','summer:mattoneP',' '},
{'summer:mattoneP','summer:mattoneP','summer:mattoneP'},
{ ' ', 'summer:mattoneP', ' ' },
{ ' ', 'summer:mattoneP', ' ' },
{ 'summer:mattoneP', 'summer:mattoneP', 'summer:mattoneP' },
}
})
minetest.register_node("summer:stairP", {
@ -273,12 +273,12 @@ minetest.register_node("summer:stairP", {
node_box = {
type = "fixed",
fixed = {
{-0.5, -0.5, -0.5, 0.5, 0, 0.5}, -- Node1
{-0.5, -0.5, 0, 0.5, 0.5, 0.5}, -- Node2
{ -0.5, -0.5, -0.5, 0.5, 0, 0.5 }, -- Node1
{ -0.5, -0.5, 0, 0.5, 0.5, 0.5 }, -- Node2
}
},
-- material = minetest.digprop_constanttime(1),
groups = {cracky = 3, stone = 1},
groups = { cracky = 3, stone = 1 },
--drop ='summer:mattoneP 6',
--legacy_mineral = true,
sounds = default.node_sound_stone_defaults(),
@ -287,13 +287,13 @@ minetest.register_node("summer:stairP", {
minetest.register_craft({
output = 'summer:stairP',
recipe = {
{'summer:mattoneP',' ',' '},
{'summer:mattoneP','summer:mattoneP',' '},
{'summer:mattoneP','summer:mattoneP','summer:mattoneP'},
{ 'summer:mattoneP', ' ', ' ' },
{ 'summer:mattoneP', 'summer:mattoneP', ' ' },
{ 'summer:mattoneP', 'summer:mattoneP', 'summer:mattoneP' },
}
})
minetest.register_node("summer:battiscopaP", {
description = "Battiscopa_granito_rosa",
description = "Battiscopa_granito_rosa",
tiles = {
"graniteP.png",
"graniteP.png",
@ -308,13 +308,13 @@ description = "Battiscopa_granito_rosa",
node_box = {
type = "fixed",
fixed = {
{-0.5, -0.5, -0.5, 0.5, -0.25, 0.5}, -- NodeBox3
{-0.5, -0.5, -0.375, 0.5, 0.25, 0.5}, -- NodeBox4
{-0.5, 0, -0.5, 0.5, 0.5, 0.5}, -- NodeBox5
{ -0.5, -0.5, -0.5, 0.5, -0.25, 0.5 }, -- NodeBox3
{ -0.5, -0.5, -0.375, 0.5, 0.25, 0.5 }, -- NodeBox4
{ -0.5, 0, -0.5, 0.5, 0.5, 0.5 }, -- NodeBox5
}
},
-- material = minetest.digprop_constanttime(1),
groups = {cracky = 3, stone = 1},
groups = { cracky = 3, stone = 1 },
--drop ='summer:mattoneP 8',
--legacy_mineral = true,
sounds = default.node_sound_stone_defaults(),
@ -323,9 +323,9 @@ description = "Battiscopa_granito_rosa",
minetest.register_craft({
output = 'summer:battiscopaP',
recipe = {
{'summer:mattoneP','summer:mattoneP','summer:mattoneP'},
{'summer:mattoneP','summer:mattoneP',' '},
{'summer:mattoneP','summer:mattoneP','summer:mattoneP'},
{ 'summer:mattoneP', 'summer:mattoneP', 'summer:mattoneP' },
{ 'summer:mattoneP', 'summer:mattoneP', ' ' },
{ 'summer:mattoneP', 'summer:mattoneP', 'summer:mattoneP' },
}
})
minetest.register_node("summer:slabP", {
@ -344,12 +344,12 @@ minetest.register_node("summer:slabP", {
node_box = {
type = "fixed",
fixed = {
{-0.5, -0.5, -0.5, 0.5, 0, 0.5}, -- Node1
{ -0.5, -0.5, -0.5, 0.5, 0, 0.5 }, -- Node1
-- {-0.5, -0.5, 0, 0.5, 0.5, 0.5}, -- Node2
}
},
-- material = minetest.digprop_constanttime(1),
groups = {cracky = 3, stone = 1},
groups = { cracky = 3, stone = 1 },
--drop ='summer:mattoneP 6',
--legacy_mineral = true,
sounds = default.node_sound_stone_defaults(),
@ -358,9 +358,9 @@ minetest.register_node("summer:slabP", {
minetest.register_craft({
output = 'summer:slabP',
recipe = {
{' ',' ',' '},
{' ',' ',' '},
{'summer:mattoneP','summer:mattoneP','summer:mattoneP'},
{ ' ', ' ', ' ' },
{ ' ', ' ', ' ' },
{ 'summer:mattoneP', 'summer:mattoneP', 'summer:mattoneP' },
}
})
--R
@ -375,7 +375,7 @@ minetest.register_node("summer:angstairR", {
"graniteR.png",
"graniteR.png"
},
--inventory_image = "s_s_R.png",
--inventory_image = "s_s_R.png",
--wield_image = "s_s_R.png",
drawtype = "nodebox",
paramtype = "light",
@ -383,14 +383,14 @@ minetest.register_node("summer:angstairR", {
node_box = {
type = "fixed",
fixed = {
{-0.5, -0.5, -0.5, 0, 0.5, 0.5}, -- NodeBox1
{-0.5, -0.5, 0, 0.5, 0.5, 0.5}, -- NodeBox2
{-0.5, -0.5, -0.5, 0.5, 0, 0.5}, -- NodeBox3
{ -0.5, -0.5, -0.5, 0, 0.5, 0.5 }, -- NodeBox1
{ -0.5, -0.5, 0, 0.5, 0.5, 0.5 }, -- NodeBox2
{ -0.5, -0.5, -0.5, 0.5, 0, 0.5 }, -- NodeBox3
}
},
-- material = minetest.digprop_constanttime(1),
groups = {cracky = 3, stone = 1},
drop ='"summer:mattoneR" 7',
groups = { cracky = 3, stone = 1 },
drop = '"summer:mattoneR" 7',
--legacy_mineral = true,
sounds = default.node_sound_stone_defaults(),
@ -399,14 +399,14 @@ minetest.register_node("summer:angstairR", {
minetest.register_craft({
output = 'summer:angstairR',
recipe = {
{'summer:mattoneR','summer:mattoneR',' '},
{'summer:mattoneR','summer:mattoneR',' '},
{'summer:mattoneR','summer:mattoneR','summer:mattoneR'},
{ 'summer:mattoneR', 'summer:mattoneR', ' ' },
{ 'summer:mattoneR', 'summer:mattoneR', ' ' },
{ 'summer:mattoneR', 'summer:mattoneR', 'summer:mattoneR' },
}
})
minetest.register_node("summer:angstairR2", {
description = "Spigolo_scala_granito_rosso",
description = "Spigolo_scala_granito_rosso",
tiles = {
"graniteR.png",
"graniteR.png",
@ -421,12 +421,12 @@ description = "Spigolo_scala_granito_rosso",
node_box = {
type = "fixed",
fixed = {
{-0.5, -0.5, 0, 0, 0.5, 0.5}, -- NodeBox2
{-0.5, -0.5, -0.5, 0.5, 0, 0.5}, -- NodeBox3
{ -0.5, -0.5, 0, 0, 0.5, 0.5 }, -- NodeBox2
{ -0.5, -0.5, -0.5, 0.5, 0, 0.5 }, -- NodeBox3
}
},
-- material = minetest.digprop_constanttime(1),
groups = {cracky = 3, stone = 1},
groups = { cracky = 3, stone = 1 },
--drop ='summer:mattoneR 5',
--legacy_mineral = true,
sounds = default.node_sound_stone_defaults(),
@ -435,9 +435,9 @@ description = "Spigolo_scala_granito_rosso",
minetest.register_craft({
output = 'summer:angstairR2',
recipe = {
{' ','summer:mattoneR',' '},
{' ','summer:mattoneR',' '},
{'summer:mattoneR','summer:mattoneR','summer:mattoneR'},
{ ' ', 'summer:mattoneR', ' ' },
{ ' ', 'summer:mattoneR', ' ' },
{ 'summer:mattoneR', 'summer:mattoneR', 'summer:mattoneR' },
}
})
minetest.register_node("summer:stairR", {
@ -456,12 +456,12 @@ minetest.register_node("summer:stairR", {
node_box = {
type = "fixed",
fixed = {
{-0.5, -0.5, -0.5, 0.5, 0, 0.5}, -- Node1
{-0.5, -0.5, 0, 0.5, 0.5, 0.5}, -- Node2
{ -0.5, -0.5, -0.5, 0.5, 0, 0.5 }, -- Node1
{ -0.5, -0.5, 0, 0.5, 0.5, 0.5 }, -- Node2
}
},
-- material = minetest.digprop_constanttime(1),
groups = {cracky = 3, stone = 1},
groups = { cracky = 3, stone = 1 },
--drop ='summer:mattoneR 6',
--legacy_mineral = true,
sounds = default.node_sound_stone_defaults(),
@ -470,13 +470,13 @@ minetest.register_node("summer:stairR", {
minetest.register_craft({
output = 'summer:stairR',
recipe = {
{'summer:mattoneR',' ',' '},
{'summer:mattoneR','summer:mattoneR',' '},
{'summer:mattoneR','summer:mattoneR','summer:mattoneR'},
{ 'summer:mattoneR', ' ', ' ' },
{ 'summer:mattoneR', 'summer:mattoneR', ' ' },
{ 'summer:mattoneR', 'summer:mattoneR', 'summer:mattoneR' },
}
})
minetest.register_node("summer:battiscopaR", {
description = "Battiscopa_granito_rosso",
description = "Battiscopa_granito_rosso",
tiles = {
"graniteR.png",
"graniteR.png",
@ -491,13 +491,13 @@ description = "Battiscopa_granito_rosso",
node_box = {
type = "fixed",
fixed = {
{-0.5, -0.5, -0.5, 0.5, -0.25, 0.5}, -- NodeBox3
{-0.5, -0.5, -0.375, 0.5, 0.25, 0.5}, -- NodeBox4
{-0.5, 0, -0.5, 0.5, 0.5, 0.5}, -- NodeBox5
{ -0.5, -0.5, -0.5, 0.5, -0.25, 0.5 }, -- NodeBox3
{ -0.5, -0.5, -0.375, 0.5, 0.25, 0.5 }, -- NodeBox4
{ -0.5, 0, -0.5, 0.5, 0.5, 0.5 }, -- NodeBox5
}
},
-- material = minetest.digprop_constanttime(1),
groups = {cracky = 3, stone = 1},
groups = { cracky = 3, stone = 1 },
--drop ='summer:mattoneR 8',
--legacy_mineral = true,
sounds = default.node_sound_stone_defaults(),
@ -506,9 +506,9 @@ description = "Battiscopa_granito_rosso",
minetest.register_craft({
output = 'summer:battiscopaR',
recipe = {
{'summer:mattoneR','summer:mattoneR','summer:mattoneR'},
{'summer:mattoneR','summer:mattoneR',' '},
{'summer:mattoneR','summer:mattoneR','summer:mattoneR'},
{ 'summer:mattoneR', 'summer:mattoneR', 'summer:mattoneR' },
{ 'summer:mattoneR', 'summer:mattoneR', ' ' },
{ 'summer:mattoneR', 'summer:mattoneR', 'summer:mattoneR' },
}
})
minetest.register_node("summer:slabR", {
@ -527,12 +527,12 @@ minetest.register_node("summer:slabR", {
node_box = {
type = "fixed",
fixed = {
{-0.5, -0.5, -0.5, 0.5, 0, 0.5}, -- Node1
{ -0.5, -0.5, -0.5, 0.5, 0, 0.5 }, -- Node1
-- {-0.5, -0.5, 0, 0.5, 0.5, 0.5}, -- Node2
}
},
-- material = minetest.digprop_constanttime(1),
groups = {cracky = 3, stone = 1},
groups = { cracky = 3, stone = 1 },
--drop ='summer:mattoneR 6',
--legacy_mineral = true,
sounds = default.node_sound_stone_defaults(),
@ -541,9 +541,9 @@ minetest.register_node("summer:slabR", {
minetest.register_craft({
output = 'summer:slabR',
recipe = {
{' ',' ',' '},
{' ',' ',' '},
{'summer:mattoneR','summer:mattoneR','summer:mattoneR'},
{ ' ', ' ', ' ' },
{ ' ', ' ', ' ' },
{ 'summer:mattoneR', 'summer:mattoneR', 'summer:mattoneR' },
}
})
--G
@ -558,7 +558,7 @@ minetest.register_node("summer:angstair", {
"granite.png",
"granite.png"
},
--inventory_image = "s_s_.png",
--inventory_image = "s_s_.png",
--wield_image = "s_s_.png",
drawtype = "nodebox",
paramtype = "light",
@ -566,13 +566,13 @@ minetest.register_node("summer:angstair", {
node_box = {
type = "fixed",
fixed = {
{-0.5, -0.5, -0.5, 0, 0.5, 0.5}, -- NodeBox1
{-0.5, -0.5, 0, 0.5, 0.5, 0.5}, -- NodeBox2
{-0.5, -0.5, -0.5, 0.5, 0, 0.5}, -- NodeBox3
{ -0.5, -0.5, -0.5, 0, 0.5, 0.5 }, -- NodeBox1
{ -0.5, -0.5, 0, 0.5, 0.5, 0.5 }, -- NodeBox2
{ -0.5, -0.5, -0.5, 0.5, 0, 0.5 }, -- NodeBox3
}
},
-- material = minetest.digprop_constanttime(1),
groups = {cracky = 3, stone = 1},
groups = { cracky = 3, stone = 1 },
--drop ='"summer:mattone" 7',
--legacy_mineral = true,
sounds = default.node_sound_stone_defaults(),
@ -582,14 +582,14 @@ minetest.register_node("summer:angstair", {
minetest.register_craft({
output = 'summer:angstair',
recipe = {
{'summer:mattone','summer:mattone',' '},
{'summer:mattone','summer:mattone',' '},
{'summer:mattone','summer:mattone','summer:mattone'},
{ 'summer:mattone', 'summer:mattone', ' ' },
{ 'summer:mattone', 'summer:mattone', ' ' },
{ 'summer:mattone', 'summer:mattone', 'summer:mattone' },
}
})
minetest.register_node("summer:angstair2", {
description = "Spigolo_scala_granito_grigio",
description = "Spigolo_scala_granito_grigio",
tiles = {
"granite.png",
"granite.png",
@ -604,12 +604,12 @@ description = "Spigolo_scala_granito_grigio",
node_box = {
type = "fixed",
fixed = {
{-0.5, -0.5, 0, 0, 0.5, 0.5}, -- NodeBox2
{-0.5, -0.5, -0.5, 0.5, 0, 0.5}, -- NodeBox3
{ -0.5, -0.5, 0, 0, 0.5, 0.5 }, -- NodeBox2
{ -0.5, -0.5, -0.5, 0.5, 0, 0.5 }, -- NodeBox3
}
},
-- material = minetest.digprop_constanttime(1),
groups = {cracky = 3, stone = 1},
groups = { cracky = 3, stone = 1 },
--drop ='summer:mattone 5',
--legacy_mineral = true,
sounds = default.node_sound_stone_defaults(),
@ -618,9 +618,9 @@ description = "Spigolo_scala_granito_grigio",
minetest.register_craft({
output = 'summer:angstair2',
recipe = {
{' ','summer:mattone',' '},
{' ','summer:mattone',' '},
{'summer:mattone','summer:mattone','summer:mattone'},
{ ' ', 'summer:mattone', ' ' },
{ ' ', 'summer:mattone', ' ' },
{ 'summer:mattone', 'summer:mattone', 'summer:mattone' },
}
})
minetest.register_node("summer:stair", {
@ -639,12 +639,12 @@ minetest.register_node("summer:stair", {
node_box = {
type = "fixed",
fixed = {
{-0.5, -0.5, -0.5, 0.5, 0, 0.5}, -- Node1
{-0.5, -0.5, 0, 0.5, 0.5, 0.5}, -- Node2
{ -0.5, -0.5, -0.5, 0.5, 0, 0.5 }, -- Node1
{ -0.5, -0.5, 0, 0.5, 0.5, 0.5 }, -- Node2
}
},
-- material = minetest.digprop_constanttime(1),
groups = {cracky = 3, stone = 1},
groups = { cracky = 3, stone = 1 },
--drop ='summer:mattone 6',
--legacy_mineral = true,
sounds = default.node_sound_stone_defaults(),
@ -653,13 +653,13 @@ minetest.register_node("summer:stair", {
minetest.register_craft({
output = 'summer:stair',
recipe = {
{'summer:mattone',' ',' '},
{'summer:mattone','summer:mattone',' '},
{'summer:mattone','summer:mattone','summer:mattone'},
{ 'summer:mattone', ' ', ' ' },
{ 'summer:mattone', 'summer:mattone', ' ' },
{ 'summer:mattone', 'summer:mattone', 'summer:mattone' },
}
})
minetest.register_node("summer:battiscopa", {
description = "Battiscopa_granito_grigio",
description = "Battiscopa_granito_grigio",
tiles = {
"granite.png",
"granite.png",
@ -674,13 +674,13 @@ description = "Battiscopa_granito_grigio",
node_box = {
type = "fixed",
fixed = {
{-0.5, -0.5, -0.5, 0.5, -0.25, 0.5}, -- NodeBox3
{-0.5, -0.5, -0.375, 0.5, 0.25, 0.5}, -- NodeBox4
{-0.5, 0, -0.5, 0.5, 0.5, 0.5}, -- NodeBox5
{ -0.5, -0.5, -0.5, 0.5, -0.25, 0.5 }, -- NodeBox3
{ -0.5, -0.5, -0.375, 0.5, 0.25, 0.5 }, -- NodeBox4
{ -0.5, 0, -0.5, 0.5, 0.5, 0.5 }, -- NodeBox5
}
},
-- material = minetest.digprop_constanttime(1),
groups = {cracky = 3, stone = 1},
groups = { cracky = 3, stone = 1 },
--drop ='summer:mattone 8',
--legacy_mineral = true,
sounds = default.node_sound_stone_defaults(),
@ -689,9 +689,9 @@ description = "Battiscopa_granito_grigio",
minetest.register_craft({
output = 'summer:battiscopa',
recipe = {
{'summer:mattone','summer:mattone','summer:mattone'},
{'summer:mattone','summer:mattone',' '},
{'summer:mattone','summer:mattone','summer:mattone'},
{ 'summer:mattone', 'summer:mattone', 'summer:mattone' },
{ 'summer:mattone', 'summer:mattone', ' ' },
{ 'summer:mattone', 'summer:mattone', 'summer:mattone' },
}
})
minetest.register_node("summer:slab", {
@ -710,12 +710,12 @@ minetest.register_node("summer:slab", {
node_box = {
type = "fixed",
fixed = {
{-0.5, -0.5, -0.5, 0.5, 0, 0.5}, -- Node1
{ -0.5, -0.5, -0.5, 0.5, 0, 0.5 }, -- Node1
--{-0.5, -0.5, 0, 0.5, 0.5, 0.5}, -- Node2
}
},
-- material = minetest.digprop_constanttime(1),
groups = {cracky = 3, stone = 1},
groups = { cracky = 3, stone = 1 },
--drop ='summer:mattone 6',
--legacy_mineral = true,
sounds = default.node_sound_stone_defaults(),
@ -724,8 +724,8 @@ minetest.register_node("summer:slab", {
minetest.register_craft({
output = 'summer:slab',
recipe = {
{' ',' ',' '},
{' ',' ',' '},
{'summer:mattone','summer:mattone','summer:mattone'},
{ ' ', ' ', ' ' },
{ ' ', ' ', ' ' },
{ 'summer:mattone', 'summer:mattone', 'summer:mattone' },
}
})

232
vetro.lua
View File

@ -1,17 +1,17 @@
local vetro_list = {
{ "Red vetro", "red"},
{ "Orange vetro", "orange"},
{ "Black vetro", "black"},
{ "Yellow vetro", "yellow"},
{ "Green vetro", "green"},
{ "Dark vetro", "dark_green"},
{ "Cyan vetro", "cyan"},
{ "Grey vetro", "grey"},
{ "Withe vetro", "white"},
{ "Fuxia vetro", "magenta"},
{ "Trasparent vetro", "trasp"},
{ "Blue vetro", "blue"},
{ "Violet vetro", "violet"},
local vetro_list = {
{ "Red vetro", "red" },
{ "Orange vetro", "orange" },
{ "Black vetro", "black" },
{ "Yellow vetro", "yellow" },
{ "Green vetro", "green" },
{ "Dark vetro", "dark_green" },
{ "Cyan vetro", "cyan" },
{ "Grey vetro", "grey" },
{ "Withe vetro", "white" },
{ "Fuxia vetro", "magenta" },
{ "Trasparent vetro", "trasp" },
{ "Blue vetro", "blue" },
{ "Violet vetro", "violet" },
}
for i in ipairs(vetro_list) do
@ -19,95 +19,142 @@ for i in ipairs(vetro_list) do
local colour = vetro_list[i][2]
--trasparente con cornice colorata
--trasparente con cornice colorata
minetest.register_node("summer:vetro_"..colour.."", {
description = vetrodesc.."trasparente incorniciata",
tiles = {"vetro_"..colour..".png"},
minetest.register_node("summer:vetro_" .. colour .. "", {
description = vetrodesc .. "trasparente incorniciata",
tiles = { "vetro_" .. colour .. ".png" },
sunlight_propagates = true,
drawtype = "glasslike",
-- use_texture_alpha = true,
paramtype = "light",
paramtype2 = "glasslikeliquidlevel",
groups = {snappy=2,cracky=3,oddly_breakable_by_hand=3,not_in_creative_inventory=0},
drop = "summer:vetro_"..colour.."",
groups = { snappy = 2, cracky = 3, oddly_breakable_by_hand = 3, not_in_creative_inventory = 0 },
drop = "summer:vetro_" .. colour .. "",
sounds = default.node_sound_glass_defaults(),
})
--trasparente cornice colorata vetro unito
minetest.register_node("summer:vetro_unito_"..colour.."", {
description = vetrodesc.."trasparente incorniciata unito",
tiles = {"vetro_"..colour..".png","vetro_trasp.png"},
minetest.register_node("summer:vetro_unito_" .. colour .. "", {
description = vetrodesc .. "trasparente incorniciata unito",
tiles = { "vetro_" .. colour .. ".png", "vetro_trasp.png" },
sunlight_propagates = true,
drawtype = "glasslike_framed",
use_texture_alpha = true,
paramtype = "light",
paramtype2 = "glasslikeliquidlevel",
groups = {snappy=2,cracky=3,oddly_breakable_by_hand=3,not_in_creative_inventory=0},
drop = "summer:vetro_unito_"..colour.."",
groups = { snappy = 2, cracky = 3, oddly_breakable_by_hand = 3, not_in_creative_inventory = 0 },
drop = "summer:vetro_unito_" .. colour .. "",
sounds = default.node_sound_glass_defaults(),
})
--colorato con cornice colorato
minetest.register_node("summer:vetro_colorato_"..colour.."", {
description = vetrodesc.."cornice colorato",
tiles = {"vetro_traspc_"..colour..".png"},
minetest.register_node("summer:vetro_colorato_" .. colour .. "", {
description = vetrodesc .. "cornice colorato",
tiles = { "vetro_traspc_" .. colour .. ".png" },
sunlight_propagates = true,
drawtype = "glasslike",
use_texture_alpha = true,
paramtype = "light",
paramtype2 = "glasslikeliquidlevel",
groups = {snappy=2,cracky=3,oddly_breakable_by_hand=3,not_in_creative_inventory=0},
drop = "summer:vetro_colorato_"..colour.."",
groups = { snappy = 2, cracky = 3, oddly_breakable_by_hand = 3, not_in_creative_inventory = 0 },
drop = "summer:vetro_colorato_" .. colour .. "",
sounds = default.node_sound_glass_defaults(),
--colorato con cornice colorato unito
})
minetest.register_node("summer:vetro_colorato_unito_"..colour.."", {
description = vetrodesc.."unito colorato",
tiles = {"vetro_traspc_"..colour..".png","vetro_trasp_"..colour..".png"},
minetest.register_node("summer:vetro_colorato_unito_" .. colour .. "", {
description = vetrodesc .. "unito colorato",
tiles = { "vetro_traspc_" .. colour .. ".png", "vetro_trasp_" .. colour .. ".png" },
sunlight_propagates = true,
drawtype = "glasslike_framed",
use_texture_alpha = true,
paramtype = "light",
paramtype2 = "glasslikeliquidlevel",
groups = {snappy=2,cracky=3,oddly_breakable_by_hand=3,not_in_creative_inventory=0},
drop = "summer:vetro_colorato_unito_"..colour.."",
groups = { snappy = 2, cracky = 3, oddly_breakable_by_hand = 3, not_in_creative_inventory = 0 },
drop = "summer:vetro_colorato_unito_" .. colour .. "",
sounds = default.node_sound_glass_defaults(),
})
--senza cornice
minetest.register_node("summer:vetro_colorato_uni_"..colour.."", {
description = vetrodesc.." uniforme colorato",
tiles = {"vetro_trasp_"..colour..".png",},
minetest.register_node("summer:vetro_colorato_uni_" .. colour .. "", {
description = vetrodesc .. " uniforme colorato",
tiles = { "vetro_trasp_" .. colour .. ".png", },
sunlight_propagates = true,
drawtype = "glasslike",
use_texture_alpha = true,
paramtype = "light",
paramtype2 = "glasslikeliquidlevel",
groups = {snappy=2,cracky=3,oddly_breakable_by_hand=3,not_in_creative_inventory=0},
drop = "summer:vetro_colorato_uni_"..colour.."",
groups = { snappy = 2, cracky = 3, oddly_breakable_by_hand = 3, not_in_creative_inventory = 0 },
drop = "summer:vetro_colorato_uni_" .. colour .. "",
sounds = default.node_sound_glass_defaults(),
})
minetest.register_craftitem("summer:vetro_traspp", {
--vetro senza cornce
minetest.register_craft({
output = "summer:vetro_colorato_uni_" .. colour .. "",
recipe = {
{ "", "dye:" .. colour, "", },
{ "", "summer:vetro_traspp", "", },
{ "", "", "", }
}
})
--vetro cornice trasp
minetest.register_craft({
output = "summer:vetro_" .. colour .. "",
recipe = {
{ "default:stick", "dye:" .. colour, "default:stick", },
{ "default:stick", "summer:vetro_traspp", "default:stick", },
{ "default:stick", "default:stick", "default:stick", }
}
})
--vetro cornice trasp unito
minetest.register_craft({
output = "summer:vetro_unito_" .. colour .. "",
recipe = {
{ "", "dye:" .. colour, "", },
{ "", "summer:vetro_traspp", "", },
{ "default:stick", "default:stick", "default:stick", }
}
})
--vetro cornice colorato
minetest.register_craft({
output = "summer:vetro_colorato_" .. colour .. "",
recipe = {
{ "default:stick", "dye:" .. colour, "default:stick" },
{ "default:stick", "summer:vetro_" .. colour, "default:stick" },
{ "default:stick", "default:stick", "default:stick" }
}
})
--vetro cornice colorato unito
minetest.register_craft({
output = "summer:vetro_colorato_unito_" .. colour .. "",
recipe = {
{ "", "dye:" .. colour, "" },
{ "", "summer:vetro_" .. colour, "" },
{ "default:stick", "default:stick", "default:stick" }
}
})
end
minetest.register_craftitem("summer:vetro_traspp", {
description = "vetrino",
inventory_image = "vetro_traspp.png",
--groups = {stick = 1, flammable = 2},
})
minetest.register_craft({
minetest.register_craft({
type = "cooking",
cooktime = 10,
output = "summer:vetro_traspp",
recipe = "summer:mattoneG"
})
minetest.register_craft({
minetest.register_craft({
type = "cooking",
cooktime = 10,
output = "summer:vetro_traspp",
@ -125,90 +172,45 @@ minetest.register_craft({
output = "summer:vetro_traspp",
recipe = "summer:mattoneP"
})
--vetro senza cornce
minetest.register_craft({
output = "summer:vetro_colorato_uni_"..colour.."",
recipe = {
{"", "dye:"..colour, "", },
{"", "summer:vetro_traspp","", },
{"", "", "", }
}
})
--vetro cornice trasp
minetest.register_craft({
output = "summer:vetro_"..colour.."",
recipe = {
{"default:stick", "dye:"..colour, "default:stick", },
{"default:stick", "summer:vetro_traspp","default:stick", },
{"default:stick", "default:stick", "default:stick", }
}
})
--vetro cornice trasp unito
minetest.register_craft({
output = "summer:vetro_unito_"..colour.."",
recipe = {
{"", "dye:"..colour, "", },
{"", "summer:vetro_traspp","", },
{"default:stick", "default:stick", "default:stick", }
}
})
--vetro cornice colorato
minetest.register_craft({
output = "summer:vetro_colorato_"..colour.."",
recipe = {
{"default:stick", "dye:"..colour, "default:stick" },
{"default:stick", "summer:vetro_"..colour,"default:stick" },
{"default:stick", "default:stick", "default:stick" }
}
})
--vetro cornice colorato unito
minetest.register_craft({
output = "summer:vetro_colorato_unito_"..colour.."",
recipe = {
{"", "dye:"..colour, "" },
{"", "summer:vetro_"..colour,"" },
{"default:stick", "default:stick", "default:stick" }
}
})
--trasp
minetest.register_craft({
--trasp
minetest.register_craft({
output = "summer:vetro_colorato_trasp",
recipe = {
{"default:stick", "default:stick", "default:stick" },
{"default:stick", "summer:vetro_traspp","default:stick" },
{"default:stick", "default:stick", "default:stick" }
{ "default:stick", "default:stick", "default:stick" },
{ "default:stick", "summer:vetro_traspp", "default:stick" },
{ "default:stick", "default:stick", "default:stick" }
}
})
minetest.register_craft({
})
minetest.register_craft({
output = "summer:vetro_colorato_unito_trasp",
recipe = {
{"", "", "" },
{"", "summer:vetro_traspp","" },
{"default:stick", "default:stick", "default:stick" }
{ "", "", "" },
{ "", "summer:vetro_traspp", "" },
{ "default:stick", "default:stick", "default:stick" }
}
})
minetest.register_craft({
})
minetest.register_craft({
output = "summer:vetro_unito_trasp",
recipe = {
{"default:stick", "", "", },
{"default:stick", "summer:vetro_traspp","", },
{"default:stick", "", "", }
{ "default:stick", "", "", },
{ "default:stick", "summer:vetro_traspp", "", },
{ "default:stick", "", "", }
}
})
minetest.register_craft({
})
minetest.register_craft({
output = "summer:vetro_colorato_uni_trasp",
recipe = {
{"", "", "", },
{"summer:vetro_traspp", "summer:vetro_traspp","", },
{"summer:vetro_traspp", "summer:vetro_traspp", "", }
{ "", "", "", },
{ "summer:vetro_traspp", "summer:vetro_traspp", "", },
{ "summer:vetro_traspp", "summer:vetro_traspp", "", }
}
})
minetest.register_craft({
})
minetest.register_craft({
output = "summer:vetro_trasp",
recipe = {
{"default:stick", "default:stick", "default:stick", },
{"default:stick", "summer:vetro_traspp","default:stick", },
{"default:stick", "", "default:stick", }
{ "default:stick", "default:stick", "default:stick", },
{ "default:stick", "summer:vetro_traspp", "default:stick", },
{ "default:stick", "", "default:stick", }
}
})
end
})