summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--init.lua1
-rw-r--r--iron_chest.lua1
-rw-r--r--rubber.lua93
-rw-r--r--textures/technic_rubber_sapling.pngbin0 -> 333 bytes
-rw-r--r--textures/technic_rubber_tree_empty.pngbin0 -> 835 bytes
-rw-r--r--textures/technic_rubber_tree_full.pngbin0 -> 808 bytes
-rw-r--r--tree_tap.lua2
7 files changed, 96 insertions, 1 deletions
diff --git a/init.lua b/init.lua
index 875f064..619f9e1 100644
--- a/init.lua
+++ b/init.lua
@@ -43,6 +43,7 @@ dofile(minetest.get_modpath("technic").."/screwdriver.lua")
dofile(minetest.get_modpath("technic").."/sonic_screwdriver.lua")
dofile(minetest.get_modpath("technic").."/node_breaker.lua")
dofile(minetest.get_modpath("technic").."/deployer.lua")
+dofile(minetest.get_modpath("technic").."/rubber.lua")
dofile(minetest.get_modpath("technic").."/tree_tap.lua")
diff --git a/iron_chest.lua b/iron_chest.lua
index d6a4cc2..1a89ed3 100644
--- a/iron_chest.lua
+++ b/iron_chest.lua
@@ -32,6 +32,7 @@ minetest.register_node("technic:iron_chest", {
groups = {snappy=2,choppy=2,oddly_breakable_by_hand=2},
legacy_facedir_simple = true,
sounds = default.node_sound_wood_defaults(),
+
on_construct = function(pos)
local meta = minetest.env:get_meta(pos)
meta:set_string("formspec",
diff --git a/rubber.lua b/rubber.lua
new file mode 100644
index 0000000..38153ce
--- /dev/null
+++ b/rubber.lua
@@ -0,0 +1,93 @@
+minetest.register_node("technic:rubber_sapling", {
+ description = "Rubber Tree Sapling",
+ drawtype = "plantlike",
+ tiles = {"technic_rubber_sapling.png"},
+ inventory_image = "technic_rubber_sapling.png",
+ wield_image = "technic_rubber_sapling.png",
+ paramtype = "light",
+ walkable = false,
+ groups = {dig_immediate=3,flammable=2},
+ sounds = default.node_sound_defaults(),
+})
+
+minetest.register_node("technic:rubber_tree_full", {
+ description = "Rubber Tree",
+ tiles = {"default_tree_top.png", "default_tree_top.png", "farming_rubber_tree_full.png"},
+ groups = {tree=1,snappy=1,choppy=2,oddly_breakable_by_hand=1,flammable=2},
+ drop = "default:tree",
+ sounds = default.node_sound_wood_defaults(),
+
+ on_dig = function(pos, node, digger)
+ minetest.node_dig(pos, node, digger)
+ minetest.env:remove_node(pos)
+ end,
+
+ after_destruct = function(pos, oldnode)
+ oldnode.name = "technic:rubber_tree_empty"
+ minetest.env:set_node(pos, oldnode)
+ end
+})
+
+
+minetest.register_node("technic:rubber_tree_empty", {
+ tiles = {"default_tree_top.png", "default_tree_top.png", "farming_rubber_tree_empty.png"},
+ groups = {tree=1,snappy=1,choppy=2,oddly_breakable_by_hand=1,flammable=2, not_in_creative_inventory=1},
+ drop = "default:tree",
+ sounds = default.node_sound_wood_defaults(),
+})
+
+minetest.register_abm({
+ nodenames = {"technic:rubber_tree_empty"},
+ interval = 60,
+ chance = 15,
+ action = function(pos, node)
+ node.name = "technic:rubber_tree_full"
+ minetest.env:set_node(pos, node)
+ end
+})
+
+minetest.register_node("technic:rubber_leaves", {
+ drawtype = "allfaces_optional",
+ visual_scale = 1.3,
+ tiles = {"default_leaves.png"},
+ paramtype = "light",
+ groups = {snappy=3, leafdecay=3, flammable=2, not_in_creative_inventory=1},
+ drop = {
+ max_items = 1,
+ items = {
+ {
+ items = {'technic:rubber_sapling'},
+ rarity = 20,
+ },
+ }
+ },
+ sounds = default.node_sound_leaves_defaults(),
+})
+
+minetest.register_abm({
+ nodenames = {"technic:rubber_sapling"},
+ interval = 60,
+ chance = 20,
+ action = function(pos, node)
+ farming:generate_tree(pos, "technic:rubber_tree_full", "technic:rubber_leaves", {"default:dirt", "default:dirt_with_grass"})
+ end
+})
+
+minetest.register_on_generated(function(minp, maxp, blockseed)
+ if math.random(1, 100) > 5 then
+ return
+ end
+ local tmp = {x=(maxp.x-minp.x)/2+minp.x, y=(maxp.y-minp.y)/2+minp.y, z=(maxp.z-minp.z)/2+minp.z}
+ local pos = minetest.env:find_node_near(tmp, maxp.x-minp.x, {"default:dirt_with_grass"})
+ if pos ~= nil then
+ farming:generate_tree({x=pos.x, y=pos.y+1, z=pos.z}, "technic:rubber_tree_full", "technic:rubber_leaves", {"default:dirt", "default:dirt_with_grass"})
+ end
+end)
+
+
+-- ========= FUEL =========
+minetest.register_craft({
+ type = "fuel",
+ recipe = "technic:rubber_sapling",
+ burntime = 10
+})
diff --git a/textures/technic_rubber_sapling.png b/textures/technic_rubber_sapling.png
new file mode 100644
index 0000000..e5c9f5d
--- /dev/null
+++ b/textures/technic_rubber_sapling.png
Binary files differ
diff --git a/textures/technic_rubber_tree_empty.png b/textures/technic_rubber_tree_empty.png
new file mode 100644
index 0000000..1792951
--- /dev/null
+++ b/textures/technic_rubber_tree_empty.png
Binary files differ
diff --git a/textures/technic_rubber_tree_full.png b/textures/technic_rubber_tree_full.png
new file mode 100644
index 0000000..08067ef
--- /dev/null
+++ b/textures/technic_rubber_tree_full.png
Binary files differ
diff --git a/tree_tap.lua b/tree_tap.lua
index 92c56b0..1973f2a 100644
--- a/tree_tap.lua
+++ b/tree_tap.lua
@@ -7,7 +7,7 @@
local pos=minetest.get_pointed_thing_position(pointed_thing,above)
local node=minetest.env:get_node(pos)
local node_name=node.name
- if node_name == "farming:rubber_tree_full" then
+ if node_name == "technic:rubber_tree_full" then
user:get_inventory():add_item("main",ItemStack("technic:caouthouc"))
minetest.env:set_node(pos,node)
local item=itemstack:to_table()