2019-12-15 01:50:17 +03:00
|
|
|
Screwdriver API
|
|
|
|
---------------
|
|
|
|
|
|
|
|
The screwdriver API allows you to control a node's behaviour when a screwdriver is used on it.
|
|
|
|
NOTE: This API is compatible with Minetest Game 5.1.0, but has some extensions.
|
|
|
|
|
|
|
|
To use it, add the `on_rotate` function to the node definition.
|
|
|
|
|
|
|
|
`on_rotate(pos, node, user, mode, new_param2)`
|
|
|
|
|
|
|
|
* `pos`: Position of the node that the screwdriver is being used on
|
|
|
|
* `node`: that node
|
|
|
|
* `user`: The player who used the screwdriver
|
|
|
|
* `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
|
|
|
|
* 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)
|
|
|
|
* use `on_rotate = false` to always disallow rotation
|
|
|
|
* use `on_rotate = screwdriver.rotate_simple` to allow only face rotation
|
2024-05-02 11:57:10 +03:00
|
|
|
* use `on_rotate = screwdriver.rotate_3way` (VoxeLibre extension) for pillar-like nodes that should only have 3 possible orientations)
|
2020-08-19 17:27:56 +03:00
|
|
|
|
|
|
|
|
|
|
|
|
2024-05-02 11:57:10 +03:00
|
|
|
`after_rotate(pos)` (VoxeLibre extension)
|
2020-08-19 17:27:56 +03:00
|
|
|
|
|
|
|
Called after the rotation has been completed
|
|
|
|
|
|
|
|
* `pos`: Position of the node that the screwdriver was used on
|