summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorHybridDog <adresse_test@t-online.de>2013-10-27 22:01:13 +0100
committerShadowNinja <noreply@gmail.com>2013-10-30 15:09:31 -0400
commitf90915c40856b41f818847be680b466765f01f50 (patch)
tree66d2ea14292036f351fc5a0f4c56358978508a49
parent0a5e521f2dd9319f63ac46a657fd8198141a208f (diff)
Add Mk2 and Mk3 mining lasers
-rw-r--r--technic/locale/es.txt8
-rw-r--r--technic/locale/template.txt5
-rw-r--r--technic/sounds/technic_laser_mk1.0.ogg (renamed from technic/sounds/technic_laser.ogg)bin13465 -> 13465 bytes
-rw-r--r--technic/sounds/technic_laser_mk1.1.oggbin0 -> 10281 bytes
-rw-r--r--technic/sounds/technic_laser_mk2.0.oggbin0 -> 16766 bytes
-rw-r--r--technic/sounds/technic_laser_mk2.1.oggbin0 -> 17725 bytes
-rw-r--r--technic/sounds/technic_laser_mk2.2.oggbin0 -> 14627 bytes
-rw-r--r--technic/sounds/technic_laser_mk3.1.oggbin0 -> 12162 bytes
-rw-r--r--technic/sounds/technic_laser_mk3.2.oggbin0 -> 12040 bytes
-rw-r--r--technic/textures/technic_laser_beam.pngbin119 -> 0 bytes
-rw-r--r--technic/textures/technic_laser_beam_mk1.pngbin0 -> 279 bytes
-rw-r--r--technic/textures/technic_laser_beam_mk2.pngbin0 -> 638 bytes
-rw-r--r--technic/textures/technic_laser_beam_mk3.pngbin0 -> 547 bytes
-rw-r--r--technic/textures/technic_mining_laser_mk1.pngbin358 -> 216 bytes
-rw-r--r--technic/textures/technic_mining_laser_mk2.pngbin0 -> 244 bytes
-rw-r--r--technic/textures/technic_mining_laser_mk3.pngbin0 -> 312 bytes
-rw-r--r--technic/tools/init.lua2
-rw-r--r--technic/tools/mining_drill.lua6
-rw-r--r--technic/tools/mining_laser_mk1.lua176
-rw-r--r--technic/tools/mining_lasers.lua157
20 files changed, 167 insertions, 187 deletions
diff --git a/technic/locale/es.txt b/technic/locale/es.txt
index 5c92c99..6867299 100644
--- a/technic/locale/es.txt
+++ b/technic/locale/es.txt
@@ -151,11 +151,11 @@ Flashlight = Linterna
3 nodes tall. = 3 nodos de alto.
3 nodes wide. = 3 nodos de ancho.
3x3 nodes. = 3x3 nodos.
-Hold shift and use to change Mining Drill Mk%d modes. = Manten pulsado Mayus y Usar para cambiar el modo del Taladro de Mineria MK%d.
+Hold shift and use to change Mining Drill Mk%d modes. = Manten pulsado Mayus y Usar para cambiar el modo del Taladro de Mineria Mk%d.
Mining Drill Mk%d Mode %d = Taladro de Mineria Mk%d Modo %d
-Mining Drill Mk1 = Taladro de Mineria Mk1
-Mining Drill Mk2 = Taladro de Mineria Mk2
-Mining Drill Mk3 = Taladro de Mineria Mk3
+Mining Drill Mk%d = Taladro de Mineria Mk%d
+Mining Laser Mk%d = Laser de Mineria Mk%d
Single node. = Nodo simple.
Sonic Screwdriver = Destonillador Sonico
Tree Tap = Grifo de Arbol
+
diff --git a/technic/locale/template.txt b/technic/locale/template.txt
index b946523..bd24aae 100644
--- a/technic/locale/template.txt
+++ b/technic/locale/template.txt
@@ -153,9 +153,8 @@ Flashlight =
3x3 nodes. =
Hold shift and use to change Mining Drill Mk%d modes. =
Mining Drill Mk%d Mode %d =
-Mining Drill Mk1 =
-Mining Drill Mk2 =
-Mining Drill Mk3 =
+Mining Drill Mk%d =
+Mining Laser Mk%d =
Single node. =
Sonic Screwdriver =
Tree Tap =
diff --git a/technic/sounds/technic_laser.ogg b/technic/sounds/technic_laser_mk1.0.ogg
index 19be080..19be080 100644
--- a/technic/sounds/technic_laser.ogg
+++ b/technic/sounds/technic_laser_mk1.0.ogg
Binary files differ
diff --git a/technic/sounds/technic_laser_mk1.1.ogg b/technic/sounds/technic_laser_mk1.1.ogg
new file mode 100644
index 0000000..7792be1
--- /dev/null
+++ b/technic/sounds/technic_laser_mk1.1.ogg
Binary files differ
diff --git a/technic/sounds/technic_laser_mk2.0.ogg b/technic/sounds/technic_laser_mk2.0.ogg
new file mode 100644
index 0000000..2cf1548
--- /dev/null
+++ b/technic/sounds/technic_laser_mk2.0.ogg
Binary files differ
diff --git a/technic/sounds/technic_laser_mk2.1.ogg b/technic/sounds/technic_laser_mk2.1.ogg
new file mode 100644
index 0000000..b3f9afb
--- /dev/null
+++ b/technic/sounds/technic_laser_mk2.1.ogg
Binary files differ
diff --git a/technic/sounds/technic_laser_mk2.2.ogg b/technic/sounds/technic_laser_mk2.2.ogg
new file mode 100644
index 0000000..a4ee091
--- /dev/null
+++ b/technic/sounds/technic_laser_mk2.2.ogg
Binary files differ
diff --git a/technic/sounds/technic_laser_mk3.1.ogg b/technic/sounds/technic_laser_mk3.1.ogg
new file mode 100644
index 0000000..f948913
--- /dev/null
+++ b/technic/sounds/technic_laser_mk3.1.ogg
Binary files differ
diff --git a/technic/sounds/technic_laser_mk3.2.ogg b/technic/sounds/technic_laser_mk3.2.ogg
new file mode 100644
index 0000000..636c306
--- /dev/null
+++ b/technic/sounds/technic_laser_mk3.2.ogg
Binary files differ
diff --git a/technic/textures/technic_laser_beam.png b/technic/textures/technic_laser_beam.png
deleted file mode 100644
index 4814a9b..0000000
--- a/technic/textures/technic_laser_beam.png
+++ /dev/null
Binary files differ
diff --git a/technic/textures/technic_laser_beam_mk1.png b/technic/textures/technic_laser_beam_mk1.png
new file mode 100644
index 0000000..4cf9b3e
--- /dev/null
+++ b/technic/textures/technic_laser_beam_mk1.png
Binary files differ
diff --git a/technic/textures/technic_laser_beam_mk2.png b/technic/textures/technic_laser_beam_mk2.png
new file mode 100644
index 0000000..9e27a8c
--- /dev/null
+++ b/technic/textures/technic_laser_beam_mk2.png
Binary files differ
diff --git a/technic/textures/technic_laser_beam_mk3.png b/technic/textures/technic_laser_beam_mk3.png
new file mode 100644
index 0000000..5a17e83
--- /dev/null
+++ b/technic/textures/technic_laser_beam_mk3.png
Binary files differ
diff --git a/technic/textures/technic_mining_laser_mk1.png b/technic/textures/technic_mining_laser_mk1.png
index acde392..29faeb4 100644
--- a/technic/textures/technic_mining_laser_mk1.png
+++ b/technic/textures/technic_mining_laser_mk1.png
Binary files differ
diff --git a/technic/textures/technic_mining_laser_mk2.png b/technic/textures/technic_mining_laser_mk2.png
new file mode 100644
index 0000000..2d67c0f
--- /dev/null
+++ b/technic/textures/technic_mining_laser_mk2.png
Binary files differ
diff --git a/technic/textures/technic_mining_laser_mk3.png b/technic/textures/technic_mining_laser_mk3.png
new file mode 100644
index 0000000..db9ee26
--- /dev/null
+++ b/technic/textures/technic_mining_laser_mk3.png
Binary files differ
diff --git a/technic/tools/init.lua b/technic/tools/init.lua
index 6bb551b..e1db7ed 100644
--- a/technic/tools/init.lua
+++ b/technic/tools/init.lua
@@ -4,7 +4,7 @@ if technic.config:get_bool("enable_mining_drill") then
dofile(path.."/mining_drill.lua")
end
if technic.config:get_bool("enable_mining_laser") then
- dofile(path.."/mining_laser_mk1.lua")
+ dofile(path.."/mining_lasers.lua")
end
if technic.config:get_bool("enable_flashlight") then
dofile(path.."/flashlight.lua")
diff --git a/technic/tools/mining_drill.lua b/technic/tools/mining_drill.lua
index c0ddbb6..d5548fb 100644
--- a/technic/tools/mining_drill.lua
+++ b/technic/tools/mining_drill.lua
@@ -222,7 +222,7 @@ end
technic.register_power_tool("technic:mining_drill", mining_drill_max_charge)
minetest.register_tool("technic:mining_drill", {
- description = S("Mining Drill Mk1"),
+ description = S("Mining Drill Mk%d"):format(1),
inventory_image = "technic_mining_drill.png",
stack_max = 1,
on_use = function(itemstack, user, pointed_thing)
@@ -245,7 +245,7 @@ minetest.register_tool("technic:mining_drill", {
})
minetest.register_tool("technic:mining_drill_mk2", {
- description = S("Mining Drill Mk2"),
+ description = S("Mining Drill Mk%d"):format(2),
inventory_image = "technic_mining_drill_mk2.png",
on_use = function(itemstack, user, pointed_thing)
mining_drill_mk2_handler(itemstack, user, pointed_thing)
@@ -270,7 +270,7 @@ for i = 1, 4 do
end
minetest.register_tool("technic:mining_drill_mk3", {
- description = S("Mining Drill Mk3"),
+ description = S("Mining Drill Mk%d"):format(3),
inventory_image = "technic_mining_drill_mk3.png",
on_use = function(itemstack, user, pointed_thing)
mining_drill_mk3_handler(itemstack,user,pointed_thing)
diff --git a/technic/tools/mining_laser_mk1.lua b/technic/tools/mining_laser_mk1.lua
deleted file mode 100644
index 4280cf7..0000000
--- a/technic/tools/mining_laser_mk1.lua
+++ /dev/null
@@ -1,176 +0,0 @@
-local laser_mk1_max_charge = 40000
-technic.register_power_tool("technic:laser_mk1", laser_mk1_max_charge)
-
-local laser_shoot = function(player, pointed_thing)
- local laser_straight_mode=0
- local playerpos=player:getpos()
- local dir=player:get_look_dir()
- if pointed_thing.type=="node" then
- pos=minetest.get_pointed_thing_position(pointed_thing, above)
- local node = minetest.env:get_node(pos)
- if node.name~="ignore" then
- minetest.node_dig(pos,node,player)
- end
- laser_straight_mode=1
- end
-
- direction_y=math.abs(math.floor(dir.y*100))
- if direction_y>50 then entity_name="technic:laser_beam_entityV"
- else entity_name="technic:laser_beam_entity" end
-
- if laser_straight_mode==1 then
- pos1=minetest.get_pointed_thing_position(pointed_thing, under)
- pos1.x=math.floor(pos1.x)
- pos1.y=math.floor(pos1.y)
- pos1.z=math.floor(pos1.z)
- obj=minetest.env:add_entity(pos1,entity_name)
- else
- obj=minetest.env:add_entity({x=playerpos.x,y=playerpos.y+1.6,z=playerpos.z},entity_name)
- end
- if obj:get_luaentity().player == nil then
- obj:get_luaentity().player = player
- end
- if laser_straight_mode==1 and direction_y<50 then
- obj:setvelocity({x=dir.x*8, y=0, z=dir.z*8})
- else if laser_straight_mode==1 and direction_y>50 then
- obj:setvelocity({x=0, y=dir.y*8, z=dir.z*8})
- end
- end
- if laser_straight_mode==0 then
- obj:setvelocity({x=dir.x*8, y=dir.y*8, z=dir.z*8})
- end
- obj:setacceleration({x=0, y=0, z=0})
- obj:setyaw(player:get_look_yaw()+math.pi)
- if obj:get_luaentity().player == nil then
- obj:get_luaentity().player = player
- end
- --obj:get_luaentity().node = player:get_inventory():get_stack("main", 1):get_name()
- minetest.sound_play("technic_laser", {pos = playerpos, gain = 1.0, max_hear_distance = 10,})
- return true
-end
-
-
-minetest.register_tool("technic:laser_mk1", {
- description = "Mining Laser MK1",
- inventory_image = "technic_mining_laser_mk1.png",
- stack_max = 1,
- on_use = function(itemstack, user, pointed_thing)
- local meta = get_item_meta(itemstack:get_metadata())
- if not meta or not meta.charge then
- return
- end
- if meta.charge - 400 > 0 then
- laser_shoot(user, pointed_thing)
- meta.charge = meta.charge - 400
- technic.set_RE_wear(itemstack, meta.charge, laser_mk1_max_charge)
- itemstack:set_metadata(set_item_meta(meta))
- end
- return itemstack
- end,
-})
-
-minetest.register_craft({
- output = 'technic:laser_mk1',
- recipe = {
- {'default:diamond', 'default:steel_ingot', 'technic:battery'},
- {'', 'default:steel_ingot', 'technic:battery'},
- {'', '', 'default:copper_ingot'},
- }
-})
-
-
-
-minetest.register_node("technic:laser_beam_box", {
- drawtype = "nodebox",
- node_box = {
- type = "fixed",
- fixed = {
- { -0.5 , -0.1, -0.1 , 0.1 , 0.1 , 0.1 },
- { -0.1 , -0.1 , -0.1 , 0.5, 0.1 , 0.1 },
- }
- },
- tiles = {"technic_laser_beam.png"},
- groups = {not_in_creative_inventory=1},
-})
-
-minetest.register_node("technic:laser_beam_boxV", {
- drawtype = "nodebox",
- node_box = {
- type = "fixed",
- fixed = {
- { -0.1 , -0.1 , -0.1 , 0.1 , 0.5, 0.1 },
- { -0.1 , -0.5, -0.1 , 0.1 , 0.1 , 0.1 },
-
- }
- },
- tiles = {"technic_laser_beam.png"},
- groups = {not_in_creative_inventory=1},
-})
-
-LASER_BEAM_ENTITY={
- physical = false,
- timer=0,
- visual = "wielditem",
- visual_size = {x=0.2, y=0.2},
- textures = {"technic:laser_beam_box"},
- lastpos={},
- max_range=10,
- count=0,
--- digger=nil,
- collisionbox = {0,0,0,0,0,0},
-}
-
-LASER_BEAM_ENTITY.on_step = function(self, dtime)
- self.timer=self.timer+dtime
- local pos = self.object:getpos()
- if self.player~=nil then if self.lastpos.x~=nil then lazer_it (pos, self.player) end end
- if self.lastpos.x ~=nil and self.lastpos.y ~=nil and self.lastpos.y ~=nil then
- temp1={x=math.floor(self.lastpos.x),y=math.floor(self.lastpos.y),z=math.floor(self.lastpos.z)}
- temp2={x=math.floor(pos.x),y=math.floor(pos.y),z=math.floor(pos.z)}
- if temp1.x==temp2.x and temp1.y==temp2.y and temp1.z==temp2.z then return end
- end
- self.lastpos={x=pos.x, y=pos.y, z=pos.z}
- self.count=self.count+1
- if self.count==self.max_range then self.object:remove() end
-end
-
-LASER_BEAM_ENTITYV={
- physical = false,
- timer=0,
- visual = "wielditem",
- visual_size = {x=0.2, y=0.2},
- textures = {"technic:laser_beam_boxV"},
- lastpos={},
- max_range=15,
- count=0,
- collisionbox = {0,0,0,0,0,0},
-}
-
-LASER_BEAM_ENTITYV.on_step = function(self, dtime)
- self.timer=self.timer+dtime
- local pos = self.object:getpos()
- if self.player~=nil then if self.lastpos.x~=nil then lazer_it (pos, self.player) end end
- if self.lastpos.x ~=nil and self.lastpos.y ~=nil and self.lastpos.y ~=nil then
- temp1={x=math.floor(self.lastpos.x),y=math.floor(self.lastpos.y),z=math.floor(self.lastpos.z)}
- temp2={x=math.floor(pos.x),y=math.floor(pos.y),z=math.floor(pos.z)}
- if temp1.x==temp2.x and temp1.y==temp2.y and temp1.z==temp2.z then return end
- end
- self.lastpos={x=pos.x, y=pos.y, z=pos.z}
- self.count=self.count+1
- if self.count==self.max_range then self.object:remove() end
-end
-
-
-minetest.register_entity("technic:laser_beam_entity", LASER_BEAM_ENTITY)
-minetest.register_entity("technic:laser_beam_entityV", LASER_BEAM_ENTITYV)
-
-function lazer_it (pos, player)
- local pos1={}
--- pos1.x=math.floor(pos.x)
--- pos1.y=math.floor(pos.y)
--- pos1.z=math.floor(pos.z)
- local node = minetest.env:get_node(pos)
- if node.name == "air" or node.name == "ignore" or node.name == "default:lava_source" or node.name == "default:lava_flowing" then return end
- if node.name == "default:water_source" or node.name == "default:water_flowing" then minetest.env:remove_node(pos) return end
- if player then minetest.node_dig(pos,node,player) end
-end
diff --git a/technic/tools/mining_lasers.lua b/technic/tools/mining_lasers.lua
new file mode 100644
index 0000000..c7f4ba8
--- /dev/null
+++ b/technic/tools/mining_lasers.lua
@@ -0,0 +1,157 @@
+
+local r_corr = 0.25 -- Remove a bit more nodes (if shooting diagonal) to let it look like a hole (sth like antialiasing)
+local mk1_charge = 40000
+
+local mining_lasers_list = {
+-- {<num>, <range of the laser shots>, <max_charge>},
+ {"1", 7, mk1_charge},
+ {"2", 11, mk1_charge * 4},
+ {"3", 30, mk1_charge * 16},
+}
+
+local f_1 = 0.5 - r_corr
+local f_2 = 0.5 + r_corr
+
+local S = technic.getter
+
+local function get_used_dir(dir)
+ local abs_dir = {x = math.abs(dir.x),
+ y = math.abs(dir.y),
+ z = math.abs(dir.z)}
+ local dir_max = math.max(abs_dir.x, abs_dir.y, abs_dir.z)
+ if dir_max == abs_dir.x then
+ local tab = {"x", {x = 1, y = dir.y / dir.x, z = dir.z / dir.x}}
+ if dir.x >= 0 then
+ tab[3] = "+"
+ end
+ return tab
+ end
+ if dir_max == abs_dir.y then
+ local tab = {"y", {x = dir.x / dir.y, y = 1, z = dir.z / dir.y}}
+ if dir.y >= 0 then
+ tab[3] = "+"
+ end
+ return tab
+ end
+ local tab = {"z", {x = dir.x / dir.z, y = dir.y / dir.z, z = 1}}
+ if dir.z >= 0 then
+ tab[3] = "+"
+ end
+ return tab
+end
+
+local function node_tab(z, d)
+ local n1 = math.floor(z * d + f_1)
+ local n2 = math.floor(z * d + f_2)
+ if n1 == n2 then
+ return {n1}
+ end
+ return {n1, n2}
+end
+
+local function laser_node(pos, player)
+ local node = minetest.get_node(pos)
+ if node.name == "air"
+ or node.name == "ignore"
+ or node.name == "default:lava_source"
+ or node.name == "default:lava_flowing" then
+ return
+ end
+ if node.name == "default:water_source"
+ or node.name == "default:water_flowing" then
+ minetest.remove_node(pos)
+ minetest.add_particle(pos,
+ {x=0, y=2, z=0},
+ {x=0, y=-1, z=0},
+ 1.5,
+ 8,
+ false,
+ "smoke_puff.png")
+ return
+ end
+ if player then
+ minetest.node_dig(pos, node, player)
+ end
+end
+
+local function laser_nodes(pos, dir, player, range)
+ local t_dir = get_used_dir(dir)
+ local dir_typ = t_dir[1]
+ if t_dir[3] == "+" then
+ f_tab = {0, range}
+ else
+ f_tab = {-range,0}
+ end
+ local d_ch = t_dir[2]
+ if dir_typ == "x" then
+ for d = f_tab[1],f_tab[2],1 do
+ local x = d
+ local ytab = node_tab(d_ch.y, d)
+ local ztab = node_tab(d_ch.z, d)
+ for _, y in pairs(ytab) do
+ for _, z in pairs(ztab) do
+ laser_node({x = pos.x + x, y = pos.y + y, z = pos.z + z}, player)
+ end
+ end
+ end
+ return
+ end
+ if dir_typ == "y" then
+ for d = f_tab[1], f_tab[2] do
+ local xtab = node_tab(d_ch.x, d)
+ local y = d
+ local ztab = node_tab(d_ch.z, d)
+ for _, x in pairs(xtab) do
+ for _, z in pairs(ztab) do
+ laser_node({x = pos.x + x, y = pos.y + y, z = pos.z + z}, player)
+ end
+ end
+ end
+ return
+ end
+ for d = f_tab[1], f_tab[2] do
+ local xtab = node_tab(d_ch.x, d)
+ local ytab = node_tab(d_ch.y, d)
+ local z = d
+ for _, x in pairs(xtab) do
+ for _, y in pairs(ytab) do
+ laser_node({x = pos.x + x, y = pos.y + y, z = pos.z + z}, player)
+ end
+ end
+ end
+end
+
+local function laser_shoot(player, range, particle_texture, sound)
+ local playerpos = player:getpos()
+ local dir = player:get_look_dir()
+
+ local startpos = {x = playerpos.x, y = playerpos.y + 1.6, z = playerpos.z}
+ local mult_dir = vector.multiply(dir, 50)
+ minetest.add_particle(startpos, dir, mult_dir, range / 11, 1, false, particle_texture)
+ laser_nodes(vector.round(startpos), dir, player, range)
+ minetest.sound_play(sound, {pos = playerpos, gain = 1.0, max_hear_distance = range})
+end
+
+
+for _, m in pairs(mining_lasers_list) do
+ technic.register_power_tool("technic:laser_mk"..m[1], m[3])
+ minetest.register_tool("technic:laser_mk"..m[1], {
+ description = S("Mining Laser Mk%d"):format(m[1]),
+ inventory_image = "technic_mining_laser_mk"..m[1]..".png",
+ stack_max = 1,
+ on_use = function(itemstack, user)
+ local meta = get_item_meta(itemstack:get_metadata())
+ if not meta or not meta.charge then
+ return
+ end
+ if meta.charge - 400 > 0 then
+ laser_shoot(user, m[2], "technic_laser_beam_mk"..m[1]..".png", "technic_laser_mk"..m[1])
+ meta.charge = meta.charge - 400
+ technic.set_RE_wear(itemstack, meta.charge, m[3])
+ itemstack:set_metadata(set_item_meta(meta))
+ end
+ return itemstack
+ end,
+ })
+end
+