2022-01-23 20:49:42 +01:00
Built-in events
===============
2023-08-27 20:43:12 +02:00
.. include :: version.rst
2023-07-09 08:42:09 +02:00
Actor events
------------
2023-12-04 17:50:18 +01:00
**Died**
2023-12-04 17:32:38 +01:00
This event is sent to an actor's local script when that actor dies.
.. code-block :: Lua
eventHandlers = {
2023-12-04 17:50:18 +01:00
Died = function()
2023-12-04 17:32:38 +01:00
print('Alas, ye hardly knew me!')
end
}
2023-08-18 22:55:43 +02:00
**StartAIPackage, RemoveAIPackages**
2022-01-23 20:49:42 +01:00
Any script can send to any actor (except player, for player will be ignored) events `` StartAIPackage `` and `` RemoveAIPackages `` .
The effect is equivalent to calling `` interfaces.AI.startPackage `` or `` interfaces.AI.removePackages `` in a local script on this actor.
Examples:
.. code-block :: Lua
actor:sendEvent('StartAIPackage', {type='Combat', target=self.object})
actor:sendEvent('RemoveAIPackages', 'Pursue')
2023-08-18 22:55:43 +02:00
**UseItem**
2023-09-11 16:21:34 +02:00
Any script can send global event `` UseItem `` with arguments `` object `` , `` actor `` , and optional boolean `` force `` .
2023-08-18 22:55:43 +02:00
The actor will use (e.g. equip or consume) the object. The object should be in the actor's inventory.
Example:
.. code-block :: Lua
2023-09-11 16:21:34 +02:00
core.sendGlobalEvent('UseItem', {object = potion, actor = player, force = true})
2023-08-18 22:55:43 +02:00
2023-07-09 08:42:09 +02:00
UI events
---------
2023-10-03 02:04:18 +02:00
**UiModeChanged**
2023-08-20 17:12:22 +02:00
Every time UI mode is changed built-in scripts send to player the event `` UiModeChanged `` with arguments `` oldMode, ` ` newMode `` (same as `` I.UI.getMode() `` )
2023-07-09 08:42:09 +02:00
and `` arg `` (for example in the mode `` Book `` the argument is the book the player is reading).
.. code-block :: Lua
eventHandlers = {
UiModeChanged = function(data)
2023-08-20 17:12:22 +02:00
print('UiModeChanged from', data.oldMode , 'to', data.newMode, '('..tostring(data.arg)..')')
2023-07-09 08:42:09 +02:00
end
}
2023-09-03 02:45:18 +02:00
2023-10-03 02:04:18 +02:00
**AddUiMode**
Equivalent to `` I.UI.addMode `` , but can be sent from another object or global script.
.. code-block :: Lua
player:sendEvent('AddUiMode', {mode = 'Book', target = book})
**SetUiMode**
Equivalent to `` I.UI.setMode `` , but can be sent from another object or global script.
.. code-block :: Lua
player:sendEvent('SetUiMode', {mode = 'Book', target = book})
2023-09-03 02:45:18 +02:00
World events
------------
Global events that just call the corresponding function in `openmw.world` .
.. code-block :: Lua
-- world.pause(tag)
core.sendGlobalEvent('Pause', tag)
-- world.unpause(tag)
core.sendGlobalEvent('Unpause', tag)
-- world.setGameTimeScale(scale)
core.sendGlobalEvent('SetGameTimeScale', scale)
-- world.setSimulationTimeScale(scale)
core.sendGlobalEvent('SetSimulationTimeScale', scale)