From 32cbff4dce73efd83cfbd1e6aeb427086b1e1bfb Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Matja=C5=BE=20Lamut?= Date: Tue, 27 Jun 2023 14:17:59 +0000 Subject: [PATCH] Documentation: Article on how to set up doors in OpenMW --- .../reference/modding/doors-and-teleports.rst | 54 +++++++++++++++++++ docs/source/reference/modding/index.rst | 1 + 2 files changed, 55 insertions(+) create mode 100644 docs/source/reference/modding/doors-and-teleports.rst diff --git a/docs/source/reference/modding/doors-and-teleports.rst b/docs/source/reference/modding/doors-and-teleports.rst new file mode 100644 index 0000000000..d0044b31d1 --- /dev/null +++ b/docs/source/reference/modding/doors-and-teleports.rst @@ -0,0 +1,54 @@ +Doors and Connecting Cells +########################## + +Cells are the basic world-building units in OpenMW and can be of either exterior +or interior type. There are two ways players can go from one cell to another. + +1. The common method is by using Door objects to instantly change player's destination cell and player's position coordinates. These need to be set-up manually in OpenMW-CS and are the topic of this article. +2. The other method is between exterior cells and is as simple as walking beyond their boundaries after which the player enters the neighbouring cell. This functionality is handled automatically by the engine and doesn't require any special setup. + + +Setting up Doors in OpenMW-CS +============================= + +First, we need an object of a Door type, as well as: + +- An associated model, to be rendered in the game world +- A name +- Sounds for when the door is opened or closed. Locked sound effect is defined in a different part of OpenMW-CS with more information available in :doc:`sound-effects`. + +.. figure:: https://gitlab.com/OpenMW/openmw-docs/-/raw/master/docs/source/reference/modding/_static/door-connect-cell-object.webp + :align: center + + An object of type Door. + + +This object is then placed in a cell and the instance of the object takes +additional parameters defining where the door will lead. + +.. figure:: https://gitlab.com/OpenMW/openmw-docs/-/raw/master/docs/source/reference/modding/_static/door-connect-cell-instance.webp + :align: center + + Instance of this object placed in the world then defines the teleport destination. + + +To interior cells +***************** + +When a door instance leads to an interior cell: + +* ``Teleport Cell`` requires ID of the destination **interior** cell. +* ``Teleport Pos X``, ``Teleport Pos Y``, and ``Teleport Pos Z`` define where relative to the cell the player will appear. +* ``Teleport Rot Z`` defines the direction the player will face. +* ``Teleport Rot X`` and ``Teleport Rot Y`` are not required as they don't do anything. + + +To exterior cells +***************** + +When the door instance leads to an exterior cell: + +* ``Teleport Cell`` **MUST** be left empty otherwise OpenMW will throw an error. This is despite the fact OpenMW-CS can suggest to input exterior cells into this field. +* ``Teleport Pos X``, ``Teleport Pos Y``, and ``Teleport Pos Z`` destination coordinates are not relative to a cell but are global to the exterior game world. +* ``Teleport Rot Z`` defines the direction the player will face. +* ``Teleport Rot X`` and ``Teleport Rot Y`` are not required as they don't do anything. diff --git a/docs/source/reference/modding/index.rst b/docs/source/reference/modding/index.rst index f64a7e3ca5..33532e385b 100644 --- a/docs/source/reference/modding/index.rst +++ b/docs/source/reference/modding/index.rst @@ -28,6 +28,7 @@ about creating new content for OpenMW, please refer to sound-effects music sky-system + doors-and-teleports custom-shader-effects extended paths