Trigger portal cleanser: Difference between revisions

From Valve Developer Community
Jump to navigation Jump to search
(Added Portal 2 and some missing stuff)
 
(34 intermediate revisions by 20 users not shown)
Line 1: Line 1:
{{portal series brush|trigger_portal_cleanser}}
{{LanguageBar}}
{{CD|CTriggerPortalCleanser|base=CBaseTrigger}}
{{this is a|brush entity|name=trigger_portal_cleanser|series=Portal}} It removes objects and portals when the player touches it. It is used to create the [[Creating a portal/object fizzler|"Material Emancipation Grid" / "Fizzler"]] particle-field in Portal.


== Entity description ==
{{Bug|hidetested=1|In {{Portal|4}} Dying while inside a fizzler will cause the player's T-posed corpse to be visibly dissolved, or may crash the game. This can happen when flags allow physical object to touch this trigger. {{workaround}} Use {{ent|filter_activator_class}} that disallows prop_ragdoll.}}
A trigger [[Entity#Brush_entities|volume]] that removes objects and portals when the player touches it.  It is used to create the [[Creating a portal/object fizzler|"Material Emancipation Grid" / "Fizzler"]] particle-field in '''''[[Portal]]'''''.
{{Bug|hidetested=1|In {{portal|4}} any {{ent|prop_physics}} entity that has an alternate body group active will have it reset to the default one when fizzled by this entity.}}
{{Warning|If a player dies inside this entity, even if they are filtered out of it, the game will crash!}}
 
{{Tip|To directly apply the dissolve effect to a specific entity, use {{ent|env_entity_dissolver}}, or for [[prop_weighted_cube|cubes]] fire the <code>Dissolve</code> input.}}
{{Tip|Portal placement is only affected when the "Clients" flag is enabled, so remove the flag to dissolve entities without affecting portal placement.}}
{{note|Entities being dissolved by {{ent|env_entity_dissolver}} or {{ent|trigger_physics_trap}} don't have their gravity disabled, unlike entities dissolved by trigger_portal_cleanser.}}
{{AABBwarning|misc=Only portal shot blocking is affected by this while portal and object fizzling works as expected.}}


== Keyvalues ==
== Keyvalues ==
{{KV|Visible|boolean|If the fizzler is visible.|since=P2}}
{{KV Targetname}}
{{KV|Use Scanline|boolean|If the field uses a scanline.|since=P2}}
{{KV|Visible|intn=Visible|boolean|If the fizzler is visible. This also controls if the sound effects are played when powered on and off.|since={{P2}}}}
{{KV|Use Scanline|intn=UseScanline|boolean|If the field uses a scanline visual effect. This only works correctly for vertical fields aligned to an axis.|since={{P2}}}}
{{KV Reflection}}
{{KV Reflection}}
{{KV Trigger}}
{{KV Trigger}}
{{KV Targetname}}


== Flags ==
== Flags ==
Line 16: Line 22:


== Inputs ==
== Inputs ==
{{IO|FizzleTouchingPortals|Cause any portals in our volume to immediately fizzle.|since=P2}}
{{I|FizzleTouchingPortals|Cause any portals in our volume to immediately fizzle.|since=P2}}
{{I Reflection}}
{{I Trigger}}
{{I Trigger}}
{{I Targetname}}


== Outputs ==
== Outputs ==
{{IO|OnDissolveBox|Fired when a box is dissolved by the trigger. {{Note|in order for this output to fire, the object it dissolves must have the world model "models/props/metal_box.mdl"}}}}
{{O|OnDissolve|Fired whenever an entity is dissolved by the trigger.}}
{{O|OnDissolveBox|Fired whenever an entity named <code>box</code> is dissolved by the trigger.}}
{{O|OnFizzle|Fired whenever portals are fizzled by the trigger.}}
{{O|OnPrimaryHit|Fired whenever the trigger has been hit by a primary shot from {{ent|weapon_portalgun}}.|only={{P2CE}}}}
{{O|OnSecondaryHit|Fired whenever the trigger has been hit by a secondary shot from {{ent|weapon_portalgun}}.|only={{P2CE}}}}
{{O Trigger}}
{{O Trigger}}


== See also ==
== See also ==
* [[Emancipation Grid]]
* [[Creating a portal/object fizzler]]
* [[Creating a portal/object fizzler]]
* [[trigger_multiple]]
* [[trigger_multiple]]
* [[Inputs and Outputs]]
* [[Inputs and Outputs]]

Latest revision as of 14:39, 19 May 2025

English (en)中文 (zh)Translate (Translate)
C++ Class hierarchy
CTriggerPortalCleanser
CBaseTrigger
CBaseToggle
CBaseEntity

trigger_portal_cleanser is a brush entity available in Portal series Portal series. It removes objects and portals when the player touches it. It is used to create the "Material Emancipation Grid" / "Fizzler" particle-field in Portal.

Icon-Bug.pngBug:In Portal Portal Dying while inside a fizzler will cause the player's T-posed corpse to be visibly dissolved, or may crash the game. This can happen when flags allow physical object to touch this trigger. PlacementTip.pngWorkaround: Use filter_activator_class that disallows prop_ragdoll.
Icon-Bug.pngBug:In Portal Portal any prop_physics entity that has an alternate body group active will have it reset to the default one when fizzled by this entity.
Tip.pngTip:To directly apply the dissolve effect to a specific entity, use env_entity_dissolver, or for cubes fire the Dissolve input.
Tip.pngTip:Portal placement is only affected when the "Clients" flag is enabled, so remove the flag to dissolve entities without affecting portal placement.
Note.pngNote:Entities being dissolved by env_entity_dissolver or trigger_physics_trap don't have their gravity disabled, unlike entities dissolved by trigger_portal_cleanser.
Warning.pngWarning:This entity applies its effect based on its AABB instead of its brush model. Only portal shot blocking is affected by this while portal and object fizzling works as expected.[ Edit ]

Keyvalues

Name (targetname) <string>[ Edit ]
The name that other entities refer to this entity by, via Inputs/Outputs or other keyvalues (e.g. parentname or target).
Also displayed in Hammer's 2D views and Entity Report.
See also:  Generic Keyvalues, Inputs and Outputs available to all entities

Visible (Visible) <boolean> (in all games since Portal 2)
If the fizzler is visible. This also controls if the sound effects are played when powered on and off.
Use Scanline (UseScanline) <boolean> (in all games since Portal 2)
If the field uses a scanline visual effect. This only works correctly for vertical fields aligned to an axis.
Render in Fast Reflections (drawinfastreflection) <boolean> (in all games since Portal 2)
If enabled, this entity will render in fast water reflections (i.e. when a water material specifies $reflectonlymarkedentities) and in the world impostor pass.
BaseTrigger
Filter Name (filtername) <filter>
A filter entity to test potential activators against.
Start Disabled (StartDisabled) <boolean>
Stay dormant until activated (with theEnableinput).

Flags

BaseTrigger
Everything (not including physics debris) : [64]
Clients (Survivors, Special Infected, Tanks Left 4 Dead seriesLeft 4 Dead series) : [1]
Only clients in vehicles : [32]
Only clients *not* in vehicles : [512]
Disallow Bots (removed since Left 4 Dead) : [4096]
NPCs (Common Infected, Witches Left 4 Dead seriesLeft 4 Dead series) : [2]
Only player ally NPCs : [16]
Only NPCs in vehicles (respects player ally flag) : [2048]
Physics Objects (not including physics debris) : [8]
Physics debris (include also physics debris) : [1024]
Pushables (Passes entities with classname func_pushable) : [4] Obsolete
Deprecated.
Equivalent to using Everything + filter_activator_class that filters func_pushable.

Inputs

FizzleTouchingPortals  (in all games since Portal 2)
Cause any portals in our volume to immediately fizzle.
BaseTrigger
Toggle
Toggles this trigger between enabled and disabled states.
Enable
Enable trigger
Disable
Disable trigger
TouchTest  (in all games since Source 2007)
Triggers either the OnTouching or OnNotTouching outputs for whether anything is touching this entity.
Icon-Bug.pngBug:Sleeping prop_physics will never fire "OnTouching". Also applies to entities using prop_physics as base.  (tested in: Half-Life 2)
StartTouch  (in all games since Source 2007) !FGD
Behave as if the !caller entity had just entered the trigger volume. Accepts non-physical entities.
EndTouch  (in all games since Source 2007) !FGD
Behave as if !caller had just exited the trigger volume.
DisableAndEndTouch  (only in Source 2013 MultiplayerTeam Fortress 2 branch)
Disables this trigger and calls EndTouch on all currently-touching entities.

Outputs

OnDissolve
Fired whenever an entity is dissolved by the trigger.
OnDissolveBox
Fired whenever an entity named box is dissolved by the trigger.
OnFizzle
Fired whenever portals are fizzled by the trigger.
OnPrimaryHit  (only in Portal 2: Community Edition)
Fired whenever the trigger has been hit by a primary shot from weapon_portalgun.
OnSecondaryHit  (only in Portal 2: Community Edition)
Fired whenever the trigger has been hit by a secondary shot from weapon_portalgun.
BaseTrigger
OnStartTouch
!activator = entity that caused this output
!caller = this entity
Fired when a valid entity starts touching this trigger.
OnStartTouchAll
!activator = entity that caused this output
!caller = this entity
Fired when a valid entity starts touching this trigger, and no other entities are touching it. If there are any other entities touching the trigger when a new one begins to touch, only OnStartTouch will fire.
OnEndTouch
!activator = entity that caused this output
!caller = this entity
Fired when a valid entity stops touching this trigger.
Note.pngNote:Will also fire for entities touching it when trigger is disabled via Disable input
Warning.pngWarning:This includes entities which are deleted while inside the trigger. In this case !activator will be invalid.
Warning.pngWarning:OnEndTouch can fire before OnStartTouch under certain circumstances[How?] where both are fired on the same tick and each have the same delay.
Note.pngFix:Add a slight delay to OnEndTouch.
OnEndTouchAll
!activator = entity that caused this output
!caller = this entity
Fired when all valid entities stop touching this trigger.
OnTouching  (in all games since Source 2007)
!activator = !caller = this entity
Fired if something is currently touching this trigger when TouchTest is fired.
OnNotTouching  (in all games since Source 2007)
!activator = !caller = this entity
Fired if nothing is currently touching this trigger when TouchTest is fired.

See also