Two-stop elevators: Difference between revisions
m (fix) |
Rpgthemute (talk | contribs) (Changed approximately two-thirds of the article from first or second person to third person.) |
||
Line 34: | Line 34: | ||
-------------------------------------------------------------------------------- | -------------------------------------------------------------------------------- | ||
One way to make elevators in HL2 is with a func_tracktrain. | |||
Some might say that it is very difficult to get things working properly, but these declarations can be dismissed if the correct procedure is used. | |||
One such trick is the use of a one-time-only path_track to spawn the elevator. | One such trick is the use of a one-time-only path_track to spawn the elevator. | ||
Line 42: | Line 41: | ||
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. | 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 | There are three adjustments that will need to be made once the elevator is working. | ||
# The position of the first path_track. | # The position of the first path_track. | ||
# The position of the substitute path_track that will replace it. | # The position of the substitute path_track that will replace it. | ||
# The func_tracktrain’s Height above the track property. | # The func_tracktrain’s Height above the track property. | ||
By tweaking these three objects | By tweaking these three objects one can get the elevator to start and stop exactly where desired. | ||
Keep in mind func_tracktrain entities must be created facing East, or to the right in the Top 2D viewport. | Keep in mind func_tracktrain entities must be created facing East, or to the right in the Top 2D viewport. | ||
But which way is east, exactly? | |||
East is the same direction as the direction right in hammer's top view. | |||
---- | -t--- | ||
Notice in the image below how the front of the elevator is facing east, or right. | Notice in the image below how the front of the elevator is facing east, or right. | ||
Line 63: | Line 61: | ||
Also, the func_tracktrain doesn’t have to be built in place. | |||
It will spawn in position at the ''First Stop Target'' | It will spawn in position at the ''First Stop Target'' specified in its properties. | ||
In this project the elevator, func_tracktrain, has as its ''First Stop Target'' ''path_track_01'' and | In this project the elevator, func_tracktrain, has as its ''First Stop Target'' ''path_track_01'' and the flags ''Fire once'' and ''Teleport to THIS path track'' have been checked for the path_track. | ||
It will only be used once, after that ''path_track_01a'' will be the first path_track. | It will only be used once, after that ''path_track_01a'' will be the first path_track. | ||
Line 82: | Line 80: | ||
Its substitute is 5 units lower. | Its substitute is 5 units lower. | ||
This really is a fast and easy way to force | This really is a fast and easy way to force the elevator to spawn, start and stop in the exact positions as needed. | ||
The first path_track is created once the func_tracktrain for your elevator has been created. | |||
The remaining path_tracks are all clones of the first created by selecting a path_track and then holding <Shift> while | The remaining path_tracks are all clones of the first created by selecting a path_track and then holding <Shift> while the clone is dragged with the mouse, the very same method that may be used for copying anything else in Hammer. | ||
Once | Once the first path_track is created, a name should be given to it right away. As the clones are created, Hammer will name the others automatically and set the ''Next Stop Target'' property as well. | ||
All necessary path_tracks can be created in a matter of seconds. | |||
Building | Building the elevator should be done once the initial func_tracktrain is functional. | ||
Create the initial func_tracktrain and the path_tracks and then test | Create the initial func_tracktrain and the path_tracks and then test the map. | ||
For this project | For this project the dynamic elevator and prop doors will be used. | ||
This elevator has two skins. | This elevator has two skins. | ||
The second skin will be used for this project because it looks less like a freight elevator. | |||
The prop is: ''models/props_lab/freightelevator.mdl'' | The prop is: ''models/props_lab/freightelevator.mdl'' | ||
Line 108: | Line 106: | ||
Both the doors and the elevator are prop_dynamic entities. | Both the doors and the elevator are prop_dynamic entities. | ||
An elevator can be created entirely as one func_tracktrain instead of being parented to one like this project. | |||
How the doors will function must also be decided. | |||
Will they move up and down with the elevator or will each floor have doors | 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. | func_tracktrain can be used in this same manner to create elevators, trains, boats, effects, etc. | ||
What | What is created and how it is done is up to the person making it. | ||
One nice addition for | One nice addition for the elevator is a trigger_multiple placed on the inside. | ||
Parent this to the func_tracktrain or the elevator. | Parent this to the func_tracktrain or the elevator. | ||
This can be used to sense when the player has entered or exited the elevator. | |||
To illustrate | To illustrate this, one has been created for this project with a single Output. | ||
OnEndTouch, prop_door*, SetAnimation, close | OnEndTouch, prop_door*, SetAnimation, close | ||
Line 135: | Line 133: | ||
Everything on this elevator works very well but the simple elevator has a shortcoming: Neither of these elevators is designed to go backwards. You should think about how your elevator will function and what it will take. | Everything on this elevator works very well but the simple elevator has a shortcoming: Neither of these elevators is 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 | 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 the amount of logic_relays can be doubled. | ||
There are elevators which acted exactly like this one in Detroit. 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. | There are elevators which acted exactly like this one in Detroit. 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. |
Revision as of 14:18, 22 April 2012

For help, see the VDC Editing Help and Wikipedia cleanup process. Also, remember to check for any notes left by the tagger at this article's talk page.

Illustrated in this project:
- A simple 4 floor elevator.
- More advanced version of the same.
- Advanced effect uses through env_sprite, func_brush, func_button, func_tracktrain, logic_relay, path_track, prop_dynamic and trigger_multiple entities.
- Demo of func_movelinear used for a similar effect.
- Elevator has a button for each floor.
- Each floor has a functional door and buttons.

Developer 1
enabled.(Visible below, next to the info_player_start entity, 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.
One way to make elevators in HL2 is with a func_tracktrain. Some might say that it is very difficult to get things working properly, but these declarations can be dismissed if the correct procedure is used.
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 that will need to be made once the elevator is working.
- The position of the first path_track.
- The position of the substitute path_track that will replace it.
- The func_tracktrain’s Height above the track property.
By tweaking these three objects one can get the elevator to start and stop exactly where desired.
Keep in mind func_tracktrain entities must be created facing East, or to the right in the Top 2D viewport.
But which way is east, exactly? East is the same direction as the direction right in hammer's top view.
-t---
Notice in the image below how the front of the elevator is facing east, or right.
Also, the func_tracktrain doesn’t have to be built in place.
It will spawn in position at the First Stop Target specified in its properties.
In this project the elevator, func_tracktrain, has as its First Stop Target path_track_01 and the flags Fire once and Teleport to THIS path track have been checked for the 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 the elevator to spawn, start and stop in the exact positions as needed.
The first path_track is created once the func_tracktrain for your elevator has been created.
The remaining path_tracks are all clones of the first created by selecting a path_track and then holding <Shift> while the clone is dragged with the mouse, the very same method that may be used for copying anything else in Hammer.
Once the first path_track is created, a name should be given to it right away. As the clones are created, Hammer will name the others automatically and set the Next Stop Target property as well.
All necessary path_tracks can be created in a matter of seconds.
Building the elevator should be done once the initial func_tracktrain is functional. Create the initial func_tracktrain and the path_tracks and then test the map.
For this project the dynamic elevator and prop doors will be used. This elevator has two skins. The second skin will be used for this project because it looks less like a freight elevator. The prop is: models/props_lab/freightelevator.mdl
The doors for the elevator are models/props_lab/elevatordoor.mdl. Both the doors and the elevator are prop_dynamic entities.
An elevator can be created entirely as one func_tracktrain instead of being parented to one like this project.
How the doors will function must also be decided. 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 is created and how it is done is up to the person making it.
One nice addition for the elevator is a trigger_multiple placed on the inside. Parent this to the func_tracktrain or the elevator. This can be used to sense when the player has entered or exited the elevator. To illustrate this, one has been created 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 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 the amount of logic_relays can be doubled.
There are elevators which acted exactly like this one in Detroit. 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.