diff options
Diffstat (limited to 'campfire')
-rw-r--r-- | campfire/depends.txt | 1 | ||||
-rw-r--r-- | campfire/init.lua | 180 | ||||
-rw-r--r-- | campfire/textures/CampFire.png | bin | 0 -> 992 bytes | |||
-rw-r--r-- | campfire/textures/CampFire_off.png | bin | 0 -> 253 bytes |
4 files changed, 181 insertions, 0 deletions
diff --git a/campfire/depends.txt b/campfire/depends.txt new file mode 100644 index 0000000..331d858 --- /dev/null +++ b/campfire/depends.txt @@ -0,0 +1 @@ +default
\ No newline at end of file diff --git a/campfire/init.lua b/campfire/init.lua new file mode 100644 index 0000000..9834ce1 --- /dev/null +++ b/campfire/init.lua @@ -0,0 +1,180 @@ +minetest.register_craft({
+ output = "campfire:campfire",
+ recipe = {{'', 'default:stick', ''}, {'default:stick', '', 'default:stick'}}
+})
+
+
+minetest.register_node("campfire:campfire", {
+ description = "Camp Fire",
+ drawtype = "plantlike",
+ tiles = {"CampFire_off.png"},
+ walkable=false,
+ sunlight_propogates=true,
+ paramtype="light",
+ paramtype2 = "facedir",
+ groups = {oddly_breakable_by_hand=1},
+ legacy_facedir_simple = true,
+ sounds = default.node_sound_stone_defaults(),
+ on_construct = function(pos)
+ local meta = minetest.get_meta(pos)
+ meta:set_string("infotext", "Campfire")
+ local inv = meta:get_inventory()
+ inv:set_size("fuel", 1)
+ inv:set_size("src", 1)
+ inv:set_size("dst", 4)
+ end,
+ can_dig = function(pos,player)
+ local meta = minetest.get_meta(pos);
+ local inv = meta:get_inventory()
+ if not inv:is_empty("fuel") then
+ return false
+ elseif not inv:is_empty("dst") then
+ return false
+ elseif not inv:is_empty("src") then
+ return false
+ end
+ return true
+ end,
+})
+
+minetest.register_node("campfire:campfire_active", {
+ description = "Campfire Active",
+ drawtype = "plantlike",
+ tiles = {{name="CampFire.png", animation={type="vertical_frames", aspect_w=16, aspect_h=16, length=3.0}}},
+ light_source = 8,
+ paramtype="light",
+ walkable=false,
+ drop = "campfire:campfire",
+ groups = {cracky=2, not_in_creative_inventory=1},
+ legacy_facedir_simple = true,
+ sounds = default.node_sound_stone_defaults(),
+ on_construct = function(pos)
+ local meta = minetest.get_meta(pos)
+ meta:set_string("formspec", default.furnace_inactive_formspec)
+ meta:set_string("infotext", "Furnace");
+ local inv = meta:get_inventory()
+ inv:set_size("fuel", 1)
+ inv:set_size("src", 1)
+ inv:set_size("dst", 4)
+ end,
+ can_dig = function(pos,player)
+ local meta = minetest.get_meta(pos);
+ local inv = meta:get_inventory()
+ if not inv:is_empty("fuel") then
+ return false
+ elseif not inv:is_empty("dst") then
+ return false
+ elseif not inv:is_empty("src") then
+ return false
+ end
+ return true
+ end,
+})
+
+function hacky_swap_node(pos,name)
+ local node = minetest.get_node(pos)
+ local meta = minetest.get_meta(pos)
+ local meta0 = meta:to_table()
+ if node.name == name then
+ return
+ end
+ node.name = name
+ local meta0 = meta:to_table()
+ minetest.set_node(pos,node)
+ meta = minetest.get_meta(pos)
+ meta:from_table(meta0)
+end
+
+minetest.register_abm({
+ nodenames = {"campfire:campfire","campfire:campfire_active"},
+ interval = 1.0,
+ chance = 1,
+ action = function(pos, node, active_object_count, active_object_count_wider)
+ local meta = minetest.get_meta(pos)
+ for i, name in ipairs({
+ "fuel_totaltime",
+ "fuel_time",
+ "src_totaltime",
+ "src_time"
+ }) do
+ if meta:get_string(name) == "" then
+ meta:set_float(name, 0.0)
+ end
+ end
+
+ local inv = meta:get_inventory()
+
+ local srclist = inv:get_list("src")
+ local cooked = nil
+
+ if srclist then
+ cooked = minetest.get_craft_result({method = "cooking", width = 1, items = srclist})
+ end
+
+ local was_active = false
+
+ if meta:get_float("fuel_time") < meta:get_float("fuel_totaltime") then
+ was_active = true
+ meta:set_float("fuel_time", meta:get_float("fuel_time") + 0.25)
+ meta:set_float("src_time", meta:get_float("src_time") + 0.25)
+ if cooked and cooked.item and meta:get_float("src_time") >= cooked.time then
+ -- check if there's room for output in "dst" list
+ if inv:room_for_item("dst",cooked.item) then
+ -- Put result in "dst" list
+ inv:add_item("dst", cooked.item)
+ -- take stuff from "src" list
+ srcstack = inv:get_stack("src", 1)
+ srcstack:take_item()
+ inv:set_stack("src", 1, srcstack)
+ else
+ print("Could not insert '"..cooked.item:to_string().."'")
+ end
+ meta:set_string("src_time", 0)
+ end
+ end
+
+ if meta:get_float("fuel_time") < meta:get_float("fuel_totaltime") then
+ local percent = math.floor(meta:get_float("fuel_time") /
+ meta:get_float("fuel_totaltime") * 100)
+ meta:set_string("infotext","Furnace active: "..percent.."%")
+ hacky_swap_node(pos,"campfire:campfire_active")
+ meta:set_string("formspec",
+ "size[8,9]"..
+ "image[2,2;1,1;default_furnace_fire_bg.png^[lowpart:"..
+ (100-percent)..":default_furnace_fire_fg.png]"..
+ "list[current_name;fuel;2,3;1,1;]"..
+ "list[current_name;src;2,1;1,1;]"..
+ "list[current_name;dst;5,1;2,2;]"..
+ "list[current_player;main;0,5;8,4;]")
+ return
+ end
+
+ local fuel = nil
+ local cooked = nil
+ local fuellist = inv:get_list("fuel")
+ local srclist = inv:get_list("src")
+
+ if srclist then
+ cooked = minetest.get_craft_result({method = "cooking", width = 1, items = srclist})
+ end
+ if fuellist then
+ fuel = minetest.get_craft_result({method = "fuel", width = 1, items = fuellist})
+ end
+
+ if fuel.time <= 0 then
+ meta:set_string("infotext","Put more wood on the fire!")
+ hacky_swap_node(pos,"campfire:campfire")
+ meta:set_string("formspec", default.furnace_inactive_formspec)
+ return
+ end
+
+
+
+ meta:set_string("fuel_totaltime", fuel.time)
+ meta:set_string("fuel_time", 0)
+
+ local stack = inv:get_stack("fuel", 1)
+ stack:take_item()
+ inv:set_stack("fuel", 1, stack)
+ end,
+})
diff --git a/campfire/textures/CampFire.png b/campfire/textures/CampFire.png Binary files differnew file mode 100644 index 0000000..85f8451 --- /dev/null +++ b/campfire/textures/CampFire.png diff --git a/campfire/textures/CampFire_off.png b/campfire/textures/CampFire_off.png Binary files differnew file mode 100644 index 0000000..cc3f980 --- /dev/null +++ b/campfire/textures/CampFire_off.png |