Lift

Description

A simple elevator plugin.

Due to the (probable) death of Bukkit Lift will be recoded for Sponge.

Primary features:

  • Command free
  • No configuration needed (but there if you want it!)
  • Database free (Lifts are determined by block arrangements, nothing more)
  • Multi floor elevators
  • Multi passenger elevators, including mobs and dropped items
  • Abstract elevator shaft shapes
  • Redstone triggers
  • Carpets can now be placed in any elevator floor. No more unsightly glass!
  • All rails can now be put in shafts. Minecarts will now go up and down lifts and resume their previous speed upon arrival (this is largely untested, more feedback here is needed!)

More video tutorials - English, Deutsch, Português

lift stats

How it works

No commands! No save file to worry about! It is easy to add, remove, or change floors. Just place or remove blocks! Lifts are made by scanning block arrangements are not saved or stored in memory after they are used. With the default configuration this is a fast process, less than 20 milliseconds.

Installation

Just drop the plugin in the plugin folder and play! No permissions to set up and the configuration is set up with defaults that will work for most servers. If you use a permission manager you might have to add add the permission "lift" and "lift.change" This is a bug in some managers

Here is the default configuration if you wish to play with the settings or language:

# Note: Smaller values result in less lag. Lift speed less than 0.4 may not work well for non spout servers.
maxLiftArea: 16
maxHeight: 256
debug: false
autoPlace: false
preventEntry: false
preventLeave: false
checkGlass: false
floorBlocks:
- GLASS
- STAINED_GLASS
baseBlockSpeeds:
  IRON_BLOCK: 0.5
redstone: false
STRING_oneFloor: "There is only one floor silly."
STRING_currentFloor: "Current Floor:"
STRING_dest: "Dest:"
STRING_cantEnter: "Can't enter elevator in use"
STRING_cantLeave: "Can't leave elevator in use"
  • maxLiftArea is the number of connected blocks the lift can be. Larger values will result in a longer start up time when using a lift. Super large values can even freeze your server for a moment.
  • maxHeight limits how tall an elevator can be.
  • debug prints out extra information that can help me track down errors
  • autoPlace will automatically position entities over the center of the base blocks which can prevent them from hitting edges and getting stuck
  • preventEntry blocks players from entering moving lift.
  • preventLeave blocks players from leaving a moving lift.
  • checkGlass prevents glass duping. With it false the plugin will NOT check to make sure all the floors have all the glass blocks filled it, but will have better performance for busy servers.
  • redstone can start a lift by using a redstone signal to the block behind the lift button. This can result in some lag on servers with a lot of pulsing redstone signals.
  • baseBlockSpeeds is a list of blocks you wish to use in the elevator base and how fast they make the lift. Multiple block types can be added. For example:
baseBlockSpeeds:
  IRON_BLOCK: 0.5
  GOLD_BLOCK: 0.75
  DIAMOND_BLOCK: 1.0

This example has three different blocks that can be used as a base, with faster lifts being more expensive. Make sure there are two spaces for proper yaml formatting!

Permission

There are two permission nodes. By default both are set to true allowing anyone to use lifts right away:

  • "lift" allow players be passengers and use lifts. To not let players use the lift, set lift to false in your permission plugin of choice.
  • "lift.change" allow players to change destination floors of any lift. To not allow players to change the floor signs, set lift.change to false in your permission plugin of choice.

I will not be adding permissions to individual lifts. It is not possible with how the code works.

Usage With Default Config

1) Create the bottom floor with iron blocks. An elevator can be as small as 1 block or as big as 15 blocks in any shape. Smaller areas will have less lag. Make sure the lift iron blocks don't touch any other iron in the building the plugin doesn't know the difference!

2) Next create the floor's control panel. On a wall place the following blocks. The signs and buttons must be "over" one of the iron base blocks.

- Required sign, leave blank for now

- Button

- Optional sign with floor name on first or second line

- Iron floor block you just placed.

3) Create the elevator shaft. To create a new floor platform use glass blocks instead of iron. Like the first floor over one of the glass blocks create the floor interface.

- Required sign, leave blank for now

- Button

- Optional sign with floor name on second line

4) Make sure the shaft is clear of all obstructions except for floor glass, buttons and signs. Torches and vines are also allowed in the elevator shaft.

5) To use your elevator right click the sign above the button to select a destination floor. The sign will automatically add the correct information.

Important Notes

If you find a bug or a feature not working as advertised please report to the ticket page. Bug reports in the comments will (probably) be ignored.

There is a config to adjust max lift area, lift height, lift speed, and a few other options. The defaults are sane and most people wont need to change them.

Data collection

This plugin uses Hidendra wonderful MCStats library - a fantastic tool that shows plugin authors how their plugin is being used to to the server http://mcstats.org/. Here is Lift's page so you can review what data has been collected, which is small compared to what the NSA probably has! You can opt of of the entire mcstats system by setting opt-out to true in plugins/PluginMetrics/config.yml or collectStats to false in plugins/Lift/config.yml

Data collected is plugin version, bukkit version, basic system info like java version and cpu type, and what country your fine server is located in.

On the other hand if you have the latest version of android phones Google knows where you parked your car.

FAQ

Q: Will you add build permissions?

A: No. Permissions are attached to players. An elevator is created by scanning a chunk for specific blocks in specific places. There is no easy way to stop a player from finishing an elevator without doing expensive, lag-causing calculations. To prevent a player from building an elevator you must prevent them from placing one of the elevator block types (iron block, sign, glass, or button). There are other plugins with this functionality.

Q: What are valid blocks to use inside the shaft?

A: Other than the glass blocks for the lift floors you play places torches, signs (ideal for sensors), buttons, vines, ladders, carpets, redstone, rails, and water.

Q: Will you add economy?

A: No. There are too many variations on how to do this and I want to keep the plugin focused and simple. There are other plugins you can use to add economy. One example is charging for button pressing:

Troubleshooting

For Lift versions < 50

You are getting errors with block X473 like:

1:34:32 [INFO] [Lift] [DEBUG] Starting elevator gen caused by: MXPLRS_Kirill v42
21:34:32 [INFO] ==Unknown Error==
21:34:32 [INFO] Yscan: 64
21:34:32 [INFO] Block: X473
21:34:32 [INFO] Is Valid Block: false
21:34:32 [INFO] Is Base Block: false
21:34:32 [INFO] [Lift] Player elevator generation returned a null object. Please report circumstances that generated this error.

The issue you are having is exceptionally likely to be due to Railcraft's tracking block (visible with the goggles as the tracking aura), you can disable it by setting block.hidden to 0 in Railcraft's config. The default ID of this block is 473.

You must login to post a comment. Don't have an account? Register to get one!

  • Avatar of djchewmacca djchewmacca Oct 12, 2014 at 17:35 UTC - 0 likes

    Just tried it mate. Doesn't appear to be working either. Thanks anyway.

    Mineville, Enjoy the Fun!

  • Avatar of djchewmacca djchewmacca Oct 12, 2014 at 17:20 UTC - 0 likes

    Thanks mate, really appreciate it. Gonna put it in shortly. :)

  • Avatar of Me_Goes_RAWR Me_Goes_RAWR Oct 12, 2014 at 01:23 UTC - 0 likes

    @djchewmacca: Go

    Hey, Just recompile it against the new spigot with the source: https://github.com/croxis/Lift

    I did it and it works now. Hoped this helped!

    In fact.... To help you, here: Lift for 1.8

    Last edited Oct 12, 2014 by Me_Goes_RAWR
  • Avatar of djchewmacca djchewmacca Oct 11, 2014 at 20:04 UTC - 0 likes

    I've recently updated to Spigot 1.7.10 along with the Carbon 1.63 plugin which allows 1.8 blocks in game. I've recently noticed that the Lift plugin no longer works. Any chance of an update??

    Thanks :)

  • Avatar of hotlavaballs900 hotlavaballs900 Oct 08, 2014 at 11:45 UTC - 0 likes

    Ok so the signs will change the dest: but the elevators wont work we have the glass signs iron button everything

  • Avatar of croxis croxis Aug 25, 2014 at 16:20 UTC - 0 likes

    @theunes06: Go

    It should. Please post a bug report if it doesn't.

  • Avatar of theunes06 theunes06 Aug 23, 2014 at 07:36 UTC - 0 likes

    Does this plugin also apply to 1.7.10 and 1.8?

  • Avatar of croxis croxis Aug 20, 2014 at 19:27 UTC - 0 likes

    @fbafaro: Go

    Set their lift.change permission to false.

  • Avatar of fbafaro fbafaro Aug 17, 2014 at 01:20 UTC - 0 likes

    Is there a way to stop player interact with the sign, when then click on it, it changes the floor where the elevator go?

  • Avatar of Doctorthunder17 Doctorthunder17 Aug 15, 2014 at 00:58 UTC - 0 likes

    @krustymk: Yeah I'm getting that error too. It is harmless doesnt effect the plugin at all. Only problem is that it spams my console every 15 minutes lol

Facts

Date created
Dec 01, 2011
Categories
Last update
Jul 29, 2014
Development stage
Release
Language
  • enUS
License
MIT License
Curse link
Lift
Downloads
441,670
Recent files
  • R: Lift 51 for CB 1.7.9-R0.2 Jul 29, 2014
  • R: Lift 50 for CB 1.7.9-R0.1 May 27, 2014
  • R: LIft 49 for CB 1.7.2-R0.3 Apr 06, 2014
  • R: Lift 48 for CB 1.7.2-R0.3 Feb 14, 2014
  • R: Lift 47 for CB 1.7.2-R0.2 Feb 11, 2014

Authors