mirror of
https://github.com/sys4-fr/server-nalc.git
synced 2025-01-11 18:40:25 +01:00
[beds & boats & bucket & ... ] Update MinetestForFun game
This commit is contained in:
parent
a2b30a2aba
commit
82c90e76e9
@ -1,23 +1,24 @@
|
|||||||
The main game for the Minetest game engine [minetest_game]
|
Minetest Game [minetest_game]
|
||||||
==========================================================
|
=============================
|
||||||
|
The main subgame for the Minetest engine
|
||||||
|
========================================
|
||||||
|
|
||||||
To use this game with Minetest, insert this repository as
|
To use this subgame with the Minetest engine, insert this repository as
|
||||||
/games/minetest_game
|
/games/minetest_game
|
||||||
in the Minetest Engine.
|
|
||||||
|
|
||||||
The Minetest Engine can be found in:
|
The Minetest engine can be found in:
|
||||||
https://github.com/minetest/minetest/
|
https://github.com/minetest/minetest/
|
||||||
|
|
||||||
Compatibility
|
Compatibility
|
||||||
--------------
|
--------------
|
||||||
The minetest_game github master HEAD is generally compatible with the github
|
The Minetest Game github master HEAD is generally compatible with the github
|
||||||
master HEAD of minetest.
|
master HEAD of the Minetest engine.
|
||||||
|
|
||||||
Additionally, when the minetest engine is tagged to be a certain version (eg.
|
Additionally, when the Minetest engine is tagged to be a certain version (eg.
|
||||||
0.4.10), minetest_game is tagged with the version too.
|
0.4.10), Minetest Game is tagged with the version too.
|
||||||
|
|
||||||
When stable releases are made, minetest_game is packaged and made available in
|
When stable releases are made, Minetest Game is packaged and made available in
|
||||||
http://minetest.net/download
|
http://minetest.net/download
|
||||||
and in case the repository has grown too much, it may be reset. In that sense,
|
and in case the repository has grown too much, it may be reset. In that sense,
|
||||||
this is not a "real" git repository. (Package maintainers please note!)
|
this is not a "real" git repository. (Package maintainers please note!)
|
||||||
|
|
||||||
|
@ -1,11 +1,11 @@
|
|||||||
minetest_game API
|
Minetest Game API
|
||||||
======================
|
=================
|
||||||
GitHub Repo: https://github.com/minetest/minetest_game
|
GitHub Repo: https://github.com/minetest/minetest_game
|
||||||
|
|
||||||
Introduction
|
Introduction
|
||||||
------------
|
------------
|
||||||
The minetest_game gamemode offers multiple new possibilities in addition to Minetest's built-in API, allowing you to
|
The Minetest Game subgame offers multiple new possibilities in addition to the Minetest engine's built-in API,
|
||||||
add new plants to farming mod, buckets for new liquids, new stairs and custom panes.
|
allowing you to add new plants to farming mod, buckets for new liquids, new stairs and custom panes.
|
||||||
For information on the Minetest API, visit https://github.com/minetest/minetest/blob/master/doc/lua_api.txt
|
For information on the Minetest API, visit https://github.com/minetest/minetest/blob/master/doc/lua_api.txt
|
||||||
Please note:
|
Please note:
|
||||||
[XYZ] refers to a section the Minetest API
|
[XYZ] refers to a section the Minetest API
|
||||||
@ -17,23 +17,24 @@ Bucket API
|
|||||||
The bucket API allows registering new types of buckets for non-default liquids.
|
The bucket API allows registering new types of buckets for non-default liquids.
|
||||||
|
|
||||||
bucket.register_liquid(
|
bucket.register_liquid(
|
||||||
"default:lava_source", -- Source node name
|
"default:lava_source", -- name of the source node
|
||||||
"default:lava_flowing", -- Flowing node name
|
"default:lava_flowing", -- name of the flowing node
|
||||||
"bucket:bucket_lava", -- Name to be used for bucket
|
"bucket:bucket_lava", -- name of the new bucket item (or nil if liquid is not takeable)
|
||||||
"bucket_lava.png", -- Bucket texture (for wielditem and inventory_image)
|
"bucket_lava.png", -- texture of the new bucket item (ignored if itemname == nil)
|
||||||
"Lava Bucket" -- Bucket description
|
"Lava Bucket", -- text description of the bucket item
|
||||||
|
{lava_bucket = 1} -- groups of the bucket item, OPTIONAL
|
||||||
)
|
)
|
||||||
|
|
||||||
Beds API
|
Beds API
|
||||||
--------
|
--------
|
||||||
beds.register_bed(
|
beds.register_bed(
|
||||||
"beds:bed", -- Bed name
|
"beds:bed", -- Bed name
|
||||||
def: See [#Bed definition] -- Bed definition
|
def: See [#Bed definition] -- Bed definition
|
||||||
)
|
)
|
||||||
|
|
||||||
beds.read_spawns() -- returns a table containing players respawn positions
|
beds.read_spawns() -- returns a table containing players respawn positions
|
||||||
beds.kick_players() -- forces all players to leave bed
|
beds.kick_players() -- forces all players to leave bed
|
||||||
beds.skip_night() -- sets world time to morning and saves respawn position of all players currently sleeping
|
beds.skip_night() -- sets world time to morning and saves respawn position of all players currently sleeping
|
||||||
|
|
||||||
#Bed definition
|
#Bed definition
|
||||||
---------------
|
---------------
|
||||||
@ -50,11 +51,11 @@ Beds API
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
nodebox = {
|
nodebox = {
|
||||||
bottom = regular nodebox, see [Node boxes], -- bottm part of bed
|
bottom = regular nodebox, see [Node boxes], -- bottm part of bed
|
||||||
top = regular nodebox, see [Node boxes], -- top part of bed
|
top = regular nodebox, see [Node boxes], -- top part of bed
|
||||||
},
|
},
|
||||||
selectionbox = regular nodebox, see [Node boxes], -- for both nodeboxes
|
selectionbox = regular nodebox, see [Node boxes], -- for both nodeboxes
|
||||||
recipe = { -- Craft recipe
|
recipe = { -- Craft recipe
|
||||||
{"group:wool", "group:wool", "group:wool"},
|
{"group:wool", "group:wool", "group:wool"},
|
||||||
{"group:wood", "group:wood", "group:wood"}
|
{"group:wood", "group:wood", "group:wood"}
|
||||||
}
|
}
|
||||||
@ -104,9 +105,9 @@ doors.register_trapdoor(name, def)
|
|||||||
sound_open = sound to play when opening the trapdoor, OPTIONAL,
|
sound_open = sound to play when opening the trapdoor, OPTIONAL,
|
||||||
sound_close = sound to play when closing the trapdoor, OPTIONAL,
|
sound_close = sound to play when closing the trapdoor, OPTIONAL,
|
||||||
-> You can add any other node definition properties for minetest.register_node,
|
-> You can add any other node definition properties for minetest.register_node,
|
||||||
such as wield_image, inventory_image, sounds, groups, description, ...
|
such as wield_image, inventory_image, sounds, groups, description, ...
|
||||||
Only node_box, selection_box, tiles, drop, drawtype, paramtype, paramtype2, on_rightclick
|
Only node_box, selection_box, tiles, drop, drawtype, paramtype, paramtype2, on_rightclick
|
||||||
will be overwritten by the trapdoor registration function
|
will be overwritten by the trapdoor registration function
|
||||||
}
|
}
|
||||||
|
|
||||||
Farming API
|
Farming API
|
||||||
@ -122,11 +123,11 @@ farming.register_plant(name, Plant definition)
|
|||||||
#Hoe Definition
|
#Hoe Definition
|
||||||
---------------
|
---------------
|
||||||
{
|
{
|
||||||
description = "", -- Description for tooltip
|
description = "", -- Description for tooltip
|
||||||
inventory_image = "unknown_item.png", -- Image to be used as wield- and inventory image
|
inventory_image = "unknown_item.png", -- Image to be used as wield- and inventory image
|
||||||
max_uses = 30, -- Uses until destroyed
|
max_uses = 30, -- Uses until destroyed
|
||||||
material = "", -- Material for recipes
|
material = "", -- Material for recipes
|
||||||
recipe = { -- Craft recipe, if material isn't used
|
recipe = { -- Craft recipe, if material isn't used
|
||||||
{"air", "air", "air"},
|
{"air", "air", "air"},
|
||||||
{"", "group:stick"},
|
{"", "group:stick"},
|
||||||
{"", "group:stick"},
|
{"", "group:stick"},
|
||||||
@ -136,12 +137,12 @@ farming.register_plant(name, Plant definition)
|
|||||||
#Plant definition
|
#Plant definition
|
||||||
-----------------
|
-----------------
|
||||||
{
|
{
|
||||||
description = "", -- Description of seed item
|
description = "", -- Description of seed item
|
||||||
inventory_image = "unknown_item.png", -- Image to be used as seed's wield- and inventory image
|
inventory_image = "unknown_item.png", -- Image to be used as seed's wield- and inventory image
|
||||||
steps = 8, -- How many steps the plant has to grow, until it can be harvested
|
steps = 8, -- How many steps the plant has to grow, until it can be harvested
|
||||||
^ Always provide a plant texture for each step, format: modname_plantname_i.png (i = stepnumber)
|
^ Always provide a plant texture for each step, format: modname_plantname_i.png (i = stepnumber)
|
||||||
minlight = 13, -- Minimum light to grow
|
minlight = 13, -- Minimum light to grow
|
||||||
maxlight = default.LIGHT_MAX -- Maximum light to grow
|
maxlight = default.LIGHT_MAX -- Maximum light to grow
|
||||||
}
|
}
|
||||||
|
|
||||||
Screwdriver API
|
Screwdriver API
|
||||||
@ -155,7 +156,7 @@ on_rotate(pos, node, user, mode, new_param2)
|
|||||||
^ mode: screwdriver.ROTATE_FACE or screwdriver.ROTATE_AXIS
|
^ mode: screwdriver.ROTATE_FACE or screwdriver.ROTATE_AXIS
|
||||||
^ new_param2: the new value of param2 that would have been set if on_rotate wasn't there
|
^ new_param2: the new value of param2 that would have been set if on_rotate wasn't there
|
||||||
^ return value: false to disallow rotation, nil to keep default behaviour, true to allow
|
^ return value: false to disallow rotation, nil to keep default behaviour, true to allow
|
||||||
it but to indicate that changed have already been made (so the screwdriver will wear out)
|
it but to indicate that changed have already been made (so the screwdriver will wear out)
|
||||||
^ use on_rotate = screwdriver.disallow to always disallow rotation
|
^ use on_rotate = screwdriver.disallow to always disallow rotation
|
||||||
^ use on_rotate = screwdriver.rotate_simple to allow only face rotation
|
^ use on_rotate = screwdriver.rotate_simple to allow only face rotation
|
||||||
|
|
||||||
@ -215,10 +216,10 @@ The following nodes use the group `connect_to_raillike` and will only connect to
|
|||||||
raillike nodes within this group and the same group value.
|
raillike nodes within this group and the same group value.
|
||||||
Use `minetest.raillike_group(<Name>)` to get the group value.
|
Use `minetest.raillike_group(<Name>)` to get the group value.
|
||||||
|
|
||||||
| Node type | Raillike group name
|
| Node type | Raillike group name
|
||||||
+-----------------------+----------------------------------
|
+-----------------------+--------------------
|
||||||
| default:rail | "rail"
|
| default:rail | "rail"
|
||||||
| tnt:gunpowder | "gunpowder"
|
| tnt:gunpowder | "gunpowder"
|
||||||
| tnt:gunpowder_burning | "gunpowder"
|
| tnt:gunpowder_burning | "gunpowder"
|
||||||
|
|
||||||
Example:
|
Example:
|
||||||
@ -281,13 +282,13 @@ default.player_get_animation(player)
|
|||||||
Model Definition
|
Model Definition
|
||||||
----------------
|
----------------
|
||||||
{
|
{
|
||||||
animation_speed = 30, -- Default animation speed, in FPS.
|
animation_speed = 30, -- Default animation speed, in FPS.
|
||||||
textures = {"character.png", }, -- Default array of textures.
|
textures = {"character.png", }, -- Default array of textures.
|
||||||
visual_size = {x=1, y=1,}, -- Used to scale the model.
|
visual_size = {x = 1, y = 1}, -- Used to scale the model.
|
||||||
animations = {
|
animations = {
|
||||||
-- <anim_name> = { x=<start_frame>, y=<end_frame>, },
|
-- <anim_name> = {x = <start_frame>, y = <end_frame>},
|
||||||
foo = { x= 0, y=19, },
|
foo = {x = 0, y = 19},
|
||||||
bar = { x=20, y=39, },
|
bar = {x = 20, y = 39},
|
||||||
-- ...
|
-- ...
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
@ -375,10 +376,22 @@ dye.excolors
|
|||||||
Trees
|
Trees
|
||||||
-----
|
-----
|
||||||
default.grow_tree(pos, is_apple_tree)
|
default.grow_tree(pos, is_apple_tree)
|
||||||
^ Grows a tree or apple tree at pos
|
^ Grows a mgv6 tree or apple tree at pos
|
||||||
|
|
||||||
default.grow_jungle_tree(pos)
|
default.grow_jungle_tree(pos)
|
||||||
^ Grows a jungletree at pos
|
^ Grows a mgv6 jungletree at pos
|
||||||
|
|
||||||
default.grow_pine_tree(pos)
|
default.grow_pine_tree(pos)
|
||||||
^ Grows a pinetree at pos
|
^ Grows a mgv6 pinetree at pos
|
||||||
|
|
||||||
|
default.grow_new_apple_tree(pos)
|
||||||
|
^ Grows a new design apple tree at pos
|
||||||
|
|
||||||
|
default.grow_new_jungle_tree(pos)
|
||||||
|
^ Grows a new design jungle tree at pos
|
||||||
|
|
||||||
|
default.grow_new_pine_tree(pos)
|
||||||
|
^ Grows a new design pine tree at pos
|
||||||
|
|
||||||
|
default.grow_new_acacia_tree(pos)
|
||||||
|
^ Grows a new design acacia tree at pos
|
||||||
|
@ -1,6 +1,4 @@
|
|||||||
# This file contains settings of minetest_game that can be changed in
|
# This file contains settings of Minetest Game that can be changed in minetest.conf
|
||||||
# minetest.conf
|
|
||||||
#
|
|
||||||
# By default, all the settings are commented and not functional.
|
# By default, all the settings are commented and not functional.
|
||||||
# Uncomment settings by removing the preceding #.
|
# Uncomment settings by removing the preceding #.
|
||||||
|
|
||||||
@ -26,3 +24,11 @@
|
|||||||
# Enable the stairs mod ABM that replaces the old 'upside down'
|
# Enable the stairs mod ABM that replaces the old 'upside down'
|
||||||
# stair and slab nodes in old maps with the new param2 versions.
|
# stair and slab nodes in old maps with the new param2 versions.
|
||||||
#enable_stairs_replace_abm = false
|
#enable_stairs_replace_abm = false
|
||||||
|
|
||||||
|
# Whether you allow respawning in beds
|
||||||
|
# Default value is true
|
||||||
|
#enable_bed_respawn = true
|
||||||
|
|
||||||
|
# Whether players can skip night by sleeping
|
||||||
|
# Default value is true
|
||||||
|
#enable_bed_night_skip = true
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
Minetest mod "Beds"
|
Minetest Game mod: beds
|
||||||
===================
|
=======================
|
||||||
by BlockMen (c) 2014-2015
|
by BlockMen (c) 2014-2015
|
||||||
|
|
||||||
Version: 1.1.1
|
Version: 1.1.1
|
||||||
@ -14,7 +14,8 @@ if more than 50% of the players are lying in bed and use this option.
|
|||||||
Another feature is a controled respawning. If you have slept in bed (not just lying in it) your respawn point
|
Another feature is a controled respawning. If you have slept in bed (not just lying in it) your respawn point
|
||||||
is set to the beds location and you will respawn there after death.
|
is set to the beds location and you will respawn there after death.
|
||||||
You can disable the respawn at beds by setting "enable_bed_respawn = false" in minetest.conf
|
You can disable the respawn at beds by setting "enable_bed_respawn = false" in minetest.conf
|
||||||
|
You can also disable the night skip feature by setting "enable_bed_night_skip = false" in minetest.conf or by using
|
||||||
|
the /set command ingame.
|
||||||
|
|
||||||
|
|
||||||
License of source code, textures: WTFPL
|
License of source code, textures: WTFPL
|
||||||
|
@ -21,6 +21,14 @@ local function get_look_yaw(pos)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local function is_night_skip_enabled()
|
||||||
|
local enable_night_skip = minetest.setting_getbool("enable_bed_night_skip")
|
||||||
|
if enable_night_skip == nil then
|
||||||
|
enable_night_skip = true
|
||||||
|
end
|
||||||
|
return enable_night_skip
|
||||||
|
end
|
||||||
|
|
||||||
local function check_in_beds(players)
|
local function check_in_beds(players)
|
||||||
local in_bed = beds.player
|
local in_bed = beds.player
|
||||||
if not players then
|
if not players then
|
||||||
@ -101,7 +109,7 @@ local function update_formspecs(finished)
|
|||||||
else
|
else
|
||||||
form_n = beds.formspec ..
|
form_n = beds.formspec ..
|
||||||
"label[2.2,11;"..tostring(player_in_bed).." of "..tostring(ges).." players are in bed]"
|
"label[2.2,11;"..tostring(player_in_bed).." of "..tostring(ges).." players are in bed]"
|
||||||
if is_majority then
|
if is_majority and is_night_skip_enabled() then
|
||||||
form_n = form_n ..
|
form_n = form_n ..
|
||||||
"button_exit[2,8;4,0.75;force;Force night skip]"
|
"button_exit[2,8;4,0.75;force;Force night skip]"
|
||||||
end
|
end
|
||||||
@ -154,11 +162,13 @@ function beds.on_rightclick(pos, player)
|
|||||||
-- skip the night and let all players stand up
|
-- skip the night and let all players stand up
|
||||||
if check_in_beds() then
|
if check_in_beds() then
|
||||||
minetest.after(2, function()
|
minetest.after(2, function()
|
||||||
beds.skip_night()
|
|
||||||
if not is_sp then
|
if not is_sp then
|
||||||
update_formspecs(true)
|
update_formspecs(is_night_skip_enabled())
|
||||||
|
end
|
||||||
|
if is_night_skip_enabled() then
|
||||||
|
beds.skip_night()
|
||||||
|
beds.kick_players()
|
||||||
end
|
end
|
||||||
beds.kick_players()
|
|
||||||
end)
|
end)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -189,9 +199,11 @@ minetest.register_on_leaveplayer(function(player)
|
|||||||
beds.player[name] = nil
|
beds.player[name] = nil
|
||||||
if check_in_beds() then
|
if check_in_beds() then
|
||||||
minetest.after(2, function()
|
minetest.after(2, function()
|
||||||
beds.skip_night()
|
update_formspecs(is_night_skip_enabled())
|
||||||
update_formspecs(true)
|
if is_night_skip_enabled() then
|
||||||
beds.kick_players()
|
beds.skip_night()
|
||||||
|
beds.kick_players()
|
||||||
|
end
|
||||||
end)
|
end)
|
||||||
end
|
end
|
||||||
end)
|
end)
|
||||||
@ -206,8 +218,10 @@ minetest.register_on_player_receive_fields(function(player, formname, fields)
|
|||||||
end
|
end
|
||||||
|
|
||||||
if fields.force then
|
if fields.force then
|
||||||
beds.skip_night()
|
update_formspecs(is_night_skip_enabled())
|
||||||
update_formspecs(true)
|
if is_night_skip_enabled() then
|
||||||
beds.kick_players()
|
beds.skip_night()
|
||||||
|
beds.kick_players()
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end)
|
end)
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
Minetest 0.4 mod: boats
|
Minetest Game mod: boats
|
||||||
=======================
|
========================
|
||||||
by PilzAdam, slightly modified for NeXt
|
by PilzAdam
|
||||||
|
|
||||||
License of source code:
|
License of source code:
|
||||||
-----------------------
|
-----------------------
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
Minetest 0.4 mod: bucket
|
Minetest Game mod: bucket
|
||||||
=========================
|
=========================
|
||||||
|
|
||||||
License of source code:
|
License of source code:
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
Minetest 0.4 mod: creative
|
Minetest Game mod: creative
|
||||||
==========================
|
===========================
|
||||||
|
|
||||||
Implements creative mode.
|
Implements creative mode.
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
Minetest 0.4 mod: default
|
Minetest Game mod: default
|
||||||
==========================
|
==========================
|
||||||
|
|
||||||
License of source code:
|
License of source code:
|
||||||
|
@ -701,7 +701,7 @@ function default.register_biomes()
|
|||||||
y_min = 2,
|
y_min = 2,
|
||||||
y_max = 31000,
|
y_max = 31000,
|
||||||
heat_point = 20,
|
heat_point = 20,
|
||||||
humidity_point = 30,
|
humidity_point = 25,
|
||||||
})
|
})
|
||||||
|
|
||||||
minetest.register_biome({
|
minetest.register_biome({
|
||||||
@ -719,9 +719,10 @@ function default.register_biomes()
|
|||||||
y_min = -112,
|
y_min = -112,
|
||||||
y_max = 1,
|
y_max = 1,
|
||||||
heat_point = 20,
|
heat_point = 20,
|
||||||
humidity_point = 30,
|
humidity_point = 25,
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
minetest.register_biome({
|
minetest.register_biome({
|
||||||
name = "taiga",
|
name = "taiga",
|
||||||
node_dust = "default:snow",
|
node_dust = "default:snow",
|
||||||
@ -737,7 +738,7 @@ function default.register_biomes()
|
|||||||
y_min = 2,
|
y_min = 2,
|
||||||
y_max = 31000,
|
y_max = 31000,
|
||||||
heat_point = 20,
|
heat_point = 20,
|
||||||
humidity_point = 70,
|
humidity_point = 75,
|
||||||
})
|
})
|
||||||
|
|
||||||
minetest.register_biome({
|
minetest.register_biome({
|
||||||
@ -755,10 +756,10 @@ function default.register_biomes()
|
|||||||
y_min = -112,
|
y_min = -112,
|
||||||
y_max = 1,
|
y_max = 1,
|
||||||
heat_point = 20,
|
heat_point = 20,
|
||||||
humidity_point = 70,
|
humidity_point = 75,
|
||||||
})
|
})
|
||||||
|
|
||||||
-- Cool
|
-- Temperate
|
||||||
|
|
||||||
minetest.register_biome({
|
minetest.register_biome({
|
||||||
name = "stone_grassland",
|
name = "stone_grassland",
|
||||||
@ -772,10 +773,10 @@ function default.register_biomes()
|
|||||||
--depth_water_top = ,
|
--depth_water_top = ,
|
||||||
--node_water = "",
|
--node_water = "",
|
||||||
--node_river_water = "",
|
--node_river_water = "",
|
||||||
y_min = 6,
|
y_min = 5,
|
||||||
y_max = 31000,
|
y_max = 31000,
|
||||||
heat_point = 45,
|
heat_point = 45,
|
||||||
humidity_point = 30,
|
humidity_point = 25,
|
||||||
})
|
})
|
||||||
|
|
||||||
minetest.register_biome({
|
minetest.register_biome({
|
||||||
@ -791,11 +792,12 @@ function default.register_biomes()
|
|||||||
--node_water = "",
|
--node_water = "",
|
||||||
--node_river_water = "",
|
--node_river_water = "",
|
||||||
y_min = -112,
|
y_min = -112,
|
||||||
y_max = 5,
|
y_max = 4,
|
||||||
heat_point = 45,
|
heat_point = 45,
|
||||||
humidity_point = 30,
|
humidity_point = 25,
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
minetest.register_biome({
|
minetest.register_biome({
|
||||||
name = "coniferous_forest",
|
name = "coniferous_forest",
|
||||||
--node_dust = "",
|
--node_dust = "",
|
||||||
@ -808,10 +810,28 @@ function default.register_biomes()
|
|||||||
--depth_water_top = ,
|
--depth_water_top = ,
|
||||||
--node_water = "",
|
--node_water = "",
|
||||||
--node_river_water = "",
|
--node_river_water = "",
|
||||||
y_min = 6,
|
y_min = 9,
|
||||||
y_max = 31000,
|
y_max = 31000,
|
||||||
heat_point = 45,
|
heat_point = 45,
|
||||||
humidity_point = 70,
|
humidity_point = 75,
|
||||||
|
})
|
||||||
|
|
||||||
|
minetest.register_biome({
|
||||||
|
name = "coniferous_forest_dunes",
|
||||||
|
--node_dust = "",
|
||||||
|
node_top = "default:sand",
|
||||||
|
depth_top = 1,
|
||||||
|
node_filler = "default:sand",
|
||||||
|
depth_filler = 2,
|
||||||
|
--node_stone = "",
|
||||||
|
--node_water_top = "",
|
||||||
|
--depth_water_top = ,
|
||||||
|
--node_water = "",
|
||||||
|
--node_river_water = "",
|
||||||
|
y_min = 5,
|
||||||
|
y_max = 8,
|
||||||
|
heat_point = 45,
|
||||||
|
humidity_point = 75,
|
||||||
})
|
})
|
||||||
|
|
||||||
minetest.register_biome({
|
minetest.register_biome({
|
||||||
@ -827,12 +847,11 @@ function default.register_biomes()
|
|||||||
--node_water = "",
|
--node_water = "",
|
||||||
--node_river_water = "",
|
--node_river_water = "",
|
||||||
y_min = -112,
|
y_min = -112,
|
||||||
y_max = 5,
|
y_max = 4,
|
||||||
heat_point = 45,
|
heat_point = 45,
|
||||||
humidity_point = 70,
|
humidity_point = 75,
|
||||||
})
|
})
|
||||||
|
|
||||||
-- Warm
|
|
||||||
|
|
||||||
minetest.register_biome({
|
minetest.register_biome({
|
||||||
name = "sandstone_grassland",
|
name = "sandstone_grassland",
|
||||||
@ -846,10 +865,10 @@ function default.register_biomes()
|
|||||||
--depth_water_top = ,
|
--depth_water_top = ,
|
||||||
--node_water = "",
|
--node_water = "",
|
||||||
--node_river_water = "",
|
--node_river_water = "",
|
||||||
y_min = 6,
|
y_min = 5,
|
||||||
y_max = 31000,
|
y_max = 31000,
|
||||||
heat_point = 70,
|
heat_point = 70,
|
||||||
humidity_point = 30,
|
humidity_point = 25,
|
||||||
})
|
})
|
||||||
|
|
||||||
minetest.register_biome({
|
minetest.register_biome({
|
||||||
@ -865,11 +884,12 @@ function default.register_biomes()
|
|||||||
--node_water = "",
|
--node_water = "",
|
||||||
--node_river_water = "",
|
--node_river_water = "",
|
||||||
y_min = -112,
|
y_min = -112,
|
||||||
y_max = 5,
|
y_max = 4,
|
||||||
heat_point = 70,
|
heat_point = 70,
|
||||||
humidity_point = 30,
|
humidity_point = 25,
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
minetest.register_biome({
|
minetest.register_biome({
|
||||||
name = "deciduous_forest",
|
name = "deciduous_forest",
|
||||||
--node_dust = "",
|
--node_dust = "",
|
||||||
@ -882,10 +902,28 @@ function default.register_biomes()
|
|||||||
--depth_water_top = ,
|
--depth_water_top = ,
|
||||||
--node_water = "",
|
--node_water = "",
|
||||||
--node_river_water = "",
|
--node_river_water = "",
|
||||||
y_min = 6,
|
y_min = 1,
|
||||||
y_max = 31000,
|
y_max = 31000,
|
||||||
heat_point = 70,
|
heat_point = 70,
|
||||||
humidity_point = 70,
|
humidity_point = 75,
|
||||||
|
})
|
||||||
|
|
||||||
|
minetest.register_biome({
|
||||||
|
name = "deciduous_forest_swamp",
|
||||||
|
--node_dust = "",
|
||||||
|
node_top = "default:dirt",
|
||||||
|
depth_top = 1,
|
||||||
|
node_filler = "default:dirt",
|
||||||
|
depth_filler = 2,
|
||||||
|
--node_stone = "",
|
||||||
|
--node_water_top = "",
|
||||||
|
--depth_water_top = ,
|
||||||
|
--node_water = "",
|
||||||
|
--node_river_water = "",
|
||||||
|
y_min = -3,
|
||||||
|
y_max = 0,
|
||||||
|
heat_point = 70,
|
||||||
|
humidity_point = 75,
|
||||||
})
|
})
|
||||||
|
|
||||||
minetest.register_biome({
|
minetest.register_biome({
|
||||||
@ -901,9 +939,9 @@ function default.register_biomes()
|
|||||||
--node_water = "",
|
--node_water = "",
|
||||||
--node_river_water = "",
|
--node_river_water = "",
|
||||||
y_min = -112,
|
y_min = -112,
|
||||||
y_max = 5,
|
y_max = -4,
|
||||||
heat_point = 70,
|
heat_point = 70,
|
||||||
humidity_point = 70,
|
humidity_point = 75,
|
||||||
})
|
})
|
||||||
|
|
||||||
-- Hot
|
-- Hot
|
||||||
@ -944,6 +982,7 @@ function default.register_biomes()
|
|||||||
humidity_point = 10,
|
humidity_point = 10,
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
minetest.register_biome({
|
minetest.register_biome({
|
||||||
name = "savanna",
|
name = "savanna",
|
||||||
--node_dust = "",
|
--node_dust = "",
|
||||||
@ -956,12 +995,30 @@ function default.register_biomes()
|
|||||||
--depth_water_top = ,
|
--depth_water_top = ,
|
||||||
--node_water = "",
|
--node_water = "",
|
||||||
--node_river_water = "",
|
--node_river_water = "",
|
||||||
y_min = 5,
|
y_min = 1,
|
||||||
y_max = 31000,
|
y_max = 31000,
|
||||||
heat_point = 95,
|
heat_point = 95,
|
||||||
humidity_point = 50,
|
humidity_point = 50,
|
||||||
})
|
})
|
||||||
|
|
||||||
|
minetest.register_biome({
|
||||||
|
name = "savanna_swamp",
|
||||||
|
--node_dust = "",
|
||||||
|
node_top = "default:dirt",
|
||||||
|
depth_top = 1,
|
||||||
|
node_filler = "default:dirt",
|
||||||
|
depth_filler = 2,
|
||||||
|
--node_stone = "",
|
||||||
|
--node_water_top = "",
|
||||||
|
--depth_water_top = ,
|
||||||
|
--node_water = "",
|
||||||
|
--node_river_water = "",
|
||||||
|
y_min = -3,
|
||||||
|
y_max = 0,
|
||||||
|
heat_point = 95,
|
||||||
|
humidity_point = 50,
|
||||||
|
})
|
||||||
|
|
||||||
minetest.register_biome({
|
minetest.register_biome({
|
||||||
name = "savanna_ocean",
|
name = "savanna_ocean",
|
||||||
--node_dust = "",
|
--node_dust = "",
|
||||||
@ -975,11 +1032,12 @@ function default.register_biomes()
|
|||||||
--node_water = "",
|
--node_water = "",
|
||||||
--node_river_water = "",
|
--node_river_water = "",
|
||||||
y_min = -112,
|
y_min = -112,
|
||||||
y_max = 4,
|
y_max = -4,
|
||||||
heat_point = 95,
|
heat_point = 95,
|
||||||
humidity_point = 50,
|
humidity_point = 50,
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
minetest.register_biome({
|
minetest.register_biome({
|
||||||
name = "rainforest",
|
name = "rainforest",
|
||||||
--node_dust = "",
|
--node_dust = "",
|
||||||
@ -1010,7 +1068,7 @@ function default.register_biomes()
|
|||||||
--depth_water_top = ,
|
--depth_water_top = ,
|
||||||
--node_water = "",
|
--node_water = "",
|
||||||
--node_river_water = "",
|
--node_river_water = "",
|
||||||
y_min = 0,
|
y_min = -3,
|
||||||
y_max = 0,
|
y_max = 0,
|
||||||
heat_point = 95,
|
heat_point = 95,
|
||||||
humidity_point = 90,
|
humidity_point = 90,
|
||||||
@ -1029,7 +1087,7 @@ function default.register_biomes()
|
|||||||
--node_water = "",
|
--node_water = "",
|
||||||
--node_river_water = "",
|
--node_river_water = "",
|
||||||
y_min = -112,
|
y_min = -112,
|
||||||
y_max = -1,
|
y_max = -4,
|
||||||
heat_point = 95,
|
heat_point = 95,
|
||||||
humidity_point = 90,
|
humidity_point = 90,
|
||||||
})
|
})
|
||||||
@ -1040,9 +1098,9 @@ function default.register_biomes()
|
|||||||
name = "underground",
|
name = "underground",
|
||||||
--node_dust = "",
|
--node_dust = "",
|
||||||
--node_top = "",
|
--node_top = "",
|
||||||
depth_top = 0,
|
--depth_top = ,
|
||||||
--node_filler = "",
|
--node_filler = "",
|
||||||
depth_filler = -4,
|
--depth_filler = ,
|
||||||
--node_stone = "",
|
--node_stone = "",
|
||||||
--node_water_top = "",
|
--node_water_top = "",
|
||||||
--depth_water_top = ,
|
--depth_water_top = ,
|
||||||
@ -1181,18 +1239,14 @@ local function register_grass_decoration(offset, scale, length)
|
|||||||
noise_params = {
|
noise_params = {
|
||||||
offset = offset,
|
offset = offset,
|
||||||
scale = scale,
|
scale = scale,
|
||||||
spread = {x = 100, y = 100, z = 100},
|
spread = {x = 200, y = 200, z = 200},
|
||||||
seed = 436,
|
seed = 329,
|
||||||
octaves = 3,
|
octaves = 3,
|
||||||
persist = 0.6
|
persist = 0.6
|
||||||
},
|
},
|
||||||
biomes = {
|
biomes = {"stone_grassland", "sandstone_grassland",
|
||||||
"stone_grassland", "stone_grassland_ocean",
|
"deciduous_forest", "coniferous_forest", "coniferous_forest_dunes"},
|
||||||
"sandstone_grassland", "sandstone_grassland_ocean",
|
y_min = 1,
|
||||||
"deciduous_forest", "deciduous_forest_ocean",
|
|
||||||
"coniferous_forest", "coniferous_forest_ocean",
|
|
||||||
},
|
|
||||||
y_min = 5,
|
|
||||||
y_max = 31000,
|
y_max = 31000,
|
||||||
decoration = "default:grass_"..length,
|
decoration = "default:grass_"..length,
|
||||||
})
|
})
|
||||||
@ -1206,13 +1260,13 @@ local function register_dry_grass_decoration(offset, scale, length)
|
|||||||
noise_params = {
|
noise_params = {
|
||||||
offset = offset,
|
offset = offset,
|
||||||
scale = scale,
|
scale = scale,
|
||||||
spread = {x = 100, y = 100, z = 100},
|
spread = {x = 200, y = 200, z = 200},
|
||||||
seed = 19822,
|
seed = 329,
|
||||||
octaves = 3,
|
octaves = 3,
|
||||||
persist = 0.6
|
persist = 0.6
|
||||||
},
|
},
|
||||||
biomes = {"savana"},
|
biomes = {"savanna"},
|
||||||
y_min = -31000,
|
y_min = 1,
|
||||||
y_max = 31000,
|
y_max = 31000,
|
||||||
decoration = "default:dry_grass_"..length,
|
decoration = "default:dry_grass_"..length,
|
||||||
})
|
})
|
||||||
@ -1230,13 +1284,13 @@ function default.register_decorations()
|
|||||||
noise_params = {
|
noise_params = {
|
||||||
offset = 0.04,
|
offset = 0.04,
|
||||||
scale = 0.02,
|
scale = 0.02,
|
||||||
spread = {x = 100, y = 100, z = 100},
|
spread = {x = 250, y = 250, z = 250},
|
||||||
seed = 1220999,
|
seed = 2,
|
||||||
octaves = 3,
|
octaves = 3,
|
||||||
persist = 0.66
|
persist = 0.66
|
||||||
},
|
},
|
||||||
biomes = {"deciduous_forest"},
|
biomes = {"deciduous_forest"},
|
||||||
y_min = 6,
|
y_min = 1,
|
||||||
y_max = 31000,
|
y_max = 31000,
|
||||||
schematic = minetest.get_modpath("default").."/schematics/apple_tree.mts",
|
schematic = minetest.get_modpath("default").."/schematics/apple_tree.mts",
|
||||||
flags = "place_center_x, place_center_z",
|
flags = "place_center_x, place_center_z",
|
||||||
@ -1254,6 +1308,7 @@ function default.register_decorations()
|
|||||||
y_max = 31000,
|
y_max = 31000,
|
||||||
schematic = minetest.get_modpath("default").."/schematics/jungle_tree.mts",
|
schematic = minetest.get_modpath("default").."/schematics/jungle_tree.mts",
|
||||||
flags = "place_center_x, place_center_z",
|
flags = "place_center_x, place_center_z",
|
||||||
|
rotation = "random",
|
||||||
})
|
})
|
||||||
|
|
||||||
-- Taiga and temperate forest pine tree
|
-- Taiga and temperate forest pine tree
|
||||||
@ -1263,10 +1318,10 @@ function default.register_decorations()
|
|||||||
place_on = {"default:snowblock", "default:dirt_with_grass"},
|
place_on = {"default:snowblock", "default:dirt_with_grass"},
|
||||||
sidelen = 16,
|
sidelen = 16,
|
||||||
noise_params = {
|
noise_params = {
|
||||||
offset = -0.02,
|
offset = 0.04,
|
||||||
scale = 0.03,
|
scale = 0.02,
|
||||||
spread = {x = 100, y = 100, z = 100},
|
spread = {x = 250, y = 250, z = 250},
|
||||||
seed = 1133,
|
seed = 2,
|
||||||
octaves = 3,
|
octaves = 3,
|
||||||
persist = 0.66
|
persist = 0.66
|
||||||
},
|
},
|
||||||
@ -1286,13 +1341,13 @@ function default.register_decorations()
|
|||||||
noise_params = {
|
noise_params = {
|
||||||
offset = 0,
|
offset = 0,
|
||||||
scale = 0.003,
|
scale = 0.003,
|
||||||
spread = {x=250, y=250, z=250},
|
spread = {x = 250, y = 250, z = 250},
|
||||||
seed = 2,
|
seed = 2,
|
||||||
octaves = 3,
|
octaves = 3,
|
||||||
persist = 0.66
|
persist = 0.66
|
||||||
},
|
},
|
||||||
biomes = {"savanna"},
|
biomes = {"savanna"},
|
||||||
y_min = 6,
|
y_min = 1,
|
||||||
y_max = 31000,
|
y_max = 31000,
|
||||||
schematic = minetest.get_modpath("default").."/schematics/acacia_tree.mts",
|
schematic = minetest.get_modpath("default").."/schematics/acacia_tree.mts",
|
||||||
flags = "place_center_x, place_center_z",
|
flags = "place_center_x, place_center_z",
|
||||||
@ -1306,10 +1361,10 @@ function default.register_decorations()
|
|||||||
place_on = {"default:desert_sand"},
|
place_on = {"default:desert_sand"},
|
||||||
sidelen = 80,
|
sidelen = 80,
|
||||||
noise_params = {
|
noise_params = {
|
||||||
offset = 0.04,
|
offset = -0.0005,
|
||||||
scale = 0.08,
|
scale = 0.0015,
|
||||||
spread = {x = 100, y = 100, z = 100},
|
spread = {x = 200, y = 200, z = 200},
|
||||||
seed = 66440,
|
seed = 230,
|
||||||
octaves = 3,
|
octaves = 3,
|
||||||
persist = 0.6
|
persist = 0.6
|
||||||
},
|
},
|
||||||
@ -1330,7 +1385,7 @@ function default.register_decorations()
|
|||||||
noise_params = {
|
noise_params = {
|
||||||
offset = -0.0005,
|
offset = -0.0005,
|
||||||
scale = 0.0015,
|
scale = 0.0015,
|
||||||
spread = {x=200, y=200, z=200},
|
spread = {x = 200, y = 200, z = 200},
|
||||||
seed = 230,
|
seed = 230,
|
||||||
octaves = 3,
|
octaves = 3,
|
||||||
persist = 0.6
|
persist = 0.6
|
||||||
@ -1347,17 +1402,17 @@ function default.register_decorations()
|
|||||||
|
|
||||||
minetest.register_decoration({
|
minetest.register_decoration({
|
||||||
deco_type = "schematic",
|
deco_type = "schematic",
|
||||||
place_on = {"default:sand"},
|
place_on = {"default:dirt"},
|
||||||
sidelen = 16,
|
sidelen = 16,
|
||||||
noise_params = {
|
noise_params = {
|
||||||
offset = -0.3,
|
offset = -0.3,
|
||||||
scale = 0.7,
|
scale = 0.7,
|
||||||
spread = {x=200, y=200, z=200},
|
spread = {x = 200, y = 200, z = 200},
|
||||||
seed = 354,
|
seed = 354,
|
||||||
octaves = 3,
|
octaves = 3,
|
||||||
persist = 0.7
|
persist = 0.7
|
||||||
},
|
},
|
||||||
biomes = {"savanna_ocean", "desert_ocean"},
|
biomes = {"savanna_swamp"},
|
||||||
y_min = 0,
|
y_min = 0,
|
||||||
y_max = 0,
|
y_max = 0,
|
||||||
schematic = minetest.get_modpath("default").."/schematics/papyrus.mts",
|
schematic = minetest.get_modpath("default").."/schematics/papyrus.mts",
|
||||||
@ -1401,7 +1456,7 @@ function default.register_decorations()
|
|||||||
noise_params = {
|
noise_params = {
|
||||||
offset = 0,
|
offset = 0,
|
||||||
scale = 0.02,
|
scale = 0.02,
|
||||||
spread = {x=200, y=200, z=200},
|
spread = {x = 200, y = 200, z = 200},
|
||||||
seed = 329,
|
seed = 329,
|
||||||
octaves = 3,
|
octaves = 3,
|
||||||
persist = 0.6
|
persist = 0.6
|
||||||
|
@ -1036,7 +1036,6 @@ minetest.register_node("default:stone_with_mese", {
|
|||||||
},
|
},
|
||||||
},
|
},
|
||||||
sounds = default.node_sound_stone_defaults(),
|
sounds = default.node_sound_stone_defaults(),
|
||||||
light_source = 1,
|
|
||||||
})
|
})
|
||||||
|
|
||||||
minetest.register_node("default:mese", {
|
minetest.register_node("default:mese", {
|
||||||
|
BIN
minetestforfun_game/mods/default/schematics/acacia_tree.mts
Executable file → Normal file
BIN
minetestforfun_game/mods/default/schematics/acacia_tree.mts
Executable file → Normal file
Binary file not shown.
BIN
minetestforfun_game/mods/default/schematics/apple_tree.mts
Executable file → Normal file
BIN
minetestforfun_game/mods/default/schematics/apple_tree.mts
Executable file → Normal file
Binary file not shown.
BIN
minetestforfun_game/mods/default/schematics/papyrus.mts
Executable file → Normal file
BIN
minetestforfun_game/mods/default/schematics/papyrus.mts
Executable file → Normal file
Binary file not shown.
BIN
minetestforfun_game/mods/default/schematics/pine_tree.mts
Executable file → Normal file
BIN
minetestforfun_game/mods/default/schematics/pine_tree.mts
Executable file → Normal file
Binary file not shown.
Binary file not shown.
Before Width: | Height: | Size: 345 B After Width: | Height: | Size: 546 B |
@ -1,5 +1,5 @@
|
|||||||
Minetest 0.4 mod: doors
|
Minetest Game mod: doors
|
||||||
=======================
|
========================
|
||||||
version: 1.3
|
version: 1.3
|
||||||
|
|
||||||
License of source code:
|
License of source code:
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
Minetest 0.4 mod: dye
|
Minetest Game mod: dye
|
||||||
======================
|
======================
|
||||||
|
|
||||||
See init.lua for documentation.
|
See init.lua for documentation.
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
Minetest 0.4 mod: fire
|
Minetest Game mod: fire
|
||||||
======================
|
=======================
|
||||||
|
|
||||||
License of source code:
|
License of source code:
|
||||||
-----------------------
|
-----------------------
|
||||||
|
@ -37,16 +37,9 @@ minetest.register_node("fire:basic_flame", {
|
|||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
-- Fire sounds table
|
|
||||||
-- key: position hash of low corner of area
|
|
||||||
-- value: {handle=sound handle, name=sound name}
|
|
||||||
fire.sounds = {}
|
|
||||||
|
|
||||||
|
|
||||||
-- Get sound area of position
|
-- Get sound area of position
|
||||||
|
|
||||||
-- size of sound areas
|
fire.D = 6 -- size of sound areas
|
||||||
fire.D = 6
|
|
||||||
|
|
||||||
function fire.get_area_p0p1(pos)
|
function fire.get_area_p0p1(pos)
|
||||||
local p0 = {
|
local p0 = {
|
||||||
@ -63,6 +56,12 @@ function fire.get_area_p0p1(pos)
|
|||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
-- Fire sounds table
|
||||||
|
-- key: position hash of low corner of area
|
||||||
|
-- value: {handle=sound handle, name=sound name}
|
||||||
|
fire.sounds = {}
|
||||||
|
|
||||||
|
|
||||||
-- Update fire sounds in sound area of position
|
-- Update fire sounds in sound area of position
|
||||||
|
|
||||||
function fire.update_sounds_around(pos)
|
function fire.update_sounds_around(pos)
|
||||||
@ -126,39 +125,90 @@ end
|
|||||||
-- Detect nearby extinguishing nodes
|
-- Detect nearby extinguishing nodes
|
||||||
|
|
||||||
function fire.flame_should_extinguish(pos)
|
function fire.flame_should_extinguish(pos)
|
||||||
if minetest.setting_getbool("disable_fire") then return true end
|
return minetest.find_node_near(pos, 1, {"group:puts_out_fire"})
|
||||||
--return minetest.find_node_near(pos, 1, {"group:puts_out_fire"})
|
|
||||||
local p0 = {x = pos.x - 1, y = pos.y, z = pos.z - 1}
|
|
||||||
local p1 = {x = pos.x + 1, y = pos.y + 1, z = pos.z + 1}
|
|
||||||
local ps = minetest.find_nodes_in_area(p0, p1, {"group:puts_out_fire"})
|
|
||||||
return (#ps ~= 0)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
-- Ignite neighboring nodes
|
-- Enable ABMs according to 'disable fire' setting
|
||||||
|
|
||||||
--[[minetest.register_abm({
|
if minetest.setting_getbool("disable_fire") then
|
||||||
nodenames = {"group:flammable"},
|
|
||||||
neighbors = {"group:igniter"},
|
-- Extinguish flames quickly with dedicated ABM
|
||||||
interval = 7,
|
|
||||||
chance = 32,
|
minetest.register_abm({
|
||||||
action = function(p0, node, _, _)
|
nodenames = {"fire:basic_flame"},
|
||||||
-- If there is water or stuff like that around flame, don't ignite
|
interval = 3,
|
||||||
if fire.flame_should_extinguish(p0) then
|
chance = 2,
|
||||||
return
|
action = function(p0, node, _, _)
|
||||||
end
|
minetest.remove_node(p0)
|
||||||
local p = fire.find_pos_for_flame_around(p0)
|
end,
|
||||||
if p then
|
})
|
||||||
minetest.set_node(p, {name = "fire:basic_flame"})
|
|
||||||
end
|
else
|
||||||
end,
|
|
||||||
})
|
-- Extinguish flames quickly with water, snow, ice
|
||||||
|
|
||||||
|
minetest.register_abm({
|
||||||
|
nodenames = {"fire:basic_flame"},
|
||||||
|
neighbors = {"group:puts_out_fire"},
|
||||||
|
interval = 3,
|
||||||
|
chance = 2,
|
||||||
|
action = function(p0, node, _, _)
|
||||||
|
minetest.remove_node(p0)
|
||||||
|
minetest.sound_play("fire_extinguish_flame",
|
||||||
|
{pos = p0, max_hear_distance = 16, gain = 0.25})
|
||||||
|
end,
|
||||||
|
})
|
||||||
|
|
||||||
|
-- Ignite neighboring nodes
|
||||||
|
|
||||||
|
minetest.register_abm({
|
||||||
|
nodenames = {"group:flammable"},
|
||||||
|
neighbors = {"group:igniter"},
|
||||||
|
interval = 7,
|
||||||
|
chance = 16,
|
||||||
|
action = function(p0, node, _, _)
|
||||||
|
-- If there is water or stuff like that around node, don't ignite
|
||||||
|
if fire.flame_should_extinguish(p0) then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
local p = fire.find_pos_for_flame_around(p0)
|
||||||
|
if p then
|
||||||
|
minetest.set_node(p, {name = "fire:basic_flame"})
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
})
|
||||||
|
|
||||||
|
-- Remove flames and flammable nodes
|
||||||
|
|
||||||
|
minetest.register_abm({
|
||||||
|
nodenames = {"fire:basic_flame"},
|
||||||
|
interval = 5,
|
||||||
|
chance = 16,
|
||||||
|
action = function(p0, node, _, _)
|
||||||
|
-- If there are no flammable nodes around flame, remove flame
|
||||||
|
if not minetest.find_node_near(p0, 1, {"group:flammable"}) then
|
||||||
|
minetest.remove_node(p0)
|
||||||
|
return
|
||||||
|
end
|
||||||
|
if math.random(1, 4) == 1 then
|
||||||
|
-- remove flammable nodes around flame
|
||||||
|
local p = minetest.find_node_near(p0, 1, {"group:flammable"})
|
||||||
|
if p then
|
||||||
|
minetest.remove_node(p)
|
||||||
|
nodeupdate(p)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
})
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
-- Rarely ignite things from far
|
-- Rarely ignite things from far
|
||||||
|
|
||||||
-- Currently disabled to reduce the chance of uncontrollable spreading
|
--[[ Currently disabled to reduce the chance of uncontrollable spreading
|
||||||
-- fires that disrupt servers. Also for less lua processing load.
|
fires that disrupt servers. Also for less lua processing load.
|
||||||
|
|
||||||
minetest.register_abm({
|
minetest.register_abm({
|
||||||
nodenames = {"group:igniter"},
|
nodenames = {"group:igniter"},
|
||||||
@ -183,44 +233,5 @@ minetest.register_abm({
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
end,
|
end,
|
||||||
})]]
|
|
||||||
|
|
||||||
-- Remove flammable nodes and flame
|
|
||||||
|
|
||||||
minetest.register_abm({
|
|
||||||
nodenames = {"fire:basic_flame"},
|
|
||||||
interval = 5,
|
|
||||||
chance = 16,
|
|
||||||
action = function(p0, node, _, _)
|
|
||||||
-- If there is water or stuff like that around flame, remove flame
|
|
||||||
if fire.flame_should_extinguish(p0) then
|
|
||||||
minetest.remove_node(p0)
|
|
||||||
return
|
|
||||||
end
|
|
||||||
-- Make the following things rarer
|
|
||||||
if math.random(1, 3) == 1 then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
-- If there are no flammable nodes around flame, remove flame
|
|
||||||
if not minetest.find_node_near(p0, 1, {"group:flammable"}) then
|
|
||||||
minetest.remove_node(p0)
|
|
||||||
return
|
|
||||||
end
|
|
||||||
if math.random(1, 4) == 1 then
|
|
||||||
-- remove a flammable node around flame
|
|
||||||
local p = minetest.find_node_near(p0, 1, {"group:flammable"})
|
|
||||||
if p then
|
|
||||||
-- If there is water or stuff like that around flame, don't remove
|
|
||||||
if fire.flame_should_extinguish(p0) then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
minetest.remove_node(p)
|
|
||||||
nodeupdate(p)
|
|
||||||
end
|
|
||||||
else
|
|
||||||
-- remove flame
|
|
||||||
minetest.remove_node(p0)
|
|
||||||
end
|
|
||||||
end,
|
|
||||||
})
|
})
|
||||||
|
--]]
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
Minetest 0.4 mod: flowers
|
Minetest Game mod: flowers
|
||||||
=========================
|
==========================
|
||||||
|
|
||||||
License of source code:
|
License of source code:
|
||||||
-----------------------
|
-----------------------
|
||||||
|
@ -46,6 +46,7 @@ local function add_simple_flower(name, desc, box, f_groups)
|
|||||||
sunlight_propagates = true,
|
sunlight_propagates = true,
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
walkable = false,
|
walkable = false,
|
||||||
|
buildable_to = true,
|
||||||
stack_max = 99,
|
stack_max = 99,
|
||||||
groups = f_groups,
|
groups = f_groups,
|
||||||
sounds = default.node_sound_leaves_defaults(),
|
sounds = default.node_sound_leaves_defaults(),
|
||||||
@ -275,6 +276,7 @@ minetest.register_node("flowers:waterlily", {
|
|||||||
wield_image = "flowers_waterlily.png",
|
wield_image = "flowers_waterlily.png",
|
||||||
liquids_pointable = true,
|
liquids_pointable = true,
|
||||||
walkable = false,
|
walkable = false,
|
||||||
|
buildable_to = true,
|
||||||
groups = {snappy = 3, flower = 1},
|
groups = {snappy = 3, flower = 1},
|
||||||
sounds = default.node_sound_leaves_defaults(),
|
sounds = default.node_sound_leaves_defaults(),
|
||||||
node_box = {
|
node_box = {
|
||||||
@ -289,10 +291,19 @@ minetest.register_node("flowers:waterlily", {
|
|||||||
after_place_node = function(pos, placer, itemstack, pointed_thing)
|
after_place_node = function(pos, placer, itemstack, pointed_thing)
|
||||||
local find_water = minetest.find_nodes_in_area({x = pos.x - 1, y = pos.y, z = pos.z - 1},
|
local find_water = minetest.find_nodes_in_area({x = pos.x - 1, y = pos.y, z = pos.z - 1},
|
||||||
{x = pos.x + 1, y = pos.y, z = pos.z + 1}, "default:water_source")
|
{x = pos.x + 1, y = pos.y, z = pos.z + 1}, "default:water_source")
|
||||||
|
local find_river_water = minetest.find_nodes_in_area({x = pos.x - 1, y = pos.y, z = pos.z - 1},
|
||||||
|
{x = pos.x + 1, y = pos.y, z = pos.z + 1}, "default:river_water_source")
|
||||||
if #find_water ~= 0 then
|
if #find_water ~= 0 then
|
||||||
minetest.set_node(pos, {name = "default:water_source"})
|
minetest.set_node(pos, {name = "default:water_source"})
|
||||||
pos.y = pos.y + 1
|
pos.y = pos.y + 1
|
||||||
|
minetest.set_node(pos, {name = "flowers:waterlily", param2 = math.random(0, 3)})
|
||||||
|
elseif #find_river_water ~= 0 then
|
||||||
|
minetest.set_node(pos, {name = "default:river_water_source"})
|
||||||
|
pos.y = pos.y + 1
|
||||||
|
minetest.set_node(pos, {name = "flowers:waterlily", param2 = math.random(0, 3)})
|
||||||
|
else
|
||||||
|
minetest.remove_node(pos)
|
||||||
|
return true
|
||||||
end
|
end
|
||||||
minetest.set_node(pos, {name = "flowers:waterlily", param2 = math.random(0, 3)})
|
|
||||||
end
|
end
|
||||||
})
|
})
|
||||||
|
@ -94,13 +94,9 @@ local function register_flower(seed, name)
|
|||||||
octaves = 3,
|
octaves = 3,
|
||||||
persist = 0.6
|
persist = 0.6
|
||||||
},
|
},
|
||||||
biomes = {
|
biomes = {"stone_grassland", "sandstone_grassland",
|
||||||
"stone_grassland",
|
"deciduous_forest", "coniferous_forest"},
|
||||||
"sandstone_grassland",
|
y_min = 1,
|
||||||
"deciduous_forest",
|
|
||||||
"coniferous_forest",
|
|
||||||
},
|
|
||||||
y_min = 6,
|
|
||||||
y_max = 31000,
|
y_max = 31000,
|
||||||
decoration = "flowers:"..name,
|
decoration = "flowers:"..name,
|
||||||
})
|
})
|
||||||
@ -120,7 +116,7 @@ local function register_mushroom(name)
|
|||||||
persist = 0.66
|
persist = 0.66
|
||||||
},
|
},
|
||||||
biomes = {"deciduous_forest", "coniferous_forest"},
|
biomes = {"deciduous_forest", "coniferous_forest"},
|
||||||
y_min = 6,
|
y_min = 1,
|
||||||
y_max = 31000,
|
y_max = 31000,
|
||||||
decoration = "flowers:"..name,
|
decoration = "flowers:"..name,
|
||||||
})
|
})
|
||||||
@ -129,7 +125,7 @@ end
|
|||||||
local function register_waterlily()
|
local function register_waterlily()
|
||||||
minetest.register_decoration({
|
minetest.register_decoration({
|
||||||
deco_type = "schematic",
|
deco_type = "schematic",
|
||||||
place_on = {"default:dirt", "default:sand"},
|
place_on = {"default:dirt"},
|
||||||
sidelen = 16,
|
sidelen = 16,
|
||||||
noise_params = {
|
noise_params = {
|
||||||
offset = -0.12,
|
offset = -0.12,
|
||||||
@ -139,8 +135,7 @@ local function register_waterlily()
|
|||||||
octaves = 3,
|
octaves = 3,
|
||||||
persist = 0.7
|
persist = 0.7
|
||||||
},
|
},
|
||||||
biomes = {"deciduous_forest_ocean", "sandstone_grassland_ocean",
|
biomes = {"rainforest_swamp", "savanna_swamp", "deciduous_forest_swamp"},
|
||||||
"rainforest_swamp", "savanna_ocean", "desert_ocean"},
|
|
||||||
y_min = 0,
|
y_min = 0,
|
||||||
y_max = 0,
|
y_max = 0,
|
||||||
schematic = minetest.get_modpath("flowers").."/schematics/waterlily.mts",
|
schematic = minetest.get_modpath("flowers").."/schematics/waterlily.mts",
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
Minetest mod: screwdriver
|
Minetest Game mod: screwdriver
|
||||||
=========================
|
==============================
|
||||||
|
|
||||||
License of source code:
|
License of source code:
|
||||||
-----------------------
|
-----------------------
|
||||||
@ -18,4 +18,4 @@ Attribution-ShareAlike 3.0 Unported (CC BY-SA 3.0)
|
|||||||
http://creativecommons.org/licenses/by-sa/3.0/
|
http://creativecommons.org/licenses/by-sa/3.0/
|
||||||
|
|
||||||
Created by Gambit (WTFPL):
|
Created by Gambit (WTFPL):
|
||||||
screwdriver.png
|
screwdriver.png
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
Minetest 0.4 mod: stairs
|
Minetest Game mod: stairs
|
||||||
=========================
|
=========================
|
||||||
|
|
||||||
License of source code:
|
License of source code:
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
Minetest 0.4 mod: vessels
|
Minetest Game mod: vessels
|
||||||
==========================
|
==========================
|
||||||
|
|
||||||
Crafts
|
Crafts
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
Minetest 0.4 mod: wool
|
Minetest Game mod: wool
|
||||||
======================
|
=======================
|
||||||
|
|
||||||
Mostly backward-compatible with jordach's 16-color wool mod.
|
Mostly backward-compatible with jordach's 16-color wool mod.
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
Minetest 0.4.x mod: xpanes
|
Minetest Game mod: xpanes
|
||||||
==========================
|
=========================
|
||||||
|
|
||||||
License:
|
License:
|
||||||
--------
|
--------
|
||||||
|
@ -17,11 +17,7 @@ local function update_pane(pos, name)
|
|||||||
end
|
end
|
||||||
local sum = 0
|
local sum = 0
|
||||||
for i, dir in pairs(directions) do
|
for i, dir in pairs(directions) do
|
||||||
local node = minetest.get_node({
|
local node = minetest.get_node(vector.add(pos, dir))
|
||||||
x = pos.x + dir.x,
|
|
||||||
y = pos.y + dir.y,
|
|
||||||
z = pos.z + dir.z
|
|
||||||
})
|
|
||||||
local def = minetest.registered_nodes[node.name]
|
local def = minetest.registered_nodes[node.name]
|
||||||
local pane_num = def and def.groups.pane or 0
|
local pane_num = def and def.groups.pane or 0
|
||||||
if pane_num > 0 or not def or (def.walkable ~= false and
|
if pane_num > 0 or not def or (def.walkable ~= false and
|
||||||
@ -50,14 +46,13 @@ local function update_nearby(pos, node)
|
|||||||
name = name:sub(8, underscore_pos - 1)
|
name = name:sub(8, underscore_pos - 1)
|
||||||
end
|
end
|
||||||
for i, dir in pairs(directions) do
|
for i, dir in pairs(directions) do
|
||||||
update_pane({
|
update_pane(vector.add(pos, dir), name)
|
||||||
x = pos.x + dir.x,
|
|
||||||
y = pos.y + dir.y,
|
|
||||||
z = pos.z + dir.z
|
|
||||||
}, name)
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
minetest.register_on_placenode(update_nearby)
|
||||||
|
minetest.register_on_dignode(update_nearby)
|
||||||
|
|
||||||
local half_boxes = {
|
local half_boxes = {
|
||||||
{0, -0.5, -1/32, 0.5, 0.5, 1/32},
|
{0, -0.5, -1/32, 0.5, 0.5, 1/32},
|
||||||
{-1/32, -0.5, 0, 1/32, 0.5, 0.5},
|
{-1/32, -0.5, 0, 1/32, 0.5, 0.5},
|
||||||
@ -82,6 +77,18 @@ local sb_full_boxes = {
|
|||||||
{-0.06, -0.5, -0.5, 0.06, 0.5, 0.5}
|
{-0.06, -0.5, -0.5, 0.06, 0.5, 0.5}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
local pane_def_fields = {
|
||||||
|
drawtype = "airlike",
|
||||||
|
paramtype = "light",
|
||||||
|
is_ground_content = false,
|
||||||
|
sunlight_propagates = true,
|
||||||
|
walkable = false,
|
||||||
|
pointable = false,
|
||||||
|
diggable = false,
|
||||||
|
buildable_to = true,
|
||||||
|
air_equivalent = true,
|
||||||
|
}
|
||||||
|
|
||||||
function xpanes.register_pane(name, def)
|
function xpanes.register_pane(name, def)
|
||||||
for i = 1, 15 do
|
for i = 1, 15 do
|
||||||
local need = {}
|
local need = {}
|
||||||
@ -132,6 +139,10 @@ function xpanes.register_pane(name, def)
|
|||||||
})
|
})
|
||||||
end
|
end
|
||||||
|
|
||||||
|
for k, v in pairs(pane_def_fields) do
|
||||||
|
def[k] = def[k] or v
|
||||||
|
end
|
||||||
|
|
||||||
def.on_construct = function(pos)
|
def.on_construct = function(pos)
|
||||||
update_pane(pos, name)
|
update_pane(pos, name)
|
||||||
end
|
end
|
||||||
@ -144,52 +155,29 @@ function xpanes.register_pane(name, def)
|
|||||||
})
|
})
|
||||||
end
|
end
|
||||||
|
|
||||||
minetest.register_on_placenode(update_nearby)
|
|
||||||
minetest.register_on_dignode(update_nearby)
|
|
||||||
|
|
||||||
xpanes.register_pane("pane", {
|
xpanes.register_pane("pane", {
|
||||||
description = "Glass Pane",
|
description = "Glass Pane",
|
||||||
tiles = {"xpanes_space.png"},
|
|
||||||
drawtype = "airlike",
|
|
||||||
paramtype = "light",
|
|
||||||
is_ground_content = false,
|
|
||||||
sunlight_propagates = true,
|
|
||||||
walkable = false,
|
|
||||||
pointable = false,
|
|
||||||
diggable = false,
|
|
||||||
buildable_to = true,
|
|
||||||
air_equivalent = true,
|
|
||||||
textures = {"default_glass.png","xpanes_pane_half.png","xpanes_white.png"},
|
textures = {"default_glass.png","xpanes_pane_half.png","xpanes_white.png"},
|
||||||
inventory_image = "default_glass.png",
|
inventory_image = "default_glass.png",
|
||||||
wield_image = "default_glass.png",
|
wield_image = "default_glass.png",
|
||||||
sounds = default.node_sound_glass_defaults(),
|
sounds = default.node_sound_glass_defaults(),
|
||||||
groups = {snappy=2, cracky=3, oddly_breakable_by_hand=3, pane=1},
|
groups = {snappy=2, cracky=3, oddly_breakable_by_hand=3, pane=1},
|
||||||
recipe = {
|
recipe = {
|
||||||
{'default:glass', 'default:glass', 'default:glass'},
|
{"default:glass", "default:glass", "default:glass"},
|
||||||
{'default:glass', 'default:glass', 'default:glass'}
|
{"default:glass", "default:glass", "default:glass"}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
xpanes.register_pane("bar", {
|
xpanes.register_pane("bar", {
|
||||||
description = "Iron bar",
|
description = "Iron bar",
|
||||||
tiles = {"xpanes_space.png"},
|
|
||||||
drawtype = "airlike",
|
|
||||||
paramtype = "light",
|
|
||||||
is_ground_content = false,
|
|
||||||
sunlight_propagates = true,
|
|
||||||
walkable = false,
|
|
||||||
pointable = false,
|
|
||||||
diggable = false,
|
|
||||||
buildable_to = true,
|
|
||||||
air_equivalent = true,
|
|
||||||
textures = {"xpanes_bar.png","xpanes_bar.png","xpanes_space.png"},
|
textures = {"xpanes_bar.png","xpanes_bar.png","xpanes_space.png"},
|
||||||
inventory_image = "xpanes_bar.png",
|
inventory_image = "xpanes_bar.png",
|
||||||
wield_image = "xpanes_bar.png",
|
wield_image = "xpanes_bar.png",
|
||||||
groups = {cracky=3, pane=1}, -- //MFF
|
groups = {cracky=3, pane=1}, -- //MFF
|
||||||
sounds = default.node_sound_stone_defaults(),
|
sounds = default.node_sound_stone_defaults(),
|
||||||
recipe = {
|
recipe = {
|
||||||
{'default:steel_ingot', 'default:steel_ingot', 'default:steel_ingot'},
|
{"default:steel_ingot", "default:steel_ingot", "default:steel_ingot"},
|
||||||
{'default:steel_ingot', 'default:steel_ingot', 'default:steel_ingot'}
|
{"default:steel_ingot", "default:steel_ingot", "default:steel_ingot"}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user