149 lines
3.7 KiB
Markdown
149 lines
3.7 KiB
Markdown
|
Minetest jumpdrive
|
||
|
======
|
||
|
|
||
|
A simple [Jumpdrive](https://en.wikipedia.org/wiki/Jump_drive) for minetest
|
||
|
|
||
|
Take your buildings with you on your journey
|
||
|
|
||
|
* Github: [https://github.com/thomasrudin-mt/jumpdrive](https://github.com/thomasrudin-mt/jumpdrive)
|
||
|
* Forum topic: [https://forum.minetest.net/viewtopic.php?f=9&t=20073](https://forum.minetest.net/viewtopic.php?f=9&t=20073)
|
||
|
|
||
|
# Operation
|
||
|
|
||
|
* Place a 'jumpdrive:engine' into the center of your creation.
|
||
|
* Connect the engine to a technic HV network
|
||
|
* Let the engine charge
|
||
|
* Choose your target coordinates (should be air or ignore blocks)
|
||
|
* Select your cube-radius
|
||
|
* Click "show" and check the green (source) and red (target) destination markers if everything is in range
|
||
|
* Click "jump"
|
||
|
|
||
|
# Compatibility
|
||
|
|
||
|
Optional dependencies:
|
||
|
* Mesecon interaction (execute jump on signal)
|
||
|
* Technic rechargeable (HV)
|
||
|
* Travelnet box (gets rewired after jump)
|
||
|
* Elevator (on_place gets called after jump)
|
||
|
* Locator (gets removed and added after each jump)
|
||
|
* Pipeworks teleport tubes (with a patch to pipeworks)
|
||
|
* Beds (thx to @tuedel)
|
||
|
* Ropes (thx to @tuedel)
|
||
|
* Mission-wand as coordinate bookmark (thx to @SwissalpS)
|
||
|
|
||
|
# Fuel
|
||
|
|
||
|
The engine connects to a technic hv network.
|
||
|
The energy requirements formula looks like this: **10 x radius x distance**
|
||
|
|
||
|
For example:
|
||
|
* Distance: 100 blocks
|
||
|
* Radius: 5 blocks
|
||
|
* Required energy: 10 x 5 x 100 = 5000
|
||
|
|
||
|
# Protection
|
||
|
|
||
|
The source and destination areas are checked for protection so you can't remove and jump into someone else's buildings.
|
||
|
There are currently no checks for plain populated areas (normal terrain) so you can jump happily into the mountains and make swiss cheese :)
|
||
|
A possible solution against this would be a global height or area restriction (see Preflight check).
|
||
|
|
||
|
|
||
|
# Screenshots
|
||
|
|
||
|
Interface:
|
||
|
|
||
|
![](screenshots/screenshot_20180507_200309.png?raw=true)
|
||
|
|
||
|
Example:
|
||
|
|
||
|
![](screenshots/screenshot_20180507_200203.png?raw=true)
|
||
|
|
||
|
# Advanced operation
|
||
|
|
||
|
## Coordinate bookmarking
|
||
|
|
||
|
You can place empty books into the drive inventory and write the coordinates to it with the "Write to book" button
|
||
|
The "Read from book" reads the coordinates from the next book in the inventory
|
||
|
|
||
|
# Settings
|
||
|
|
||
|
Settings in minetest.conf:
|
||
|
|
||
|
* **jumpdrive.maxradius** max radius of the jumpdrive (default: *15*)
|
||
|
* **jumpdrive.powerstorage** power storage of the drive (default: *1000000*)
|
||
|
* **jumpdrive.power_requirement** power requirement for chargin (default: *2500*)
|
||
|
|
||
|
# Lua api
|
||
|
|
||
|
## Preflight check
|
||
|
|
||
|
The preflight check can be overriden to execute additional checks:
|
||
|
|
||
|
```lua
|
||
|
jumpdrive.preflight_check = function(source, destination, radius, player)
|
||
|
-- check for height limit, only space travel allowed
|
||
|
if destination.y < 1000 then
|
||
|
return { success=false, message="Atmospheric travel not allowed!" }
|
||
|
end
|
||
|
|
||
|
-- everything ok
|
||
|
return { success=true }
|
||
|
end
|
||
|
```
|
||
|
|
||
|
## Fuel calc
|
||
|
|
||
|
The default fuel calc can be overwritten by a depending mod:
|
||
|
|
||
|
```lua
|
||
|
-- calculates the power requirements for a jump
|
||
|
jumpdrive.calculate_power = function(radius, distance, sourcePos, targetPos)
|
||
|
return 10 * distance * radius
|
||
|
end
|
||
|
```
|
||
|
|
||
|
# Sources
|
||
|
|
||
|
* jumprive_engine.ogg: https://freesound.org/people/kaboose102/sounds/340257/
|
||
|
|
||
|
# Contributors
|
||
|
|
||
|
* @tuedel
|
||
|
* @SwissalpS
|
||
|
* @Panquesito7
|
||
|
|
||
|
# History
|
||
|
|
||
|
## Next
|
||
|
|
||
|
## 2.0
|
||
|
|
||
|
* various fixes and optimizations
|
||
|
* Fleetcontroller
|
||
|
* Digiline interface
|
||
|
* mod.conf (minetest >= 5.0)
|
||
|
* Beds,ropes,missions compatibility
|
||
|
* calculate_power() override
|
||
|
* overlap check
|
||
|
* No fuel consumption if creative
|
||
|
* Protection checks for source and destination
|
||
|
* preflight check with custom override
|
||
|
* Settings in minetest.conf
|
||
|
* vacuum compatibility (jump into vacuum with air filled vessel)
|
||
|
|
||
|
## 1.1
|
||
|
|
||
|
* improved performance
|
||
|
* Documentation
|
||
|
* Removed complicated cascade function
|
||
|
|
||
|
## 1.0
|
||
|
|
||
|
* Initial version
|
||
|
* Cascade operation (with issues)
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|