Indicator Lights (Portal 2): Difference between revisions
| m (→Step 5) |  (Rewrite Template:Lang to Template:LanguageBar. This action was performed by a bot.) | ||
| (6 intermediate revisions by 5 users not shown) | |||
| Line 1: | Line 1: | ||
| {{ | {{LanguageBar|Indicator Lights (Portal 2)}} | ||
| | | |||
| }} | |||
| [[File:Indiclights 1.png|right|170px]] | [[File:Indiclights 1.png|right|170px]] | ||
| '''Indicator Lights''' are lines of small lights that are present in test chambers to indicate the interaction between two or more entities in the map, for example a button and a cube dropper. | '''Indicator Lights''' are lines of small lights that are present in test chambers to indicate the interaction between two or more entities in the map, for example a button and a cube dropper. | ||
| Line 7: | Line 5: | ||
| == How to make Indicator Lights == | == How to make Indicator Lights == | ||
| [[ | [[File:Indicator example1.jpg|300px|thumb|right|Indicator lights all laid out]] | ||
| This tutorial assumes basic knowledge of [[Hammer]].   | This tutorial assumes basic knowledge of [[Hammer]].   | ||
| === Step 1 === | === Step 1 === | ||
| In your map, create two entities you want to interact with each other. These could vary from a [[Button (Portal 2)#Floor Button|Heavy Duty Super-Colliding Super-Button]] opening a simple exit [[Test Door (Portal 2)|door]], to a [[Button (Portal 2)#Button|button]] that will temporarily interact with a [[Diversity Vent]] which will deliver [[Gel (Portal 2)|gel]] bringing the player one step closer to the solution. Whatever you decide to do is up to you, but always next to the '''activated thing''' place an [[env_texturetoggle]] entity — this will help us change the indicator colors further in the tutorial and help you remember were you place your entities, resulting in a cleaner map. | In your map, create two entities you want to interact with each other. These could vary from a [[Button (Portal 2)#Floor Button|1500MW Aperture Science Heavy Duty Super-Colliding Super-Button]] opening a simple exit [[Test Door (Portal 2)|door]], to a [[Button (Portal 2)#Button|button]] that will temporarily interact with a [[Diversity Vent]] which will deliver [[Gel (Portal 2)|gel]] bringing the player one step closer to the solution. Whatever you decide to do is up to you, but always next to the '''activated thing''' place an [[env_texturetoggle]] entity — this will help us change the indicator colors further in the tutorial and help you remember were you place your entities, resulting in a cleaner map. | ||
| === Step 2 === | === Step 2 === | ||
| Line 38: | Line 36: | ||
| ! My Output > !! Target Entity !! Target Input !! Parameter !! Delay !! Only Once | ! My Output > !! Target Entity !! Target Input !! Parameter !! Delay !! Only Once | ||
| |- | |- | ||
| | [[ | | [[File:Io11.png]] || OnPressed || texturetoggle_lights_01 || SetTextureIndex || 1 || 0.00 || No | ||
| |- | |- | ||
| | [[ | | [[File:Io11.png]] || OnButtonReset || texturetoggle_lights_01 || SetTextureIndex || 0 || 0.00 || No | ||
| |} | |} | ||
| So basically, now when the button is pressed the <code>texturetoggle_lights_01</code> will change the overlays connected to it to the alternate "skin" of theirs, namely the appropriate orange texture. After that when the button will reset the "skin" would return to the normal color of blue. | So basically, now when the button is pressed the <code>texturetoggle_lights_01</code> will change the overlays connected to it to the alternate "skin" of theirs, namely the appropriate orange texture. After that when the button will reset the "skin" would return to the normal color of blue. | ||
| Done! Your indicator lights should now be working! | Done! Your indicator lights should now be working! | ||
| == Checkmark Box == | == Checkmark Box == | ||
| [[ | [[File:Indicator checkbox placement.jpg|250px|right|thumb|How to position the <code>prop_indicator_panel</code>.]] | ||
| A '''checkmark box''' is a binary indicator, meaning it only has off and on states. It is used to indicate the operated entity 'active state' - a blue 'X' mark when inactive and an orange checkmark when active. | A '''checkmark box''' is a binary indicator, meaning it only has off and on states. It is used to indicate the operated entity 'active state' - a blue 'X' mark when inactive and an orange checkmark when active. | ||
| {{tip|Checkmark boxes are generally only used for the exit door, or when an item has multiple inputs.}} | |||
| === Step 1 === | === Step 1 === | ||
| Use the Clipping Tool to cut the surface so there is a single brush 32x32 units in size where the indicator panel will go. Texture this brush with <code>tools/toolsnodraw</code>. (The nodraw will be covered up by the indicator panel.) | |||
| === Step 2 === | === Step 2 === | ||
| Place a {{ent|prop_indicator_panel}}. Rotate it to match the orientation of the surface, and position it one unit in front of the nodraw tile. | |||
| {{Note|Do not be fooled by the  | {{Note|Do not be fooled by the <code>prop_indicator_panel</code>'s appearance in Hammer; in-game it is drawn as the checkmark box.}} | ||
| {{tip|[[TeamSpen's Hammer Addons]] include a custom Hammer model for this entity, accurately representing the in-game position and appearance.}} | |||
| === Step 3 === | === Step 3 === | ||
| Fill the  | Fill the <code>prop_indicator_panel</code>s fields as desired. Give the entity a name, and make sure it is linked to the overlay ''not'' the env_texturetoggle. | ||
| ::{| class=standard-table | ::{| class=standard-table | ||
| !  Property Name || Value | !  Property Name || Value | ||
| Line 75: | Line 67: | ||
| |} | |} | ||
| {{Note|If you decide to fill the 'Indicator Lights' field in the prop_indicator_panel's properties, the prop_indicator_panel will act as an env_texturetoggle. So when it is "Checked" or Unchecked" it will change the "skin" of the indicator light path you attached to it accordingly.}} | {{Note|If you decide to fill the 'Indicator Lights' field in the prop_indicator_panel's properties, the prop_indicator_panel will act as an env_texturetoggle. So when it is "Checked" or Unchecked" it will change the "skin" of the indicator light path you attached to it accordingly. The texturetoggle is no longer needed and can be removed.}} | ||
| === Step 4 === | === Step 4 === | ||
| Line 84: | Line 76: | ||
| ! My Output > !! Target Entity !! Target Input !! Parameter !! Delay !! Only Once | ! My Output > !! Target Entity !! Target Input !! Parameter !! Delay !! Only Once | ||
| |- | |- | ||
| | [[ | | [[File:Io11.png]] || OnPressed || checkmark_indlights_1 || Check ||   || 0.00 || No | ||
| |- | |- | ||
| | [[ | | [[File:Io11.png]] || OnButtonReset || checkmark_indlights_1 || Uncheck ||   || 0.00 || No | ||
| |} | |} | ||
| You now have a functioning checkmark box. | |||
| == Checkmark Timer == | == Checkmark Timer == | ||
| A '''checkmark timer''' acts almost as the checkmark box: showing the active state of the operated entity. However, it shows that the operation will last a limited amount of time. It is usually advised that the activator would be a simple [[Button (Portal 2)#Button|button]] because when activating a [[Button (Portal 2)#Floor Button|floor button]] the player expects the operation to be permanent until they step off the button. | A '''checkmark timer''' acts almost as the checkmark box: showing the active state of the operated entity. However, it shows that the operation will last a limited amount of time. It is usually advised that the activator would be a simple [[Button (Portal 2)#Button|pedestal button]] because when activating a [[Button (Portal 2)#Floor Button|floor button]] the player expects the operation to be permanent until they step off the button. | ||
| Before placing a timer think if you ''really'' need it, and if so, how much time is the timer's active state going to be? You don't want the task to be impossible, you just want to add an element of stress to the puzzle.   | Before placing a timer think if you ''really'' need it, and if so, how much time is the timer's active state going to be? You don't want the task to be impossible, you just want to add an element of stress to the puzzle.   | ||
| === Step 1 === | === Step 1 === | ||
| Use the Clipping Tool to cut the surface so there is a single brush 32x32 units in size where the indicator panel will go. Texture this brush with <code>tools/toolsnodraw</code>. (The nodraw will be covered up by the indicator panel.) | |||
| === Step 2 === | === Step 2 === | ||
| Place a  | Place a <code>prop_indicator_panel</code>. Rotate it to match the orientation of the surface, and position it one unit in front of the nodraw tile. Set the following keyvalues: | ||
| ::{| class=standard-table | ::{| class=standard-table | ||
| !  Property Name || Value | !  Property Name || Value | ||
| Line 111: | Line 97: | ||
| | Name || checktime_indlights_1 | | Name || checktime_indlights_1 | ||
| |- | |- | ||
| | Timer Duration ||  | | Timer Duration || <Number of seconds to count down> | ||
| |- | |- | ||
| | Is a timer || Yes | | Is a timer || Yes | ||
| Line 121: | Line 105: | ||
| | Indicator Lights || indlights_1 | | Indicator Lights || indlights_1 | ||
| |} | |} | ||
| {{Note|Is checked  | {{Note|"Is checked" sets if the panel will start as a checkmark. Because you want a timer make sure this field is set to 'No'.}} | ||
| === Step 3 === | === Step 3 === | ||
| Set the following properties on your {{ent|prop_button}}: | |||
| ::{| class=standard-table | ::{| class=standard-table | ||
| !  Property Name || Value | !  Property Name || Value | ||
| Line 130: | Line 114: | ||
| | Name || button_01 | | Name || button_01 | ||
| |- | |- | ||
| | Delay Before Reset ||  | | Delay Before Reset || <Number of seconds to remain active> | ||
| |- | |- | ||
| |  | | Play timer sound || Yes | ||
| |} | |} | ||
| Setting the time in the 'Delay Before Reset' field will tell the button how much time the timer sound  | Setting the time in the 'Delay Before Reset' field will tell the button how much time the button should remain pressed, and play the timer sound. Setting 'Prevent fast reset' to 'No' allows to re-press the button at any given time during the timer duration. This will allow the player to restart the timer when they understand they acted too slowly without having to wait for the timer to reset on its own. | ||
| {{Tip|It is also useful to use the 'Delay Before Reset' field to prevent pressing the button again while the connected entity is still working. For example, when delivering a [[Cube (Portal 2)|cube]] you don't want the player to be able to fizzle it before the dropper has closed completely.}} | {{Tip|It is also useful to use the 'Delay Before Reset' field to prevent pressing the button again while the connected entity is still working. For example, when delivering a [[Cube (Portal 2)|cube]] you don't want the player to be able to fizzle it before the dropper has closed completely.}} | ||
| === Step 4 === | === Step 4 === | ||
| The last thing that needs to be done to make this timer  | The last thing that needs to be done to make this timer functional is to add a single output to the button: | ||
| :{| border=1 cellpadding="2" cellspacing="1" | :{| border=1 cellpadding="2" cellspacing="1" | ||
| |- align=left style="background:#DCDCDC; color:black" | |- align=left style="background:#DCDCDC; color:black" | ||
| Line 146: | Line 128: | ||
| ! My Output > !! Target Entity !! Target Input !! Parameter !! Delay !! Only Once | ! My Output > !! Target Entity !! Target Input !! Parameter !! Delay !! Only Once | ||
| |- | |- | ||
| | [[ | | [[File:Io11.png]] || OnPressed || checktime_indlights_1 || Start ||   || 0.00 || No | ||
| |} | |} | ||
| The timer will reset automatically when the time runs out. However, you can still add a 'Stop' command to stop the timer on it's current value or to send a 'Reset' output to reset it manually. | The timer will reset automatically when the time runs out. However, you can still add a 'Stop' command to stop the timer on it's current value or to send a 'Reset' output to reset it manually. | ||
| Line 184: | Line 166: | ||
| ! My Output > !! Target Entity !! Target Input !! Parameter !! Delay !! Only Once | ! My Output > !! Target Entity !! Target Input !! Parameter !! Delay !! Only Once | ||
| |- | |- | ||
| | [[ | | [[File:Io11.png]] || OnPressed || <indicator_light_name>_sound || PlaySound ||  || 0.00 || No | ||
| |} | |} | ||
| [[Category:Portal 2 Level Design]] | [[Category:Portal 2 Level Design]] | ||
Latest revision as of 17:25, 18 July 2025
Indicator Lights are lines of small lights that are present in test chambers to indicate the interaction between two or more entities in the map, for example a button and a cube dropper. The typical usage of the lights is the lights being blue when inactive, and orange when active.
How to make Indicator Lights
This tutorial assumes basic knowledge of Hammer.
Step 1
In your map, create two entities you want to interact with each other. These could vary from a 1500MW Aperture Science Heavy Duty Super-Colliding Super-Button opening a simple exit door, to a button that will temporarily interact with a Diversity Vent which will deliver gel bringing the player one step closer to the solution. Whatever you decide to do is up to you, but always next to the activated thing place an env_texturetoggle entity — this will help us change the indicator colors further in the tutorial and help you remember were you place your entities, resulting in a cleaner map.
Step 2
Select a texture for the lights in the texture browser, for this tutorial use "signage/indicator_lights/indicator_lights_floor" (Easily found by typing "indicator" in the filter bar).
A1. signage/indicator_lights/indicator_lights_floor
A2. signage/indicator_lights/indicator_lights_wall
B1. signage/indicator_lights/indicator_lights_corner_wall
B2. signage/indicator_lights/indicator_lights_corner_floor
 Note:The textures in each pair of overlays are functionally indistinguishable, but cosmeticaly, the floor antline looks cheaper after you walk from it some length.
Note:The textures in each pair of overlays are functionally indistinguishable, but cosmeticaly, the floor antline looks cheaper after you walk from it some length.Step 3
Select the Overlay option in hammer, and place your lights overlays as desired. Functionally it doesn't matter how they're placed, though a logical line between the entities interacting is desired, usually the shortest way between the two entities; don't forget the shortest way could travel on walls at some point. Also, to keep consistent with Valve's approach to these lights, when the line turns a corner (not including transitions from wall to floor, for example), a signage/indicator_lights/indicator_lights_corner_wall should be in the corner, as well as at the start of the activator (but not the activated thing).
The length of one strip is four circles, however sometimes you might want to have fewer overlays to keep your map clean. Luckily you can adjust the overlay properties to make it longer rather than make duplicates of the strip. This is accomplished by editing the U Start or U End keyvalue in the properties window for the overlay. Another way of accomplishing this is to stretch 'physically' the overlay in one of the 2D views — make sure that the 'Texture Lock' is unchecked. Remember that indicator lights never go in between tiles!
 Tip:Remember that you can add decimal key values to the strips length. This is helpful if you want a strip of 5 circles, for example, which would be possible if you set the strip's length to 1.25 (each circle is 0.25). So if you want a strip of 11 circles, the strip's length would be 2.75.
Tip:Remember that you can add decimal key values to the strips length. This is helpful if you want a strip of 5 circles, for example, which would be possible if you set the strip's length to 1.25 (each circle is 0.25). So if you want a strip of 11 circles, the strip's length would be 2.75. Tip:If you set the 2D grid to 16, you will never have to worry about having fractional circles since the texture has 16*16 circles.  This will only work if you are either adjusting the texture with "texture lock" off or using fractional decimals, aka 3 dots have a length of 0.75.
Tip:If you set the 2D grid to 16, you will never have to worry about having fractional circles since the texture has 16*16 circles.  This will only work if you are either adjusting the texture with "texture lock" off or using fractional decimals, aka 3 dots have a length of 0.75.Step 4
Select the overlays you just placed (and ONLY the overlays you want) and name them all the same. Use "indlights_1" for this tutorial. Then open up the env_texturetoggle you previously placed, and enter the same name into the Target Brush(es) field. Now name the env_texturetoggle "texturetoggle_lights_01"
Step 5
Select the activator entity, and go to the outputs menu. In this tutorial a simple button entity was used, so all output parameters in the table would relate to it. All you need to do is to add these two outputs to your activator:
- My Output > - Target Entity - Target Input - Parameter - Delay - Only Once  - OnPressed - texturetoggle_lights_01 - SetTextureIndex - 1 - 0.00 - No  - OnButtonReset - texturetoggle_lights_01 - SetTextureIndex - 0 - 0.00 - No 
So basically, now when the button is pressed the texturetoggle_lights_01 will change the overlays connected to it to the alternate "skin" of theirs, namely the appropriate orange texture. After that when the button will reset the "skin" would return to the normal color of blue.
Done! Your indicator lights should now be working!
Checkmark Box
A checkmark box is a binary indicator, meaning it only has off and on states. It is used to indicate the operated entity 'active state' - a blue 'X' mark when inactive and an orange checkmark when active.
 Tip:Checkmark boxes are generally only used for the exit door, or when an item has multiple inputs.
Tip:Checkmark boxes are generally only used for the exit door, or when an item has multiple inputs.Step 1
Use the Clipping Tool to cut the surface so there is a single brush 32x32 units in size where the indicator panel will go. Texture this brush with tools/toolsnodraw. (The nodraw will be covered up by the indicator panel.)
Step 2
Place a prop_indicator_panel. Rotate it to match the orientation of the surface, and position it one unit in front of the nodraw tile.
 Note:Do not be fooled by the
Note:Do not be fooled by the prop_indicator_panel's appearance in Hammer; in-game it is drawn as the checkmark box. Tip:TeamSpen's Hammer Addons include a custom Hammer model for this entity, accurately representing the in-game position and appearance.
Tip:TeamSpen's Hammer Addons include a custom Hammer model for this entity, accurately representing the in-game position and appearance.Step 3
Fill the prop_indicator_panels fields as desired. Give the entity a name, and make sure it is linked to the overlay not the env_texturetoggle.
- Property Name - Value - Name - checkmark_indlights_1 - Indicator Lights - indlights_1 
 
 Note:If you decide to fill the 'Indicator Lights' field in the prop_indicator_panel's properties, the prop_indicator_panel will act as an env_texturetoggle. So when it is "Checked" or Unchecked" it will change the "skin" of the indicator light path you attached to it accordingly. The texturetoggle is no longer needed and can be removed.
Note:If you decide to fill the 'Indicator Lights' field in the prop_indicator_panel's properties, the prop_indicator_panel will act as an env_texturetoggle. So when it is "Checked" or Unchecked" it will change the "skin" of the indicator light path you attached to it accordingly. The texturetoggle is no longer needed and can be removed.Step 4
Add to the activator entity another two outputs:
- My Output > - Target Entity - Target Input - Parameter - Delay - Only Once  - OnPressed - checkmark_indlights_1 - Check - 0.00 - No  - OnButtonReset - checkmark_indlights_1 - Uncheck - 0.00 - No 
You now have a functioning checkmark box.
Checkmark Timer
A checkmark timer acts almost as the checkmark box: showing the active state of the operated entity. However, it shows that the operation will last a limited amount of time. It is usually advised that the activator would be a simple pedestal button because when activating a floor button the player expects the operation to be permanent until they step off the button.
Before placing a timer think if you really need it, and if so, how much time is the timer's active state going to be? You don't want the task to be impossible, you just want to add an element of stress to the puzzle.
Step 1
Use the Clipping Tool to cut the surface so there is a single brush 32x32 units in size where the indicator panel will go. Texture this brush with tools/toolsnodraw. (The nodraw will be covered up by the indicator panel.)
Step 2
Place a prop_indicator_panel. Rotate it to match the orientation of the surface, and position it one unit in front of the nodraw tile. Set the following keyvalues:
- Property Name - Value - Name - checktime_indlights_1 - Timer Duration - <Number of seconds to count down> - Is a timer - Yes - Is checked - No - Indicator Lights - indlights_1 
 
 Note:"Is checked" sets if the panel will start as a checkmark. Because you want a timer make sure this field is set to 'No'.
Note:"Is checked" sets if the panel will start as a checkmark. Because you want a timer make sure this field is set to 'No'.Step 3
Set the following properties on your prop_button:
- Property Name - Value - Name - button_01 - Delay Before Reset - <Number of seconds to remain active> - Play timer sound - Yes 
 
Setting the time in the 'Delay Before Reset' field will tell the button how much time the button should remain pressed, and play the timer sound. Setting 'Prevent fast reset' to 'No' allows to re-press the button at any given time during the timer duration. This will allow the player to restart the timer when they understand they acted too slowly without having to wait for the timer to reset on its own.
 Tip:It is also useful to use the 'Delay Before Reset' field to prevent pressing the button again while the connected entity is still working. For example, when delivering a cube you don't want the player to be able to fizzle it before the dropper has closed completely.
Tip:It is also useful to use the 'Delay Before Reset' field to prevent pressing the button again while the connected entity is still working. For example, when delivering a cube you don't want the player to be able to fizzle it before the dropper has closed completely.Step 4
The last thing that needs to be done to make this timer functional is to add a single output to the button:
- My Output > - Target Entity - Target Input - Parameter - Delay - Only Once  - OnPressed - checktime_indlights_1 - Start - 0.00 - No 
The timer will reset automatically when the time runs out. However, you can still add a 'Stop' command to stop the timer on it's current value or to send a 'Reset' output to reset it manually.
Old Aperture Indicator Lights
Select a texture for the lights in the texture browser (Easily found by typing "neon" in the filter bar).
In this tutorial we'll be using "signage/indicator_lights/indicator_neon_straight"
 Note:The Old-Aperture indicator lights overlay is normally a 64x64 texture with a single neon stripe.
Note:The Old-Aperture indicator lights overlay is normally a 64x64 texture with a single neon stripe.As you might have noticed the default texture size of each light is a lot bigger than what it should be. To simply fix it check the 'Texture Lock' key, and in one of the 2D views shrink the overlay until it's a 16x16 one light texture. Now go back to Step 2 to finish the indicator line and triggers.
Old Aperture CheckMark box
Create a 32Wx2Lx32H block brush textured with tools/toolsnodraw. Place a signage/indicator_lights/indicator_neon_check overlay on the front, and texture the sides with plastic/plasticwall004a_dirty. Make sure your 'Texture Lock' key is checked and shrink the overlay to fit the brush. Move this brush so it is aligned with your indicator lights.
Tie the brush to a func_brush entity and give it the same name as your info_overlay entities.
Everything should be working now.
Finishing up
To add a neon light-up flicker sound, simply place a ambient_generic on your checkmark box with the following properties:
- Property Name - Value - Name - <indicator_light_name>_sound - Sound Name - VFX.OGSignFlicker 
 
Make sure, in the flags tab, that it is NOT looped, and add another Output to your activator:





























