Merge branch 'technicworld' of https://git.tchncs.de/Illuna-Minetest/minetest_game into technicworld
This commit is contained in:
commit
00de0eff80
244 changed files with 7788 additions and 2585 deletions
|
@ -23,22 +23,35 @@ All gunpowder textures except tnt_gunpowder_inventory.png.
|
|||
sofar (sofar@foo-projects.org) (CC BY-SA 3.0):
|
||||
tnt_blast.png
|
||||
|
||||
paramat (CC BY-SA 3.0)
|
||||
tnt_tnt_stick.png - Derived from a texture by benrob0329.
|
||||
|
||||
Introduction
|
||||
------------
|
||||
This mod adds TNT to Minetest. TNT is a tool to help the player
|
||||
in mining.
|
||||
|
||||
How to use the mod:
|
||||
Craft gunpowder by placing coal and gravel in the crafting area.
|
||||
The gunpowder can be used to craft TNT or as fuse for TNT.
|
||||
To craft TNT place items like this:
|
||||
-- wood - gunpowder -- wood -
|
||||
gunpowder gunpowder gunpowder
|
||||
-- wood - gunpowder -- wood -
|
||||
|
||||
There are different ways to blow up TNT:
|
||||
Craft gunpowder by placing coal and gravel in the crafting area.
|
||||
The gunpowder can be used to craft TNT sticks or as a fuse trail for TNT.
|
||||
|
||||
To craft 2 TNT sticks:
|
||||
G_G
|
||||
GPG
|
||||
G_G
|
||||
G = gunpowder
|
||||
P = paper
|
||||
The sticks are not usable as an explosive.
|
||||
|
||||
Craft TNT from 9 TNT sticks.
|
||||
|
||||
There are different ways to ignite TNT:
|
||||
1. Hit it with a torch.
|
||||
2. Hit a gunpowder fuse that leads to a TNT block with a torch or flint-and-steel.
|
||||
2. Hit a gunpowder fuse trail that leads to TNT with a torch or
|
||||
flint-and-steel.
|
||||
3. Activate it with mesecons (fastest way).
|
||||
|
||||
Be aware of the damage radius of 6 blocks!
|
||||
For 1 TNT:
|
||||
Node destruction radius is 3 nodes.
|
||||
Player and object damage radius is 6 nodes.
|
||||
|
|
|
@ -59,8 +59,8 @@ local function eject_drops(drops, pos, radius)
|
|||
local obj = minetest.add_item(drop_pos, dropitem)
|
||||
if obj then
|
||||
obj:get_luaentity().collect = true
|
||||
obj:setacceleration({x = 0, y = -10, z = 0})
|
||||
obj:setvelocity({x = math.random(-3, 3),
|
||||
obj:set_acceleration({x = 0, y = -10, z = 0})
|
||||
obj:set_velocity({x = math.random(-3, 3),
|
||||
y = math.random(0, 10),
|
||||
z = math.random(-3, 3)})
|
||||
end
|
||||
|
@ -153,7 +153,7 @@ end
|
|||
local function entity_physics(pos, radius, drops)
|
||||
local objs = minetest.get_objects_inside_radius(pos, radius)
|
||||
for _, obj in pairs(objs) do
|
||||
local obj_pos = obj:getpos()
|
||||
local obj_pos = obj:get_pos()
|
||||
local dist = math.max(1, vector.distance(pos, obj_pos))
|
||||
|
||||
local damage = (4 / dist) * radius
|
||||
|
@ -165,7 +165,7 @@ local function entity_physics(pos, radius, drops)
|
|||
local moveoff = vector.multiply(dir, dist + 1.0)
|
||||
local newpos = vector.add(pos, moveoff)
|
||||
newpos = vector.add(newpos, {x = 0, y = 0.2, z = 0})
|
||||
obj:setpos(newpos)
|
||||
obj:set_pos(newpos)
|
||||
|
||||
obj:set_hp(obj:get_hp() - damage)
|
||||
else
|
||||
|
@ -180,8 +180,8 @@ local function entity_physics(pos, radius, drops)
|
|||
end
|
||||
|
||||
if do_knockback then
|
||||
local obj_vel = obj:getvelocity()
|
||||
obj:setvelocity(calc_velocity(pos, obj_pos,
|
||||
local obj_vel = obj:get_velocity()
|
||||
obj:set_velocity(calc_velocity(pos, obj_pos,
|
||||
obj_vel, radius * 10))
|
||||
end
|
||||
if do_damage then
|
||||
|
@ -209,6 +209,7 @@ local function add_effects(pos, radius, drops)
|
|||
collisiondetection = false,
|
||||
vertical = false,
|
||||
texture = "tnt_boom.png",
|
||||
glow = 15,
|
||||
})
|
||||
minetest.add_particlespawner({
|
||||
amount = 64,
|
||||
|
@ -273,7 +274,7 @@ function tnt.burn(pos, nodename)
|
|||
end
|
||||
end
|
||||
|
||||
local function tnt_explode(pos, radius, ignore_protection, ignore_on_blast, owner)
|
||||
local function tnt_explode(pos, radius, ignore_protection, ignore_on_blast, owner, explode_center)
|
||||
pos = vector.round(pos)
|
||||
-- scan for adjacent TNT nodes first, and enlarge the explosion
|
||||
local vm1 = VoxelManip()
|
||||
|
@ -287,6 +288,10 @@ local function tnt_explode(pos, radius, ignore_protection, ignore_on_blast, owne
|
|||
local c_tnt_burning = minetest.get_content_id("tnt:tnt_burning")
|
||||
local c_tnt_boom = minetest.get_content_id("tnt:boom")
|
||||
local c_air = minetest.get_content_id("air")
|
||||
-- make sure we still have explosion even when centre node isnt tnt related
|
||||
if explode_center then
|
||||
count = 1
|
||||
end
|
||||
|
||||
for z = pos.z - 2, pos.z + 2 do
|
||||
for y = pos.y - 2, pos.y + 2 do
|
||||
|
@ -383,14 +388,21 @@ local function tnt_explode(pos, radius, ignore_protection, ignore_on_blast, owne
|
|||
end
|
||||
|
||||
function tnt.boom(pos, def)
|
||||
def = def or {}
|
||||
def.radius = def.radius or 1
|
||||
def.damage_radius = def.damage_radius or def.radius * 2
|
||||
local meta = minetest.get_meta(pos)
|
||||
local owner = meta:get_string("owner")
|
||||
minetest.sound_play("tnt_explode", {pos = pos, gain = 1.5, max_hear_distance = 2*64})
|
||||
minetest.set_node(pos, {name = "tnt:boom"})
|
||||
if not def.explode_center then
|
||||
minetest.set_node(pos, {name = "tnt:boom"})
|
||||
end
|
||||
local sound = def.sound or "tnt_explode"
|
||||
minetest.sound_play(sound, {pos = pos, gain = 1.5,
|
||||
max_hear_distance = math.min(def.radius * 20, 128)})
|
||||
local drops, radius = tnt_explode(pos, def.radius, def.ignore_protection,
|
||||
def.ignore_on_blast, owner)
|
||||
def.ignore_on_blast, owner, def.explode_center)
|
||||
-- append entity drops
|
||||
local damage_radius = (radius / def.radius) * def.damage_radius
|
||||
local damage_radius = (radius / math.max(1, def.radius)) * def.damage_radius
|
||||
entity_physics(pos, damage_radius, drops)
|
||||
if not def.disable_drops then
|
||||
eject_drops(drops, pos, radius)
|
||||
|
@ -406,12 +418,6 @@ minetest.register_node("tnt:boom", {
|
|||
walkable = false,
|
||||
drop = "",
|
||||
groups = {dig_immediate = 3},
|
||||
on_construct = function(pos)
|
||||
minetest.get_node_timer(pos):start(0.4)
|
||||
end,
|
||||
on_timer = function(pos, elapsed)
|
||||
minetest.remove_node(pos)
|
||||
end,
|
||||
-- unaffected by explosions
|
||||
on_blast = function() end,
|
||||
})
|
||||
|
@ -545,13 +551,28 @@ minetest.register_craft({
|
|||
recipe = {"default:coal_lump", "default:gravel"}
|
||||
})
|
||||
|
||||
minetest.register_craftitem("tnt:tnt_stick", {
|
||||
description = "TNT Stick",
|
||||
inventory_image = "tnt_tnt_stick.png",
|
||||
groups = {flammable = 5},
|
||||
})
|
||||
|
||||
if enable_tnt then
|
||||
minetest.register_craft({
|
||||
output = "tnt:tnt_stick 2",
|
||||
recipe = {
|
||||
{"tnt:gunpowder", "", "tnt:gunpowder"},
|
||||
{"tnt:gunpowder", "default:paper", "tnt:gunpowder"},
|
||||
{"tnt:gunpowder", "", "tnt:gunpowder"},
|
||||
}
|
||||
})
|
||||
|
||||
minetest.register_craft({
|
||||
output = "tnt:tnt",
|
||||
recipe = {
|
||||
{"group:wood", "tnt:gunpowder", "group:wood"},
|
||||
{"tnt:gunpowder", "tnt:gunpowder", "tnt:gunpowder"},
|
||||
{"group:wood", "tnt:gunpowder", "group:wood"}
|
||||
{"tnt:tnt_stick", "tnt:tnt_stick", "tnt:tnt_stick"},
|
||||
{"tnt:tnt_stick", "tnt:tnt_stick", "tnt:tnt_stick"},
|
||||
{"tnt:tnt_stick", "tnt:tnt_stick", "tnt:tnt_stick"}
|
||||
}
|
||||
})
|
||||
|
||||
|
|
|
@ -35,6 +35,7 @@ Copyright (C) 2014-2016 BlockMen
|
|||
Copyright (C) 2014-2016 ShadowNinja
|
||||
Copyright (C) 2015-2016 Wuzzy
|
||||
Copyright (C) 2016 sofar (sofar@foo-projects.org)
|
||||
Copyright (C) 2018 paramat
|
||||
|
||||
You are free to:
|
||||
Share — copy and redistribute the material in any medium or format.
|
||||
|
|
BIN
mods/tnt/textures/tnt_tnt_stick.png
Normal file
BIN
mods/tnt/textures/tnt_tnt_stick.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 149 B |
Loading…
Add table
Add a link
Reference in a new issue