Blender Git Commit Log
Git Commits -> Revision 493a52a
Revision 493a52a by Wayde Moss (arcpatch-D8867_Nla_Merge_Strips) October 21, 2020, 04:19 (GMT) |
Feature: NLA Merge Strips Todo: add media and example files This patch is relative to {D8296} (which is relative to {D9247}. Apply {D9247} first then {D8296} then this one. For user-facing design discussion: {T80235} ____ **Problem/Solution:** Before, the only way to combine multiple Nla strips into a single strip is to execute a Bake operator. However, this will merge **all** strips into a replace strip with full influence. This patch creates a new operator "Resample Strips To New" which effectively allows merging a set of selected NlaStrips into a single strip of any blendmode and any nonzero influence. The old selected strips will be muted while preserving the whole Nla result. (I used the word "resample" because it's more general. But most animators will recognize it as a "merge"). This patch offers a more flexible solution to {T69105}, where the solution implemented was to force baking to a single replace strip with full influence. **Feature:** Nla add support for resampling selected strips into a new track. The more specific use is to support merging selected Nla strips into a single strip. The core resampling function is (anim_sys.c) //BKE_animsys_resample_selected_strips()// (direct copy+paste of function comment) ``` /** Mute selected NLA strips and resample into a new track. The final Nla stack result will be * preserved when possible. New resampled strip will be selected. Previously selected strips will * be muted and deselected afterward. * * param resample_blendmode: Resulting resampled strip's blend mode. * param resample_influence: Resulting resampled strip's influence. above. * param resample_insertion_nlt_index: NlaTrack to insert the resample track above or below. * param insert_track_lower: Side of resample_insertion_nlt_index to place resample track. * returns: The new resample track. Returns NULL and does nothing if in tweak mode, resample * influence zero, or no fcurves are involved in the resample. */ ``` **Intended Uses:** Merge Strips: User selects a block of NlaStrips and Resamples. Effectively, all selected strips will become muted and a new "merged" track will be created. Since the overall NLA stack result is preserved, the result is equivalent to a merge. Convert Strip: User selects a single NlaStrip and Resamples with a different blendmode and/or influence. **Potential improvements/changes:** For frames where user had a keyframe, make them non-selected. Select non-user keys. This allows a follow-up op to do an Fcurve simplify or decimate of only the baked keyframes. Effectively it allows a follow-up Smart Bake that preserves user keys. Perhaps this can be done by the caller. Allow user to somehow select channels to be resampled. Currently all channels found in all selected strips are resampled. Though a simple work around is to delete the undesired channels after the resample. **Limitations and potential problems:** Design: When resample strip value not valid, what should we do? Currently we write a default value. Nothing we write will preserve the animation. This leaves the problem as a "Known Issue". This operator will not properly resample outside of the resample bounds. Generally, it's not possible since multiple strips with non-None extend modes can not be represented by a single strip of any extend mode.. Maybe it's possible by properly setting the pre and post extrapolation for individual fcurves? _____ **Some existing functions in (anim_sys.c) that had to be modified slightly for //BKE_animsys_resample_selected_strips()//:** - changes (anim_sys.c) //nlastrip_evaluate()// and its nested calls to pass //allow_alloc_channels //to control whether NlaEvalChannels are allocated or to only blend existing channels. Flushing and keyframing require allocation. The new merging operator only needs to blend existing channels and requires no allocation. There are potential areas for refactoring but haven't been implemented to keep the review simpler and more linear. It's an attempt to prevent introducing bugs that occur as a result of refactoring instead of the patch itself. Differential Revision: https://developer.blender.org/D8867 |
Commit Details:
Full Hash: 493a52aca4a0702ab80c2d9fc8f1a74f253e6493
Parent Commit: d3caa9e
Lines Changed: +1149, -67
9 Modified Paths:
/release/scripts/presets/keyconfig/keymap_data/blender_default.py (+1, -0) (Diff)
/release/scripts/startup/bl_ui/space_nla.py (+5, -0) (Diff)
/source/blender/blenkernel/BKE_animsys.h (+9, -0) (Diff)
/source/blender/blenkernel/intern/anim_sys.c (+815, -23) (Diff)
/source/blender/blenkernel/nla_private.h (+2, -1) (Diff)
/source/blender/editors/space_nla/nla_edit.c (+272, -0) (Diff)
/source/blender/editors/space_nla/nla_intern.h (+1, -0) (Diff)
/source/blender/editors/space_nla/nla_ops.c (+1, -0) (Diff)
/source/blender/makesrna/intern/rna_nla.c (+43, -43) (Diff)
/release/scripts/startup/bl_ui/space_nla.py (+5, -0) (Diff)
/source/blender/blenkernel/BKE_animsys.h (+9, -0) (Diff)
/source/blender/blenkernel/intern/anim_sys.c (+815, -23) (Diff)
/source/blender/blenkernel/nla_private.h (+2, -1) (Diff)
/source/blender/editors/space_nla/nla_edit.c (+272, -0) (Diff)
/source/blender/editors/space_nla/nla_intern.h (+1, -0) (Diff)
/source/blender/editors/space_nla/nla_ops.c (+1, -0) (Diff)
/source/blender/makesrna/intern/rna_nla.c (+43, -43) (Diff)