mirror of
https://git.minetest.land/Mineclonia/Mineclonia.git
synced 2024-11-24 11:25:09 +00:00
Add peony and large plant support
This commit is contained in:
parent
e3af138f14
commit
24006e7832
4 changed files with 74 additions and 59 deletions
|
@ -38,7 +38,6 @@ add_simple_flower("tulip_pink", "Pink Tulip", "mcl_flowers_tulip_pink", box_tuli
|
||||||
add_simple_flower("tulip_red", "Red Tulip", "mcl_flowers_tulip_red", box_tulip)
|
add_simple_flower("tulip_red", "Red Tulip", "mcl_flowers_tulip_red", box_tulip)
|
||||||
add_simple_flower("tulip_white", "White Tulip", "mcl_flowers_tulip_white", box_tulip)
|
add_simple_flower("tulip_white", "White Tulip", "mcl_flowers_tulip_white", box_tulip)
|
||||||
add_simple_flower("allium", "Allium", "mcl_flowers_allium", { -0.2, -0.5, -0.2, 0.2, 6/16, 0.2 })
|
add_simple_flower("allium", "Allium", "mcl_flowers_allium", { -0.2, -0.5, -0.2, 0.2, 6/16, 0.2 })
|
||||||
add_simple_flower("peony", "Peony", "mcl_flowers_peony", { -0.15, -0.5, -0.15, 0.15, 0.2, 0.15 })
|
|
||||||
add_simple_flower("azure_bluet", "Azure Bluet", "mcl_flowers_azure_bluet", { -3/16, -0.5, -3/16, 3/16, 2/16, 3/16 })
|
add_simple_flower("azure_bluet", "Azure Bluet", "mcl_flowers_azure_bluet", { -3/16, -0.5, -3/16, 3/16, 2/16, 3/16 })
|
||||||
add_simple_flower("blue_orchid", "Blue Orchid", "mcl_flowers_blue_orchid", { -5/16, -0.5, -5/16, 5/16, 6/16, 5/16 })
|
add_simple_flower("blue_orchid", "Blue Orchid", "mcl_flowers_blue_orchid", { -5/16, -0.5, -5/16, 5/16, 6/16, 5/16 })
|
||||||
|
|
||||||
|
@ -72,66 +71,83 @@ minetest.register_node("mcl_flowers:fern", {
|
||||||
},
|
},
|
||||||
})
|
})
|
||||||
|
|
||||||
function register_large(name, desc, inv_img, bot_img, colr) --change in function
|
local function add_large_flower(name, desc, longdesc, inv_img, bottom_img, top_img)
|
||||||
minetest.register_node("mcl_flowers:"..name.."_bottom", {
|
minetest.register_node("mcl_flowers:"..name, {
|
||||||
description = desc.." Bottom",
|
description = desc,
|
||||||
drawtype = "plantlike",
|
_doc_items_longdesc = longdesc,
|
||||||
tiles = { "double_plant_"..name.."_bottom.png" },
|
drawtype = "plantlike",
|
||||||
inventory_image = "flowers_"..inv_img..".png",
|
tiles = { bottom_img },
|
||||||
wield_image = "flowers_"..inv_img..".png",
|
inventory_image = inv_img,
|
||||||
sunlight_propagates = true,
|
wield_image = inv_img,
|
||||||
paramtype = "light",
|
sunlight_propagates = true,
|
||||||
walkable = false,
|
paramtype = "light",
|
||||||
buildable_to = true,
|
walkable = false,
|
||||||
--[[
|
node_placement_prediction = "",
|
||||||
on_place = function(itemstack, placer, pointed_thing)
|
on_place = function(itemstack, placer, pointed_thing)
|
||||||
pointed_thing.under = pointed_thing.under-1
|
-- We can only place on nodes
|
||||||
local name = minetest.get_node({x=pointed_thing.under, y=pointed_thing.under-1, z=pointed_thing.under}).name
|
if pointed_thing.type ~= "node" then
|
||||||
if minetest.get_item_group(name, "soil") ~= 0 then
|
--return
|
||||||
pointed_thing.under = pointed_thing.under+1
|
end
|
||||||
local height = 0
|
-- Check for a floor and a space of 1×2×1
|
||||||
while minetest.get_node(pointed_thing.under).name == "mcl_flowers:"..name.."_bottom" and height < 2 do
|
local ptu_node = minetest.get_node(pointed_thing.under)
|
||||||
height = height+1
|
local bottom
|
||||||
pointed_thing.under = pointed_thing.under+1
|
if minetest.registered_nodes[ptu_node.name].buildable_to then
|
||||||
end
|
bottom = pointed_thing.under
|
||||||
if height <2 then
|
else
|
||||||
if minetest.get_node(pointed_thing.under).name == "air" then
|
bottom = pointed_thing.above
|
||||||
minetest.set_node(pointed_thing.under, {name="mcl_flowers:"..name.."_top"})
|
end
|
||||||
end
|
local top = { x = bottom.x, y = bottom.y + 1, z = bottom.z }
|
||||||
end
|
local bottom_buildable = minetest.registered_nodes[minetest.get_node(bottom).name].buildable_to
|
||||||
end
|
local top_buildable = minetest.registered_nodes[minetest.get_node(top).name].buildable_to
|
||||||
end,
|
local floorname = minetest.get_node({x=bottom.x, y=bottom.y-1, z=bottom.z}).name
|
||||||
]]
|
if minetest.registered_nodes[floorname].walkable and bottom_buildable and top_buildable then
|
||||||
drop = "mcl_flowers:"..name,
|
-- Success! We can now place the flower
|
||||||
groups = {dig_immediate=3,flammable=2,flower=1,attached_node=1,colr=1, dig_by_water=1, double_bottom =1,deco_block=1,deco_block=1},
|
minetest.sound_play(minetest.registered_nodes["mcl_flowers:"..name].sounds.place, {pos = bottom, gain=1})
|
||||||
sounds = mcl_sounds.node_sound_leaves_defaults(),
|
minetest.set_node(bottom, {name="mcl_flowers:"..name})
|
||||||
selection_box = {
|
minetest.set_node(top, {name="mcl_flowers:"..name.."_top"})
|
||||||
type = "fixed",
|
if not minetest.setting_getbool("creative_mode") then
|
||||||
fixed = { -0.25, -0.5, -0.25, 0.25, 0.5, 0.25 },
|
itemstack:take_item()
|
||||||
},
|
end
|
||||||
})
|
end
|
||||||
|
return itemstack
|
||||||
|
end,
|
||||||
|
after_destruct = function(pos, oldnode)
|
||||||
|
-- Remove top half of flower (if it exists)
|
||||||
|
local bottom = pos
|
||||||
|
local top = { x = bottom.x, y = bottom.y + 1, z = bottom.z }
|
||||||
|
if minetest.get_node(top).name == "mcl_flowers:"..name.."_top" then
|
||||||
|
minetest.remove_node(top)
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
groups = {dig_immediate=3,flammable=2,flower=1,attached_node=1, dig_by_water=1, double_plant=1,deco_block=1},
|
||||||
|
sounds = mcl_sounds.node_sound_leaves_defaults(),
|
||||||
|
})
|
||||||
|
|
||||||
-- Top
|
-- Top
|
||||||
minetest.register_node("mcl_flowers:"..name.."_top", {
|
minetest.register_node("mcl_flowers:"..name.."_top", {
|
||||||
description = desc.." Top",
|
description = desc.." (Top Part)",
|
||||||
drawtype = "plantlike",
|
_doc_items_create_entry = false,
|
||||||
tiles = { "double_plant_"..name.."_top.png" },
|
drawtype = "plantlike",
|
||||||
inventory_image = "double_plant_"..inv_img.."_top.png",
|
tiles = { top_img },
|
||||||
wield_image = "double_plant_"..inv_img.."_top.png",
|
sunlight_propagates = true,
|
||||||
sunlight_propagates = true,
|
paramtype = "light",
|
||||||
paramtype = "light",
|
walkable = false,
|
||||||
walkable = false,
|
drop = "",
|
||||||
buildable_to = true,
|
after_destruct = function(pos, oldnode)
|
||||||
drop = "mcl_flowers:"..name,
|
-- "Dig" bottom half of flower (if it exists)
|
||||||
groups = {dig_immediate=3,flammable=2,flower=1,attached_node=1,colr=1, dig_by_water=1, not_in_creative_inventory = 1, double_top =1},
|
local top = pos
|
||||||
sounds = mcl_sounds.node_sound_leaves_defaults(),
|
local bottom = { x = top.x, y = top.y - 1, z = top.z }
|
||||||
selection_box = {
|
if minetest.get_node(bottom).name == "mcl_flowers:"..name then
|
||||||
type = "fixed",
|
minetest.dig_node(bottom)
|
||||||
fixed = { -0.25, -0.5, -0.25, 0.25, 0.5, 0.25 },
|
end
|
||||||
},
|
end,
|
||||||
})
|
groups = {dig_immediate=3,flammable=2,flower=1, dig_by_water=1, not_in_creative_inventory = 1, double_plant=2},
|
||||||
|
sounds = mcl_sounds.node_sound_leaves_defaults(),
|
||||||
|
})
|
||||||
end
|
end
|
||||||
|
|
||||||
|
add_large_flower("peony", "Peony", nil, "mcl_flowers_double_plant_paeonia_top.png", "mcl_flowers_double_plant_paeonia_bottom.png", "mcl_flowers_double_plant_paeonia_top.png")
|
||||||
|
|
||||||
|
|
||||||
-- Lily Pad
|
-- Lily Pad
|
||||||
minetest.register_node("mcl_flowers:waterlily", {
|
minetest.register_node("mcl_flowers:waterlily", {
|
||||||
|
|
Binary file not shown.
After Width: | Height: | Size: 1 KiB |
Binary file not shown.
After Width: | Height: | Size: 1.2 KiB |
|
@ -18,7 +18,6 @@ local wip_items = {
|
||||||
"mcl_end:chorus_fruit",
|
"mcl_end:chorus_fruit",
|
||||||
"mcl_end:chorus_flower",
|
"mcl_end:chorus_flower",
|
||||||
"mcl_end:chorus_flower_dead",
|
"mcl_end:chorus_flower_dead",
|
||||||
"mcl_flowers:peony",
|
|
||||||
"mcl_fishing:fishing_rod",
|
"mcl_fishing:fishing_rod",
|
||||||
"mcl_fishing:pufferfish_raw",
|
"mcl_fishing:pufferfish_raw",
|
||||||
"mcl_maps:filled_map",
|
"mcl_maps:filled_map",
|
||||||
|
|
Loading…
Reference in a new issue