This article's documentation is for anything that uses the Source engine. Click here for more information.

Prop ragdoll: Difference between revisions

From Valve Developer Community
Jump to navigation Jump to search
(Add undocumented 'Use LRU Retirement' spawnflag)
(Maybe we can set this entity up with something akin to what CPhysicsProp was given to *stop* it from spawning without a defined model?)
 
(55 intermediate revisions by 17 users not shown)
Line 1: Line 1:
{{lang|Prop ragdoll}}
{{LanguageBar}}
{{seealso|For details on creating a ragdoll, see {{ent|$collisionjoints}}.}}
{{seealso|For details on creating a ragdoll, see {{ent|mode=name|$collisionjoints}}.}}
 
{{Split|Split Black Mesa and Valve games to separate pages}}
{{CD|CRagdollProp|file1=1}}
[[File:prop_ragdoll.jpg|thumb|prop_ragdoll can interact with dynamic objects, unlike death ragdolls.]]
[[File:prop_ragdoll.jpg|thumb|prop_ragdoll can interact with dynamic objects, unlike death ragdolls.]]


{{point ent|prop_ragdoll}} It is a [[VPhysics]] [[Wikipedia:Ragdoll physics|ragdoll]]. Ragdolls are collections of physics objects constrained together to simulate a jointed object like a dead body. They are very [[expensive]] to simulate.
{{this is a|model entity|name=prop_ragdoll}} It is a [[VPhysics]] [[Wikipedia:Ragdoll physics|ragdoll]]. Ragdolls are collections of physics objects constrained together to simulate a jointed object like a dead body. They are very [[expensive]] to simulate.


{{warning|This entity generates server-side ragdolls, which collide with everything but produce very large amounts of network traffic. Network traffic can be significantly reduced by making the ragdoll start asleep, disabling motion and disabling collisions with dynamic objects ({{not in FGD}} add "solid" keyvalue with value of 0) and only enabling motion when necessary.}}
{{warning|This entity generates server-side ragdolls, which collide with everything but produce very large amounts of network traffic. Network traffic can be significantly reduced by making the ragdoll start asleep, disabling motion and disabling collisions with dynamic objects ({{not in FGD}} add "solid" keyvalue with value of 0) and only enabling motion when necessary.}}
{{bug|Setting a custom pose via Hammer and making the ragdoll start asleep will make the rendering box fail to update. Making the ragdoll wake for a single frame when spawned and then sleeping it will fix this issue.}}
{{bug|Setting a custom pose via Hammer and making the ragdoll start asleep will make the rendering box fail to update. Making the ragdoll wake for a single frame when spawned and then sleeping it will fix this issue.|tested={{portal}},{{p2ce}}}}
{{bug|{{Portal2}} ragdolls cannot pass through portals. This often occurs in {{Portal}} as well.}}
{{bug|{{Portal2|4}} ragdolls cannot pass through portals. This often occurs in {{Portal|4}} as well.|hidetested=1}}
 
{{bug|Ragdolls are ignored in prediction, this causes lots of prediction errors when touching a ragdoll.|tested={{bms}},{{hl2dm}}}}
{{bug|Using this entity with a model that doesn't support the ragdoll system will result in a crash after a save load.|tested={{bms}}}}
{{bug|Using this entity without a model specified will also result in a crash.|hidetested=1}}
{{altnames|name1=physics_prop_ragdoll}}
{{altnames|name1=physics_prop_ragdoll}}
{{Expand|title={{bms|4}} specific notices and bugs.|
{{note|Original entity version is available as <code>prop_ragdoll_original</code>. The difference is: <code>prop_ragdoll_original</code> can't be gibbed with explosions, crowbar can hit <code>prop_ragdoll_original</code> if <code>[4] Debris</code> spawnflag is unchecked (crowbar's raycast skips <code>prop_ragdoll</code> for some reason), <code>prop_ragdoll_original</code> doesn't bleed or have decals on it, <code>prop_ragdoll_original</code> can't be picked up, <code>prop_ragdoll_original</code> have realistic bullet push.}}
{{bug|
* server side ragdolls created by NPCs never gib before loading save since the first Steam version, the same for gibs created by gibbed ragdolls.  Use [https://community.lambdageneration.com/black-mesa/post/efesc2f8cyf the workshop addon] if you want to use server side ragdolls in your mod.
* crowbar's raycast skips/ignores server side ragdolls since the first [[Steam]] version.
* Tripmines do not gib ragdolls
* In multiplayer ragdolls do not create hole decals and blood from bullets if <code>[4] Debris</code> spawnflag is enabled. If this flag is disabled - ragdolls still will not create blood effects and hand blood overlays.|hidetested=1}}
}}


{{code class|CRagdollProp|physics_prop_ragdoll.cpp}}
See also [[Prop Types Overview]].


==Death Ragdolls/Ragdoll Transformation==
==Death Ragdolls/Ragdoll Transformation==
When a NPC/player dies or an entity receives the <code>BecomeRagdoll</code> input, it normally creates a '''client-side''' ragdoll and copies most of its animation and visual data to it. Unlike server-side <tt>prop_ragdoll</tt>s, these client-side ragdolls are handled completely on a per-client basis and are ''much'' cheaper and simpler than their server-side counterparts, at the expense of being virtually nonexistent on the server, being inconsistent across client perspectives, and only colliding with entities that have physics objects on the client (e.g. {{ent|worldspawn}}).
When a NPC/player dies or an entity receives the <code>BecomeRagdoll</code> input, it normally creates a [[client_ragdoll|'''client-side''' ragdoll]] and copies most of its animation and visual data to it. Unlike server-side <tt>prop_ragdoll</tt>s, these client-side ragdolls are handled completely on a per-client basis and are ''much'' cheaper and simpler than their server-side counterparts, at the expense of being virtually nonexistent on the server, being inconsistent across client perspectives, and only colliding with entities that have physics objects on the client (e.g. {{ent|mode=name|worldspawn}}).


However, a NPC will become a server-side ragdoll while it's under any of the following conditions:
However, a NPC will become a server-side ragdoll while it's under any of the following conditions:
* The NPC is inside the volume of a {{ent|trigger_serverragdoll}}
* The NPC is inside the volume of a {{ent|mode=name|trigger_serverragdoll}}
* The NPC is killed by a vehicle in singleplayer
* The NPC is killed by a vehicle in singleplayer
* The [[weapon_physcannon|gravity gun]] is supercharged
* The [[weapon_physcannon|gravity gun]] is supercharged
* The NPC dies on fire while in [[env_global|Alyx darkness mode]]
* The NPC dies on fire while in [[env_global|Alyx darkness mode]]
* The NPC is a vital ally (e.g., {{ent|npc_alyx}})
* The NPC is a vital ally (e.g., {{ent|mode=name|npc_alyx}})
These server-side death ragdolls will collide with physics objects and beyond, like any <tt>prop_ragdoll</tt>, but they are marked as debris and do not collide with each other. They do not collide with ''themselves'' either, unlike client-side ragdolls. This is believed to be intentional behavior to reduce performance/networking costs.
These server-side death ragdolls will collide with physics objects and beyond, like any <tt>prop_ragdoll</tt>, but they are marked as debris and do not collide with each other. They do not collide with ''themselves'' either, unlike client-side ragdolls (fixed in {{ez2|4}} and {{bms|4}}). This is believed to be intentional behavior to reduce performance/networking costs.
{{bug|Server side ragdolls don't save blood decals. Fixed in {{mapbase|4}} and {{bms|4}}.|tested={{hl2}},{{p2ce}}}}
{{note|Most of this list ''theoretically'' applies to players as well, although that hasn't been tested.}}
{{note|Most of this list ''theoretically'' applies to players as well, although that hasn't been tested.}}


Line 32: Line 41:


==Keyvalues==
==Keyvalues==
{{KV|sequence|int|The ragdoll will be moved to the first frame of this animation before VPhysics takes over.|nofgd=1}} {{bug|Doesn't function.}}
{{KV Targetname}}
{{KV|Body|intn=body|int|Specifies which [[$bodygroup|body group]] should be used.|nofgd=1}}
{{KV|Override Animation|intn=angleOverride|string|List of joint rotations in the format <code>index,x y z,...</code>. Filled in by the engine via [[hammer_update_entity]] or after simulating ragdolls in {{hammerpp|2}} physics simulation.}}
{{KV|Override Animation|intn=angleOverride|string|Filled in by the engine via [[wc_update_entity]]. Do not edit by hand except to clear.}}
{{Expand|title=Non-Valve games {{gmod}}{{bms}}|
{{KV|Health|intn=health|integer|The amount of damage the ragdoll takes before gibbing.|only=BMS}}
{{KV|Character Manifest Mimic Name|intn=MimicName|string|Choose a name or a classname from the character manifest to dress the ragdoll.|only=BMS}}
{{KV GMOD}}
{{KV GMOD}}
{{KV BaseAnimating|noscroll=0}}
}}
{{KV BaseEntity|noscroll=0}}
{{expand|title=CBaseAnimating|{{KV CBaseAnimating|no sequence=1}}}}
 
==Flags==
==Flags==
{{fl|4|Debris|Don't collide with the player or other debris}}
{{fl|4|Debris|Don't collide with the player or other debris}}
{{fl|4096|Use 'Least Recently Used' Retirement}} {{Not in FGD}}
{{fl|4096|Use 'Least Recently Used' Retirement|nofgd=1|LRU in this case it's referring to Source's ragdoll cleanup system, which automatically removes ragdolls which haven't been used. Serverside ragdolls spawned by NPCs are automatically added to this system, while prop_ragdolls spawned by the map are not}}
{{fl|8192|Allow Dissolve}}
{{fl|8192|Allow Dissolve|Allow dissolve by [[prop_combine_ball]]|only={{hl2}}{{portal series}}{{confirm}}}}
{{fl|16384|Motion Disabled}}
{{fl|16384|Motion Disabled}}
{{fl|32768|Allow stretch}}
{{fl|32768|Allow stretch}}
Line 47: Line 59:


==Inputs==
==Inputs==
{{IO|StartRagdollBoogie|Begins ragdoll boogie effect for 5 seconds.{{bugfix|This input is actually supposed to use a parameter for how long the ragdoll should boogie, but it uses the wrong field type in the data description.|In <code>CRagdollProp</code>'s data description, find <code>DEFINE_INPUTFUNC( FIELD_VOID, "StartRagdollBoogie", InputStartRadgollBoogie )</code> and replace <code>FIELD_VOID</code> with <code>FIELD_FLOAT</code>.|code}}}}
{{I|StartRagdollBoogie|Begins ragdoll boogie effect for 5 seconds.{{bug|This input is actually supposed to use a parameter for how long the ragdoll should boogie, but it uses the wrong field type in the data description.{{code fix|In <code>CRagdollProp</code>'s data description, find <code>DEFINE_INPUTFUNC( FIELD_VOID, "StartRagdollBoogie", InputStartRadgollBoogie )</code> and replace <code>FIELD_VOID</code> with <code>FIELD_FLOAT</code>.}}
{{IO|EnableMotion, DisableMotion|Enable/disable physics simulation.}}
|hidetested=1
{{IO|FadeAndRemove|Fade out then remove (kill) self. Parameter override <nowiki>=</nowiki> duration of fade.|since={{hl2ep2}}}}
}}
{{I BaseAnimating|noscroll=0}}
}}
{{I BaseEntity|noscroll=0}}
{{I|EnableMotion / DisableMotion|Enable / disable physics simulation.}}
==Outputs==
{{I|FadeAndRemove|Fade out then remove (kill) self. Parameter override <nowiki>=</nowiki> duration of fade.|since={{hl2ep2}}}}
{{O BaseAnimating|portal2=1}}
{{I|AllowBloodPool|Сorpse once will create pool of blood (particle effect) if it is placed on brush. {{note|Not available for <code>prop_ragdoll_original</code> and <code>prop_ragdoll_attached</code>.}}|nofgd=1|only={{bms}}}}
{{O BaseEntity|l4d=1}}
 
== See Also ==
* {{ent|env_ragdoll_boogie}}
* [[Prop Types Overview]]
 
[[Category:Physics]]
[[Category:Prop entities|ragdoll]]

Latest revision as of 14:28, 12 October 2025

English (en)中文 (zh)Translate (Translate)
See also:  For details on creating a ragdoll, see $collisionjoints.

Split-arrows.png Split

It has been suggested that this article or section be split into multiple articles: Split Black Mesa and Valve games to separate pages. (Discuss)

C++ Class hierarchy
CRagdollProp
CBaseAnimating
CBaseEntity
C++ physics_prop_ragdoll.cpp
prop_ragdoll can interact with dynamic objects, unlike death ragdolls.

prop_ragdoll is a model entity available in all Source Source games. It is a VPhysics ragdoll. Ragdolls are collections of physics objects constrained together to simulate a jointed object like a dead body. They are very expensive to simulate.

Warning.pngWarning:This entity generates server-side ragdolls, which collide with everything but produce very large amounts of network traffic. Network traffic can be significantly reduced by making the ragdoll start asleep, disabling motion and disabling collisions with dynamic objects (!FGD add "solid" keyvalue with value of 0) and only enabling motion when necessary.
Icon-Bug.pngBug:Setting a custom pose via Hammer and making the ragdoll start asleep will make the rendering box fail to update. Making the ragdoll wake for a single frame when spawned and then sleeping it will fix this issue.  (tested in: Portal,Portal 2: Community Edition)
Icon-Bug.pngBug:Portal 2 Portal 2 ragdolls cannot pass through portals. This often occurs in Portal Portal as well.
Icon-Bug.pngBug:Ragdolls are ignored in prediction, this causes lots of prediction errors when touching a ragdoll.  (tested in: Black Mesa,Half-Life 2: Deathmatch)
Icon-Bug.pngBug:Using this entity with a model that doesn't support the ragdoll system will result in a crash after a save load.  (tested in: Black Mesa)
Icon-Bug.pngBug:Using this entity without a model specified will also result in a crash.
AltNames.pngAltNames: This entity is also tied to physics_prop_ragdoll.
Black Mesa Black Mesa specific notices and bugs.
Note.pngNote:Original entity version is available as prop_ragdoll_original. The difference is: prop_ragdoll_original can't be gibbed with explosions, crowbar can hit prop_ragdoll_original if [4] Debris spawnflag is unchecked (crowbar's raycast skips prop_ragdoll for some reason), prop_ragdoll_original doesn't bleed or have decals on it, prop_ragdoll_original can't be picked up, prop_ragdoll_original have realistic bullet push.
Icon-Bug.pngBug:
  • server side ragdolls created by NPCs never gib before loading save since the first Steam version, the same for gibs created by gibbed ragdolls. Use the workshop addon if you want to use server side ragdolls in your mod.
  • crowbar's raycast skips/ignores server side ragdolls since the first Steam version.
  • Tripmines do not gib ragdolls
  • In multiplayer ragdolls do not create hole decals and blood from bullets if [4] Debris spawnflag is enabled. If this flag is disabled - ragdolls still will not create blood effects and hand blood overlays.


Death Ragdolls/Ragdoll Transformation

When a NPC/player dies or an entity receives the BecomeRagdoll input, it normally creates a client-side ragdoll and copies most of its animation and visual data to it. Unlike server-side prop_ragdolls, these client-side ragdolls are handled completely on a per-client basis and are much cheaper and simpler than their server-side counterparts, at the expense of being virtually nonexistent on the server, being inconsistent across client perspectives, and only colliding with entities that have physics objects on the client (e.g. worldspawn).

However, a NPC will become a server-side ragdoll while it's under any of the following conditions:

These server-side death ragdolls will collide with physics objects and beyond, like any prop_ragdoll, but they are marked as debris and do not collide with each other. They do not collide with themselves either, unlike client-side ragdolls (fixed in Entropy : Zero 2 Entropy : Zero 2 and Black Mesa Black Mesa). This is believed to be intentional behavior to reduce performance/networking costs.

Icon-Bug.pngBug:Server side ragdolls don't save blood decals. Fixed in Mapbase Mapbase and Black Mesa Black Mesa.  (tested in: Half-Life 2,Portal 2: Community Edition)
Note.pngNote:Most of this list theoretically applies to players as well, although that hasn't been tested.
Warning.pngWarning:While most of the relevant animation/visual data is copied to ragdolls, some fields, like fade distances, are not transferred.
Cpp.pngCode:This can be modified at CBaseAnimating::CopyAnimationDataFrom() in baseanimating.cpp for server-side ragdolls and C_BaseAnimating::CreateRagdollCopy() in c_baseanimating.cpp for client-side ragdolls.

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

Override Animation (angleOverride) <string>
List of joint rotations in the format index,x y z,.... Filled in by the engine via hammer_update_entity or after simulating ragdolls in Hammer++ Hammer++ physics simulation.
Non-Valve games Garry's ModBlack Mesa
Health (health) <integer> (only in Black Mesa)
The amount of damage the ragdoll takes before gibbing.
Character Manifest Mimic Name (MimicName) <string> (only in Black Mesa)
Choose a name or a classname from the character manifest to dress the ragdoll.

GMODSandbox:

Allow Physics Gun (gmod_allowphysgun) <boolean> (only in Garry's Mod)
If set, players cannot use Physics Gun on this entity.
Sandbox Tool Whitelist (gmod_allowtools) <string> (only in Garry's Mod)
If set, only given tools can be used on this entity. You need to supply the tool class names, the names of the .lua files of those tools. This also includes the context menu properties!
CBaseAnimating
CBaseAnimating:
World Model (model) <model path>
The model this entity should appear as. 128-character limit.
Skin (skin) <integer>
Some models have multiple skins. This value selects from the index, starting with 0. May be overridden by game code.
Tip.pngTip:Hammer's model browser automatically updates this value if you use it to view different skins.
Model Scale (modelscale) <float> (in all games since Alien Swarm) (also in Source 2013)
A multiplier for the size of the model.
Tip.pngTip:In Hammer++ Hammer++ with a prop selected in 3D view, hold Ctrl and scroll the mouse wheel to change the modelscale in increments of 0.5. Holding Shift will scale it in smaller increments of 0.05.
Bodygroup (body / SetBodyGroup) <integer>
Some models have multiple submodels. This value selects from the index, starting with 0. May be overridden by animations and/or game code.
Note.pngNote:If both body and SetBodyGroup are present (even if set to 0), body will be prioritized.


Lighting Origin (lightingorigin) <targetname>
Select an entity (not info_lighting!) from which to sample lighting and cubemaps instead of the entity's $illumposition.

Shadow:

Disable Shadows (disableshadows) <boolean>
Prevents the entity from creating cheap render-to-texture shadows, or lightmap shadows if the entity is a prop_static. Does not affect shadow mapping.
Disable Receiving Shadows (disablereceiveshadows) <boolean>
Prevent the entity from receiving dynamic shadows on itself.
Shadow Cast Distance (shadowcastdist) <integer> !FGD
Sets how far the entity casts dynamic shadows. 0 means default distance from the shadow_control entity.
Disable Shadow Depth (disableshadowdepth) <boolean> (in all games since Portal 2)
Used to disable rendering into shadow depth (for projected textures) for this entity.
Disable flashlight (disableflashlight) <boolean> (in all games since Portal 2)
Used to disable projected texture lighting and shadows on this entity.
Projected Texture Cache (shadowdepthnocache) <integer choices> (in all games since Portal 2)
Used to hint projected texture system whether it is sufficient to cache shadow volume of this entity or to force render it every frame instead.
Choices
  • 0 : Default
  • 1 : No cache - render every frame
  • 2 : Cache it - render only once
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.

Flags

Debris : [4]
Don't collide with the player or other debris
Use 'Least Recently Used' Retirement : [4096] !FGD
LRU in this case it's referring to Source's ragdoll cleanup system, which automatically removes ragdolls which haven't been used. Serverside ragdolls spawned by NPCs are automatically added to this system, while prop_ragdolls spawned by the map are not
Allow Dissolve : [8192] (only in Half-Life 2Portal series[confirm])
Allow dissolve by prop_combine_ball
Motion Disabled : [16384]
Allow stretch : [32768]
Start asleep : [65536]

Inputs

StartRagdollBoogie
Begins ragdoll boogie effect for 5 seconds.
Icon-Bug.pngBug:This input is actually supposed to use a parameter for how long the ragdoll should boogie, but it uses the wrong field type in the data description.
Cpp.pngCode Fix:In CRagdollProp's data description, find DEFINE_INPUTFUNC( FIELD_VOID, "StartRagdollBoogie", InputStartRadgollBoogie ) and replace FIELD_VOID with FIELD_FLOAT.
EnableMotion / DisableMotion
Enable / disable physics simulation.
FadeAndRemove  (in all games since Half-Life 2: Episode Two)
Fade out then remove (kill) self. Parameter override = duration of fade.
AllowBloodPool  (only in Black Mesa) !FGD
Сorpse once will create pool of blood (particle effect) if it is placed on brush.
Note.pngNote:Not available for prop_ragdoll_original and prop_ragdoll_attached.

See Also