Two-stop elevators
- Illustrated in this project:
- 1) A simple 4 floor Elevator.
- 2) More advanced version of the same. Both vmf files are included below.
- 3) Advanced effect uses env_sprite, func_brush, func_button, func_tracktrain, logic_relay, path_track, prop_dynamic and trigger_multiple entities.
- 4) Demo of func_movelinear used for a similar effect.
- 5) Elevator has a button for each floor.
- 6) Each floor has a functional door and buttons.
==Note: It is not wise to use Elevators and lifts in any of the multiplayer Source games. This is due to the multiplayer network physics which are optimized for on-line play. Always test your Elevators and Lifts with Developer 1 enabled.
(Visible below, next to the Player start, in the images of the Elevator interior.) These are brush based entities you texture as needed. The one in this project uses two Outputs back to itself. OnFullyOpen, crate_lift, Close, 3.0 OnFullyClosed, crate_lift, Open, 3.0
And a logic_auto to open it when the map starts. OnMapSpawn, crate_lift, Open, 0.0
After its initial opening the func_movelinear will trigger itself. You can easily control func_movelinear with buttons and triggers.
I believe the best way to make Elevators in HL2 is with func_tracktrain. You will see a lot of comments about how difficult it is to get things working properly but I can assure you it’s not at all difficult. Once you know a few tricks these can be created in a matter of minutes.
One such trick is the use of a one-time-only path_track to spawn the Elevator. It is never used again after that. In the case of this 4 floor Elevator another path_track is in the same general area as the first and it will be used instead each time the Elevator returns to floor 1.
There are three adjustments you will need to make once your Elevator is working. 1) The position of the first path_track. 2) The position of the substitute path_track that will replace it. 3) The func_tracktrain’s Height above the track property.
By tweaking these three objects you can get the Elevator to start and stop exactly where you want.
Keep in mind func_tracktrain entities must be created facing East, or to the right in the Top 2D viewport.
How can you tell which way is East? Once you create the first block for your func_tracktrain think of the right side as the front. During the rest of your design time build your func_tracktrain accordingling.
Notice in the image below how the front of the Elevator is facing East, or Right.
 
You should also know that the func_tracktrain doesn’t have to be built in place. It will spawn in position at the First Stop Target you specify.
In this project the Elevator, func_tracktrain, has as its First Stop Target path_track_01 and I’ve checked the flags Fire once and Teleport to THIS path track for that path_track.
It will only be used once, after that path_track_01a will be the first path_track.
Notice their position in this image.
 
path_track_01, the first path_track, is shown in red. Its substitute is 5 units lower. This really is a fast and easy way to force your Elevator to spawn, start and stop in the exact positions you want it to.
Your first path_track is created once you have created the func_tracktrain for your Elevator. The remaining path_tracks are all clones of the first created by selecting a path_track and then holding Shift while you drag a clone with the mouse. The very same method you may be using for ropes. Once you create the first path_track give it a name right away. As you create the clones Hammer will name the others for you and set the Next Stop Target property as well. You can create all of your path_tracks in a matter of seconds.
Building your Elevator should be done once you have the initial func_tracktrain functional. Create the initial func_tracktrain and the path_tracks and then test your map.
For this project I’ve used the dynamic elevator and prop doors. This elevator has two skins. I’m using the second skin for this project because it looks less like a freight elevator. The prop is: models/props_lab/freightelevator.mdl
Skin 0
Skin 1
The doors for the Elevator are models/props_lab/elevatordoor.mdl
Both the doors and the elevator are prop_dynamic. 
Your Elevator can be created entirely as one func_tracktrain instead of being parented to one like this project.
You must also decide how the doors will function. Will they move up and down with the Elevator or will each floor have doors.
func_tracktrain can be used in this same manner to create Elevators, Trains, Boats, Effects, etc. What you create and how you do it is up to your imagination.
One nice addition for your Elevator is a trigger_multiple placed on the inside. Parent this to the func_tracktrain or the Elevator. You can use this to sense when the Player has entered or exited the Elevator. To illustrate that I’ve created one for this project with a single Output. OnEndTouch, prop_door*, SetAnimation, close
When the Player exits the Elevator the prop doors will close. Notice the asterisk. (prop_door*) This will cause each of the 4 prop doors to be closed because they are named prop_door1, prop_door2, prop_door3 and prop_door4.
Each floor has a button to open the Elevator doors by way of a func_button. OnPressed, prop_door1, SetAnimation, open
In the more advanced sample file below the Elevator can be called from each floor. Leaving the Elevator will cause these doors to close, pressing the button on the outside wall will open the doors, when the Elevator starts each time the doors will close.
Everything on this Elevator works very well but the simple Elevator has a shortcoming. Neither of these Elevators is not designed to go backwards. You should think about how your Elevator will function and what it will take. This Elevator can be made to go backwards with a variety of methods, the func_tracktrain can be made to go backwards, each path_track can have an alternate path and you can double the amount of logic_relays.
For me this is acceptable because where I grew up in Detroit there were Elevators which acted exactly like this one, they would start from the first floor and collect passengers as they went to the top, then they would return to the lower levels to start all over again. Just how much detail and time you put into the Elevator is of course up to you.
Should all your floors be the same height to make it easier on creating the path for your Elevator? I don’t think so. To illustrate that I intentionally made these 4 floors different heights. The first floor is the only tricky part; each remaining path_track is simple to get in place.
I don’t think there’s a right and wrong way to create these Elevators, if it’s working the way you want, without errors, then it’s right.
Notice the differences between the two sample vmf’s below. Each uses the same Elevator and surroundings. One is simple and stops on each floor. This is done by adding an Output to each path_track to stop the func_tracktrain and in this case another Output to pen the doors.
The more advanced version below doesn’t do that. Each path_track has a logic_relay it triggers. The trick is to have the Elevator buttons enable or disable the logic_relays. A logic_relay that is disabled won’t do anything when it’s triggered.
Inside the Elevator I’ve created 4 func_button entities, shown below.
These buttons are textured with nodraw and each one is parented to the Elevator.
For each button is a env_sprite, a really cheap way to create buttons but effective. 
When the Player presses any of the 4 buttons the sprite color is changed, a series of logic_relays are either enabled or disabled, the door animation is changed and the Elevator is told to start forward. Shown below are the Outputs for button #4.
 
Each button has the same amount of Outputs, only different according to which floor is picked.
One thing I didn’t do for the simple Elevator in this project is create the Elevator so it can be called back to a floor from outside the Elevator. This can be done by applying the outputs from these buttons to their respective floors. 
The more advanced Elevator below can be called from each floor, and the Player spawns on Floor 3 to illustrate this. 
Another consideration for your Elevator would be custom materials for the buttons.
Notice one additional feature of this Elevator, on the outside. I’ve created clips for the columns on each side of the Elevator. These are not necessary but they add a nice touch to your maps.
 
Clips like this can also be used inside your Elevator, to make it smother for the Player and NPCs.
This is a rather long tutorial so I’m not going to detail each of the entity properties as I normally do. Please open the sample projects below and examine the properties I’ve used, and make changes as needed according to your desires and imagination.




