L4D2 Level Design/Wandering Witch: Difference between revisions
(added section about switching behaviour at runtime) |
(→Changing Behaviour at runtime: used proper Outputs template.) |
||
Line 41: | Line 41: | ||
Any entity capable of firing [[Inputs and Outputs|outputs]], such as [[logic_timer]], [[trigger_once]], [[func_button]], [[logic_case]], ect. can have the following output to change the behaviour of the next spawned witches until changed:<br> | Any entity capable of firing [[Inputs and Outputs|outputs]], such as [[logic_timer]], [[trigger_once]], [[func_button]], [[logic_case]], ect. can have the following output to change the behaviour of the next spawned witches until changed:<br> | ||
'''Sitting Witch''' | '''Sitting Witch''' | ||
{| {{OutputsTable}} | |||
| [[Image:Io11.png]] || ''Depends on entity'' || <logic_script entity name> || RunScriptCode|| WitchSit() || 0.00 || No | |||
|} | |||
'''Wandering Witch''' | '''Wandering Witch''' | ||
{| {{OutputsTable}} | |||
| [[Image:Io11.png]] || ''Depends on entity'' || <logic_script entity name> || RunScriptCode|| WitchWalk() || 0.00 || No | |||
|} | |||
{{note|This will not make a wandering witch sit down or vice versa.}} | {{note|This will not make a wandering witch sit down or vice versa.}} | ||
Revision as of 02:19, 25 March 2021
In L4D2, we discover that witches sit and rock themselves only at night. If there's sunlight, they wander. You can control this in your map from the Map > Map Properties... menu item.
If you change Time of day to any time of day when the sun is out, including "Dawn
", "Morning
", and "Afternoon
", witches spawned by the Director will wander.
Changing Behaviour at runtime
If you would like to have both standing and sitting witches, or randomly pick which to use, you can do so by using a vscript.
Create a text file called Witch_behaviour.nut (or any sensical name) and put it into the scripts/vscripts folder.
The script should contain the following:
function WitchWalk(){ worldspawn_timeofday <- [ "3" ] worldspawn <- Entities.FindByClassname (null, "worldspawn"); local i = RandomInt(0,worldspawn_timeofday.len()-1); printl("TimeOfDay is "+worldspawn_timeofday[i]); printl( worldspawn.__KeyValueFromString("timeofday",worldspawn_timeofday[i]) ); } function WitchSit(){ worldspawn_timeofday <- [ "0" ] worldspawn <- Entities.FindByClassname (null, "worldspawn"); local i = RandomInt(0,worldspawn_timeofday.len()-1); printl("TimeOfDay is "+worldspawn_timeofday[i]); printl( worldspawn.__KeyValueFromString("timeofday",worldspawn_timeofday[i]) ); }

Next, place a logic_script entity into your map, using "Witch_behaviour" in the "Entity Scripts" field.
Any entity capable of firing outputs, such as logic_timer, trigger_once, func_button, logic_case, ect. can have the following output to change the behaviour of the next spawned witches until changed:
Sitting Witch
My Output | Target Entity | Target Input | Parameter | Delay | Only Once | |
---|---|---|---|---|---|---|
![]() |
Depends on entity | <logic_script entity name> | RunScriptCode | WitchSit() | 0.00 | No |
Wandering Witch
My Output | Target Entity | Target Input | Parameter | Delay | Only Once | |
---|---|---|---|---|---|---|
![]() |
Depends on entity | <logic_script entity name> | RunScriptCode | WitchWalk() | 0.00 | No |

You could also make an intricate setup of a logic_case randomly picking between witch behaviours and spawns them one after another, to get a map such as the Sugarmill, but with both sitting and wandering witches.