Difference between revisions of "Talk:Dissecting the Scripts for Weapon Racks"
Jump to navigation
Jump to search
imported>HawkFest |
imported>HawkFest |
||
Line 6: | Line 6: | ||
<source lang="papyrus"> | <source lang="papyrus"> | ||
Scriptname FactionDetectionScript extends ObjectReference | Scriptname FactionDetectionScript extends ObjectReference | ||
{Script to be attached to some object in the cell you wish to be monitoring for the player to be a member | {Script to be attached to some object in the cell you wish to be monitoring for the player to be a member of some allowed faction} | ||
Actor Property PlayerREF Auto | Actor Property PlayerREF Auto | ||
Bool ShouldWaitForAllowedFaction = True | Bool ShouldWaitForAllowedFaction = True |
Revision as of 16:08, 29 January 2013
Erroneous assertion
It's written: « I'm not going to try and explain states here, but it's redundant and has no utility if you only have a single state in a script. »
That's plain wrong: a singleton state can be essential e.g. when monitoring things, while using RegisterForSingleUpdateGameTime for instance. One example which is quite self-explanatory:
Scriptname FactionDetectionScript extends ObjectReference
{Script to be attached to some object in the cell you wish to be monitoring for the player to be a member of some allowed faction}
Actor Property PlayerREF Auto
Bool ShouldWaitForAllowedFaction = True
Event OnLoad()
If ShouldWaitForAllowedFaction
GoToState("WaitForAllowedFaction")
EndIf
EndEvent
State WaitForAllowedFaction
Event OnBeginState()
If PlayerREF.IsInFaction(AllowedFaction)
ShouldWaitForAllowedFaction = False
; Do what you want to do
Else
RegisterForSingleUpdateGameTime(0.9)
EndIf
EndEvent
Event OnUpdateGameTime()
GoToState("WaitForAllowedFaction")
EndEvent
EndState