This wiki is a copy of the original Oblivion CS wiki created and maintained by the UESP.net. See CSwiki:Copy Notice for more info.

Difference between revisions of "Quest scripts"

From the Oblivion ConstructionSet Wiki
Jump to navigation Jump to search
imported>GuidoBot
imported>Haama
(Removed quirk - that's a general problem in TroubleShooting)
 
(7 intermediate revisions by 3 users not shown)
Line 1: Line 1:
Quest scripts can be created by selecting Quest script type in the script editing window. Scripts must be designated as quest scripts in order to be attached to [[:Category:Quests|quests]]. Quest scripts are [[non-reference scripts]] and therefore somewhat restricted in the function syntax they can use.  
Quest scripts can be created by selecting Quest script type in the script editing window. Scripts must be designated as quest scripts in order to be attached to [[:Category:Quests|quests]]. Quest scripts are [[non-reference scripts]] and therefore somewhat restricted in the function syntax they can use.  


Basic facts:
Basic facts:


* Quest scripts run only when the quest is running (you can determine that in the game by using sqv QUEST_NAME). Quests can be started and stopped using the StartQuest and StopQuest script commands. Note that this is independent of a quest being complete or not. Completing a quest means that the quest moves to the Completed Quest tab in the player's journal -- but it will still be running unless you use a StopQuest command to turn it off.
* Quest scripts run only when the quest is running (you can determine that in the game by using sqv QUEST_NAME). Quests can be started and stopped using the [[StartQuest]] and [[StopQuest]] script commands. Note that this is independent of a quest being complete or not. Completing a quest means that the quest moves to the Completed Quest tab in the player's journal -- but it will still be running unless you use a StopQuest command to turn it off.
* Quests automatically turn on when an entry is written to the player's journal. So if you do SetStage QUESTNAME 10, assuming entry 10 has journal text, this will automatically start the quest.
* Quests automatically turn on when an entry is written to the player's journal. So if you do ''[[SetStage]] QUESTNAME 10'', assuming entry 10 has journal text, this will automatically start the quest.
* In general, you should stop quests when a quest is complete, in order to stop its script from processing. If there is some reason you need to keep the quest running (you have post-quest dialogue or script), consider creating a second quest (i.e. MS38 and MS38FIN).
* In general, you should stop quests when a quest is complete, in order to stop its script from processing. If there is some reason you need to keep the quest running (you have post-quest dialogue or script), consider creating a second quest (i.e. MS38 and MS38FIN).
* Quest variables can still be accessed and modified when the quest is not running. When a quest is stopped, its script is not being processed, but it still exists and the state of the variables remains intact.
* Quest variables can still be accessed and modified when the quest is not running. When a quest is stopped, its script is not being processed, but it still exists and the state of the variables remains intact.
Line 11: Line 10:


How to change how often a quest script is processed:
How to change how often a quest script is processed:
* Declare the "magic variable" '''float fQuestDelayTime''' in your quest script.
* Declare the "magic variable" '''float [[fQuestDelayTime]]''' in your quest script.
* Set fQuestDelayTime to how often you want the quest script to process, in seconds. If you set it to something very small (.01), it will effectively process every frame. If you set it to 0, the quest script will revert to the default processing time (every 5 seconds). Use this feature with caution -- in general, fQuestDelayTime should only be set less than 5 under very controlled and limited circumstances.
* Set fQuestDelayTime to how often you want the quest script to process, in seconds. If you set it to something very small (.01), it will effectively process every frame. If you set it to 0, the quest script will revert to the default processing time (every 5 seconds). Use this feature with caution -- in general, fQuestDelayTime should only be set less than 5 under very controlled and limited circumstances.
* fQuestDelayTime may be set from another script by addressing the quest, e.g. '''set MyQuestFunction.fQuestDelayTime to 0.01'''. In conjuction with effectively disabling the quest script using a long recurrence time, e.g. '''set MyQuestFunction.fQuestDelayTime to 10000''', this allows quest scripts to be employed effectively as functions (starting on a subsequent frame from the calling script).
* fQuestDelayTime may be set from another script by addressing the quest, e.g. '''set MyQuest.fQuestDelayTime to 0.01'''.
* When using quest scripts to perform some function it always a good idea to use some sort of flag at the very start of the GameMode block to ensure the script is only run at times you want it to.
* Quest scripts are the only ones that actually process a MenuMode block while you are resting or using fast travel.
* Quest scripts are the only ones that actually process MenuMode while you are resting or using fast travel.
* Because Quest scripts are run always based on time intervals they will not necessary frame sync, even with fQuestDelayTime set to a very low value. For some effects (e.g. those using SetPos) this can have undesired effects. In these cases Object and Magic scripts may be more appropriate to achieve an effect smoothly.
* Because Quest scripts are run always based on time intervals they will not necessary frame sync, even with fQuestDelayTime set to a very low value. For some effects (e.g. those using SetPos) this can have undesired effects. In these cases Object and Magic scripts may be more appropriate to achieve an effect smootly.





Latest revision as of 23:13, 10 February 2008

Quest scripts can be created by selecting Quest script type in the script editing window. Scripts must be designated as quest scripts in order to be attached to quests. Quest scripts are non-reference scripts and therefore somewhat restricted in the function syntax they can use.

Basic facts:

  • Quest scripts run only when the quest is running (you can determine that in the game by using sqv QUEST_NAME). Quests can be started and stopped using the StartQuest and StopQuest script commands. Note that this is independent of a quest being complete or not. Completing a quest means that the quest moves to the Completed Quest tab in the player's journal -- but it will still be running unless you use a StopQuest command to turn it off.
  • Quests automatically turn on when an entry is written to the player's journal. So if you do SetStage QUESTNAME 10, assuming entry 10 has journal text, this will automatically start the quest.
  • In general, you should stop quests when a quest is complete, in order to stop its script from processing. If there is some reason you need to keep the quest running (you have post-quest dialogue or script), consider creating a second quest (i.e. MS38 and MS38FIN).
  • Quest variables can still be accessed and modified when the quest is not running. When a quest is stopped, its script is not being processed, but it still exists and the state of the variables remains intact.


How to change how often a quest script is processed:

  • Declare the "magic variable" float fQuestDelayTime in your quest script.
  • Set fQuestDelayTime to how often you want the quest script to process, in seconds. If you set it to something very small (.01), it will effectively process every frame. If you set it to 0, the quest script will revert to the default processing time (every 5 seconds). Use this feature with caution -- in general, fQuestDelayTime should only be set less than 5 under very controlled and limited circumstances.
  • fQuestDelayTime may be set from another script by addressing the quest, e.g. set MyQuest.fQuestDelayTime to 0.01.
  • Quest scripts are the only ones that actually process a MenuMode block while you are resting or using fast travel.
  • Because Quest scripts are run always based on time intervals they will not necessary frame sync, even with fQuestDelayTime set to a very low value. For some effects (e.g. those using SetPos) this can have undesired effects. In these cases Object and Magic scripts may be more appropriate to achieve an effect smoothly.