diff --git a/docs/source/reference/modding/extended.rst b/docs/source/reference/modding/extended.rst new file mode 100644 index 000000000..ac8066a6c --- /dev/null +++ b/docs/source/reference/modding/extended.rst @@ -0,0 +1,212 @@ +Extended modding feature overview +################################# + +OpenMW supports some extended modding features out of the box. +These features can conflict with mods, and such situations should be handled as any other mod conflict by patching the mods themselves. +The engine itself does not provide any kind of blacklisting of incompatible mods. + + +Native herbalism support +------------------------ + +In OpenMW it is possible to add one or more NiSwitchNodes with a ``HerbalismSwitch`` name. +Every switch node should have at least two child nodes (the first one represents the unharvested container, the second one - the harvested container). +If an organic container's mesh has such nodes, it is considered to be a plant. During activation, a window with the plant's content is not shown, +OpenMW transfers the contents directly into the player's inventory, triggers a theft crime event if the plant is owned and toggles the harvested model state. + +It is also possible to use scripts with ``OnActivate`` command for such containers. For example, when player needs a tool to harvest a plant (e.g. a pickaxe for ore). + +Keep in mind that the collision detection system ignores switch nodes, so add a ``RootCollisionNode`` or ``NCO`` NiStringExtraData to harvestable meshes. + +Advantages of described approach over old herbalism mods: + +1. There is no need to spawn separate "harvested" objects + +2. There is no need to attach a script to every container + +3. It supports an ownership check (the original engine without MWSE does not) + +4. It does not alter original respawn mechanics + +An example of mod which uses this feature is `Graphic Herbalism`_. + +Animated containers support +--------------------------- + +It is possible to attach opening/closing animations for containers. To do this, you need to create a KF-file for the container with the following groups: + +1. ``Idle`` (with ``Start`` and ``Stop`` keys) + +2. ``ContainerOpen`` (with ``Start``, ``Loot`` and ``Stop`` keys) + +3. ``ContainerClose`` (with ``Start`` and ``Stop`` keys) + +The ``Idle`` group can have the zero time, the ``Loot`` key for ``ContainerOpen`` allows to play a part of opening animation in the background. + +For example, with the following setup, the opening animation has 1.0 sec duration and shows the container window in the middle of opening animation: + +:: + + 0.0: ContainerOpen: start + 0.5: ContainerOpen: loot + 1.0: ContainerOpen: stop + +It is also possible to attach opening/closing sounds to container's animations: + +:: + + 1.0: ContainerClose: open + 1.01: Sound: AC_dw_drawer_close + 2.0: ContainerClose: stop + +The text key approach is the same as the one used for sound playback in animations in general +Note that the sound starting time value is slightly higher than the closing animation start, otherwise sound will be played at the end of opening animation in this example. + +It is important to assign a RootCollisionNode to the container mesh -- the collision shape will depend on the animation state otherwise, and this can have a performance impact. + +Advantages of described approach over old animated containers mods: + +1. There is no need to attach a script to every container + +2. Part of the opening animation can be played in the background, so we do not waste the player's time + +An example of a mod which uses this feature is `OpenMW Containers Animated`_. + + +Day/night state support +----------------------- + +It is possible to add one or more NiSwitchNodes named ``NightDaySwitch``. +Every such switch should have at least two child nodes +(the first node represents the normal node state, the second one represents the node state during night, +the optional third node represents the node state during daytime in interior cells). + +The behavior of such a model: + +1. During the day in exteriors, it is in the "normal" mode (child 0). + +2. During the night in exteriors, it is in the "night" mode (child 1). + +3. During the day in interiors, it is in the "normal" mode or "interior day" mode (child 2) depending on weather. + +4. During the night in interiors, it is in the "normal" mode. + +The actual state toggling time depends on the sunrise/sunset time settings in `openmw.cfg`: + +:: + + fallback=Weather_Sunrise_Time,6 + fallback=Weather_Sunset_Time,18 + fallback=Weather_Sunrise_Duration,2 + fallback=Weather_Sunset_Duration,2 + +These settings lead to the "night" starting at 20:00 and ending at 6:00. + +The engine checks if the weather is bright enough to support the "interior day" mode using the Glare_View setting. If it is >= 0.5, the engine considers the weather bright. + +:: + + fallback=Weather_Clear_Glare_View,1 + fallback=Weather_Foggy_Glare_View,0.25 + +With these settings, the "interior day" mode would be used for Clear weather, but would not be used for Foggy weather. + +Keep in mind that the engine will not update the weather type after a teleportation to a different region if the player did not move to an exterior cell in the new region yet. + +This feature can be used to implement street illumination, glowing windows, etc. + +Advantages of the described approach over old mods with glowing windows: + +1. There is no need to spawn additional objects for day and night mode + +2. There is no need to attach a script to every switchable object + +An example of a mod which uses this feature is `Glow in the Dahrk`_. + + +Per-group animation files support +--------------------------------- + +In the original engine it is possible to add a custom animation file to NPC to override some animations (usually idle ones). +In OpenMW it is possible to override animations via the same file for all actors which use a given basic animation file. + +If you want to override animations for all biped actors (which use the xbase_anim.nif skeleton), you can put your animations in the +``Animations/xbase_anim`` folder in your ``Data Files``. You can also have them in a data folder with a higher priority. +In this case any biped actor without a custom animation will use your animations, but – if he has additional animations – they have a higher priority. + +For example, all biped actors in Morrowind normally use the same spellcasting animations, so overriding xbase_anim spellcasting animations is sufficient. +If you want to override walking animations, you should override ``xbase_anim_female`` and ``xbase_anim_kna`` animations -- these are used for women and beast races, and +– because they have their own walking animations – they override ones which come from ``xbase_anim`` and its loose overrides. + +To enable this feature, you should have this line in your settings.cfg: + +:: + + [Game] + use additional anim sources = true + +An example of a mod which uses this feature is `Almalexia's Cast for Beasts`_. + + +Weapon sheathing support +------------------------ + +In OpenMW it is possible to display equipped, but not currently wielded weapons on the actor's model, including quivers and scabbards. + +This feature conflicts with old mods which use scripted scabbards, arrows with particles or decorative quivers (attached to the left pauldron, for example). + +1. Basics + +The minimum you need is the ``xbase_anim_sh.nif`` file from the `Weapon Sheathing`_ mod and this line in your settings.cfg: + +:: + + [Game] + weapon sheathing = true + +The ``xbase_anim_sh.nif`` contains default placement points for different weapon types. +That way you'll get Gothic-style weapon sheathing for all biped actors (without quivers and scabbards). + +2. Scabbards + +For a scabbard to be displayed, you need a mesh with an ``_sh`` suffix. For example, if the weapon has a model named foo.nif, the scabbard model must be named foo_sh.nif. + +There should be an least two nodes in the sheath file: + +``Bip01 Weapon`` - represents the weapon itself (may be just a grip for sword, for example). It is not shown when the weapon is drawn. + +``Bip01 Sheath`` - represents scabbards, quivers, etc. It is shown always when the weapon is equipped. + +You can move or rotate nodes if the default placement from the ``xbase_anim_sh.nif`` does not look good for your weapon. + +If you want to exempt a specific weapon from using this feature, you can create a stub sheath mesh with just one root node. + +If you want to use the common weapon mesh, but with custom placement, you can create a sheath mesh with an empty ``Bip01 Weapon`` node and move it as you want. + +3. Quivers + +To show the quiver for a ranged weapon, you need these nodes in the sheath file: + +``Bip01 Sheath`` node, as for scabbards + +``Bip01 Ammo`` node to show ammunition in the quiver + +``Bip01 Weapon`` to show the weapon itself (not needed for throwing weapons) + +The ``Bip01 Ammo`` should have some empty child nodes, to which the engine will attach ammunition nodes. + +The appearance and count of shown ammunition depends on type and count of equipped ammunition. If the ammunition has a wrong type (e.g. bolts for bow), it won't be shown. + +It is important to make sure the names of empty nodes start with ``"Bip01 "``, or the engine will optimize them out. + +4. Shields + +Shield holstering is not supported at the moment since it conflicts with any mods which use pseudo-shields as held items (such as Animated Morrowind and Hold It). + +An example of a mod which uses this feature is `Weapon Sheathing`_. + +.. _`Graphic Herbalism`: https://www.nexusmods.com/morrowind/mods/46599 +.. _`OpenMW Containers Animated`: https://www.nexusmods.com/morrowind/mods/46232 +.. _`Glow in the Dahrk`: https://www.nexusmods.com/morrowind/mods/45886 +.. _`Almalexia's Cast for Beasts`: https://www.nexusmods.com/morrowind/mods/45853 +.. _`Weapon sheathing`: https://www.nexusmods.com/morrowind/mods/46069` diff --git a/docs/source/reference/modding/index.rst b/docs/source/reference/modding/index.rst index 30793504e..69ec0a56a 100644 --- a/docs/source/reference/modding/index.rst +++ b/docs/source/reference/modding/index.rst @@ -23,4 +23,5 @@ about creating new content for OpenMW, please refer to settings/index texture-modding/index font + extended paths