| 
									
										
										
										
											2011-02-23 10:52:22 +00:00
										 |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2010-03-21 01:14:04 +00:00
										 |  |  |  * $Id$ | 
					
						
							| 
									
										
										
										
											2009-05-29 12:26:47 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * ***** BEGIN GPL LICENSE BLOCK ***** | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is free software; you can redistribute it and/or | 
					
						
							|  |  |  |  * modify it under the terms of the GNU General Public License | 
					
						
							|  |  |  |  * as published by the Free Software Foundation; either version 2 | 
					
						
							|  |  |  |  * of the License, or (at your option) any later version.  | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |  * GNU General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  |  * along with this program; if not, write to the Free Software Foundation, | 
					
						
							| 
									
										
										
										
											2010-02-12 13:34:04 +00:00
										 |  |  |  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. | 
					
						
							| 
									
										
										
										
											2009-05-29 12:26:47 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * The Original Code is Copyright (C) 2009 Blender Foundation, Joshua Leung | 
					
						
							|  |  |  |  * All rights reserved. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *  | 
					
						
							|  |  |  |  * Contributor(s): Joshua Leung (major recode) | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * ***** END GPL LICENSE BLOCK ***** | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-27 20:29:51 +00:00
										 |  |  | /** \file blender/editors/space_nla/nla_edit.c
 | 
					
						
							|  |  |  |  *  \ingroup spnla | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-29 12:26:47 +00:00
										 |  |  | #include <string.h>
 | 
					
						
							|  |  |  | #include <stdio.h>
 | 
					
						
							| 
									
										
										
										
											2009-06-11 03:19:08 +00:00
										 |  |  | #include <math.h>
 | 
					
						
							| 
									
										
										
										
											2009-05-29 12:26:47 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "DNA_anim_types.h"
 | 
					
						
							|  |  |  | #include "DNA_scene_types.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "MEM_guardedalloc.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "BLI_blenlib.h"
 | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | #include "BLI_math.h"
 | 
					
						
							| 
									
										
										
										
											2009-05-29 12:26:47 +00:00
										 |  |  | #include "BLI_rand.h"
 | 
					
						
							| 
									
										
										
										
											2011-01-07 18:36:47 +00:00
										 |  |  | #include "BLI_utildefines.h"
 | 
					
						
							| 
									
										
										
										
											2009-05-29 12:26:47 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-24 12:50:20 +00:00
										 |  |  | #include "BKE_action.h"
 | 
					
						
							|  |  |  | #include "BKE_fcurve.h"
 | 
					
						
							| 
									
										
										
										
											2009-05-29 12:26:47 +00:00
										 |  |  | #include "BKE_nla.h"
 | 
					
						
							|  |  |  | #include "BKE_context.h"
 | 
					
						
							| 
									
										
										
										
											2009-06-19 04:45:56 +00:00
										 |  |  | #include "BKE_main.h"
 | 
					
						
							| 
									
										
										
										
											2009-05-29 12:26:47 +00:00
										 |  |  | #include "BKE_report.h"
 | 
					
						
							|  |  |  | #include "BKE_screen.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "ED_anim_api.h"
 | 
					
						
							| 
									
										
										
										
											2009-06-24 12:50:20 +00:00
										 |  |  | #include "ED_keyframes_edit.h"
 | 
					
						
							| 
									
										
										
										
											2009-05-30 10:41:41 +00:00
										 |  |  | #include "ED_markers.h"
 | 
					
						
							| 
									
										
										
										
											2009-05-29 12:26:47 +00:00
										 |  |  | #include "ED_screen.h"
 | 
					
						
							| 
									
										
										
										
											2009-07-10 02:04:50 +00:00
										 |  |  | #include "ED_transform.h"
 | 
					
						
							| 
									
										
										
										
											2009-06-19 12:57:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-30 10:41:41 +00:00
										 |  |  | #include "RNA_access.h"
 | 
					
						
							|  |  |  | #include "RNA_define.h"
 | 
					
						
							| 
									
										
										
										
											2009-07-02 06:41:10 +00:00
										 |  |  | #include "RNA_enum_types.h"
 | 
					
						
							| 
									
										
										
										
											2009-05-29 12:26:47 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "WM_api.h"
 | 
					
						
							|  |  |  | #include "WM_types.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "UI_interface.h"
 | 
					
						
							| 
									
										
										
										
											2011-02-27 18:03:19 +00:00
										 |  |  | #include "UI_resources.h"
 | 
					
						
							| 
									
										
										
										
											2009-05-29 12:26:47 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "nla_intern.h"	// own include
 | 
					
						
							| 
									
										
										
										
											2009-06-24 12:50:20 +00:00
										 |  |  | #include "nla_private.h" // FIXME... maybe this shouldn't be included?
 | 
					
						
							| 
									
										
										
										
											2009-05-29 12:26:47 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-24 06:51:33 +00:00
										 |  |  | /* *********************************************** */ | 
					
						
							|  |  |  | /* Utilities exported to other places... */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Perform validation for blending/extend settings */ | 
					
						
							|  |  |  | void ED_nla_postop_refresh (bAnimContext *ac) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	ListBase anim_data = {NULL, NULL}; | 
					
						
							|  |  |  | 	bAnimListElem *ale; | 
					
						
							|  |  |  | 	short filter= (ANIMFILTER_VISIBLE | ANIMFILTER_ANIMDATA | ANIMFILTER_FOREDIT); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* get blocks to work on */ | 
					
						
							| 
									
										
										
										
											2009-07-24 13:34:45 +00:00
										 |  |  | 	ANIM_animdata_filter(ac, &anim_data, filter, ac->data, ac->datatype); | 
					
						
							| 
									
										
										
										
											2009-07-24 06:51:33 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	for (ale= anim_data.first; ale; ale= ale->next) { | 
					
						
							|  |  |  | 		/* performing auto-blending, extend-mode validation, etc. */ | 
					
						
							|  |  |  | 		BKE_nla_validate_state(ale->data); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* free temp memory */ | 
					
						
							|  |  |  | 	BLI_freelistN(&anim_data); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-29 12:26:47 +00:00
										 |  |  | /* *********************************************** */ | 
					
						
							| 
									
										
										
										
											2009-06-09 12:28:49 +00:00
										 |  |  | /* 'Special' Editing */ | 
					
						
							| 
									
										
											  
											
												NLA SoC: Operators for 'tweaking' strip actions (TAB-Key for both)
In this commit, I've introduced the mechanism by which actions already referenced by strips used in the NLA can be edited (or 'tweaked'). To use, simply select a strip you wish to edit, and hit that TAB key to start tweaking that strip's action, and hit TAB again once you're done.
What happens when you enter 'tweak mode':
1) The action of the active strip temporarily becomes the 'active action' of the AnimData block. You are now able to edit this in one of the Animation Editors (DopeSheet/Action, Graph Editors) as per normal (i.e. sliding keyframes around, inserting keyframes, etc.). The 'action-line' will therefore get drawn immediately above the active track containing the active strip, so that it's clear that that's what we're editing.
2) All the NLA-tracks (and all the strips within them) that occur after the track that the active strip lived in get disabled while you're in tweakmode. This is equivalent to travelling back to an earlier state in a construction history stack.
3) The active NLA track also gets disabled while in tweakmode, since it would otherwise interfere with the correct functioning of the tweaking for the action of interest.
4) The 'real' active action (i.e. the one displaced by the active strip's action) gets put into temp storage, and will be restored after you exit tweakmode.
5) Any strips which also reference the action being tweaked will get highlighted in red shading to indicate that you may be making some changes to the action which you don't really want to make for the other users too.
Please note though, that this is only a rough prototype of this functionality, with some niceties still to come. i.e.:
* NLA-tracks after the active track should still get drawn above the 'tweaking action line', but perhaps with different appearance?
* Various tools will still need awareness of this to prevent corrupting operations from taking place. How to proceed is still undecided...
* When exiting tweak-mode, the strip the action came from still needs some form of syncing with the modified action... there are a few tricky issues here that will need to be solved
* Evaluation code doesn't totally take this into account yet...
---
Also, fixed a number of bugs with various code (notably selection, and also a few drawing bugs)
											
										 
											2009-06-05 05:18:07 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* ******************** Tweak-Mode Operators ***************************** */ | 
					
						
							|  |  |  | /* 'Tweak mode' allows the action referenced by the active NLA-strip to be edited 
 | 
					
						
							|  |  |  |  * as if it were the normal Active-Action of its AnimData block.  | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int nlaedit_enable_tweakmode_exec (bContext *C, wmOperator *op) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	bAnimContext ac; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	ListBase anim_data = {NULL, NULL}; | 
					
						
							|  |  |  | 	bAnimListElem *ale; | 
					
						
							|  |  |  | 	int filter; | 
					
						
							|  |  |  | 	int ok=0; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* get editor data */ | 
					
						
							|  |  |  | 	if (ANIM_animdata_get_context(C, &ac) == 0) | 
					
						
							|  |  |  | 		return OPERATOR_CANCELLED; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 	/* get a list of the AnimData blocks being shown in the NLA */ | 
					
						
							|  |  |  | 	filter= (ANIMFILTER_VISIBLE | ANIMFILTER_ANIMDATA); | 
					
						
							|  |  |  | 	ANIM_animdata_filter(&ac, &anim_data, filter, ac.data, ac.datatype); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* if no blocks, popup error? */ | 
					
						
							|  |  |  | 	if (anim_data.first == NULL) { | 
					
						
							|  |  |  | 		BKE_report(op->reports, RPT_ERROR, "No AnimData blocks to enter tweakmode for"); | 
					
						
							|  |  |  | 		return OPERATOR_CANCELLED; | 
					
						
							|  |  |  | 	}	 | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* for each AnimData block with NLA-data, try setting it in tweak-mode */ | 
					
						
							|  |  |  | 	for (ale= anim_data.first; ale; ale= ale->next) { | 
					
						
							|  |  |  | 		AnimData *adt= ale->data; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* try entering tweakmode if valid */ | 
					
						
							|  |  |  | 		ok += BKE_nla_tweakmode_enter(adt); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* free temp data */ | 
					
						
							|  |  |  | 	BLI_freelistN(&anim_data); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* if we managed to enter tweakmode on at least one AnimData block, 
 | 
					
						
							|  |  |  | 	 * set the flag for this in the active scene and send notifiers | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	if (ac.scene && ok) { | 
					
						
							|  |  |  | 		/* set editing flag */ | 
					
						
							|  |  |  | 		ac.scene->flag |= SCE_NLA_EDIT_ON; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* set notifier that things have changed */ | 
					
						
							| 
									
										
										
										
											2009-07-10 10:48:25 +00:00
										 |  |  | 		WM_event_add_notifier(C, NC_ANIMATION|ND_NLA_ACTCHANGE, NULL); | 
					
						
							| 
									
										
											  
											
												NLA SoC: Operators for 'tweaking' strip actions (TAB-Key for both)
In this commit, I've introduced the mechanism by which actions already referenced by strips used in the NLA can be edited (or 'tweaked'). To use, simply select a strip you wish to edit, and hit that TAB key to start tweaking that strip's action, and hit TAB again once you're done.
What happens when you enter 'tweak mode':
1) The action of the active strip temporarily becomes the 'active action' of the AnimData block. You are now able to edit this in one of the Animation Editors (DopeSheet/Action, Graph Editors) as per normal (i.e. sliding keyframes around, inserting keyframes, etc.). The 'action-line' will therefore get drawn immediately above the active track containing the active strip, so that it's clear that that's what we're editing.
2) All the NLA-tracks (and all the strips within them) that occur after the track that the active strip lived in get disabled while you're in tweakmode. This is equivalent to travelling back to an earlier state in a construction history stack.
3) The active NLA track also gets disabled while in tweakmode, since it would otherwise interfere with the correct functioning of the tweaking for the action of interest.
4) The 'real' active action (i.e. the one displaced by the active strip's action) gets put into temp storage, and will be restored after you exit tweakmode.
5) Any strips which also reference the action being tweaked will get highlighted in red shading to indicate that you may be making some changes to the action which you don't really want to make for the other users too.
Please note though, that this is only a rough prototype of this functionality, with some niceties still to come. i.e.:
* NLA-tracks after the active track should still get drawn above the 'tweaking action line', but perhaps with different appearance?
* Various tools will still need awareness of this to prevent corrupting operations from taking place. How to proceed is still undecided...
* When exiting tweak-mode, the strip the action came from still needs some form of syncing with the modified action... there are a few tricky issues here that will need to be solved
* Evaluation code doesn't totally take this into account yet...
---
Also, fixed a number of bugs with various code (notably selection, and also a few drawing bugs)
											
										 
											2009-06-05 05:18:07 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-06-08 01:07:19 +00:00
										 |  |  | 	else { | 
					
						
							|  |  |  | 		BKE_report(op->reports, RPT_ERROR, "No active strip(s) to enter tweakmode on."); | 
					
						
							|  |  |  | 		return OPERATOR_CANCELLED; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
											  
											
												NLA SoC: Operators for 'tweaking' strip actions (TAB-Key for both)
In this commit, I've introduced the mechanism by which actions already referenced by strips used in the NLA can be edited (or 'tweaked'). To use, simply select a strip you wish to edit, and hit that TAB key to start tweaking that strip's action, and hit TAB again once you're done.
What happens when you enter 'tweak mode':
1) The action of the active strip temporarily becomes the 'active action' of the AnimData block. You are now able to edit this in one of the Animation Editors (DopeSheet/Action, Graph Editors) as per normal (i.e. sliding keyframes around, inserting keyframes, etc.). The 'action-line' will therefore get drawn immediately above the active track containing the active strip, so that it's clear that that's what we're editing.
2) All the NLA-tracks (and all the strips within them) that occur after the track that the active strip lived in get disabled while you're in tweakmode. This is equivalent to travelling back to an earlier state in a construction history stack.
3) The active NLA track also gets disabled while in tweakmode, since it would otherwise interfere with the correct functioning of the tweaking for the action of interest.
4) The 'real' active action (i.e. the one displaced by the active strip's action) gets put into temp storage, and will be restored after you exit tweakmode.
5) Any strips which also reference the action being tweaked will get highlighted in red shading to indicate that you may be making some changes to the action which you don't really want to make for the other users too.
Please note though, that this is only a rough prototype of this functionality, with some niceties still to come. i.e.:
* NLA-tracks after the active track should still get drawn above the 'tweaking action line', but perhaps with different appearance?
* Various tools will still need awareness of this to prevent corrupting operations from taking place. How to proceed is still undecided...
* When exiting tweak-mode, the strip the action came from still needs some form of syncing with the modified action... there are a few tricky issues here that will need to be solved
* Evaluation code doesn't totally take this into account yet...
---
Also, fixed a number of bugs with various code (notably selection, and also a few drawing bugs)
											
										 
											2009-06-05 05:18:07 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* done */ | 
					
						
							|  |  |  | 	return OPERATOR_FINISHED; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  |   | 
					
						
							| 
									
										
										
										
											2009-06-28 03:13:01 +00:00
										 |  |  | void NLA_OT_tweakmode_enter (wmOperatorType *ot) | 
					
						
							| 
									
										
											  
											
												NLA SoC: Operators for 'tweaking' strip actions (TAB-Key for both)
In this commit, I've introduced the mechanism by which actions already referenced by strips used in the NLA can be edited (or 'tweaked'). To use, simply select a strip you wish to edit, and hit that TAB key to start tweaking that strip's action, and hit TAB again once you're done.
What happens when you enter 'tweak mode':
1) The action of the active strip temporarily becomes the 'active action' of the AnimData block. You are now able to edit this in one of the Animation Editors (DopeSheet/Action, Graph Editors) as per normal (i.e. sliding keyframes around, inserting keyframes, etc.). The 'action-line' will therefore get drawn immediately above the active track containing the active strip, so that it's clear that that's what we're editing.
2) All the NLA-tracks (and all the strips within them) that occur after the track that the active strip lived in get disabled while you're in tweakmode. This is equivalent to travelling back to an earlier state in a construction history stack.
3) The active NLA track also gets disabled while in tweakmode, since it would otherwise interfere with the correct functioning of the tweaking for the action of interest.
4) The 'real' active action (i.e. the one displaced by the active strip's action) gets put into temp storage, and will be restored after you exit tweakmode.
5) Any strips which also reference the action being tweaked will get highlighted in red shading to indicate that you may be making some changes to the action which you don't really want to make for the other users too.
Please note though, that this is only a rough prototype of this functionality, with some niceties still to come. i.e.:
* NLA-tracks after the active track should still get drawn above the 'tweaking action line', but perhaps with different appearance?
* Various tools will still need awareness of this to prevent corrupting operations from taking place. How to proceed is still undecided...
* When exiting tweak-mode, the strip the action came from still needs some form of syncing with the modified action... there are a few tricky issues here that will need to be solved
* Evaluation code doesn't totally take this into account yet...
---
Also, fixed a number of bugs with various code (notably selection, and also a few drawing bugs)
											
										 
											2009-06-05 05:18:07 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	/* identifiers */ | 
					
						
							|  |  |  | 	ot->name= "Enter Tweak Mode"; | 
					
						
							| 
									
										
										
										
											2009-06-28 03:13:01 +00:00
										 |  |  | 	ot->idname= "NLA_OT_tweakmode_enter"; | 
					
						
							| 
									
										
										
										
											2010-02-10 21:15:44 +00:00
										 |  |  | 	ot->description= "Enter tweaking mode for the action referenced by the active strip"; | 
					
						
							| 
									
										
											  
											
												NLA SoC: Operators for 'tweaking' strip actions (TAB-Key for both)
In this commit, I've introduced the mechanism by which actions already referenced by strips used in the NLA can be edited (or 'tweaked'). To use, simply select a strip you wish to edit, and hit that TAB key to start tweaking that strip's action, and hit TAB again once you're done.
What happens when you enter 'tweak mode':
1) The action of the active strip temporarily becomes the 'active action' of the AnimData block. You are now able to edit this in one of the Animation Editors (DopeSheet/Action, Graph Editors) as per normal (i.e. sliding keyframes around, inserting keyframes, etc.). The 'action-line' will therefore get drawn immediately above the active track containing the active strip, so that it's clear that that's what we're editing.
2) All the NLA-tracks (and all the strips within them) that occur after the track that the active strip lived in get disabled while you're in tweakmode. This is equivalent to travelling back to an earlier state in a construction history stack.
3) The active NLA track also gets disabled while in tweakmode, since it would otherwise interfere with the correct functioning of the tweaking for the action of interest.
4) The 'real' active action (i.e. the one displaced by the active strip's action) gets put into temp storage, and will be restored after you exit tweakmode.
5) Any strips which also reference the action being tweaked will get highlighted in red shading to indicate that you may be making some changes to the action which you don't really want to make for the other users too.
Please note though, that this is only a rough prototype of this functionality, with some niceties still to come. i.e.:
* NLA-tracks after the active track should still get drawn above the 'tweaking action line', but perhaps with different appearance?
* Various tools will still need awareness of this to prevent corrupting operations from taking place. How to proceed is still undecided...
* When exiting tweak-mode, the strip the action came from still needs some form of syncing with the modified action... there are a few tricky issues here that will need to be solved
* Evaluation code doesn't totally take this into account yet...
---
Also, fixed a number of bugs with various code (notably selection, and also a few drawing bugs)
											
										 
											2009-06-05 05:18:07 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* api callbacks */ | 
					
						
							|  |  |  | 	ot->exec= nlaedit_enable_tweakmode_exec; | 
					
						
							|  |  |  | 	ot->poll= nlaop_poll_tweakmode_off; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* flags */ | 
					
						
							|  |  |  | 	ot->flag= OPTYPE_REGISTER|OPTYPE_UNDO; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ------------- */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int nlaedit_disable_tweakmode_exec (bContext *C, wmOperator *op) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	bAnimContext ac; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	ListBase anim_data = {NULL, NULL}; | 
					
						
							|  |  |  | 	bAnimListElem *ale; | 
					
						
							|  |  |  | 	int filter; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* get editor data */ | 
					
						
							|  |  |  | 	if (ANIM_animdata_get_context(C, &ac) == 0) | 
					
						
							|  |  |  | 		return OPERATOR_CANCELLED; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 	/* get a list of the AnimData blocks being shown in the NLA */ | 
					
						
							|  |  |  | 	filter= (ANIMFILTER_VISIBLE | ANIMFILTER_ANIMDATA); | 
					
						
							|  |  |  | 	ANIM_animdata_filter(&ac, &anim_data, filter, ac.data, ac.datatype); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* if no blocks, popup error? */ | 
					
						
							|  |  |  | 	if (anim_data.first == NULL) { | 
					
						
							|  |  |  | 		BKE_report(op->reports, RPT_ERROR, "No AnimData blocks to enter tweakmode for"); | 
					
						
							|  |  |  | 		return OPERATOR_CANCELLED; | 
					
						
							|  |  |  | 	}	 | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* for each AnimData block with NLA-data, try exitting tweak-mode */ | 
					
						
							|  |  |  | 	for (ale= anim_data.first; ale; ale= ale->next) { | 
					
						
							|  |  |  | 		AnimData *adt= ale->data; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* try entering tweakmode if valid */ | 
					
						
							|  |  |  | 		BKE_nla_tweakmode_exit(adt); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* free temp data */ | 
					
						
							|  |  |  | 	BLI_freelistN(&anim_data); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* if we managed to enter tweakmode on at least one AnimData block, 
 | 
					
						
							|  |  |  | 	 * set the flag for this in the active scene and send notifiers | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	if (ac.scene) { | 
					
						
							|  |  |  | 		/* clear editing flag */ | 
					
						
							|  |  |  | 		ac.scene->flag &= ~SCE_NLA_EDIT_ON; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* set notifier that things have changed */ | 
					
						
							| 
									
										
										
										
											2009-07-10 10:48:25 +00:00
										 |  |  | 		WM_event_add_notifier(C, NC_ANIMATION|ND_NLA_ACTCHANGE, NULL); | 
					
						
							| 
									
										
											  
											
												NLA SoC: Operators for 'tweaking' strip actions (TAB-Key for both)
In this commit, I've introduced the mechanism by which actions already referenced by strips used in the NLA can be edited (or 'tweaked'). To use, simply select a strip you wish to edit, and hit that TAB key to start tweaking that strip's action, and hit TAB again once you're done.
What happens when you enter 'tweak mode':
1) The action of the active strip temporarily becomes the 'active action' of the AnimData block. You are now able to edit this in one of the Animation Editors (DopeSheet/Action, Graph Editors) as per normal (i.e. sliding keyframes around, inserting keyframes, etc.). The 'action-line' will therefore get drawn immediately above the active track containing the active strip, so that it's clear that that's what we're editing.
2) All the NLA-tracks (and all the strips within them) that occur after the track that the active strip lived in get disabled while you're in tweakmode. This is equivalent to travelling back to an earlier state in a construction history stack.
3) The active NLA track also gets disabled while in tweakmode, since it would otherwise interfere with the correct functioning of the tweaking for the action of interest.
4) The 'real' active action (i.e. the one displaced by the active strip's action) gets put into temp storage, and will be restored after you exit tweakmode.
5) Any strips which also reference the action being tweaked will get highlighted in red shading to indicate that you may be making some changes to the action which you don't really want to make for the other users too.
Please note though, that this is only a rough prototype of this functionality, with some niceties still to come. i.e.:
* NLA-tracks after the active track should still get drawn above the 'tweaking action line', but perhaps with different appearance?
* Various tools will still need awareness of this to prevent corrupting operations from taking place. How to proceed is still undecided...
* When exiting tweak-mode, the strip the action came from still needs some form of syncing with the modified action... there are a few tricky issues here that will need to be solved
* Evaluation code doesn't totally take this into account yet...
---
Also, fixed a number of bugs with various code (notably selection, and also a few drawing bugs)
											
										 
											2009-06-05 05:18:07 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* done */ | 
					
						
							|  |  |  | 	return OPERATOR_FINISHED; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  |   | 
					
						
							| 
									
										
										
										
											2009-06-28 03:13:01 +00:00
										 |  |  | void NLA_OT_tweakmode_exit (wmOperatorType *ot) | 
					
						
							| 
									
										
											  
											
												NLA SoC: Operators for 'tweaking' strip actions (TAB-Key for both)
In this commit, I've introduced the mechanism by which actions already referenced by strips used in the NLA can be edited (or 'tweaked'). To use, simply select a strip you wish to edit, and hit that TAB key to start tweaking that strip's action, and hit TAB again once you're done.
What happens when you enter 'tweak mode':
1) The action of the active strip temporarily becomes the 'active action' of the AnimData block. You are now able to edit this in one of the Animation Editors (DopeSheet/Action, Graph Editors) as per normal (i.e. sliding keyframes around, inserting keyframes, etc.). The 'action-line' will therefore get drawn immediately above the active track containing the active strip, so that it's clear that that's what we're editing.
2) All the NLA-tracks (and all the strips within them) that occur after the track that the active strip lived in get disabled while you're in tweakmode. This is equivalent to travelling back to an earlier state in a construction history stack.
3) The active NLA track also gets disabled while in tweakmode, since it would otherwise interfere with the correct functioning of the tweaking for the action of interest.
4) The 'real' active action (i.e. the one displaced by the active strip's action) gets put into temp storage, and will be restored after you exit tweakmode.
5) Any strips which also reference the action being tweaked will get highlighted in red shading to indicate that you may be making some changes to the action which you don't really want to make for the other users too.
Please note though, that this is only a rough prototype of this functionality, with some niceties still to come. i.e.:
* NLA-tracks after the active track should still get drawn above the 'tweaking action line', but perhaps with different appearance?
* Various tools will still need awareness of this to prevent corrupting operations from taking place. How to proceed is still undecided...
* When exiting tweak-mode, the strip the action came from still needs some form of syncing with the modified action... there are a few tricky issues here that will need to be solved
* Evaluation code doesn't totally take this into account yet...
---
Also, fixed a number of bugs with various code (notably selection, and also a few drawing bugs)
											
										 
											2009-06-05 05:18:07 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	/* identifiers */ | 
					
						
							|  |  |  | 	ot->name= "Exit Tweak Mode"; | 
					
						
							| 
									
										
										
										
											2009-06-28 03:13:01 +00:00
										 |  |  | 	ot->idname= "NLA_OT_tweakmode_exit"; | 
					
						
							| 
									
										
										
										
											2010-02-10 21:15:44 +00:00
										 |  |  | 	ot->description= "Exit tweaking mode for the action referenced by the active strip"; | 
					
						
							| 
									
										
											  
											
												NLA SoC: Operators for 'tweaking' strip actions (TAB-Key for both)
In this commit, I've introduced the mechanism by which actions already referenced by strips used in the NLA can be edited (or 'tweaked'). To use, simply select a strip you wish to edit, and hit that TAB key to start tweaking that strip's action, and hit TAB again once you're done.
What happens when you enter 'tweak mode':
1) The action of the active strip temporarily becomes the 'active action' of the AnimData block. You are now able to edit this in one of the Animation Editors (DopeSheet/Action, Graph Editors) as per normal (i.e. sliding keyframes around, inserting keyframes, etc.). The 'action-line' will therefore get drawn immediately above the active track containing the active strip, so that it's clear that that's what we're editing.
2) All the NLA-tracks (and all the strips within them) that occur after the track that the active strip lived in get disabled while you're in tweakmode. This is equivalent to travelling back to an earlier state in a construction history stack.
3) The active NLA track also gets disabled while in tweakmode, since it would otherwise interfere with the correct functioning of the tweaking for the action of interest.
4) The 'real' active action (i.e. the one displaced by the active strip's action) gets put into temp storage, and will be restored after you exit tweakmode.
5) Any strips which also reference the action being tweaked will get highlighted in red shading to indicate that you may be making some changes to the action which you don't really want to make for the other users too.
Please note though, that this is only a rough prototype of this functionality, with some niceties still to come. i.e.:
* NLA-tracks after the active track should still get drawn above the 'tweaking action line', but perhaps with different appearance?
* Various tools will still need awareness of this to prevent corrupting operations from taking place. How to proceed is still undecided...
* When exiting tweak-mode, the strip the action came from still needs some form of syncing with the modified action... there are a few tricky issues here that will need to be solved
* Evaluation code doesn't totally take this into account yet...
---
Also, fixed a number of bugs with various code (notably selection, and also a few drawing bugs)
											
										 
											2009-06-05 05:18:07 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* api callbacks */ | 
					
						
							|  |  |  | 	ot->exec= nlaedit_disable_tweakmode_exec; | 
					
						
							|  |  |  | 	ot->poll= nlaop_poll_tweakmode_on; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* flags */ | 
					
						
							|  |  |  | 	ot->flag= OPTYPE_REGISTER|OPTYPE_UNDO; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2009-05-29 12:26:47 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* *********************************************** */ | 
					
						
							| 
									
										
										
										
											2009-06-24 12:50:20 +00:00
										 |  |  | /* NLA Editing Operations (Constructive/Destructive) */ | 
					
						
							| 
									
										
										
										
											2009-06-09 12:28:49 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-19 04:45:56 +00:00
										 |  |  | /* ******************** Add Action-Clip Operator ***************************** */ | 
					
						
							|  |  |  | /* Add a new Action-Clip strip to the active track (or the active block if no space in the track) */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* add the specified action as new strip */ | 
					
						
							|  |  |  | static int nlaedit_add_actionclip_exec (bContext *C, wmOperator *op) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	bAnimContext ac; | 
					
						
							|  |  |  | 	Scene *scene; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	ListBase anim_data = {NULL, NULL}; | 
					
						
							|  |  |  | 	bAnimListElem *ale; | 
					
						
							|  |  |  | 	int filter, items; | 
					
						
							| 
									
										
										
										
											2010-02-23 19:32:32 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	bAction *act; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-19 04:45:56 +00:00
										 |  |  | 	float cfra; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* get editor data */ | 
					
						
							|  |  |  | 	if (ANIM_animdata_get_context(C, &ac) == 0) | 
					
						
							|  |  |  | 		return OPERATOR_CANCELLED; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 	scene= ac.scene; | 
					
						
							|  |  |  | 	cfra= (float)CFRA; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 	/* get action to use */ | 
					
						
							| 
									
										
										
										
											2010-05-05 15:41:38 +00:00
										 |  |  | 	act= BLI_findlink(&CTX_data_main(C)->action, RNA_enum_get(op->ptr, "action")); | 
					
						
							| 
									
										
										
										
											2009-06-19 04:45:56 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	if (act == NULL) { | 
					
						
							|  |  |  | 		BKE_report(op->reports, RPT_ERROR, "No valid Action to add."); | 
					
						
							|  |  |  | 		//printf("Add strip - actname = '%s' \n", actname);
 | 
					
						
							|  |  |  | 		return OPERATOR_CANCELLED; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* get a list of the editable tracks being shown in the NLA
 | 
					
						
							|  |  |  | 	 *	- this is limited to active ones for now, but could be expanded to  | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	filter= (ANIMFILTER_VISIBLE | ANIMFILTER_ACTIVE | ANIMFILTER_NLATRACKS | ANIMFILTER_FOREDIT); | 
					
						
							|  |  |  | 	items= ANIM_animdata_filter(&ac, &anim_data, filter, ac.data, ac.datatype); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if (items == 0) { | 
					
						
							|  |  |  | 		BKE_report(op->reports, RPT_ERROR, "No active track(s) to add strip to."); | 
					
						
							|  |  |  | 		return OPERATOR_CANCELLED; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* for every active track, try to add strip to free space in track or to the top of the stack if no space */ | 
					
						
							|  |  |  | 	for (ale= anim_data.first; ale; ale= ale->next) { | 
					
						
							|  |  |  | 		NlaTrack *nlt= (NlaTrack *)ale->data; | 
					
						
							| 
									
										
										
										
											2009-07-28 06:50:30 +00:00
										 |  |  | 		AnimData *adt= ale->adt; | 
					
						
							| 
									
										
										
										
											2009-06-19 04:45:56 +00:00
										 |  |  | 		NlaStrip *strip= NULL; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* create a new strip, and offset it to start on the current frame */ | 
					
						
							|  |  |  | 		strip= add_nlastrip(act); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		strip->end 		+= (cfra - strip->start); | 
					
						
							|  |  |  | 		strip->start	 = cfra; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* firstly try adding strip to our current track, but if that fails, add to a new track */ | 
					
						
							|  |  |  | 		if (BKE_nlatrack_add_strip(nlt, strip) == 0) { | 
					
						
							|  |  |  | 			/* trying to add to the current failed (no space), 
 | 
					
						
							|  |  |  | 			 * so add a new track to the stack, and add to that... | 
					
						
							|  |  |  | 			 */ | 
					
						
							|  |  |  | 			nlt= add_nlatrack(adt, NULL); | 
					
						
							|  |  |  | 			BKE_nlatrack_add_strip(nlt, strip); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-07-10 23:25:30 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		/* auto-name it */ | 
					
						
							|  |  |  | 		BKE_nlastrip_validate_name(adt, strip); | 
					
						
							| 
									
										
										
										
											2009-06-19 04:45:56 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* free temp data */ | 
					
						
							|  |  |  | 	BLI_freelistN(&anim_data); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-07-24 06:51:33 +00:00
										 |  |  | 	/* refresh auto strip properties */ | 
					
						
							|  |  |  | 	ED_nla_postop_refresh(&ac); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-06-19 04:45:56 +00:00
										 |  |  | 	/* set notifier that things have changed */ | 
					
						
							| 
									
										
										
										
											2010-06-18 04:39:32 +00:00
										 |  |  | 	WM_event_add_notifier(C, NC_ANIMATION|ND_NLA|NA_EDITED, NULL); | 
					
						
							| 
									
										
										
										
											2009-06-19 04:45:56 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* done */ | 
					
						
							|  |  |  | 	return OPERATOR_FINISHED; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-28 14:37:21 +00:00
										 |  |  | void NLA_OT_actionclip_add (wmOperatorType *ot) | 
					
						
							| 
									
										
										
										
											2009-06-19 04:45:56 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2010-02-23 19:32:32 +00:00
										 |  |  | 	PropertyRNA *prop; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-19 04:45:56 +00:00
										 |  |  | 	/* identifiers */ | 
					
						
							|  |  |  | 	ot->name= "Add Action Strip"; | 
					
						
							| 
									
										
										
										
											2009-11-28 14:37:21 +00:00
										 |  |  | 	ot->idname= "NLA_OT_actionclip_add"; | 
					
						
							| 
									
										
										
										
											2010-02-10 21:15:44 +00:00
										 |  |  | 	ot->description= "Add an Action-Clip strip (i.e. an NLA Strip referencing an Action) to the active track"; | 
					
						
							| 
									
										
										
										
											2009-06-19 04:45:56 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* api callbacks */ | 
					
						
							| 
									
										
										
										
											2010-02-23 19:32:32 +00:00
										 |  |  | 	ot->invoke= WM_enum_search_invoke; | 
					
						
							| 
									
										
										
										
											2009-06-19 04:45:56 +00:00
										 |  |  | 	ot->exec= nlaedit_add_actionclip_exec; | 
					
						
							|  |  |  | 	ot->poll= nlaop_poll_tweakmode_off; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* flags */ | 
					
						
							|  |  |  | 	ot->flag= OPTYPE_REGISTER|OPTYPE_UNDO; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* props */ | 
					
						
							|  |  |  | 		// TODO: this would be nicer as an ID-pointer...
 | 
					
						
							| 
									
										
										
										
											2010-05-05 15:41:38 +00:00
										 |  |  | 	prop= RNA_def_enum(ot->srna, "action", DummyRNA_NULL_items, 0, "Action", ""); | 
					
						
							| 
									
										
										
										
											2010-02-23 19:32:32 +00:00
										 |  |  | 	RNA_def_enum_funcs(prop, RNA_action_itemf); | 
					
						
							|  |  |  | 	ot->prop= prop; | 
					
						
							| 
									
										
										
										
											2009-06-19 04:45:56 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ******************** Add Transition Operator ***************************** */ | 
					
						
							|  |  |  | /* Add a new transition strip between selected strips */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int nlaedit_add_transition_exec (bContext *C, wmOperator *op) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	bAnimContext ac; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	ListBase anim_data = {NULL, NULL}; | 
					
						
							|  |  |  | 	bAnimListElem *ale; | 
					
						
							|  |  |  | 	int filter; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	int done = 0; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* get editor data */ | 
					
						
							|  |  |  | 	if (ANIM_animdata_get_context(C, &ac) == 0) | 
					
						
							|  |  |  | 		return OPERATOR_CANCELLED; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* get a list of the editable tracks being shown in the NLA */ | 
					
						
							|  |  |  | 	filter= (ANIMFILTER_VISIBLE | ANIMFILTER_NLATRACKS | ANIMFILTER_FOREDIT); | 
					
						
							|  |  |  | 	ANIM_animdata_filter(&ac, &anim_data, filter, ac.data, ac.datatype); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* for each track, find pairs of strips to add transitions to */ | 
					
						
							|  |  |  | 	for (ale= anim_data.first; ale; ale= ale->next) { | 
					
						
							|  |  |  | 		NlaTrack *nlt= (NlaTrack *)ale->data; | 
					
						
							| 
									
										
										
										
											2009-07-28 06:50:30 +00:00
										 |  |  | 		AnimData *adt= ale->adt; | 
					
						
							| 
									
										
										
										
											2009-06-19 04:45:56 +00:00
										 |  |  | 		NlaStrip *s1, *s2; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* get initial pair of strips */ | 
					
						
							|  |  |  | 		if ELEM(nlt->strips.first, NULL, nlt->strips.last) | 
					
						
							|  |  |  | 			continue; | 
					
						
							|  |  |  | 		s1= nlt->strips.first; | 
					
						
							|  |  |  | 		s2= s1->next; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* loop over strips */ | 
					
						
							|  |  |  | 		for (; s1 && s2; s1=s2, s2=s2->next) { | 
					
						
							|  |  |  | 			NlaStrip *strip; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* check if both are selected */ | 
					
						
							|  |  |  | 			if ELEM(0, (s1->flag & NLASTRIP_FLAG_SELECT), (s2->flag & NLASTRIP_FLAG_SELECT)) | 
					
						
							|  |  |  | 				continue; | 
					
						
							|  |  |  | 			/* check if there's space between the two */ | 
					
						
							|  |  |  | 			if (IS_EQ(s1->end, s2->start)) | 
					
						
							|  |  |  | 				continue; | 
					
						
							| 
									
										
										
										
											2009-07-03 01:10:46 +00:00
										 |  |  | 			/* make neither one is a transition 
 | 
					
						
							|  |  |  | 			 *	- although this is impossible to create with the standard tools,  | 
					
						
							|  |  |  | 			 * 	  the user may have altered the settings | 
					
						
							|  |  |  | 			 */ | 
					
						
							|  |  |  | 			if (ELEM(NLASTRIP_TYPE_TRANSITION, s1->type, s2->type)) | 
					
						
							|  |  |  | 				continue; | 
					
						
							| 
									
										
										
										
											2009-06-19 04:45:56 +00:00
										 |  |  | 				 | 
					
						
							|  |  |  | 			/* allocate new strip */ | 
					
						
							|  |  |  | 			strip= MEM_callocN(sizeof(NlaStrip), "NlaStrip"); | 
					
						
							|  |  |  | 			BLI_insertlinkafter(&nlt->strips, s1, strip); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* set the type */ | 
					
						
							|  |  |  | 			strip->type= NLASTRIP_TYPE_TRANSITION; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* generic settings 
 | 
					
						
							|  |  |  | 			 *	- selected flag to highlight this to the user | 
					
						
							|  |  |  | 			 *	- auto-blends to ensure that blend in/out values are automatically  | 
					
						
							|  |  |  | 			 *	  determined by overlaps of strips | 
					
						
							|  |  |  | 			 */ | 
					
						
							|  |  |  | 			strip->flag = NLASTRIP_FLAG_SELECT|NLASTRIP_FLAG_AUTO_BLENDS; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* range is simply defined as the endpoints of the adjacent strips */ | 
					
						
							|  |  |  | 			strip->start 	= s1->end; | 
					
						
							|  |  |  | 			strip->end 		= s2->start; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* scale and repeat aren't of any use, but shouldn't ever be 0 */ | 
					
						
							|  |  |  | 			strip->scale= 1.0f; | 
					
						
							|  |  |  | 			strip->repeat = 1.0f; | 
					
						
							|  |  |  | 			 | 
					
						
							| 
									
										
										
										
											2009-07-10 23:25:30 +00:00
										 |  |  | 			/* auto-name it */ | 
					
						
							|  |  |  | 			BKE_nlastrip_validate_name(adt, strip); | 
					
						
							|  |  |  | 			 | 
					
						
							| 
									
										
										
										
											2009-06-19 04:45:56 +00:00
										 |  |  | 			/* make note of this */ | 
					
						
							|  |  |  | 			done++; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* free temp data */ | 
					
						
							|  |  |  | 	BLI_freelistN(&anim_data); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* was anything added? */ | 
					
						
							|  |  |  | 	if (done) { | 
					
						
							| 
									
										
										
										
											2009-07-24 06:51:33 +00:00
										 |  |  | 		/* refresh auto strip properties */ | 
					
						
							|  |  |  | 		ED_nla_postop_refresh(&ac); | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2009-06-19 04:45:56 +00:00
										 |  |  | 		/* set notifier that things have changed */ | 
					
						
							| 
									
										
										
										
											2010-06-18 04:39:32 +00:00
										 |  |  | 		WM_event_add_notifier(C, NC_ANIMATION|ND_NLA|NA_EDITED, NULL); | 
					
						
							| 
									
										
										
										
											2009-06-19 04:45:56 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		/* done */ | 
					
						
							|  |  |  | 		return OPERATOR_FINISHED; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2009-07-07 23:33:39 +00:00
										 |  |  | 		BKE_report(op->reports, RPT_ERROR, "Needs at least a pair of adjacent selected strips with a gap between them."); | 
					
						
							| 
									
										
										
										
											2009-06-19 04:45:56 +00:00
										 |  |  | 		return OPERATOR_CANCELLED; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-28 14:37:21 +00:00
										 |  |  | void NLA_OT_transition_add (wmOperatorType *ot) | 
					
						
							| 
									
										
										
										
											2009-06-19 04:45:56 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	/* identifiers */ | 
					
						
							|  |  |  | 	ot->name= "Add Transition"; | 
					
						
							| 
									
										
										
										
											2009-11-28 14:37:21 +00:00
										 |  |  | 	ot->idname= "NLA_OT_transition_add"; | 
					
						
							| 
									
										
										
										
											2010-02-10 21:15:44 +00:00
										 |  |  | 	ot->description= "Add a transition strip between two adjacent selected strips"; | 
					
						
							| 
									
										
										
										
											2009-06-19 04:45:56 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* api callbacks */ | 
					
						
							|  |  |  | 	ot->exec= nlaedit_add_transition_exec; | 
					
						
							|  |  |  | 	ot->poll= nlaop_poll_tweakmode_off; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* flags */ | 
					
						
							|  |  |  | 	ot->flag= OPTYPE_REGISTER|OPTYPE_UNDO; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-06 11:06:34 +00:00
										 |  |  | /* ******************** Add Meta-Strip Operator ***************************** */ | 
					
						
							|  |  |  | /* Add new meta-strips incorporating the selected strips */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* add the specified action as new strip */ | 
					
						
							| 
									
										
										
										
											2010-10-15 01:36:14 +00:00
										 |  |  | static int nlaedit_add_meta_exec (bContext *C, wmOperator *UNUSED(op)) | 
					
						
							| 
									
										
										
										
											2009-07-06 11:06:34 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	bAnimContext ac; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	ListBase anim_data = {NULL, NULL}; | 
					
						
							|  |  |  | 	bAnimListElem *ale; | 
					
						
							|  |  |  | 	int filter; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* get editor data */ | 
					
						
							|  |  |  | 	if (ANIM_animdata_get_context(C, &ac) == 0) | 
					
						
							|  |  |  | 		return OPERATOR_CANCELLED; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* get a list of the editable tracks being shown in the NLA */ | 
					
						
							|  |  |  | 	filter= (ANIMFILTER_VISIBLE | ANIMFILTER_NLATRACKS | ANIMFILTER_FOREDIT); | 
					
						
							|  |  |  | 	ANIM_animdata_filter(&ac, &anim_data, filter, ac.data, ac.datatype); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* for each track, find pairs of strips to add transitions to */ | 
					
						
							|  |  |  | 	for (ale= anim_data.first; ale; ale= ale->next) { | 
					
						
							|  |  |  | 		NlaTrack *nlt= (NlaTrack *)ale->data; | 
					
						
							| 
									
										
										
										
											2009-07-28 06:50:30 +00:00
										 |  |  | 		AnimData *adt= ale->adt; | 
					
						
							| 
									
										
										
										
											2009-07-10 23:25:30 +00:00
										 |  |  | 		NlaStrip *strip; | 
					
						
							| 
									
										
										
										
											2009-07-06 11:06:34 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		/* create meta-strips from the continuous chains of selected strips */ | 
					
						
							|  |  |  | 		BKE_nlastrips_make_metas(&nlt->strips, 0); | 
					
						
							| 
									
										
										
										
											2009-07-10 23:25:30 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		/* name the metas */ | 
					
						
							|  |  |  | 		for (strip= nlt->strips.first; strip; strip= strip->next) { | 
					
						
							|  |  |  | 			/* auto-name this strip if selected (that means it is a meta) */ | 
					
						
							|  |  |  | 			if (strip->flag & NLASTRIP_FLAG_SELECT) | 
					
						
							|  |  |  | 				BKE_nlastrip_validate_name(adt, strip); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-07-06 11:06:34 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* free temp data */ | 
					
						
							|  |  |  | 	BLI_freelistN(&anim_data); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* set notifier that things have changed */ | 
					
						
							| 
									
										
										
										
											2010-06-18 04:39:32 +00:00
										 |  |  | 	WM_event_add_notifier(C, NC_ANIMATION|ND_NLA|NA_EDITED, NULL); | 
					
						
							| 
									
										
										
										
											2009-07-06 11:06:34 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* done */ | 
					
						
							|  |  |  | 	return OPERATOR_FINISHED; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-28 14:37:21 +00:00
										 |  |  | void NLA_OT_meta_add (wmOperatorType *ot) | 
					
						
							| 
									
										
										
										
											2009-07-06 11:06:34 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	/* identifiers */ | 
					
						
							|  |  |  | 	ot->name= "Add Meta-Strips"; | 
					
						
							| 
									
										
										
										
											2009-11-28 14:37:21 +00:00
										 |  |  | 	ot->idname= "NLA_OT_meta_add"; | 
					
						
							| 
									
										
										
										
											2010-02-10 21:15:44 +00:00
										 |  |  | 	ot->description= "Add new meta-strips incorporating the selected strips"; | 
					
						
							| 
									
										
										
										
											2009-07-06 11:06:34 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* api callbacks */ | 
					
						
							|  |  |  | 	ot->exec= nlaedit_add_meta_exec; | 
					
						
							|  |  |  | 	ot->poll= nlaop_poll_tweakmode_off; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* flags */ | 
					
						
							|  |  |  | 	ot->flag= OPTYPE_REGISTER|OPTYPE_UNDO; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ******************** Remove Meta-Strip Operator ***************************** */ | 
					
						
							|  |  |  | /* Separate out the strips held by the selected meta-strips */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-15 01:36:14 +00:00
										 |  |  | static int nlaedit_remove_meta_exec (bContext *C, wmOperator *UNUSED(op)) | 
					
						
							| 
									
										
										
										
											2009-07-06 11:06:34 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	bAnimContext ac; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	ListBase anim_data = {NULL, NULL}; | 
					
						
							|  |  |  | 	bAnimListElem *ale; | 
					
						
							|  |  |  | 	int filter; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* get editor data */ | 
					
						
							|  |  |  | 	if (ANIM_animdata_get_context(C, &ac) == 0) | 
					
						
							|  |  |  | 		return OPERATOR_CANCELLED; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* get a list of the editable tracks being shown in the NLA */ | 
					
						
							|  |  |  | 	filter= (ANIMFILTER_VISIBLE | ANIMFILTER_NLATRACKS | ANIMFILTER_FOREDIT); | 
					
						
							|  |  |  | 	ANIM_animdata_filter(&ac, &anim_data, filter, ac.data, ac.datatype); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* for each track, find pairs of strips to add transitions to */ | 
					
						
							|  |  |  | 	for (ale= anim_data.first; ale; ale= ale->next) { | 
					
						
							|  |  |  | 		NlaTrack *nlt= (NlaTrack *)ale->data; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* clear all selected meta-strips, regardless of whether they are temporary or not */ | 
					
						
							|  |  |  | 		BKE_nlastrips_clear_metas(&nlt->strips, 1, 0); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* free temp data */ | 
					
						
							|  |  |  | 	BLI_freelistN(&anim_data); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* set notifier that things have changed */ | 
					
						
							| 
									
										
										
										
											2010-06-18 04:39:32 +00:00
										 |  |  | 	WM_event_add_notifier(C, NC_ANIMATION|ND_NLA|NA_EDITED, NULL); | 
					
						
							| 
									
										
										
										
											2009-07-06 11:06:34 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* done */ | 
					
						
							|  |  |  | 	return OPERATOR_FINISHED; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-28 14:37:21 +00:00
										 |  |  | void NLA_OT_meta_remove (wmOperatorType *ot) | 
					
						
							| 
									
										
										
										
											2009-07-06 11:06:34 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	/* identifiers */ | 
					
						
							|  |  |  | 	ot->name= "Remove Meta-Strips"; | 
					
						
							| 
									
										
										
										
											2009-11-28 14:37:21 +00:00
										 |  |  | 	ot->idname= "NLA_OT_meta_remove"; | 
					
						
							| 
									
										
										
										
											2010-02-10 21:15:44 +00:00
										 |  |  | 	ot->description= "Separate out the strips held by the selected meta-strips"; | 
					
						
							| 
									
										
										
										
											2009-07-06 11:06:34 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* api callbacks */ | 
					
						
							|  |  |  | 	ot->exec= nlaedit_remove_meta_exec; | 
					
						
							|  |  |  | 	ot->poll= nlaop_poll_tweakmode_off; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* flags */ | 
					
						
							|  |  |  | 	ot->flag= OPTYPE_REGISTER|OPTYPE_UNDO; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-19 12:45:08 +00:00
										 |  |  | /* ******************** Duplicate Strips Operator ************************** */ | 
					
						
							|  |  |  | /* Duplicates the selected NLA-Strips, putting them on new tracks above the one
 | 
					
						
							|  |  |  |  * the originals were housed in. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  |   | 
					
						
							| 
									
										
										
										
											2010-10-15 01:36:14 +00:00
										 |  |  | static int nlaedit_duplicate_exec (bContext *C, wmOperator *UNUSED(op)) | 
					
						
							| 
									
										
										
										
											2009-06-19 12:45:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	bAnimContext ac; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	ListBase anim_data = {NULL, NULL}; | 
					
						
							|  |  |  | 	bAnimListElem *ale; | 
					
						
							|  |  |  | 	int filter; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	short done = 0; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* get editor data */ | 
					
						
							|  |  |  | 	if (ANIM_animdata_get_context(C, &ac) == 0) | 
					
						
							|  |  |  | 		return OPERATOR_CANCELLED; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 	/* get a list of editable tracks being shown in the NLA */ | 
					
						
							|  |  |  | 	filter= (ANIMFILTER_VISIBLE | ANIMFILTER_NLATRACKS | ANIMFILTER_FOREDIT); | 
					
						
							|  |  |  | 	ANIM_animdata_filter(&ac, &anim_data, filter, ac.data, ac.datatype); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* duplicate strips in tracks starting from the last one so that we're 
 | 
					
						
							|  |  |  | 	 * less likely to duplicate strips we just duplicated... | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	for (ale= anim_data.last; ale; ale= ale->prev) { | 
					
						
							|  |  |  | 		NlaTrack *nlt= (NlaTrack *)ale->data; | 
					
						
							| 
									
										
										
										
											2009-07-28 06:50:30 +00:00
										 |  |  | 		AnimData *adt= ale->adt; | 
					
						
							| 
									
										
										
										
											2009-06-19 12:45:08 +00:00
										 |  |  | 		NlaStrip *strip, *nstrip, *next; | 
					
						
							|  |  |  | 		NlaTrack *track; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		for (strip= nlt->strips.first; strip; strip= next) { | 
					
						
							|  |  |  | 			next= strip->next; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* if selected, split the strip at its midpoint */ | 
					
						
							|  |  |  | 			if (strip->flag & NLASTRIP_FLAG_SELECT) { | 
					
						
							|  |  |  | 				/* make a copy (assume that this is possible) */ | 
					
						
							|  |  |  | 				nstrip= copy_nlastrip(strip); | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 				/* in case there's no space in the track above, or we haven't got a reference to it yet, try adding */ | 
					
						
							|  |  |  | 				if (BKE_nlatrack_add_strip(nlt->next, nstrip) == 0) { | 
					
						
							|  |  |  | 					/* need to add a new track above the one above the current one
 | 
					
						
							|  |  |  | 					 *	- if the current one is the last one, nlt->next will be NULL, which defaults to adding  | 
					
						
							|  |  |  | 					 *	  at the top of the stack anyway... | 
					
						
							|  |  |  | 					 */ | 
					
						
							|  |  |  | 					track= add_nlatrack(adt, nlt->next); | 
					
						
							|  |  |  | 					BKE_nlatrack_add_strip(track, nstrip); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				 | 
					
						
							| 
									
										
										
										
											2009-06-20 04:02:49 +00:00
										 |  |  | 				/* deselect the original and the active flag */ | 
					
						
							|  |  |  | 				strip->flag &= ~(NLASTRIP_FLAG_SELECT|NLASTRIP_FLAG_ACTIVE); | 
					
						
							| 
									
										
										
										
											2009-06-19 12:45:08 +00:00
										 |  |  | 				 | 
					
						
							| 
									
										
										
										
											2011-01-20 09:26:36 +00:00
										 |  |  | 				/* auto-name newly created strip */ | 
					
						
							|  |  |  | 				BKE_nlastrip_validate_name(adt, nstrip); | 
					
						
							| 
									
										
										
										
											2009-07-10 23:25:30 +00:00
										 |  |  | 				 | 
					
						
							| 
									
										
										
										
											2009-06-19 12:45:08 +00:00
										 |  |  | 				done++; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* free temp data */ | 
					
						
							|  |  |  | 	BLI_freelistN(&anim_data); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if (done) { | 
					
						
							| 
									
										
										
										
											2009-07-24 06:51:33 +00:00
										 |  |  | 		/* refresh auto strip properties */ | 
					
						
							|  |  |  | 		ED_nla_postop_refresh(&ac); | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2009-06-19 12:45:08 +00:00
										 |  |  | 		/* set notifier that things have changed */ | 
					
						
							| 
									
										
										
										
											2010-06-18 04:39:32 +00:00
										 |  |  | 		WM_event_add_notifier(C, NC_ANIMATION|ND_NLA|NA_EDITED, NULL); | 
					
						
							| 
									
										
										
										
											2009-06-19 12:45:08 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2009-06-19 12:57:31 +00:00
										 |  |  | 		/* done */ | 
					
						
							|  |  |  | 		return OPERATOR_FINISHED; | 
					
						
							| 
									
										
										
										
											2009-06-19 12:45:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else | 
					
						
							|  |  |  | 		return OPERATOR_CANCELLED; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-15 01:36:14 +00:00
										 |  |  | static int nlaedit_duplicate_invoke(bContext *C, wmOperator *op, wmEvent *UNUSED(event)) | 
					
						
							| 
									
										
										
										
											2009-06-19 12:57:31 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	nlaedit_duplicate_exec(C, op); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2011-03-22 12:53:36 +00:00
										 |  |  | 	RNA_enum_set(op->ptr, "mode", TFM_TRANSLATION); | 
					
						
							| 
									
										
										
										
											2009-12-10 10:36:32 +00:00
										 |  |  | 	WM_operator_name_call(C, "TRANSFORM_OT_transform", WM_OP_INVOKE_REGION_WIN, op->ptr); | 
					
						
							| 
									
										
										
										
											2009-06-19 12:57:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	return OPERATOR_FINISHED; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-28 03:13:01 +00:00
										 |  |  | void NLA_OT_duplicate (wmOperatorType *ot) | 
					
						
							| 
									
										
										
										
											2009-06-19 12:45:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	/* identifiers */ | 
					
						
							|  |  |  | 	ot->name= "Duplicate Strips"; | 
					
						
							| 
									
										
										
										
											2009-06-28 03:13:01 +00:00
										 |  |  | 	ot->idname= "NLA_OT_duplicate"; | 
					
						
							| 
									
										
										
										
											2010-02-10 21:15:44 +00:00
										 |  |  | 	ot->description= "Duplicate selected NLA-Strips, adding the new strips in new tracks above the originals"; | 
					
						
							| 
									
										
										
										
											2009-06-19 12:45:08 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* api callbacks */ | 
					
						
							| 
									
										
										
										
											2009-06-19 12:57:31 +00:00
										 |  |  | 	ot->invoke= nlaedit_duplicate_invoke; | 
					
						
							| 
									
										
										
										
											2009-06-19 12:45:08 +00:00
										 |  |  | 	ot->exec= nlaedit_duplicate_exec; | 
					
						
							|  |  |  | 	ot->poll= nlaop_poll_tweakmode_off; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* flags */ | 
					
						
							|  |  |  | 	ot->flag= OPTYPE_REGISTER|OPTYPE_UNDO; | 
					
						
							| 
									
										
										
										
											2009-06-19 12:57:31 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* to give to transform */ | 
					
						
							| 
									
										
										
										
											2011-04-01 08:51:12 +00:00
										 |  |  | 	RNA_def_enum(ot->srna, "mode", transform_mode_types, TFM_TRANSLATION, "Mode", ""); | 
					
						
							| 
									
										
										
										
											2009-06-19 12:45:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-11 02:18:29 +00:00
										 |  |  | /* ******************** Delete Strips Operator ***************************** */ | 
					
						
							| 
									
										
										
										
											2009-06-09 12:28:49 +00:00
										 |  |  | /* Deletes the selected NLA-Strips */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-15 01:36:14 +00:00
										 |  |  | static int nlaedit_delete_exec (bContext *C, wmOperator *UNUSED(op)) | 
					
						
							| 
									
										
										
										
											2009-06-09 12:28:49 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	bAnimContext ac; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	ListBase anim_data = {NULL, NULL}; | 
					
						
							|  |  |  | 	bAnimListElem *ale; | 
					
						
							|  |  |  | 	int filter; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* get editor data */ | 
					
						
							|  |  |  | 	if (ANIM_animdata_get_context(C, &ac) == 0) | 
					
						
							|  |  |  | 		return OPERATOR_CANCELLED; | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2009-06-19 04:45:56 +00:00
										 |  |  | 	/* get a list of the editable tracks being shown in the NLA */ | 
					
						
							| 
									
										
										
										
											2009-06-09 12:28:49 +00:00
										 |  |  | 	filter= (ANIMFILTER_VISIBLE | ANIMFILTER_NLATRACKS | ANIMFILTER_FOREDIT); | 
					
						
							|  |  |  | 	ANIM_animdata_filter(&ac, &anim_data, filter, ac.data, ac.datatype); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* for each NLA-Track, delete all selected strips */ | 
					
						
							|  |  |  | 	for (ale= anim_data.first; ale; ale= ale->next) { | 
					
						
							|  |  |  | 		NlaTrack *nlt= (NlaTrack *)ale->data; | 
					
						
							|  |  |  | 		NlaStrip *strip, *nstrip; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		for (strip= nlt->strips.first; strip; strip= nstrip) { | 
					
						
							|  |  |  | 			nstrip= strip->next; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* if selected, delete */ | 
					
						
							| 
									
										
										
										
											2009-07-03 01:10:46 +00:00
										 |  |  | 			if (strip->flag & NLASTRIP_FLAG_SELECT) { | 
					
						
							|  |  |  | 				/* if a strip either side of this was a transition, delete those too */ | 
					
						
							|  |  |  | 				if ((strip->prev) && (strip->prev->type == NLASTRIP_TYPE_TRANSITION))  | 
					
						
							|  |  |  | 					free_nlastrip(&nlt->strips, strip->prev); | 
					
						
							|  |  |  | 				if ((nstrip) && (nstrip->type == NLASTRIP_TYPE_TRANSITION)) { | 
					
						
							|  |  |  | 					nstrip= nstrip->next; | 
					
						
							|  |  |  | 					free_nlastrip(&nlt->strips, strip->next); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 				/* finally, delete this strip */ | 
					
						
							| 
									
										
										
										
											2009-06-09 12:28:49 +00:00
										 |  |  | 				free_nlastrip(&nlt->strips, strip); | 
					
						
							| 
									
										
										
										
											2009-07-03 01:10:46 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2009-06-09 12:28:49 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* free temp data */ | 
					
						
							|  |  |  | 	BLI_freelistN(&anim_data); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-07-24 06:51:33 +00:00
										 |  |  | 	/* refresh auto strip properties */ | 
					
						
							|  |  |  | 	ED_nla_postop_refresh(&ac); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-06-09 12:28:49 +00:00
										 |  |  | 	/* set notifier that things have changed */ | 
					
						
							| 
									
										
										
										
											2010-06-18 04:39:32 +00:00
										 |  |  | 	WM_event_add_notifier(C, NC_ANIMATION|ND_NLA|NA_EDITED, NULL); | 
					
						
							| 
									
										
										
										
											2009-06-09 12:28:49 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* done */ | 
					
						
							|  |  |  | 	return OPERATOR_FINISHED; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-28 03:13:01 +00:00
										 |  |  | void NLA_OT_delete (wmOperatorType *ot) | 
					
						
							| 
									
										
										
										
											2009-06-09 12:28:49 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	/* identifiers */ | 
					
						
							|  |  |  | 	ot->name= "Delete Strips"; | 
					
						
							| 
									
										
										
										
											2009-06-28 03:13:01 +00:00
										 |  |  | 	ot->idname= "NLA_OT_delete"; | 
					
						
							| 
									
										
										
										
											2010-02-10 21:15:44 +00:00
										 |  |  | 	ot->description= "Delete selected strips"; | 
					
						
							| 
									
										
										
										
											2009-06-09 12:28:49 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* api callbacks */ | 
					
						
							|  |  |  | 	ot->exec= nlaedit_delete_exec; | 
					
						
							|  |  |  | 	ot->poll= nlaop_poll_tweakmode_off; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* flags */ | 
					
						
							|  |  |  | 	ot->flag= OPTYPE_REGISTER|OPTYPE_UNDO; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2009-05-29 12:26:47 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-11 02:18:29 +00:00
										 |  |  | /* ******************** Split Strips Operator ***************************** */ | 
					
						
							|  |  |  | /* Splits the selected NLA-Strips into two strips at the midpoint of the strip */ | 
					
						
							|  |  |  | // TODO's? 
 | 
					
						
							|  |  |  | // 	- multiple splits
 | 
					
						
							|  |  |  | //	- variable-length splits?
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-06 12:24:09 +00:00
										 |  |  | /* split a given Action-Clip strip */ | 
					
						
							| 
									
										
										
										
											2009-07-12 07:28:25 +00:00
										 |  |  | static void nlaedit_split_strip_actclip (AnimData *adt, NlaTrack *nlt, NlaStrip *strip, float cfra) | 
					
						
							| 
									
										
										
										
											2009-07-06 12:24:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	NlaStrip *nstrip; | 
					
						
							| 
									
										
										
										
											2009-07-12 07:28:25 +00:00
										 |  |  | 	float splitframe, splitaframe; | 
					
						
							| 
									
										
										
										
											2009-07-06 12:24:09 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-07-12 07:28:25 +00:00
										 |  |  | 	/* calculate the frames to do the splitting at 
 | 
					
						
							|  |  |  | 	 *	- use current frame if within extents of strip  | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	if ((cfra > strip->start) && (cfra < strip->end)) { | 
					
						
							|  |  |  | 		/* use the current frame */ | 
					
						
							|  |  |  | 		splitframe= cfra; | 
					
						
							|  |  |  | 		splitaframe= nlastrip_get_frame(strip, cfra, NLATIME_CONVERT_UNMAP); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		/* split in the middle */ | 
					
						
							|  |  |  | 		float len; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* strip extents */ | 
					
						
							|  |  |  | 		len= strip->end - strip->start; | 
					
						
							|  |  |  | 		if (IS_EQ(len, 0.0f))  | 
					
						
							|  |  |  | 			return; | 
					
						
							|  |  |  | 		else | 
					
						
							|  |  |  | 			splitframe= strip->start + (len / 2.0f); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* action range */ | 
					
						
							|  |  |  | 		len= strip->actend - strip->actstart; | 
					
						
							|  |  |  | 		if (IS_EQ(len, 0.0f)) | 
					
						
							|  |  |  | 			splitaframe= strip->actend; | 
					
						
							|  |  |  | 		else | 
					
						
							|  |  |  | 			splitaframe= strip->actstart + (len / 2.0f); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-07-06 12:24:09 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* make a copy (assume that this is possible) and append
 | 
					
						
							|  |  |  | 	 * it immediately after the current strip | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	nstrip= copy_nlastrip(strip); | 
					
						
							|  |  |  | 	BLI_insertlinkafter(&nlt->strips, strip, nstrip); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* set the endpoint of the first strip and the start of the new strip 
 | 
					
						
							| 
									
										
										
										
											2009-07-12 07:28:25 +00:00
										 |  |  | 	 * to the splitframe values calculated above | 
					
						
							| 
									
										
										
										
											2009-07-06 12:24:09 +00:00
										 |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2009-07-12 07:28:25 +00:00
										 |  |  | 	strip->end= splitframe; | 
					
						
							|  |  |  | 	nstrip->start= splitframe; | 
					
						
							| 
									
										
										
										
											2009-07-06 12:24:09 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-07-12 07:28:25 +00:00
										 |  |  | 	if ((splitaframe > strip->actstart) && (splitaframe < strip->actend)) { | 
					
						
							|  |  |  | 		/* only do this if we're splitting down the middle...  */ | 
					
						
							|  |  |  | 		strip->actend= splitaframe; | 
					
						
							|  |  |  | 		nstrip->actstart= splitaframe; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-07-06 12:24:09 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* clear the active flag from the copy */ | 
					
						
							|  |  |  | 	nstrip->flag &= ~NLASTRIP_FLAG_ACTIVE; | 
					
						
							| 
									
										
										
										
											2009-07-10 23:25:30 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* auto-name the new strip */ | 
					
						
							|  |  |  | 	BKE_nlastrip_validate_name(adt, nstrip); | 
					
						
							| 
									
										
										
										
											2009-07-06 12:24:09 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* split a given Meta strip */ | 
					
						
							| 
									
										
										
										
											2010-10-16 08:03:28 +00:00
										 |  |  | static void nlaedit_split_strip_meta (NlaTrack *nlt, NlaStrip *strip) | 
					
						
							| 
									
										
										
										
											2009-07-06 12:24:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	/* simply ungroup it for now...  */ | 
					
						
							|  |  |  | 	BKE_nlastrips_clear_metastrip(&nlt->strips, strip); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ----- */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-15 01:36:14 +00:00
										 |  |  | static int nlaedit_split_exec (bContext *C, wmOperator *UNUSED(op)) | 
					
						
							| 
									
										
										
										
											2009-06-11 02:18:29 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	bAnimContext ac; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	ListBase anim_data = {NULL, NULL}; | 
					
						
							|  |  |  | 	bAnimListElem *ale; | 
					
						
							|  |  |  | 	int filter; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* get editor data */ | 
					
						
							|  |  |  | 	if (ANIM_animdata_get_context(C, &ac) == 0) | 
					
						
							|  |  |  | 		return OPERATOR_CANCELLED; | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2009-06-19 04:45:56 +00:00
										 |  |  | 	/* get a list of editable tracks being shown in the NLA */ | 
					
						
							| 
									
										
										
										
											2009-06-11 02:18:29 +00:00
										 |  |  | 	filter= (ANIMFILTER_VISIBLE | ANIMFILTER_NLATRACKS | ANIMFILTER_FOREDIT); | 
					
						
							|  |  |  | 	ANIM_animdata_filter(&ac, &anim_data, filter, ac.data, ac.datatype); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-06-21 03:02:40 +00:00
										 |  |  | 	/* for each NLA-Track, split all selected strips into two strips */ | 
					
						
							| 
									
										
										
										
											2009-06-11 02:18:29 +00:00
										 |  |  | 	for (ale= anim_data.first; ale; ale= ale->next) { | 
					
						
							|  |  |  | 		NlaTrack *nlt= (NlaTrack *)ale->data; | 
					
						
							| 
									
										
										
										
											2009-07-28 06:50:30 +00:00
										 |  |  | 		AnimData *adt= ale->adt; | 
					
						
							| 
									
										
										
										
											2009-07-06 12:24:09 +00:00
										 |  |  | 		NlaStrip *strip, *next; | 
					
						
							| 
									
										
										
										
											2009-06-11 02:18:29 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		for (strip= nlt->strips.first; strip; strip= next) { | 
					
						
							|  |  |  | 			next= strip->next; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* if selected, split the strip at its midpoint */ | 
					
						
							|  |  |  | 			if (strip->flag & NLASTRIP_FLAG_SELECT) { | 
					
						
							| 
									
										
										
										
											2009-07-06 12:24:09 +00:00
										 |  |  | 				/* splitting method depends on the type of strip */ | 
					
						
							|  |  |  | 				switch (strip->type) { | 
					
						
							|  |  |  | 					case NLASTRIP_TYPE_CLIP: /* action-clip */ | 
					
						
							| 
									
										
										
										
											2009-07-12 07:28:25 +00:00
										 |  |  | 						nlaedit_split_strip_actclip(adt, nlt, strip, (float)ac.scene->r.cfra); | 
					
						
							| 
									
										
										
										
											2009-07-06 12:24:09 +00:00
										 |  |  | 						break; | 
					
						
							|  |  |  | 						 | 
					
						
							|  |  |  | 					case NLASTRIP_TYPE_META: /* meta-strips need special handling */ | 
					
						
							| 
									
										
										
										
											2010-10-16 08:03:28 +00:00
										 |  |  | 						nlaedit_split_strip_meta(nlt, strip); | 
					
						
							| 
									
										
										
										
											2009-07-06 12:24:09 +00:00
										 |  |  | 						break; | 
					
						
							| 
									
										
										
										
											2009-06-11 02:18:29 +00:00
										 |  |  | 					 | 
					
						
							| 
									
										
										
										
											2009-07-06 12:24:09 +00:00
										 |  |  | 					default: /* for things like Transitions, do not split! */ | 
					
						
							|  |  |  | 						break; | 
					
						
							|  |  |  | 				} | 
					
						
							| 
									
										
										
										
											2009-06-11 02:18:29 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* free temp data */ | 
					
						
							|  |  |  | 	BLI_freelistN(&anim_data); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-07-24 06:51:33 +00:00
										 |  |  | 	/* refresh auto strip properties */ | 
					
						
							|  |  |  | 	ED_nla_postop_refresh(&ac); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-06-11 02:18:29 +00:00
										 |  |  | 	/* set notifier that things have changed */ | 
					
						
							| 
									
										
										
										
											2010-06-18 04:39:32 +00:00
										 |  |  | 	WM_event_add_notifier(C, NC_ANIMATION|ND_NLA|NA_EDITED, NULL); | 
					
						
							| 
									
										
										
										
											2009-06-11 02:18:29 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* done */ | 
					
						
							|  |  |  | 	return OPERATOR_FINISHED; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-28 03:13:01 +00:00
										 |  |  | void NLA_OT_split (wmOperatorType *ot) | 
					
						
							| 
									
										
										
										
											2009-06-11 02:18:29 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	/* identifiers */ | 
					
						
							|  |  |  | 	ot->name= "Split Strips"; | 
					
						
							| 
									
										
										
										
											2009-06-28 03:13:01 +00:00
										 |  |  | 	ot->idname= "NLA_OT_split"; | 
					
						
							| 
									
										
										
										
											2010-02-10 21:15:44 +00:00
										 |  |  | 	ot->description= "Split selected strips at their midpoints"; | 
					
						
							| 
									
										
										
										
											2009-06-11 02:18:29 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* api callbacks */ | 
					
						
							|  |  |  | 	ot->exec= nlaedit_split_exec; | 
					
						
							|  |  |  | 	ot->poll= nlaop_poll_tweakmode_off; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* flags */ | 
					
						
							|  |  |  | 	ot->flag= OPTYPE_REGISTER|OPTYPE_UNDO; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-16 02:21:43 +00:00
										 |  |  | /* ******************** Bake Strips Operator ***************************** */ | 
					
						
							|  |  |  | /* Bakes the NLA Strips for the active AnimData blocks */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-15 01:36:14 +00:00
										 |  |  | static int nlaedit_bake_exec (bContext *C, wmOperator *UNUSED(op)) | 
					
						
							| 
									
										
										
										
											2009-08-16 02:21:43 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	bAnimContext ac; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	ListBase anim_data = {NULL, NULL}; | 
					
						
							|  |  |  | 	bAnimListElem *ale; | 
					
						
							|  |  |  | 	int filter; | 
					
						
							| 
									
										
										
										
											2010-04-17 15:47:00 +00:00
										 |  |  | //	int flag = 0;
 | 
					
						
							| 
									
										
										
										
											2009-08-16 02:21:43 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* get editor data */ | 
					
						
							|  |  |  | 	if (ANIM_animdata_get_context(C, &ac) == 0) | 
					
						
							|  |  |  | 		return OPERATOR_CANCELLED; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 	/* get a list of the editable tracks being shown in the NLA */ | 
					
						
							|  |  |  | 	filter= (ANIMFILTER_VISIBLE | ANIMFILTER_ANIMDATA | ANIMFILTER_FOREDIT); | 
					
						
							|  |  |  | 	ANIM_animdata_filter(&ac, &anim_data, filter, ac.data, ac.datatype); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* for each AnimData block, bake strips to animdata... */ | 
					
						
							|  |  |  | 	for (ale= anim_data.first; ale; ale= ale->next) { | 
					
						
							| 
									
										
										
										
											2010-04-01 06:26:41 +00:00
										 |  |  | 		//BKE_nla_bake(ac.scene, ale->id, ale->data, flag);
 | 
					
						
							| 
									
										
										
										
											2009-08-16 02:21:43 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* free temp data */ | 
					
						
							|  |  |  | 	BLI_freelistN(&anim_data); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* refresh auto strip properties */ | 
					
						
							|  |  |  | 	ED_nla_postop_refresh(&ac); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* set notifier that things have changed */ | 
					
						
							| 
									
										
										
										
											2010-06-18 04:39:32 +00:00
										 |  |  | 	WM_event_add_notifier(C, NC_ANIMATION|ND_NLA|NA_EDITED, NULL); | 
					
						
							| 
									
										
										
										
											2009-08-16 02:21:43 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* done */ | 
					
						
							|  |  |  | 	return OPERATOR_FINISHED; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-14 17:55:27 +00:00
										 |  |  | static void NLA_OT_bake (wmOperatorType *ot) | 
					
						
							| 
									
										
										
										
											2009-08-16 02:21:43 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	/* identifiers */ | 
					
						
							|  |  |  | 	ot->name= "Bake Strips"; | 
					
						
							|  |  |  | 	ot->idname= "NLA_OT_bake"; | 
					
						
							| 
									
										
										
										
											2010-02-10 21:15:44 +00:00
										 |  |  | 	ot->description= "Bake all strips of selected AnimData blocks"; | 
					
						
							| 
									
										
										
										
											2009-08-16 02:21:43 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* api callbacks */ | 
					
						
							|  |  |  | 	ot->exec= nlaedit_bake_exec; | 
					
						
							|  |  |  | 	ot->poll= nlaop_poll_tweakmode_off; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* flags */ | 
					
						
							|  |  |  | 	ot->flag= OPTYPE_REGISTER|OPTYPE_UNDO; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-29 12:26:47 +00:00
										 |  |  | /* *********************************************** */ | 
					
						
							| 
									
										
										
										
											2009-06-24 12:50:20 +00:00
										 |  |  | /* NLA Editing Operations (Modifying) */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-09 01:32:13 +00:00
										 |  |  | /* ******************** Toggle Muting Operator ************************** */ | 
					
						
							|  |  |  | /* Toggles whether strips are muted or not */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-15 01:36:14 +00:00
										 |  |  | static int nlaedit_toggle_mute_exec (bContext *C, wmOperator *UNUSED(op)) | 
					
						
							| 
									
										
										
										
											2009-07-09 01:32:13 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	bAnimContext ac; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	ListBase anim_data = {NULL, NULL}; | 
					
						
							|  |  |  | 	bAnimListElem *ale; | 
					
						
							|  |  |  | 	int filter; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* get editor data */ | 
					
						
							|  |  |  | 	if (ANIM_animdata_get_context(C, &ac) == 0) | 
					
						
							|  |  |  | 		return OPERATOR_CANCELLED; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 	/* get a list of the editable tracks being shown in the NLA */ | 
					
						
							|  |  |  | 	filter= (ANIMFILTER_VISIBLE | ANIMFILTER_NLATRACKS | ANIMFILTER_FOREDIT); | 
					
						
							|  |  |  | 	ANIM_animdata_filter(&ac, &anim_data, filter, ac.data, ac.datatype); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* go over all selected strips */ | 
					
						
							|  |  |  | 	for (ale= anim_data.first; ale; ale= ale->next) { | 
					
						
							|  |  |  | 		NlaTrack *nlt= (NlaTrack *)ale->data; | 
					
						
							|  |  |  | 		NlaStrip *strip; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* for every selected strip, toggle muting  */ | 
					
						
							|  |  |  | 		for (strip= nlt->strips.first; strip; strip= strip->next) { | 
					
						
							|  |  |  | 			if (strip->flag & NLASTRIP_FLAG_SELECT) { | 
					
						
							|  |  |  | 				/* just flip the mute flag for now */ | 
					
						
							|  |  |  | 				// TODO: have a pre-pass to check if mute all or unmute all?
 | 
					
						
							|  |  |  | 				strip->flag ^= NLASTRIP_FLAG_MUTED; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* free temp data */ | 
					
						
							|  |  |  | 	BLI_freelistN(&anim_data); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* set notifier that things have changed */ | 
					
						
							| 
									
										
										
										
											2010-06-18 04:39:32 +00:00
										 |  |  | 	WM_event_add_notifier(C, NC_ANIMATION|ND_NLA|NA_EDITED, NULL); | 
					
						
							| 
									
										
										
										
											2009-07-09 01:32:13 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* done */ | 
					
						
							|  |  |  | 	return OPERATOR_FINISHED; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void NLA_OT_mute_toggle (wmOperatorType *ot) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	/* identifiers */ | 
					
						
							|  |  |  | 	ot->name= "Toggle Muting"; | 
					
						
							|  |  |  | 	ot->idname= "NLA_OT_mute_toggle"; | 
					
						
							| 
									
										
										
										
											2011-04-19 10:35:24 +00:00
										 |  |  | 	ot->description= "Mute or un-mute selected strips"; | 
					
						
							| 
									
										
										
										
											2009-07-09 01:32:13 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* api callbacks */ | 
					
						
							|  |  |  | 	ot->exec= nlaedit_toggle_mute_exec; | 
					
						
							|  |  |  | 	ot->poll= nlaop_poll_tweakmode_off; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* flags */ | 
					
						
							|  |  |  | 	ot->flag= OPTYPE_REGISTER|OPTYPE_UNDO; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-01-18 23:38:36 +00:00
										 |  |  | /* ******************** Swap Strips Operator ************************** */ | 
					
						
							|  |  |  | /* Tries to exchange strips within their owner tracks */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int nlaedit_swap_exec (bContext *C, wmOperator *op) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	bAnimContext ac; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	ListBase anim_data = {NULL, NULL}; | 
					
						
							|  |  |  | 	bAnimListElem *ale; | 
					
						
							|  |  |  | 	int filter; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* get editor data */ | 
					
						
							|  |  |  | 	if (ANIM_animdata_get_context(C, &ac) == 0) | 
					
						
							|  |  |  | 		return OPERATOR_CANCELLED; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 	/* get a list of the editable tracks being shown in the NLA */ | 
					
						
							|  |  |  | 	filter= (ANIMFILTER_VISIBLE | ANIMFILTER_NLATRACKS | ANIMFILTER_FOREDIT); | 
					
						
							|  |  |  | 	ANIM_animdata_filter(&ac, &anim_data, filter, ac.data, ac.datatype); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* consider each track in turn */ | 
					
						
							|  |  |  | 	for (ale= anim_data.first; ale; ale= ale->next) { | 
					
						
							|  |  |  | 		NlaTrack *nlt= (NlaTrack *)ale->data; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		NlaStrip *strip, *stripN=NULL; | 
					
						
							|  |  |  | 		NlaStrip *sa=NULL, *sb=NULL; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* make temporary metastrips so that entire islands of selections can be moved around */ | 
					
						
							|  |  |  | 		BKE_nlastrips_make_metas(&nlt->strips, 1); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* special case: if there is only 1 island (i.e. temp meta BUT NOT unselected/normal/normal-meta strips) left after this, 
 | 
					
						
							|  |  |  | 		 * and this island has two strips inside it, then we should be able to just swap these still... | 
					
						
							|  |  |  | 		 */ | 
					
						
							| 
									
										
										
										
											2011-01-20 09:26:36 +00:00
										 |  |  | 		if ((nlt->strips.first == nlt->strips.last) && (nlt->strips.first != NULL)) { | 
					
						
							| 
									
										
										
										
											2011-01-18 23:38:36 +00:00
										 |  |  | 			NlaStrip *mstrip = (NlaStrip *)nlt->strips.first; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			if ((mstrip->flag & NLASTRIP_FLAG_TEMP_META) && (BLI_countlist(&mstrip->strips) == 2))  | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				/* remove this temp meta, so that we can see the strips inside */ | 
					
						
							|  |  |  | 				BKE_nlastrips_clear_metas(&nlt->strips, 0, 1); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* get two selected strips only (these will be metas due to prev step) to operate on
 | 
					
						
							|  |  |  | 		 * 	- only allow swapping 2, as with more the context becomes unclear | 
					
						
							|  |  |  | 		 */ | 
					
						
							|  |  |  | 		for (strip = nlt->strips.first; strip; strip = stripN) { | 
					
						
							|  |  |  | 			stripN = strip->next; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			if (strip->flag & NLASTRIP_FLAG_SELECT) { | 
					
						
							|  |  |  | 				/* first or second strip? */ | 
					
						
							|  |  |  | 				if (sa == NULL) { | 
					
						
							|  |  |  | 					/* store as first */ | 
					
						
							|  |  |  | 					sa = strip; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				else if (sb == NULL) { | 
					
						
							|  |  |  | 					/* store as second */ | 
					
						
							|  |  |  | 					sb = strip; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				else { | 
					
						
							|  |  |  | 					/* too many selected */ | 
					
						
							|  |  |  | 					break; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		if (strip) { | 
					
						
							|  |  |  | 			/* too many selected warning */ | 
					
						
							|  |  |  | 			BKE_reportf(op->reports, RPT_WARNING,  | 
					
						
							|  |  |  | 				"Too many clusters of strips selected in NLA Track (%s). Needs exactly 2 to be selected.", | 
					
						
							|  |  |  | 				nlt->name); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else if (sa == NULL) { | 
					
						
							|  |  |  | 			/* no warning as this is just a common case, and it may get annoying when doing multiple tracks */ | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else if (sb == NULL) { | 
					
						
							|  |  |  | 			/* too few selected warning */ | 
					
						
							|  |  |  | 			BKE_reportf(op->reports, RPT_WARNING, | 
					
						
							|  |  |  | 				"Too few clusters of strips selected in NLA Track (%s). Needs exactly 2 to be selected.", | 
					
						
							|  |  |  | 				nlt->name); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							|  |  |  | 			float nsa[2], nsb[2]; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* remove these strips from the track, so that we can test if they can fit in the proposed places */ | 
					
						
							|  |  |  | 			BLI_remlink(&nlt->strips, sa); | 
					
						
							|  |  |  | 			BLI_remlink(&nlt->strips, sb); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* calculate new extents for strips */ | 
					
						
							|  |  |  | 				/* a --> b */ | 
					
						
							|  |  |  | 			nsa[0] = sb->start; | 
					
						
							|  |  |  | 			nsa[1] = sb->start + (sa->end - sa->start); | 
					
						
							|  |  |  | 				/* b --> a */ | 
					
						
							|  |  |  | 			nsb[0] = sa->start; | 
					
						
							|  |  |  | 			nsb[1] = sa->start + (sb->end - sb->start); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* check if the track has room for the strips to be swapped */ | 
					
						
							|  |  |  | 			if (BKE_nlastrips_has_space(&nlt->strips, nsa[0], nsa[1]) &&  | 
					
						
							|  |  |  | 				BKE_nlastrips_has_space(&nlt->strips, nsb[0], nsb[1])) | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				/* set new extents for strips then */ | 
					
						
							|  |  |  | 				sa->start = nsa[0]; | 
					
						
							|  |  |  | 				sa->end   = nsa[1]; | 
					
						
							|  |  |  | 				BKE_nlameta_flush_transforms(sa); | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 				sb->start = nsb[0]; | 
					
						
							|  |  |  | 				sb->end   = nsb[1]; | 
					
						
							|  |  |  | 				BKE_nlameta_flush_transforms(sb); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							|  |  |  | 				/* not enough room to swap, so show message */ | 
					
						
							|  |  |  | 				if ((sa->flag & NLASTRIP_FLAG_TEMP_META) || (sb->flag & NLASTRIP_FLAG_TEMP_META)) { | 
					
						
							|  |  |  | 					BKE_report(op->reports, RPT_WARNING, | 
					
						
							|  |  |  | 						"Cannot swap selected strips as they will not be able to fit in their new places"); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				else { | 
					
						
							|  |  |  | 					BKE_reportf(op->reports, RPT_WARNING, 	 | 
					
						
							|  |  |  | 						"Cannot swap '%s' and '%s' as one or both will not be able to fit in their new places", | 
					
						
							|  |  |  | 						sa->name, sb->name); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* add strips back to track now */ | 
					
						
							|  |  |  | 			BKE_nlatrack_add_strip(nlt, sa); | 
					
						
							|  |  |  | 			BKE_nlatrack_add_strip(nlt, sb); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* clear (temp) metastrips */ | 
					
						
							|  |  |  | 		BKE_nlastrips_clear_metas(&nlt->strips, 0, 1); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* free temp data */ | 
					
						
							|  |  |  | 	BLI_freelistN(&anim_data); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* refresh auto strip properties */ | 
					
						
							|  |  |  | 	ED_nla_postop_refresh(&ac); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* set notifier that things have changed */ | 
					
						
							|  |  |  | 	WM_event_add_notifier(C, NC_ANIMATION|ND_NLA|NA_EDITED, NULL); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* done */ | 
					
						
							|  |  |  | 	return OPERATOR_FINISHED; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void NLA_OT_swap (wmOperatorType *ot) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	/* identifiers */ | 
					
						
							|  |  |  | 	ot->name= "Swap Strips"; | 
					
						
							|  |  |  | 	ot->idname= "NLA_OT_swap"; | 
					
						
							|  |  |  | 	ot->description= "Swap order of selected strips within tracks"; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* api callbacks */ | 
					
						
							|  |  |  | 	ot->exec= nlaedit_swap_exec; | 
					
						
							|  |  |  | 	ot->poll= nlaop_poll_tweakmode_off; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* flags */ | 
					
						
							|  |  |  | 	ot->flag= OPTYPE_REGISTER|OPTYPE_UNDO; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-27 13:00:22 +00:00
										 |  |  | /* ******************** Move Strips Up Operator ************************** */ | 
					
						
							|  |  |  | /* Tries to move the selected strips into the track above if possible. */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-15 01:36:14 +00:00
										 |  |  | static int nlaedit_move_up_exec (bContext *C, wmOperator *UNUSED(op)) | 
					
						
							| 
									
										
										
										
											2009-06-27 13:00:22 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	bAnimContext ac; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	ListBase anim_data = {NULL, NULL}; | 
					
						
							|  |  |  | 	bAnimListElem *ale; | 
					
						
							|  |  |  | 	int filter; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* get editor data */ | 
					
						
							|  |  |  | 	if (ANIM_animdata_get_context(C, &ac) == 0) | 
					
						
							|  |  |  | 		return OPERATOR_CANCELLED; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 	/* get a list of the editable tracks being shown in the NLA */ | 
					
						
							|  |  |  | 	filter= (ANIMFILTER_VISIBLE | ANIMFILTER_NLATRACKS | ANIMFILTER_FOREDIT); | 
					
						
							|  |  |  | 	ANIM_animdata_filter(&ac, &anim_data, filter, ac.data, ac.datatype); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* since we're potentially moving strips from lower tracks to higher tracks, we should
 | 
					
						
							|  |  |  | 	 * loop over the tracks in reverse order to avoid moving earlier strips up multiple tracks | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	for (ale= anim_data.last; ale; ale= ale->prev) { | 
					
						
							|  |  |  | 		NlaTrack *nlt= (NlaTrack *)ale->data; | 
					
						
							|  |  |  | 		NlaTrack *nltn= nlt->next; | 
					
						
							|  |  |  | 		NlaStrip *strip, *stripn; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* if this track has no tracks after it, skip for now... */ | 
					
						
							|  |  |  | 		if (nltn == NULL) | 
					
						
							|  |  |  | 			continue; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* for every selected strip, try to move */ | 
					
						
							|  |  |  | 		for (strip= nlt->strips.first; strip; strip= stripn) { | 
					
						
							|  |  |  | 			stripn= strip->next; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			if (strip->flag & NLASTRIP_FLAG_SELECT) { | 
					
						
							|  |  |  | 				/* check if the track above has room for this strip */ | 
					
						
							|  |  |  | 				if (BKE_nlatrack_has_space(nltn, strip->start, strip->end)) { | 
					
						
							|  |  |  | 					/* remove from its current track, and add to the one above (it 'should' work, so no need to worry) */ | 
					
						
							|  |  |  | 					BLI_remlink(&nlt->strips, strip); | 
					
						
							|  |  |  | 					BKE_nlatrack_add_strip(nltn, strip); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* free temp data */ | 
					
						
							|  |  |  | 	BLI_freelistN(&anim_data); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-07-24 06:51:33 +00:00
										 |  |  | 	/* refresh auto strip properties */ | 
					
						
							|  |  |  | 	ED_nla_postop_refresh(&ac); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-06-27 13:00:22 +00:00
										 |  |  | 	/* set notifier that things have changed */ | 
					
						
							| 
									
										
										
										
											2010-06-18 04:39:32 +00:00
										 |  |  | 	WM_event_add_notifier(C, NC_ANIMATION|ND_NLA|NA_EDITED, NULL); | 
					
						
							| 
									
										
										
										
											2009-06-27 13:00:22 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* done */ | 
					
						
							|  |  |  | 	return OPERATOR_FINISHED; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-28 03:13:01 +00:00
										 |  |  | void NLA_OT_move_up (wmOperatorType *ot) | 
					
						
							| 
									
										
										
										
											2009-06-27 13:00:22 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	/* identifiers */ | 
					
						
							|  |  |  | 	ot->name= "Move Strips Up"; | 
					
						
							| 
									
										
										
										
											2009-06-28 03:13:01 +00:00
										 |  |  | 	ot->idname= "NLA_OT_move_up"; | 
					
						
							| 
									
										
										
										
											2010-02-10 21:15:44 +00:00
										 |  |  | 	ot->description= "Move selected strips up a track if there's room"; | 
					
						
							| 
									
										
										
										
											2009-06-27 13:00:22 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* api callbacks */ | 
					
						
							|  |  |  | 	ot->exec= nlaedit_move_up_exec; | 
					
						
							|  |  |  | 	ot->poll= nlaop_poll_tweakmode_off; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* flags */ | 
					
						
							|  |  |  | 	ot->flag= OPTYPE_REGISTER|OPTYPE_UNDO; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ******************** Move Strips Down Operator ************************** */ | 
					
						
							|  |  |  | /* Tries to move the selected strips into the track above if possible. */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-15 01:36:14 +00:00
										 |  |  | static int nlaedit_move_down_exec (bContext *C, wmOperator *UNUSED(op)) | 
					
						
							| 
									
										
										
										
											2009-06-27 13:00:22 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	bAnimContext ac; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	ListBase anim_data = {NULL, NULL}; | 
					
						
							|  |  |  | 	bAnimListElem *ale; | 
					
						
							|  |  |  | 	int filter; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* get editor data */ | 
					
						
							|  |  |  | 	if (ANIM_animdata_get_context(C, &ac) == 0) | 
					
						
							|  |  |  | 		return OPERATOR_CANCELLED; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 	/* get a list of the editable tracks being shown in the NLA */ | 
					
						
							|  |  |  | 	filter= (ANIMFILTER_VISIBLE | ANIMFILTER_NLATRACKS | ANIMFILTER_FOREDIT); | 
					
						
							|  |  |  | 	ANIM_animdata_filter(&ac, &anim_data, filter, ac.data, ac.datatype); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* loop through the tracks in normal order, since we're pushing strips down,
 | 
					
						
							|  |  |  | 	 * strips won't get operated on twice | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	for (ale= anim_data.first; ale; ale= ale->next) { | 
					
						
							|  |  |  | 		NlaTrack *nlt= (NlaTrack *)ale->data; | 
					
						
							|  |  |  | 		NlaTrack *nltp= nlt->prev; | 
					
						
							|  |  |  | 		NlaStrip *strip, *stripn; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* if this track has no tracks before it, skip for now... */ | 
					
						
							|  |  |  | 		if (nltp == NULL) | 
					
						
							|  |  |  | 			continue; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* for every selected strip, try to move */ | 
					
						
							|  |  |  | 		for (strip= nlt->strips.first; strip; strip= stripn) { | 
					
						
							|  |  |  | 			stripn= strip->next; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			if (strip->flag & NLASTRIP_FLAG_SELECT) { | 
					
						
							|  |  |  | 				/* check if the track below has room for this strip */ | 
					
						
							|  |  |  | 				if (BKE_nlatrack_has_space(nltp, strip->start, strip->end)) { | 
					
						
							|  |  |  | 					/* remove from its current track, and add to the one above (it 'should' work, so no need to worry) */ | 
					
						
							|  |  |  | 					BLI_remlink(&nlt->strips, strip); | 
					
						
							|  |  |  | 					BKE_nlatrack_add_strip(nltp, strip); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* free temp data */ | 
					
						
							|  |  |  | 	BLI_freelistN(&anim_data); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-07-24 06:51:33 +00:00
										 |  |  | 	/* refresh auto strip properties */ | 
					
						
							|  |  |  | 	ED_nla_postop_refresh(&ac); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-06-27 13:00:22 +00:00
										 |  |  | 	/* set notifier that things have changed */ | 
					
						
							| 
									
										
										
										
											2010-06-18 04:39:32 +00:00
										 |  |  | 	WM_event_add_notifier(C, NC_ANIMATION|ND_NLA|NA_EDITED, NULL); | 
					
						
							| 
									
										
										
										
											2009-06-27 13:00:22 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* done */ | 
					
						
							|  |  |  | 	return OPERATOR_FINISHED; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-28 03:13:01 +00:00
										 |  |  | void NLA_OT_move_down (wmOperatorType *ot) | 
					
						
							| 
									
										
										
										
											2009-06-27 13:00:22 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	/* identifiers */ | 
					
						
							|  |  |  | 	ot->name= "Move Strips Down"; | 
					
						
							| 
									
										
										
										
											2009-06-28 03:13:01 +00:00
										 |  |  | 	ot->idname= "NLA_OT_move_down"; | 
					
						
							| 
									
										
										
										
											2010-02-10 21:15:44 +00:00
										 |  |  | 	ot->description= "Move selected strips down a track if there's room"; | 
					
						
							| 
									
										
										
										
											2009-06-27 13:00:22 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* api callbacks */ | 
					
						
							|  |  |  | 	ot->exec= nlaedit_move_down_exec; | 
					
						
							|  |  |  | 	ot->poll= nlaop_poll_tweakmode_off; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* flags */ | 
					
						
							|  |  |  | 	ot->flag= OPTYPE_REGISTER|OPTYPE_UNDO; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-24 06:28:53 +00:00
										 |  |  | /* ******************** Sync Action Length Operator ***************************** */ | 
					
						
							|  |  |  | /* Recalculate the extents of the action ranges used for the selected strips  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int nlaedit_sync_actlen_exec (bContext *C, wmOperator *op) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	bAnimContext ac; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	ListBase anim_data = {NULL, NULL}; | 
					
						
							|  |  |  | 	bAnimListElem *ale; | 
					
						
							|  |  |  | 	int filter; | 
					
						
							|  |  |  | 	short active_only= RNA_boolean_get(op->ptr, "active"); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* get editor data */ | 
					
						
							|  |  |  | 	if (ANIM_animdata_get_context(C, &ac) == 0) | 
					
						
							|  |  |  | 		return OPERATOR_CANCELLED; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 	/* get a list of the editable tracks being shown in the NLA */ | 
					
						
							|  |  |  | 	filter= (ANIMFILTER_VISIBLE | ANIMFILTER_NLATRACKS | ANIMFILTER_FOREDIT); | 
					
						
							|  |  |  | 	if (active_only) filter |= ANIMFILTER_ACTIVE; | 
					
						
							|  |  |  | 	ANIM_animdata_filter(&ac, &anim_data, filter, ac.data, ac.datatype); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* for each NLA-Track, apply scale of all selected strips */ | 
					
						
							|  |  |  | 	for (ale= anim_data.first; ale; ale= ale->next) { | 
					
						
							|  |  |  | 		NlaTrack *nlt= (NlaTrack *)ale->data; | 
					
						
							|  |  |  | 		NlaStrip *strip; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		for (strip= nlt->strips.first; strip; strip= strip->next) { | 
					
						
							|  |  |  | 			/* strip selection/active status check */ | 
					
						
							|  |  |  | 			if (active_only) { | 
					
						
							|  |  |  | 				if ((strip->flag & NLASTRIP_FLAG_ACTIVE) == 0) | 
					
						
							|  |  |  | 					continue; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							|  |  |  | 				if ((strip->flag & NLASTRIP_FLAG_SELECT) == 0) | 
					
						
							|  |  |  | 					continue; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* must be action-clip only (transitions don't have scale) */ | 
					
						
							|  |  |  | 			if (strip->type == NLASTRIP_TYPE_CLIP) { | 
					
						
							|  |  |  | 				if (strip->act == NULL)  | 
					
						
							|  |  |  | 					continue; | 
					
						
							|  |  |  | 					 | 
					
						
							|  |  |  | 				/* recalculate the length of the action */ | 
					
						
							|  |  |  | 				calc_action_range(strip->act, &strip->actstart, &strip->actend, 0); | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 				/* adjust the strip extents in response to this */ | 
					
						
							|  |  |  | 				BKE_nlastrip_recalculate_bounds(strip); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* free temp data */ | 
					
						
							|  |  |  | 	BLI_freelistN(&anim_data); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* set notifier that things have changed */ | 
					
						
							| 
									
										
										
										
											2010-06-18 04:39:32 +00:00
										 |  |  | 	WM_event_add_notifier(C, NC_ANIMATION|ND_NLA|NA_EDITED, NULL); | 
					
						
							| 
									
										
										
										
											2010-01-24 06:28:53 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* done */ | 
					
						
							|  |  |  | 	return OPERATOR_FINISHED; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void NLA_OT_action_sync_length (wmOperatorType *ot) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	/* identifiers */ | 
					
						
							|  |  |  | 	ot->name= "Sync Action Length"; | 
					
						
							|  |  |  | 	ot->idname= "NLA_OT_action_sync_length"; | 
					
						
							| 
									
										
										
										
											2011-04-19 10:35:24 +00:00
										 |  |  | 	ot->description= "Synchronise the length of the referenced Action with the lengths used in the strip"; | 
					
						
							| 
									
										
										
										
											2010-01-24 06:28:53 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* api callbacks */ | 
					
						
							|  |  |  | 	ot->exec= nlaedit_sync_actlen_exec; | 
					
						
							|  |  |  | 	ot->poll= ED_operator_nla_active; // XXX: is this satisfactory... probably requires a check for active strip...
 | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* flags */ | 
					
						
							|  |  |  | 	ot->flag= OPTYPE_REGISTER|OPTYPE_UNDO; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* properties */ | 
					
						
							|  |  |  | 	ot->prop= RNA_def_boolean(ot->srna, "active", 1, "Active Strip Only", "Only sync the active length for the active strip."); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-24 12:50:20 +00:00
										 |  |  | /* ******************** Apply Scale Operator ***************************** */ | 
					
						
							|  |  |  | /* Reset the scaling of the selected strips to 1.0f */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* apply scaling to keyframe */ | 
					
						
							| 
									
										
										
										
											2010-04-02 12:02:39 +00:00
										 |  |  | static short bezt_apply_nlamapping (KeyframeEditData *ked, BezTriple *bezt) | 
					
						
							| 
									
										
										
										
											2009-06-24 12:50:20 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2010-04-02 12:02:39 +00:00
										 |  |  | 	/* NLA-strip which has this scaling is stored in ked->data */ | 
					
						
							|  |  |  | 	NlaStrip *strip= (NlaStrip *)ked->data; | 
					
						
							| 
									
										
										
										
											2009-06-24 12:50:20 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* adjust all the times */ | 
					
						
							| 
									
										
										
										
											2009-06-28 07:32:00 +00:00
										 |  |  | 	bezt->vec[0][0]= nlastrip_get_frame(strip, bezt->vec[0][0], NLATIME_CONVERT_MAP); | 
					
						
							|  |  |  | 	bezt->vec[1][0]= nlastrip_get_frame(strip, bezt->vec[1][0], NLATIME_CONVERT_MAP); | 
					
						
							|  |  |  | 	bezt->vec[2][0]= nlastrip_get_frame(strip, bezt->vec[2][0], NLATIME_CONVERT_MAP); | 
					
						
							| 
									
										
										
										
											2009-06-24 12:50:20 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* nothing to return or else we exit */ | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-15 01:36:14 +00:00
										 |  |  | static int nlaedit_apply_scale_exec (bContext *C, wmOperator *UNUSED(op)) | 
					
						
							| 
									
										
										
										
											2009-06-24 12:50:20 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	bAnimContext ac; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	ListBase anim_data = {NULL, NULL}; | 
					
						
							|  |  |  | 	bAnimListElem *ale; | 
					
						
							|  |  |  | 	int filter; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2011-03-05 10:29:10 +00:00
										 |  |  | 	KeyframeEditData ked= {{NULL}}; | 
					
						
							| 
									
										
										
										
											2009-06-24 12:50:20 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* get editor data */ | 
					
						
							|  |  |  | 	if (ANIM_animdata_get_context(C, &ac) == 0) | 
					
						
							|  |  |  | 		return OPERATOR_CANCELLED; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 	/* get a list of the editable tracks being shown in the NLA */ | 
					
						
							|  |  |  | 	filter= (ANIMFILTER_VISIBLE | ANIMFILTER_NLATRACKS | ANIMFILTER_FOREDIT); | 
					
						
							|  |  |  | 	ANIM_animdata_filter(&ac, &anim_data, filter, ac.data, ac.datatype); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* init the editing data */ | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* for each NLA-Track, apply scale of all selected strips */ | 
					
						
							|  |  |  | 	for (ale= anim_data.first; ale; ale= ale->next) { | 
					
						
							|  |  |  | 		NlaTrack *nlt= (NlaTrack *)ale->data; | 
					
						
							|  |  |  | 		NlaStrip *strip; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		for (strip= nlt->strips.first; strip; strip= strip->next) { | 
					
						
							|  |  |  | 			/* strip must be selected, and must be action-clip only (transitions don't have scale) */ | 
					
						
							|  |  |  | 			if ((strip->flag & NLASTRIP_FLAG_SELECT) && (strip->type == NLASTRIP_TYPE_CLIP)) { | 
					
						
							|  |  |  | 				/* if the referenced action is used by other strips, make this strip use its own copy */ | 
					
						
							|  |  |  | 				if (strip->act == NULL)  | 
					
						
							|  |  |  | 					continue; | 
					
						
							|  |  |  | 				if (strip->act->id.us > 1) { | 
					
						
							|  |  |  | 					/* make a copy of the Action to work on */ | 
					
						
							|  |  |  | 					bAction *act= copy_action(strip->act); | 
					
						
							|  |  |  | 					 | 
					
						
							|  |  |  | 					/* set this as the new referenced action, decrementing the users of the old one */ | 
					
						
							|  |  |  | 					strip->act->id.us--; | 
					
						
							|  |  |  | 					strip->act= act; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 				/* setup iterator, and iterate over all the keyframes in the action, applying this scaling */ | 
					
						
							| 
									
										
										
										
											2010-04-02 12:02:39 +00:00
										 |  |  | 				ked.data= strip; | 
					
						
							|  |  |  | 				ANIM_animchanneldata_keyframes_loop(&ked, strip->act, ALE_ACT, NULL, bezt_apply_nlamapping, calchandles_fcurve, 0); | 
					
						
							| 
									
										
										
										
											2009-06-24 12:50:20 +00:00
										 |  |  | 				 | 
					
						
							| 
									
										
										
										
											2009-06-27 04:56:20 +00:00
										 |  |  | 				/* clear scale of strip now that it has been applied,
 | 
					
						
							|  |  |  | 				 * and recalculate the extents of the action now that it has been scaled | 
					
						
							|  |  |  | 				 * but leave everything else alone  | 
					
						
							|  |  |  | 				 */ | 
					
						
							| 
									
										
										
										
											2009-06-24 12:50:20 +00:00
										 |  |  | 				strip->scale= 1.0f; | 
					
						
							| 
									
										
										
										
											2009-08-25 01:46:05 +00:00
										 |  |  | 				calc_action_range(strip->act, &strip->actstart, &strip->actend, 0); | 
					
						
							| 
									
										
										
										
											2009-06-24 12:50:20 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* free temp data */ | 
					
						
							|  |  |  | 	BLI_freelistN(&anim_data); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* set notifier that things have changed */ | 
					
						
							| 
									
										
										
										
											2010-06-18 04:39:32 +00:00
										 |  |  | 	WM_event_add_notifier(C, NC_ANIMATION|ND_NLA|NA_EDITED, NULL); | 
					
						
							| 
									
										
										
										
											2009-06-24 12:50:20 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* done */ | 
					
						
							|  |  |  | 	return OPERATOR_FINISHED; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-28 03:13:01 +00:00
										 |  |  | void NLA_OT_apply_scale (wmOperatorType *ot) | 
					
						
							| 
									
										
										
										
											2009-06-24 12:50:20 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	/* identifiers */ | 
					
						
							|  |  |  | 	ot->name= "Apply Scale"; | 
					
						
							| 
									
										
										
										
											2009-06-28 03:13:01 +00:00
										 |  |  | 	ot->idname= "NLA_OT_apply_scale"; | 
					
						
							| 
									
										
										
										
											2010-02-10 21:15:44 +00:00
										 |  |  | 	ot->description= "Apply scaling of selected strips to their referenced Actions"; | 
					
						
							| 
									
										
										
										
											2009-06-24 12:50:20 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* api callbacks */ | 
					
						
							|  |  |  | 	ot->exec= nlaedit_apply_scale_exec; | 
					
						
							|  |  |  | 	ot->poll= nlaop_poll_tweakmode_off; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* flags */ | 
					
						
							|  |  |  | 	ot->flag= OPTYPE_REGISTER|OPTYPE_UNDO; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ******************** Clear Scale Operator ***************************** */ | 
					
						
							|  |  |  | /* Reset the scaling of the selected strips to 1.0f */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-15 01:36:14 +00:00
										 |  |  | static int nlaedit_clear_scale_exec (bContext *C, wmOperator *UNUSED(op)) | 
					
						
							| 
									
										
										
										
											2009-06-24 12:50:20 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	bAnimContext ac; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	ListBase anim_data = {NULL, NULL}; | 
					
						
							|  |  |  | 	bAnimListElem *ale; | 
					
						
							|  |  |  | 	int filter; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* get editor data */ | 
					
						
							|  |  |  | 	if (ANIM_animdata_get_context(C, &ac) == 0) | 
					
						
							|  |  |  | 		return OPERATOR_CANCELLED; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 	/* get a list of the editable tracks being shown in the NLA */ | 
					
						
							|  |  |  | 	filter= (ANIMFILTER_VISIBLE | ANIMFILTER_NLATRACKS | ANIMFILTER_FOREDIT); | 
					
						
							|  |  |  | 	ANIM_animdata_filter(&ac, &anim_data, filter, ac.data, ac.datatype); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* for each NLA-Track, reset scale of all selected strips */ | 
					
						
							|  |  |  | 	for (ale= anim_data.first; ale; ale= ale->next) { | 
					
						
							|  |  |  | 		NlaTrack *nlt= (NlaTrack *)ale->data; | 
					
						
							|  |  |  | 		NlaStrip *strip; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		for (strip= nlt->strips.first; strip; strip= strip->next) { | 
					
						
							|  |  |  | 			/* strip must be selected, and must be action-clip only (transitions don't have scale) */ | 
					
						
							|  |  |  | 			if ((strip->flag & NLASTRIP_FLAG_SELECT) && (strip->type == NLASTRIP_TYPE_CLIP)) { | 
					
						
							|  |  |  | 				PointerRNA strip_ptr; | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 				RNA_pointer_create(NULL, &RNA_NlaStrip, strip, &strip_ptr); | 
					
						
							|  |  |  | 				RNA_float_set(&strip_ptr, "scale", 1.0f); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* free temp data */ | 
					
						
							|  |  |  | 	BLI_freelistN(&anim_data); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-07-24 06:51:33 +00:00
										 |  |  | 	/* refresh auto strip properties */ | 
					
						
							|  |  |  | 	ED_nla_postop_refresh(&ac); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-06-24 12:50:20 +00:00
										 |  |  | 	/* set notifier that things have changed */ | 
					
						
							| 
									
										
										
										
											2010-06-18 04:39:32 +00:00
										 |  |  | 	WM_event_add_notifier(C, NC_ANIMATION|ND_NLA|NA_EDITED, NULL); | 
					
						
							| 
									
										
										
										
											2009-06-24 12:50:20 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* done */ | 
					
						
							|  |  |  | 	return OPERATOR_FINISHED; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-28 03:13:01 +00:00
										 |  |  | void NLA_OT_clear_scale (wmOperatorType *ot) | 
					
						
							| 
									
										
										
										
											2009-06-24 12:50:20 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	/* identifiers */ | 
					
						
							|  |  |  | 	ot->name= "Clear Scale"; | 
					
						
							| 
									
										
										
										
											2009-06-28 03:13:01 +00:00
										 |  |  | 	ot->idname= "NLA_OT_clear_scale"; | 
					
						
							| 
									
										
										
										
											2010-02-10 21:15:44 +00:00
										 |  |  | 	ot->description= "Reset scaling of selected strips"; | 
					
						
							| 
									
										
										
										
											2009-06-24 12:50:20 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* api callbacks */ | 
					
						
							|  |  |  | 	ot->exec= nlaedit_clear_scale_exec; | 
					
						
							|  |  |  | 	ot->poll= nlaop_poll_tweakmode_off; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* flags */ | 
					
						
							|  |  |  | 	ot->flag= OPTYPE_REGISTER|OPTYPE_UNDO; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-06 03:44:44 +00:00
										 |  |  | /* ******************** Snap Strips Operator ************************** */ | 
					
						
							|  |  |  | /* Moves the start-point of the selected strips to the specified places */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* defines for snap keyframes tool */ | 
					
						
							| 
									
										
										
										
											2011-02-14 17:55:27 +00:00
										 |  |  | static EnumPropertyItem prop_nlaedit_snap_types[] = { | 
					
						
							| 
									
										
										
										
											2009-07-06 03:44:44 +00:00
										 |  |  | 	{NLAEDIT_SNAP_CFRA, "CFRA", 0, "Current frame", ""}, | 
					
						
							|  |  |  | 	{NLAEDIT_SNAP_NEAREST_FRAME, "NEAREST_FRAME", 0, "Nearest Frame", ""}, // XXX as single entry?
 | 
					
						
							|  |  |  | 	{NLAEDIT_SNAP_NEAREST_SECOND, "NEAREST_SECOND", 0, "Nearest Second", ""}, // XXX as single entry?
 | 
					
						
							|  |  |  | 	{NLAEDIT_SNAP_NEAREST_MARKER, "NEAREST_MARKER", 0, "Nearest Marker", ""}, | 
					
						
							|  |  |  | 	{0, NULL, 0, NULL, NULL} | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int nlaedit_snap_exec (bContext *C, wmOperator *op) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	bAnimContext ac; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	ListBase anim_data = {NULL, NULL}; | 
					
						
							|  |  |  | 	bAnimListElem *ale; | 
					
						
							|  |  |  | 	int filter; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-07-06 11:06:34 +00:00
										 |  |  | 	Scene *scene; | 
					
						
							| 
									
										
										
										
											2009-07-06 03:44:44 +00:00
										 |  |  | 	int mode = RNA_enum_get(op->ptr, "type"); | 
					
						
							| 
									
										
										
										
											2009-07-06 11:06:34 +00:00
										 |  |  | 	float secf; | 
					
						
							| 
									
										
										
										
											2009-07-06 03:44:44 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* get editor data */ | 
					
						
							|  |  |  | 	if (ANIM_animdata_get_context(C, &ac) == 0) | 
					
						
							|  |  |  | 		return OPERATOR_CANCELLED; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 	/* get a list of the editable tracks being shown in the NLA */ | 
					
						
							|  |  |  | 	filter= (ANIMFILTER_VISIBLE | ANIMFILTER_NLATRACKS | ANIMFILTER_FOREDIT); | 
					
						
							|  |  |  | 	ANIM_animdata_filter(&ac, &anim_data, filter, ac.data, ac.datatype); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-07-06 11:06:34 +00:00
										 |  |  | 	/* get some necessary vars */ | 
					
						
							|  |  |  | 	scene= ac.scene; | 
					
						
							|  |  |  | 	secf= (float)FPS; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-07-06 03:44:44 +00:00
										 |  |  | 	/* since we may add tracks, perform this in reverse order */ | 
					
						
							|  |  |  | 	for (ale= anim_data.last; ale; ale= ale->prev) { | 
					
						
							|  |  |  | 		ListBase tmp_strips = {NULL, NULL}; | 
					
						
							| 
									
										
										
										
											2009-07-28 06:50:30 +00:00
										 |  |  | 		AnimData *adt= ale->adt; | 
					
						
							| 
									
										
										
										
											2009-07-06 03:44:44 +00:00
										 |  |  | 		NlaTrack *nlt= (NlaTrack *)ale->data; | 
					
						
							|  |  |  | 		NlaStrip *strip, *stripn; | 
					
						
							| 
									
										
										
										
											2009-07-06 11:06:34 +00:00
										 |  |  | 		NlaTrack *track; | 
					
						
							| 
									
										
										
										
											2009-07-06 03:44:44 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2009-07-06 11:06:34 +00:00
										 |  |  | 		/* create meta-strips from the continuous chains of selected strips */ | 
					
						
							|  |  |  | 		BKE_nlastrips_make_metas(&nlt->strips, 1); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* apply the snapping to all the temp meta-strips, then put them in a separate list to be added
 | 
					
						
							|  |  |  | 		 * back to the original only if they still fit | 
					
						
							|  |  |  | 		 */ | 
					
						
							| 
									
										
										
										
											2009-07-06 03:44:44 +00:00
										 |  |  | 		for (strip= nlt->strips.first; strip; strip= stripn) { | 
					
						
							|  |  |  | 			stripn= strip->next; | 
					
						
							|  |  |  | 			 | 
					
						
							| 
									
										
										
										
											2009-07-06 11:06:34 +00:00
										 |  |  | 			if (strip->flag & NLASTRIP_FLAG_TEMP_META) { | 
					
						
							| 
									
										
										
										
											2009-07-06 03:44:44 +00:00
										 |  |  | 				float start, end; | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 				/* get the existing end-points */ | 
					
						
							|  |  |  | 				start= strip->start; | 
					
						
							|  |  |  | 				end= strip->end; | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 				/* calculate new start position based on snapping mode */ | 
					
						
							|  |  |  | 				switch (mode) { | 
					
						
							|  |  |  | 					case NLAEDIT_SNAP_CFRA: /* to current frame */ | 
					
						
							|  |  |  | 						strip->start= (float)CFRA; | 
					
						
							|  |  |  | 						break; | 
					
						
							|  |  |  | 					case NLAEDIT_SNAP_NEAREST_FRAME: /* to nearest frame */ | 
					
						
							|  |  |  | 						strip->start= (float)(floor(start+0.5)); | 
					
						
							|  |  |  | 						break; | 
					
						
							|  |  |  | 					case NLAEDIT_SNAP_NEAREST_SECOND: /* to nearest second */ | 
					
						
							|  |  |  | 						strip->start= ((float)floor(start/secf + 0.5f) * secf); | 
					
						
							|  |  |  | 						break; | 
					
						
							|  |  |  | 					case NLAEDIT_SNAP_NEAREST_MARKER: /* to nearest marker */ | 
					
						
							|  |  |  | 						strip->start= (float)ED_markers_find_nearest_marker_time(ac.markers, start); | 
					
						
							|  |  |  | 						break; | 
					
						
							|  |  |  | 					default: /* just in case... no snapping */ | 
					
						
							|  |  |  | 						strip->start= start; | 
					
						
							|  |  |  | 						break; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 				/* get new endpoint based on start-point (and old length) */ | 
					
						
							|  |  |  | 				strip->end= strip->start + (end - start); | 
					
						
							|  |  |  | 				 | 
					
						
							| 
									
										
										
										
											2009-07-06 11:06:34 +00:00
										 |  |  | 				/* apply transforms to meta-strip to its children */ | 
					
						
							|  |  |  | 				BKE_nlameta_flush_transforms(strip); | 
					
						
							|  |  |  | 				 | 
					
						
							| 
									
										
										
										
											2009-07-06 03:44:44 +00:00
										 |  |  | 				/* remove strip from track, and add to the temp buffer */ | 
					
						
							|  |  |  | 				BLI_remlink(&nlt->strips, strip); | 
					
						
							|  |  |  | 				BLI_addtail(&tmp_strips, strip); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2009-07-06 11:06:34 +00:00
										 |  |  | 		/* try adding each meta-strip back to the track one at a time, to make sure they'll fit */ | 
					
						
							|  |  |  | 		for (strip= tmp_strips.first; strip; strip= stripn) { | 
					
						
							|  |  |  | 			stripn= strip->next; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* remove from temp-strips list */ | 
					
						
							|  |  |  | 			BLI_remlink(&tmp_strips, strip); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* in case there's no space in the current track, try adding */ | 
					
						
							|  |  |  | 			if (BKE_nlatrack_add_strip(nlt, strip) == 0) { | 
					
						
							|  |  |  | 				/* need to add a new track above the current one */ | 
					
						
							|  |  |  | 				track= add_nlatrack(adt, nlt); | 
					
						
							|  |  |  | 				BKE_nlatrack_add_strip(track, strip); | 
					
						
							| 
									
										
										
										
											2009-07-07 02:12:50 +00:00
										 |  |  | 				 | 
					
						
							|  |  |  | 				/* clear temp meta-strips on this new track, as we may not be able to get back to it */ | 
					
						
							|  |  |  | 				BKE_nlastrips_clear_metas(&track->strips, 0, 1); | 
					
						
							| 
									
										
										
										
											2009-07-06 11:06:34 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* remove the meta-strips now that we're done */ | 
					
						
							|  |  |  | 		BKE_nlastrips_clear_metas(&nlt->strips, 0, 1); | 
					
						
							| 
									
										
										
										
											2009-07-06 03:44:44 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* free temp data */ | 
					
						
							|  |  |  | 	BLI_freelistN(&anim_data); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-07-24 06:51:33 +00:00
										 |  |  | 	/* refresh auto strip properties */ | 
					
						
							|  |  |  | 	ED_nla_postop_refresh(&ac); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-07-06 03:44:44 +00:00
										 |  |  | 	/* set notifier that things have changed */ | 
					
						
							| 
									
										
										
										
											2010-06-18 04:39:32 +00:00
										 |  |  | 	WM_event_add_notifier(C, NC_ANIMATION|ND_NLA|NA_EDITED, NULL); | 
					
						
							| 
									
										
										
										
											2009-07-06 03:44:44 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* done */ | 
					
						
							|  |  |  | 	return OPERATOR_FINISHED; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void NLA_OT_snap (wmOperatorType *ot) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	/* identifiers */ | 
					
						
							|  |  |  | 	ot->name= "Snap Strips"; | 
					
						
							|  |  |  | 	ot->idname= "NLA_OT_snap"; | 
					
						
							| 
									
										
										
										
											2010-02-10 21:15:44 +00:00
										 |  |  | 	ot->description= "Move start of strips to specified time"; | 
					
						
							| 
									
										
										
										
											2009-07-06 03:44:44 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* api callbacks */ | 
					
						
							|  |  |  | 	ot->invoke= WM_menu_invoke; | 
					
						
							|  |  |  | 	ot->exec= nlaedit_snap_exec; | 
					
						
							|  |  |  | 	ot->poll= nlaop_poll_tweakmode_off; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* flags */ | 
					
						
							|  |  |  | 	ot->flag= OPTYPE_REGISTER|OPTYPE_UNDO; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* properties */ | 
					
						
							| 
									
										
										
										
											2010-01-15 22:40:33 +00:00
										 |  |  | 	ot->prop= RNA_def_enum(ot->srna, "type", prop_nlaedit_snap_types, 0, "Type", ""); | 
					
						
							| 
									
										
										
										
											2009-07-06 03:44:44 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-24 12:50:20 +00:00
										 |  |  | /* *********************************************** */ | 
					
						
							| 
									
										
										
										
											2009-07-02 06:41:10 +00:00
										 |  |  | /* NLA Modifiers */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ******************** Add F-Modifier Operator *********************** */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-03 01:10:46 +00:00
										 |  |  | /* present a special customised popup menu for this, with some filtering */ | 
					
						
							| 
									
										
										
										
											2010-10-15 01:36:14 +00:00
										 |  |  | static int nla_fmodifier_add_invoke (bContext *C, wmOperator *UNUSED(op), wmEvent *UNUSED(event)) | 
					
						
							| 
									
										
										
										
											2009-07-03 01:10:46 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	uiPopupMenu *pup; | 
					
						
							|  |  |  | 	uiLayout *layout; | 
					
						
							|  |  |  | 	int i; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2011-02-27 18:03:19 +00:00
										 |  |  | 	pup= uiPupMenuBegin(C, "Add F-Modifier", ICON_NONE); | 
					
						
							| 
									
										
										
										
											2009-07-03 01:10:46 +00:00
										 |  |  | 	layout= uiPupMenuLayout(pup); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* start from 1 to skip the 'Invalid' modifier type */ | 
					
						
							|  |  |  | 	for (i = 1; i < FMODIFIER_NUM_TYPES; i++) { | 
					
						
							|  |  |  | 		FModifierTypeInfo *fmi= get_fmodifier_typeinfo(i); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* check if modifier is valid for this context */ | 
					
						
							|  |  |  | 		if (fmi == NULL) | 
					
						
							|  |  |  | 			continue; | 
					
						
							|  |  |  | 		if (i == FMODIFIER_TYPE_CYCLES) /* we already have repeat... */ | 
					
						
							|  |  |  | 			continue; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* add entry to add this type of modifier */ | 
					
						
							| 
									
										
										
										
											2010-03-23 15:25:33 +00:00
										 |  |  | 		uiItemEnumO(layout, "NLA_OT_fmodifier_add", fmi->name, 0, "type", i); | 
					
						
							| 
									
										
										
										
											2009-07-03 01:10:46 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	uiItemS(layout); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	uiPupMenuEnd(C, pup); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	return OPERATOR_CANCELLED; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-02 06:41:10 +00:00
										 |  |  | static int nla_fmodifier_add_exec(bContext *C, wmOperator *op) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	bAnimContext ac; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	ListBase anim_data = {NULL, NULL}; | 
					
						
							|  |  |  | 	bAnimListElem *ale; | 
					
						
							|  |  |  | 	int filter; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	FModifier *fcm; | 
					
						
							|  |  |  | 	int type= RNA_enum_get(op->ptr, "type"); | 
					
						
							|  |  |  | 	short onlyActive = RNA_boolean_get(op->ptr, "only_active"); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* get editor data */ | 
					
						
							|  |  |  | 	if (ANIM_animdata_get_context(C, &ac) == 0) | 
					
						
							|  |  |  | 		return OPERATOR_CANCELLED; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 	/* get a list of the editable tracks being shown in the NLA */ | 
					
						
							|  |  |  | 	filter= (ANIMFILTER_VISIBLE | ANIMFILTER_NLATRACKS | ANIMFILTER_FOREDIT); | 
					
						
							|  |  |  | 	ANIM_animdata_filter(&ac, &anim_data, filter, ac.data, ac.datatype); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* for each NLA-Track, add the specified modifier to all selected strips */ | 
					
						
							|  |  |  | 	for (ale= anim_data.first; ale; ale= ale->next) { | 
					
						
							|  |  |  | 		NlaTrack *nlt= (NlaTrack *)ale->data; | 
					
						
							|  |  |  | 		NlaStrip *strip; | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2010-04-03 11:19:17 +00:00
										 |  |  | 		for (strip= nlt->strips.first; strip; strip=strip->next) { | 
					
						
							|  |  |  | 			/* can F-Modifier be added to the current strip? */ | 
					
						
							|  |  |  | 			if (onlyActive) { | 
					
						
							|  |  |  | 				/* if not active, cannot add since we're only adding to active strip */ | 
					
						
							|  |  |  | 				if ((strip->flag & NLASTRIP_FLAG_ACTIVE)==0) | 
					
						
							|  |  |  | 					continue; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							|  |  |  | 				/* strip must be selected, since we're not just doing active */ | 
					
						
							|  |  |  | 				if ((strip->flag & NLASTRIP_FLAG_SELECT)==0) | 
					
						
							|  |  |  | 					continue; | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2009-07-02 06:41:10 +00:00
										 |  |  | 			 | 
					
						
							|  |  |  | 			/* add F-Modifier of specified type to selected, and make it the active one */ | 
					
						
							|  |  |  | 			fcm= add_fmodifier(&strip->modifiers, type); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			if (fcm) | 
					
						
							|  |  |  | 				set_active_fmodifier(&strip->modifiers, fcm); | 
					
						
							|  |  |  | 			else { | 
					
						
							| 
									
										
										
										
											2010-04-03 11:19:17 +00:00
										 |  |  | 				BKE_reportf(op->reports, RPT_ERROR, | 
					
						
							|  |  |  | 					"Modifier couldn't be added to (%s : %s). See console for details.",  | 
					
						
							|  |  |  | 					nlt->name, strip->name); | 
					
						
							| 
									
										
										
										
											2009-07-02 06:41:10 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* free temp data */ | 
					
						
							|  |  |  | 	BLI_freelistN(&anim_data); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* set notifier that things have changed */ | 
					
						
							| 
									
										
										
										
											2010-06-18 04:39:32 +00:00
										 |  |  | 	WM_event_add_notifier(C, NC_ANIMATION|ND_NLA|NA_EDITED, NULL); | 
					
						
							| 
									
										
										
										
											2009-07-02 06:41:10 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* done */ | 
					
						
							|  |  |  | 	return OPERATOR_FINISHED; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | void NLA_OT_fmodifier_add (wmOperatorType *ot) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	/* identifiers */ | 
					
						
							|  |  |  | 	ot->name= "Add F-Modifier"; | 
					
						
							|  |  |  | 	ot->idname= "NLA_OT_fmodifier_add"; | 
					
						
							| 
									
										
										
										
											2011-04-19 10:35:24 +00:00
										 |  |  | 	ot->description= "Add F-Modifier of the specified type to the selected NLA-Strips"; | 
					
						
							| 
									
										
										
										
											2009-07-02 06:41:10 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* api callbacks */ | 
					
						
							| 
									
										
										
										
											2009-07-03 01:10:46 +00:00
										 |  |  | 	ot->invoke= nla_fmodifier_add_invoke; | 
					
						
							| 
									
										
										
										
											2009-07-02 06:41:10 +00:00
										 |  |  | 	ot->exec= nla_fmodifier_add_exec; | 
					
						
							|  |  |  | 	ot->poll= nlaop_poll_tweakmode_off;  | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* flags */ | 
					
						
							|  |  |  | 	ot->flag= OPTYPE_REGISTER|OPTYPE_UNDO; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* id-props */ | 
					
						
							| 
									
										
										
										
											2010-02-01 09:26:50 +00:00
										 |  |  | 	ot->prop= RNA_def_enum(ot->srna, "type", fmodifier_type_items, 0, "Type", ""); | 
					
						
							| 
									
										
										
										
											2009-07-02 06:41:10 +00:00
										 |  |  | 	RNA_def_boolean(ot->srna, "only_active", 0, "Only Active", "Only add F-Modifier of the specified type to the active strip."); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-18 13:04:46 +00:00
										 |  |  | /* ******************** Copy F-Modifiers Operator *********************** */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int nla_fmodifier_copy_exec(bContext *C, wmOperator *op) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	bAnimContext ac; | 
					
						
							|  |  |  | 	ListBase anim_data = {NULL, NULL}; | 
					
						
							|  |  |  | 	bAnimListElem *ale; | 
					
						
							|  |  |  | 	int filter, ok=0; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* get editor data */ | 
					
						
							|  |  |  | 	if (ANIM_animdata_get_context(C, &ac) == 0) | 
					
						
							|  |  |  | 		return OPERATOR_CANCELLED; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* clear buffer first */ | 
					
						
							|  |  |  | 	free_fmodifiers_copybuf(); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* get a list of the editable tracks being shown in the NLA */ | 
					
						
							|  |  |  | 	filter= (ANIMFILTER_VISIBLE | ANIMFILTER_NLATRACKS | ANIMFILTER_FOREDIT); | 
					
						
							|  |  |  | 	ANIM_animdata_filter(&ac, &anim_data, filter, ac.data, ac.datatype); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* for each NLA-Track, add the specified modifier to all selected strips */ | 
					
						
							|  |  |  | 	for (ale= anim_data.first; ale; ale= ale->next) { | 
					
						
							|  |  |  | 		NlaTrack *nlt= (NlaTrack *)ale->data; | 
					
						
							|  |  |  | 		NlaStrip *strip; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		for (strip= nlt->strips.first; strip; strip=strip->next) { | 
					
						
							|  |  |  | 			/* only add F-Modifier if on active strip? */ | 
					
						
							|  |  |  | 			if ((strip->flag & NLASTRIP_FLAG_ACTIVE)==0) | 
					
						
							|  |  |  | 				continue; | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 			// TODO: when 'active' vs 'all' boolean is added, change last param!
 | 
					
						
							|  |  |  | 			ok += ANIM_fmodifiers_copy_to_buf(&strip->modifiers, 0); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* successful or not? */ | 
					
						
							|  |  |  | 	if (ok == 0) { | 
					
						
							|  |  |  | 		BKE_report(op->reports, RPT_ERROR, "No F-Modifiers available to be copied"); | 
					
						
							|  |  |  | 		return OPERATOR_CANCELLED; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else | 
					
						
							|  |  |  | 		return OPERATOR_FINISHED; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | void NLA_OT_fmodifier_copy (wmOperatorType *ot) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	/* identifiers */ | 
					
						
							|  |  |  | 	ot->name= "Copy F-Modifiers"; | 
					
						
							|  |  |  | 	ot->idname= "NLA_OT_fmodifier_copy"; | 
					
						
							| 
									
										
										
										
											2010-12-08 21:56:50 +00:00
										 |  |  | 	ot->description= "Copy the F-Modifier(s) of the active NLA-Strip"; | 
					
						
							| 
									
										
										
										
											2010-03-18 13:04:46 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* api callbacks */ | 
					
						
							|  |  |  | 	ot->exec= nla_fmodifier_copy_exec; | 
					
						
							|  |  |  | 	ot->poll= nlaop_poll_tweakmode_off;  | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* flags */ | 
					
						
							|  |  |  | 	ot->flag= OPTYPE_REGISTER|OPTYPE_UNDO; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* id-props */ | 
					
						
							|  |  |  | 	//ot->prop = RNA_def_boolean(ot->srna, "all", 1, "All F-Modifiers", "Copy all the F-Modifiers, instead of just the active one");
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ******************** Paste F-Modifiers Operator *********************** */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int nla_fmodifier_paste_exec(bContext *C, wmOperator *op) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	bAnimContext ac; | 
					
						
							|  |  |  | 	ListBase anim_data = {NULL, NULL}; | 
					
						
							|  |  |  | 	bAnimListElem *ale; | 
					
						
							|  |  |  | 	int filter, ok=0; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* get editor data */ | 
					
						
							|  |  |  | 	if (ANIM_animdata_get_context(C, &ac) == 0) | 
					
						
							|  |  |  | 		return OPERATOR_CANCELLED; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* get a list of the editable tracks being shown in the NLA */ | 
					
						
							|  |  |  | 	filter= (ANIMFILTER_VISIBLE | ANIMFILTER_NLATRACKS | ANIMFILTER_SEL | ANIMFILTER_FOREDIT); | 
					
						
							|  |  |  | 	ANIM_animdata_filter(&ac, &anim_data, filter, ac.data, ac.datatype); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* for each NLA-Track, add the specified modifier to all selected strips */ | 
					
						
							|  |  |  | 	for (ale= anim_data.first; ale; ale= ale->next) { | 
					
						
							|  |  |  | 		NlaTrack *nlt= (NlaTrack *)ale->data; | 
					
						
							|  |  |  | 		NlaStrip *strip; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		for (strip= nlt->strips.first; strip; strip=strip->next) { | 
					
						
							|  |  |  | 			// TODO: do we want to replace existing modifiers? add user pref for that!
 | 
					
						
							|  |  |  | 			ok += ANIM_fmodifiers_paste_from_buf(&strip->modifiers, 0); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* clean up */ | 
					
						
							|  |  |  | 	BLI_freelistN(&anim_data); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* successful or not? */ | 
					
						
							|  |  |  | 	if (ok) { | 
					
						
							|  |  |  | 		/* set notifier that things have changed */ | 
					
						
							|  |  |  | 		/* set notifier that things have changed */ | 
					
						
							| 
									
										
										
										
											2010-06-18 04:39:32 +00:00
										 |  |  | 		WM_event_add_notifier(C, NC_ANIMATION|ND_NLA|NA_EDITED, NULL); | 
					
						
							| 
									
										
										
										
											2010-03-18 13:04:46 +00:00
										 |  |  | 		return OPERATOR_FINISHED; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		BKE_report(op->reports, RPT_ERROR, "No F-Modifiers to paste"); | 
					
						
							|  |  |  | 		return OPERATOR_CANCELLED; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | void NLA_OT_fmodifier_paste (wmOperatorType *ot) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	/* identifiers */ | 
					
						
							|  |  |  | 	ot->name= "Paste F-Modifiers"; | 
					
						
							|  |  |  | 	ot->idname= "NLA_OT_fmodifier_paste"; | 
					
						
							|  |  |  | 	ot->description= "Add copied F-Modifiers to the selected NLA-Strips"; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* api callbacks */ | 
					
						
							|  |  |  | 	ot->exec= nla_fmodifier_paste_exec; | 
					
						
							|  |  |  | 	ot->poll= nlaop_poll_tweakmode_off; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* flags */ | 
					
						
							|  |  |  | 	ot->flag= OPTYPE_REGISTER|OPTYPE_UNDO; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-02 06:41:10 +00:00
										 |  |  | /* *********************************************** */ |