mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-26 03:56:39 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			90 lines
		
	
	
	
		
			4.4 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
			
		
		
	
	
			90 lines
		
	
	
	
		
			4.4 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
| Animation blending
 | |
| ##################
 | |
| 
 | |
| Animation blending introduces smooth animation transitions between essentially every animation in the game without affecting gameplay. Effective if ``smooth animation transitions`` setting is enabled in the launcher or the config files.
 | |
| 
 | |
| Animation developers can bundle ``.yaml``/``.json`` files together with their ``.kf`` files to specify the blending style of their animations. Those settings will only affect the corresponding animation files.
 | |
| 
 | |
| The default OpenMW animation blending config file (the global config) affects actors only, that restriction doesn't apply to other animation blending config files; they can affect animated objects too.
 | |
| Do not override the global config file in your mod, instead create a ``your_modded_animation_file_name.yaml`` file and put it in the same folder as your ``.kf`` file.
 | |
| 
 | |
| For example, if your mod includes a ``newAnimations.kf`` file, you can put a ``newAnimations.yaml`` file beside it and fill it with your blending rules.
 | |
| Animation config files shipped in this fashion will only affect your modded animations and will not meddle with other animations in the game. 
 | |
| 
 | |
| Local (per-kf-file) animation rules will only affect transitions between animations provided in that file and transitions to those animations; they will not affect transitions from the file animation to some other animation.
 | |
| 
 | |
| Editing animation config files
 | |
| ------------------------------
 | |
| 
 | |
| In examples below ``.yaml`` config file will be used. You can provide ``.json`` files instead of ``.yaml`` if you adhere to the same overall structures and field names.
 | |
| 
 | |
| Animation blending config file is a list of blending rules that look like this:
 | |
| 
 | |
| ::
 | |
| 
 | |
|  blending_rules:
 | |
|   - from: "*"
 | |
|     to: "*"
 | |
|     easing: "sineOut"
 | |
|     duration: 0.25
 | |
|   - from: "*"
 | |
|     to: "idlesneak*"
 | |
|     easing: "springOutWeak"
 | |
|     duration: 0.4
 | |
| 
 | |
| See `files/data/animations/animation-config.yaml <https://gitlab.com/OpenMW/openmw/-/tree/master/files/data/animations/animation-config.yaml>`__ for an example of such a file.
 | |
| 
 | |
| Every blending rule should include a set of following fields:
 | |
| 
 | |
| ``from`` and ``to`` are rules that will attempt to match animation names; they usually look like ``animationGroupName:keyName`` where ``keyName`` is essentially the name of a specific action within the animation group. 
 | |
| Examples: ``"weapononehanded: chop start"``, ``"idle1h"``, ``"jump: start"`` e.t.c.
 | |
| 
 | |
| .. note::
 | |
| 
 | |
|     ``keyName`` is not always present and if omitted - the rule will match any ``keyName``.
 | |
|     The different animation names the game uses can be inspected by opening ``.kf`` animation files in Blender.
 | |
| 
 | |
| 
 | |
| Both ``animationGroupName`` and ``keyName`` support wildcard characters either at the beginning, the end of the name, or instead of the name:
 | |
| 
 | |
| - ``"*"`` will match any name.
 | |
| - ``"*idle:sta*"`` will match an animationGroupName ending with ``idle`` and a keyName starting with ``sta``.
 | |
| - ``"weapon*handed: chop*attack"`` will not work since we don't support wildcards in the middle.
 | |
| 
 | |
| ``easing`` is an animation blending function, i.e., a style of transition between animations, look below to see the list of possible easings.
 | |
| 
 | |
| ``duration`` is the transition duration in seconds, 0.2-0.4 are usually reasonable transition times, but this highly depends on your use case.
 | |
| 
 | |
| .. note::
 | |
| 
 | |
|     The bottom-most rule takes precedence in the animation config files.
 | |
| 
 | |
| 
 | |
| List of possible easings
 | |
| ------------------------
 | |
| 
 | |
| - "linear"
 | |
| - "sineOut"
 | |
| - "sineIn"
 | |
| - "sineInOut"
 | |
| - "cubicOut"
 | |
| - "cubicIn"
 | |
| - "cubicInOut"
 | |
| - "quartOut"
 | |
| - "quartIn"
 | |
| - "quartInOut"
 | |
| - "springOutGeneric"
 | |
| - "springOutWeak"
 | |
| - "springOutMed"
 | |
| - "springOutStrong"
 | |
| - "springOutTooMuch"
 | |
| 
 | |
| ``"sineOut"`` easing is usually a safe bet. In general ``"...Out"`` easing functions will yield a transition that is fast at the beginning of the transition but slows down towards the end, that style of transitions usually looks good on organic animations e.g. humanoids and creatures.
 | |
| 
 | |
| ``"...In"`` transitions begin slow but end fast, ``"...InOut"`` begin fast, slowdown in the middle, end fast.
 | |
| 
 | |
| Its hard to give an example of use cases for the latter 2 types of easing functions, they are there for developers to experiment.
 | |
| 
 | |
| The possible easings are largely ported from `easings.net <https://easings.net/>`__ and have similar names. Except for the ``springOut`` family, those are similar to ``elasticOut``, with ``springOutWeak`` being almost identical to ``elasticOut``.
 | |
| 
 | |
| Don't be afraid to experiment with different timing and easing functions!
 |