minetest_modding_book/_en/map/abms.md

67 lines
2.3 KiB
Markdown
Raw Normal View History

2014-12-15 12:04:40 -08:00
---
title: Active Block Modifiers
layout: default
2017-08-26 08:40:30 -07:00
root: ../../
2018-07-15 07:28:10 -07:00
idx: 3.2
description: Learn how to make ABMs to change blocks.
2018-07-15 11:13:16 -07:00
redirect_from: /en/chapters/abms.html
2014-12-15 12:04:40 -08:00
---
2015-02-22 02:28:37 -08:00
## Introduction
2014-12-15 12:04:40 -08:00
An **A**ctive **B**lock **M**odifier (**ABM**) allows you to run code on
certain nodes at specific intervals.
Please be warned, ABMs which are too frequent or act on a large number of nodes
cause massive amounts of lag. Use them sparingly.
2014-12-15 12:04:40 -08:00
2017-08-29 04:17:21 -07:00
* [Example: Growing Alien Grass](#example-growing-alien-grass)
* [Your Turn](#your-turn)
## Example: Growing Alien Grass
2014-12-15 12:04:40 -08:00
Alien grass, for the purposes of this chapter, is a type of grass which
has a chance to appear near water.
2014-12-15 12:04:40 -08:00
To create it, you first need to register the grass, then
write an ABM.
2014-12-15 12:04:40 -08:00
{% highlight lua %}
minetest.register_node("aliens:grass", {
description = "Alien Grass",
light_source = 3, -- The node radiates light. Values can be from 1 to 15
tiles = {"aliens_grass.png"},
groups = {choppy=1},
on_use = minetest.item_eat(20)
2014-12-15 12:04:40 -08:00
})
minetest.register_abm({
nodenames = {"default:dirt_with_grass"},
neighbors = {"default:water_source", "default:water_flowing"},
interval = 10.0, -- Run every 10 seconds
chance = 50, -- Select every 1 in 50 nodes
action = function(pos, node, active_object_count, active_object_count_wider)
minetest.set_node({x = pos.x, y = pos.y + 1, z = pos.z}, {name = "aliens:grass"})
end
2014-12-15 12:04:40 -08:00
})
{% endhighlight %}
This ABM runs every ten seconds. There is a 1 in 5 chance of the ABM running on each
node that has the correct name and the correct neighbors. If the ABM runs on a
node, an alien grass node is placed above it. Please be warned, this will delete any
node previously located in that position. To prevent this you should include a check
using minetest.get_node to make sure there is space for the grass.
2014-12-15 12:04:40 -08:00
Specifying a neighbor is optional. If you specify multiple neighbors, only one of them
needs to be present to meet the requirements.
Specifying chance is also optional. If you don't specify the chance, the ABM will
always run when the other conditions are met.
2014-12-15 12:04:40 -08:00
2015-02-22 02:28:37 -08:00
## Your Turn
2014-12-15 12:04:40 -08:00
* **Midas touch**: Make water turn to gold blocks with a 1 in 100 chance, every 5 seconds.
* **Decay**: Make wood turn into dirt when water is a neighbor.
* **Burnin'**: Make every air node catch on fire. (Tip: "air" and "fire:basic_flame").
Warning: expect the game to crash.