Difference between revisions of "Oolite JavaScript Reference: World script event handlers"

From Elite Wiki
m (Removed from Category: Oolite (Category: Oolite scripting is sufficient). Noted outdatedness.)
(Updated all old handler names to the current ones.)
Line 28: Line 28:
 
==== <code>willDock</code> ====
 
==== <code>willDock</code> ====
  
The <code>willDock</code> handler is called at the beginning of the docking tunnel effect.
+
The <code>shipWillDockWithStation</code> handler is called at the beginning of the docking tunnel effect.
  
  this.willDock = function()
+
  this.shipWillDockWithStation = function(station)
 
  {
 
  {
 
       // Your code here
 
       // Your code here
Line 38: Line 38:
 
==== <code>didDock</code> ====
 
==== <code>didDock</code> ====
  
The <code>didDock</code> handler is called at the end of the docking tunnel effect.
+
The <code>shipDockedWithStation</code> handler is called at the end of the docking tunnel effect.
  
  this.didDock = function()
+
  this.shipDockedWithStation = function(station)
 
  {
 
  {
 
       // Your code here
 
       // Your code here
Line 46: Line 46:
  
  
==== <code>willLaunch</code> ====
+
==== <code>shipWillLaunchFromStation</code> ====
  
The <code>willLaunch</code> handler is called at the beginning of the launch tunnel effect.
+
The <code>shipWillLaunchFromStation</code> handler is called at the beginning of the launch tunnel effect. (Is this code still in?)
  
  this.willLaunch = function()
+
  this.shipWillLaunchFromStation = function()
 
  {
 
  {
 
       // Your code here
 
       // Your code here
Line 56: Line 56:
  
  
==== <code>didLaunch</code> ====
+
==== <code>shipLaunchedFromStation</code> ====
  
The <code>didLaunch</code> handler is called at the end of the launch tunnel effect.
+
The <code>shipLaunchedFromStation</code> handler is called at the end of the launch tunnel effect.
  
  this.didLaunch = function()
+
  this.shipLaunchedFromStation = function()
 
  {
 
  {
 
       // Your code here
 
       // Your code here
Line 86: Line 86:
  
  
==== <code>didRecieveDockingRefusal</code> ====
+
==== <code> playerDockingRefused</code> ====
  
The <code>didRecieveDockingRefusal</code> handler is called when a station refuses to provide autopilot docking instructions.
+
The <code> playerDockingRefused</code> handler is called when a station refuses to provide autopilot docking instructions.
  
  this.didRecieveDockingRefusal = function()
+
  this. playerDockingRefused = function()
 
  {
 
  {
 
       // Your code here
 
       // Your code here
Line 118: Line 118:
  
  
==== <code>didFailToJump</code> ====
+
==== <code>playerJumpFailed</code> ====
  
The <code>didFailToJump</code> handler is called at the end of a witchspace or galactic witchspace countdown, if the jump is not possible. The <code>reason</code> parameter is a string specifying why the jump failed; currently, the possible values are “blocked”, “too far” and “insufficient fuel”. Other values may be added in future.
+
The <code>playerJumpFailed</code> handler is called at the end of a witchspace or galactic witchspace countdown, if the jump is not possible. The <code>reason</code> parameter is a string specifying why the jump failed; currently, the possible values are “blocked”, “too far” and “insufficient fuel”. Other values may be added in future.
  
  this.didFailToJump = function(reason)
+
  this.playerJumpFailed = function(reason)
 
  {
 
  {
 
       // Your code here
 
       // Your code here
Line 128: Line 128:
  
  
==== <code>willEnterWitchSpace</code> ====
+
==== <code>shipWillEnterWitchspace</code> ====
  
The <code>willEnterWitchSpace</code> handler is called immediately before a witchspace jump, while the player is still in the starting system. The <code>cause</code> parameter is a string specifying what sort of jump is occuring; currently, the possible values are “standard jump”, “galactic jump” and “wormhole”. Other values may be added in future.
+
The <code>shipWillEnterWitchspace</code> handler is called immediately before a witchspace jump, while the player is still in the starting system. The <code>cause</code> parameter is a string specifying what sort of jump is occuring; currently, the possible values are “standard jump”, “galactic jump” and “wormhole”. Other values may be added in future.
  
  this.willEnterWitchSpace = function(cause)
+
  this.shipWillEnterWitchspace = function(cause)
 
  {
 
  {
 
       // Your code here
 
       // Your code here
Line 138: Line 138:
  
  
==== <code>willExitWitchSpace</code> ====
+
==== <code>shipWillExitWitchspace</code> ====
  
The <code>willExitWitchSpace</code> handler is called as a witchspace jump concludes. When it is called, the player is (from a program perspective) in the destination system, but the tunnel effect has not yet been shown. This is the reccomended time to set up elements which, so to speak, were already there when the player arrived.
+
The <code>shipWillExitWitchspace</code> handler is called as a witchspace jump concludes. When it is called, the player is (from a program perspective) in the destination system, but the tunnel effect has not yet been shown. This is the reccomended time to set up elements which, so to speak, were already there when the player arrived.
  
  this.willExitWitchSpace = function()
+
  this.shipWillExitWitchspace = function()
 
  {
 
  {
 
       // Your code here
 
       // Your code here
 
  }
 
  }
  
==== <code>didExitWitchSpace</code> ====
+
==== <code>shipExitedWitchspace</code> ====
  
The <code>didExitWitchSpace</code> handler is called after a witchspace jump has concluded and the tunnel effect has been shown.
+
The <code>shipExitedWitchspace</code> handler is called after a witchspace jump has concluded and the tunnel effect has been shown.
  
  this.didExitWitchSpace = function()
+
  this.shipExitedWitchspace = function()
 +
{
 +
      // Your code here
 +
}
 +
 
 +
==== <code>shipWillEnterWormhole</code> ====
 +
 
 +
The <code>shipWillEnterWormhole</code> handler is called before entering the wormhole.
 +
 
 +
this.shipWillEnterWormhole = function()
 +
{
 +
      // Your code here
 +
}
 +
 
 +
==== <code>shipExitedWormhole</code> ====
 +
 
 +
The <code>shipExitedWormhole</code> handler is called after leaving the wormhole.
 +
 
 +
this.shipExitedWormhole = function()
 +
{
 +
      // Your code here
 +
}
 +
 
 +
==== <code>playerEnteredNewGalaxy</code> ====
 +
 
 +
The <code>playerEnteredNewGalaxy</code> handler is called just before a witchspace jump starts.
 +
 
 +
this.playerEnteredNewGalaxy = function(galaxyNumber)
 
  {
 
  {
 
       // Your code here
 
       // Your code here
Line 169: Line 196:
  
  
==== <code>didBecomeDead</code> ====
+
==== <code>shipDied</code> ====
 +
 
 +
The <code>shipDied</code> handler is called when the player dies. Expect a <code>reset()</code> shortly.
 +
 
 +
this.shipDied = function(whom, why)
 +
{
 +
      // Your code here
 +
}
  
The <code>didBecomeDead</code> handler is called when the player dies. Expect a <code>reset()</code> shortly.
+
The <code> shipScoopedOther</code> handler is called when the player scoops cargo. (Cargo receives a <code>shipWasScooped</code> handler.)
  
  this.didBecomeDead = function(whom, why)
+
  this.shipScoopedOther = function(whom)
 
  {
 
  {
 
       // Your code here
 
       // Your code here
Line 180: Line 214:
 
==== <code>didLaunchEscapePod</code> ====
 
==== <code>didLaunchEscapePod</code> ====
  
The <code>didLaunchEscapePod</code> handler is called when the player bails out. This will be followed by a <code>willDock()</code>/<code>didDock()</code> pair after a few seconds.
+
The <code>shipLaunchedEscapePod</code> handler is called when the player bails out. This will be followed by a <code>willDock()</code>/<code>didDock()</code> pair after a few seconds.
  
  this.didLaunchEscapePod = function()
+
  this.shipLaunchedEscapePod = function(escapepod)
 
  {
 
  {
 
       // Your code here
 
       // Your code here

Revision as of 10:13, 20 June 2008

Note: this documentation is incomplete and out of date. It will be updated soon.

This page provides an exhaustive list of event handlers which can be implemented by JavaScript scripts for Oolite.

Game State

startUp

The startUp handler is called after all OXPs have been loaded. It can be used to do one-off initialisation such as registering to listen for certain keystrokes etc.

this.startUp = function()
{
     // Your code here
}


reset

The reset handler is called whenever the player is respawned, such as after dying or when loading a saved game. It should be used to reset any local state in the script.

this.reset = function()
{
     // Your code here
}

Docking

willDock

The shipWillDockWithStation handler is called at the beginning of the docking tunnel effect.

this.shipWillDockWithStation = function(station)
{
     // Your code here
}


didDock

The shipDockedWithStation handler is called at the end of the docking tunnel effect.

this.shipDockedWithStation = function(station)
{
     // Your code here
}


shipWillLaunchFromStation

The shipWillLaunchFromStation handler is called at the beginning of the launch tunnel effect. (Is this code still in?)

this.shipWillLaunchFromStation = function()
{
     // Your code here
}


shipLaunchedFromStation

The shipLaunchedFromStation handler is called at the end of the launch tunnel effect.

this.shipLaunchedFromStation = function()
{
     // Your code here
}


didStartAutoPilot

The didStartAutoPilot handler is called when the player starts autopilot docking. It is not called for the instantaneous dock command.

this.didStartAutoPilot = function()
{
     // Your code here
}


didAbortAutoPilot

The didAbortAutoPilot handler is called when the player cancels autopilot docking.

this.didAbortAutoPilot = function()
{
     // Your code here
}


playerDockingRefused

The playerDockingRefused handler is called when a station refuses to provide autopilot docking instructions.

this. playerDockingRefused = function()
{
     // Your code here
}


Witchspace Jumps

didBeginJumpCountDown

The didBeginJumpCountDown handler is called when the user starts a witchspace or galactic witchspace jump countdown. The type parameter is a string specifying which type of jump is occuring; currently, the possible values are “standard” and “galactic”. Other values may be added in future.

this.didBeginJumpCountDown = function(type)
{
     // Your code here
}


didCancelJumpCountDown

The didCancelJumpCountDown handler is called when the user cancels a witchspace or galactic witchspace jump countdown.

this.didCancelJumpCountDown = function()
{
     // Your code here
}


playerJumpFailed

The playerJumpFailed handler is called at the end of a witchspace or galactic witchspace countdown, if the jump is not possible. The reason parameter is a string specifying why the jump failed; currently, the possible values are “blocked”, “too far” and “insufficient fuel”. Other values may be added in future.

this.playerJumpFailed = function(reason)
{
     // Your code here
}


shipWillEnterWitchspace

The shipWillEnterWitchspace handler is called immediately before a witchspace jump, while the player is still in the starting system. The cause parameter is a string specifying what sort of jump is occuring; currently, the possible values are “standard jump”, “galactic jump” and “wormhole”. Other values may be added in future.

this.shipWillEnterWitchspace = function(cause)
{
     // Your code here
}


shipWillExitWitchspace

The shipWillExitWitchspace handler is called as a witchspace jump concludes. When it is called, the player is (from a program perspective) in the destination system, but the tunnel effect has not yet been shown. This is the reccomended time to set up elements which, so to speak, were already there when the player arrived.

this.shipWillExitWitchspace = function()
{
     // Your code here
}

shipExitedWitchspace

The shipExitedWitchspace handler is called after a witchspace jump has concluded and the tunnel effect has been shown.

this.shipExitedWitchspace = function()
{
     // Your code here
}

shipWillEnterWormhole

The shipWillEnterWormhole handler is called before entering the wormhole.

this.shipWillEnterWormhole = function()
{
     // Your code here
}

shipExitedWormhole

The shipExitedWormhole handler is called after leaving the wormhole.

this.shipExitedWormhole = function()
{
     // Your code here
}

playerEnteredNewGalaxy

The playerEnteredNewGalaxy handler is called just before a witchspace jump starts.

this.playerEnteredNewGalaxy = function(galaxyNumber)
{
     // Your code here
}


Other

alertConditionChanged

The alertConditionChanged handler is called when the player’s alert status (player.alertCondition) changes.

this.alertConditionChanged = function()
{
     // Your code here
}


shipDied

The shipDied handler is called when the player dies. Expect a reset() shortly.

this.shipDied = function(whom, why)
{
     // Your code here
}

The shipScoopedOther handler is called when the player scoops cargo. (Cargo receives a shipWasScooped handler.)

this.shipScoopedOther = function(whom)
{
     // Your code here
}

didLaunchEscapePod

The shipLaunchedEscapePod handler is called when the player bails out. This will be followed by a willDock()/didDock() pair after a few seconds.

this.shipLaunchedEscapePod = function(escapepod)
{
     // Your code here
}


tickle

The tickle handler is called periodically-ish, whenever the old plist scripts are updated. For performance reasons, it is reccomended that you avoid using this if possible, but it may be needed until the planned timer mechanism is implemented.

The status parameter is a string containing the player’s current status - “STATUS_IN_FLIGHT” and “STATUS_DOCKED” being commonly-seen examples.

this.tickle = function(status)
{
     // Your code here
}

Not Yet Implemented

Handlers do not yet exist for the following events:

  • Enter/exit station aegis.
  • Target changed.
  • Advanced space compass mode changed.
  • Cloaking device events.

Additionally, there are plans for a timer mechanism whereby a script can request that a function be called at a specific point in the future. If there are other events you would like to be able to respond to, please write a request on the forum.