spacecannon/readme.md

116 lines
2.6 KiB
Markdown
Raw Normal View History

2018-11-16 08:43:37 +01:00
2021-01-10 19:55:15 +01:00
Spacecannon mod
2021-01-10 19:59:26 +01:00
[![ContentDB](https://content.minetest.net/packages/BuckarooBanzay/spacecannon/shields/downloads/)](https://content.minetest.net/packages/BuckarooBanzay/spacecannon/)
2021-01-10 19:55:15 +01:00
# Overview
Adds five scifi/space cannons with various projectile-speed and explosion-strength.
2021-01-10 19:55:15 +01:00
The cannons need HV-Power from a `technic` network and can be controlled via formspec/hand, mesecons or digilines.
They also need to charge first, which can take a couple of seconds depending on cannon-type.
The projectile detonates on impact but only in _non-protected_ areas!
# Screenshots
<img src="./screenshot_1.png"/>
<img src="./screenshot_2.png"/>
<img src="./screenshot_3.png"/>
# Dependencies
Depends on:
* `technic`
Supports:
* `mesecons`
* `digilines`
# Mesecons
2018-11-16 08:43:37 +01:00
2021-01-10 19:55:15 +01:00
An "on" signal triggers a fire-action.
# Digilines
Fire a cannon:
```lua
if event.type == "program" then
digiline_send("cannon", { command="fire", verbose=false })
2021-01-10 19:55:15 +01:00
end
```
Example response from a "get" request:
```lua
{
type = "digiline",
channel = "c7",
msg = {
HV_EU_input = 0,
HV_EU_demand = 0,
dir = {
y = 0,
x = 0,
z = 1
},
powerstorage = 10000,
ready = true,
origin = "c7",
name = "spacecannon:cannon_green",
pos = {
y = 10,
x = -64,
z = -53
}
}
}
```
The "fire" request can specify an optional "verbose" flag. If this flag
evaluates to true, then the following example response will be sent back.
Note that if you have a large number of cannons that you will likely want
to disable responses. N cannons firing and generating responses will
cause N^2 messages to be processed, as each cannon receives the fire response
from all of its peers. If N>20, your LUAC will overheat. N>900, and your
server admin will want to have a chat with you.
2021-01-10 19:55:15 +01:00
```lua
{
type = "digiline",
channel = "c2",
msg = {
pos = {
y = 10,
x = -59,
z = -53
},
origin = "c2",
success = true
}
}
```
# Api
Modify the ability to shoot depending on position or playername:
```lua
spacecannon.can_shoot = function(pos, playername)
return true
end
```
2021-01-10 19:55:15 +01:00
# Contributors
* @BuckarooBanzay
* @dennisjenkins75
2023-05-31 17:33:14 +02:00
* @kiedtl
2021-01-10 19:55:15 +01:00
# License
Code: MIT
Textures: CC-BY-SA 3.0
# Attributions
2018-11-16 08:43:37 +01:00
2021-01-10 19:55:15 +01:00
* sounds/spacecannon_shoot.ogg https://freesound.org/people/jonccox/sounds/175261/