51 lines
1.2 KiB
Markdown
51 lines
1.2 KiB
Markdown
|
# Sound API
|
||
|
|
||
|
This mod is a wrapper for [sound api library](https://github.com/mt-mods/sound_api_core/).
|
||
|
|
||
|
## Usage of the sound api
|
||
|
|
||
|
### Option 1: embed
|
||
|
|
||
|
You can insert the [sound api library](https://github.com/mt-mods/sound_api_core/) directly into your mod as a submodule and use the following to load it.
|
||
|
|
||
|
```lua
|
||
|
local sound_api = dofile(modpath .. "/sound_api_core/init.lua")
|
||
|
```
|
||
|
|
||
|
additionally the author recommends that you use dependabot(github) or similar to help you keep the submodule up to date.
|
||
|
|
||
|
### Option 2: Agnostically depend
|
||
|
|
||
|
You can do this by using a custom field in your node def instead of the `sounds` key.
|
||
|
|
||
|
```lua
|
||
|
minetest.register_node(nodename, {
|
||
|
...
|
||
|
_sound_def = {
|
||
|
key = "",
|
||
|
input = {},
|
||
|
},
|
||
|
...
|
||
|
})
|
||
|
```
|
||
|
|
||
|
where:
|
||
|
|
||
|
* key: string name of the field from the sound api you want to use, for example `node_sound_stone_defaults`
|
||
|
* input: table input of fields you want passed to the key field, used to override specific sounds.
|
||
|
|
||
|
### Option 3: Hard depend
|
||
|
|
||
|
add this mod to your mod.confs depends and directly call the sound_api as follows
|
||
|
|
||
|
```lua
|
||
|
minetest.register_node(nodename, {
|
||
|
...
|
||
|
sounds = sound_api.node_sound_stone_defaults(input)
|
||
|
...
|
||
|
})
|
||
|
```
|
||
|
|
||
|
* input: optional table to override some or all of returned values
|
||
|
|