2008-12-20 08:24:24 +00:00
|
|
|
/**
|
|
|
|
* $Id:
|
|
|
|
*
|
|
|
|
* ***** 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,
|
|
|
|
* Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
|
|
*
|
|
|
|
* The Original Code is Copyright (C) 2008 Blender Foundation.
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* Contributor(s): Joshua Leung
|
|
|
|
*
|
|
|
|
* ***** END GPL LICENSE BLOCK *****
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef ED_ANIM_API_H
|
|
|
|
#define ED_ANIM_API_H
|
|
|
|
|
|
|
|
struct ID;
|
2009-01-10 14:19:14 +00:00
|
|
|
struct Scene;
|
2008-12-20 08:24:24 +00:00
|
|
|
struct ListBase;
|
|
|
|
struct bContext;
|
2008-12-23 11:02:39 +00:00
|
|
|
struct wmWindowManager;
|
|
|
|
struct ScrArea;
|
|
|
|
struct ARegion;
|
2008-12-20 08:24:24 +00:00
|
|
|
struct View2D;
|
2008-12-22 08:13:25 +00:00
|
|
|
struct gla2DDrawInfo;
|
|
|
|
struct Object;
|
2008-12-20 08:24:24 +00:00
|
|
|
struct bActionGroup;
|
2009-01-20 11:07:42 +00:00
|
|
|
struct FCurve;
|
|
|
|
struct IpoCurve; // xxx
|
2008-12-20 08:24:24 +00:00
|
|
|
|
|
|
|
/* ************************************************ */
|
|
|
|
/* ANIMATION CHANNEL FILTERING */
|
2009-01-02 00:56:48 +00:00
|
|
|
/* anim_filter.c */
|
2008-12-20 08:24:24 +00:00
|
|
|
|
2008-12-22 08:13:25 +00:00
|
|
|
/* --------------- Context --------------------- */
|
|
|
|
|
|
|
|
/* This struct defines a structure used for animation-specific
|
|
|
|
* 'context' information
|
|
|
|
*/
|
|
|
|
typedef struct bAnimContext {
|
|
|
|
void *data; /* data to be filtered for use in animation editor */
|
|
|
|
short datatype; /* type of data eAnimCont_Types */
|
|
|
|
|
|
|
|
short mode; /* editor->mode */
|
|
|
|
short spacetype; /* sa->spacetype */
|
|
|
|
short regiontype; /* active region -> type (channels or main) */
|
|
|
|
struct ScrArea *sa; /* editor */
|
2008-12-23 11:02:39 +00:00
|
|
|
struct ARegion *ar; /* region within editor */
|
2008-12-22 08:13:25 +00:00
|
|
|
|
|
|
|
struct Scene *scene; /* active scene */
|
|
|
|
struct Object *obact; /* active object */
|
|
|
|
} bAnimContext;
|
|
|
|
|
|
|
|
/* Main Data container types */
|
|
|
|
// XXX was ACTCONT_*
|
|
|
|
typedef enum eAnimCont_Types {
|
|
|
|
ANIMCONT_NONE = 0, /* invalid or no data */
|
|
|
|
ANIMCONT_ACTION, /* action (bAction) */
|
|
|
|
ANIMCONT_SHAPEKEY, /* shapekey (Key) */
|
|
|
|
ANIMCONT_GPENCIL, /* grease pencil (screen) */
|
|
|
|
ANIMCONT_DOPESHEET, /* dopesheet (bDopesheet) */
|
Animato/2.5 - Graph Editor (i.e. the new 'IPO Editor')
This commit brings back the drawing code for the 'Graph Editor'. I've decided to call it this, as currently it can show either F-Curves for Animation stored in Actions, or F-Curves for Drivers.
Currently, it shows all curves, since some of the necessary filtering code (i.e. for limiting curve visibility) hasn't been put in place yet. At least this serves as good proof that we can have F-Curves from multiple sources at least.
It should be noted that the code still has to be modified to work with some of the new Animato features, such as F-Curve Modifiers (cycles are an example of one of the features that use this). Also, a nicer way to set the colours of the curves needs to be investigated.
Notes:
* Fixed a few bugs in RNA User-Preferences wrapping
* The keyframe drawing uses the new-style drawing for handles from AnimSys2. There's a minor bug that sometimes occurs, where a distorted handle gets drawn at the origin of the grid on the first run. Hints anyone?
* Removed most of the old data from SpaceIpo struct, as the new code uses that. Maybe later, the directories/files at least should get renamed.
* Removed ancient hack for NVidia/TNT drivers. It is probably no longer needed, but could be restored if someone needs it.
2009-01-26 11:33:16 +00:00
|
|
|
ANIMCONT_FCURVES, /* animation F-Curves (bDopesheet) */ // XXX
|
|
|
|
ANIMCONT_DRIVERS, /* drivers (bDopesheet) */
|
2008-12-22 08:13:25 +00:00
|
|
|
} eAnimCont_Types;
|
|
|
|
|
|
|
|
/* --------------- Channels -------------------- */
|
2008-12-20 08:24:24 +00:00
|
|
|
|
|
|
|
/* This struct defines a structure used for quick and uniform access for
|
|
|
|
* channels of animation data
|
|
|
|
*/
|
|
|
|
typedef struct bAnimListElem {
|
|
|
|
struct bAnimListElem *next, *prev;
|
|
|
|
|
|
|
|
void *data; /* source data this elem represents */
|
|
|
|
int type; /* one of the ANIMTYPE_* values */
|
|
|
|
int flag; /* copy of elem's flags for quick access */
|
|
|
|
int index; /* copy of adrcode where applicable */
|
|
|
|
|
|
|
|
void *key_data; /* motion data - ipo or ipo-curve */
|
|
|
|
short datatype; /* type of motion data to expect */
|
|
|
|
|
2009-01-23 02:50:04 +00:00
|
|
|
struct ID *id; /* ID block that channel is attached to (may be used */
|
2008-12-20 08:24:24 +00:00
|
|
|
|
2009-01-23 02:50:04 +00:00
|
|
|
void *owner; /* group or channel which acts as this channel's owner */
|
2008-12-20 08:24:24 +00:00
|
|
|
short ownertype; /* type of owner */
|
|
|
|
} bAnimListElem;
|
|
|
|
|
|
|
|
|
|
|
|
/* Some types for easier type-testing */
|
2008-12-21 03:14:01 +00:00
|
|
|
// XXX was ACTTYPE_*
|
2008-12-20 08:24:24 +00:00
|
|
|
typedef enum eAnim_ChannelType {
|
|
|
|
ANIMTYPE_NONE= 0,
|
|
|
|
ANIMTYPE_SPECIALDATA,
|
|
|
|
|
2009-02-13 06:33:07 +00:00
|
|
|
ANIMTYPE_SCENE,
|
2008-12-20 08:24:24 +00:00
|
|
|
ANIMTYPE_OBJECT,
|
|
|
|
ANIMTYPE_GROUP,
|
2009-01-20 11:07:42 +00:00
|
|
|
ANIMTYPE_FCURVE,
|
2008-12-20 08:24:24 +00:00
|
|
|
|
|
|
|
ANIMTYPE_FILLACTD,
|
2009-01-30 08:10:31 +00:00
|
|
|
ANIMTYPE_FILLDRIVERS,
|
2008-12-20 08:24:24 +00:00
|
|
|
ANIMTYPE_FILLMATD,
|
|
|
|
|
|
|
|
ANIMTYPE_DSMAT,
|
|
|
|
ANIMTYPE_DSLAM,
|
|
|
|
ANIMTYPE_DSCAM,
|
|
|
|
ANIMTYPE_DSCUR,
|
|
|
|
ANIMTYPE_DSSKEY,
|
2009-02-13 06:33:07 +00:00
|
|
|
ANIMTYPE_DSWOR,
|
2008-12-20 08:24:24 +00:00
|
|
|
|
2009-01-20 11:07:42 +00:00
|
|
|
ANIMTYPE_SHAPEKEY, // XXX probably can become depreceated???
|
2008-12-20 08:24:24 +00:00
|
|
|
|
|
|
|
ANIMTYPE_GPDATABLOCK,
|
|
|
|
ANIMTYPE_GPLAYER,
|
|
|
|
} eAnim_ChannelType;
|
|
|
|
|
|
|
|
/* types of keyframe data in bAnimListElem */
|
|
|
|
typedef enum eAnim_KeyType {
|
|
|
|
ALE_NONE = 0, /* no keyframe data */
|
2009-01-20 11:07:42 +00:00
|
|
|
ALE_FCURVE, /* F-Curve */
|
2008-12-20 08:24:24 +00:00
|
|
|
ALE_GPFRAME, /* Grease Pencil Frames */
|
|
|
|
|
|
|
|
// XXX the following are for summaries... should these be kept?
|
2009-02-13 06:33:07 +00:00
|
|
|
ALE_SCE, /* Scene summary */
|
2008-12-20 08:24:24 +00:00
|
|
|
ALE_OB, /* Object summary */
|
|
|
|
ALE_ACT, /* Action summary */
|
|
|
|
ALE_GROUP, /* Action Group summary */
|
|
|
|
} eAnim_KeyType;
|
|
|
|
|
2008-12-22 08:13:25 +00:00
|
|
|
/* ----------------- Filtering -------------------- */
|
2008-12-20 08:24:24 +00:00
|
|
|
|
|
|
|
/* filtering flags - under what circumstances should a channel be added */
|
2008-12-21 03:14:01 +00:00
|
|
|
// XXX was ACTFILTER_*
|
2008-12-20 08:24:24 +00:00
|
|
|
typedef enum eAnimFilter_Flags {
|
Animato/2.5 - Graph Editor (i.e. the new 'IPO Editor')
This commit brings back the drawing code for the 'Graph Editor'. I've decided to call it this, as currently it can show either F-Curves for Animation stored in Actions, or F-Curves for Drivers.
Currently, it shows all curves, since some of the necessary filtering code (i.e. for limiting curve visibility) hasn't been put in place yet. At least this serves as good proof that we can have F-Curves from multiple sources at least.
It should be noted that the code still has to be modified to work with some of the new Animato features, such as F-Curve Modifiers (cycles are an example of one of the features that use this). Also, a nicer way to set the colours of the curves needs to be investigated.
Notes:
* Fixed a few bugs in RNA User-Preferences wrapping
* The keyframe drawing uses the new-style drawing for handles from AnimSys2. There's a minor bug that sometimes occurs, where a distorted handle gets drawn at the origin of the grid on the first run. Hints anyone?
* Removed most of the old data from SpaceIpo struct, as the new code uses that. Maybe later, the directories/files at least should get renamed.
* Removed ancient hack for NVidia/TNT drivers. It is probably no longer needed, but could be restored if someone needs it.
2009-01-26 11:33:16 +00:00
|
|
|
ANIMFILTER_VISIBLE = (1<<0), /* should channels be visible (in terms of hierarchy only) */
|
2008-12-21 04:11:19 +00:00
|
|
|
ANIMFILTER_SEL = (1<<1), /* should channels be selected */
|
|
|
|
ANIMFILTER_FOREDIT = (1<<2), /* does editable status matter */
|
2009-01-20 11:07:42 +00:00
|
|
|
ANIMFILTER_CURVESONLY = (1<<3), /* don't include summary-channels, etc. */
|
|
|
|
ANIMFILTER_CHANNELS = (1<<4), /* make list for interface drawing */
|
|
|
|
ANIMFILTER_ACTGROUPED = (1<<5), /* belongs to the active actiongroup */
|
Animato/2.5 - Graph Editor (i.e. the new 'IPO Editor')
This commit brings back the drawing code for the 'Graph Editor'. I've decided to call it this, as currently it can show either F-Curves for Animation stored in Actions, or F-Curves for Drivers.
Currently, it shows all curves, since some of the necessary filtering code (i.e. for limiting curve visibility) hasn't been put in place yet. At least this serves as good proof that we can have F-Curves from multiple sources at least.
It should be noted that the code still has to be modified to work with some of the new Animato features, such as F-Curve Modifiers (cycles are an example of one of the features that use this). Also, a nicer way to set the colours of the curves needs to be investigated.
Notes:
* Fixed a few bugs in RNA User-Preferences wrapping
* The keyframe drawing uses the new-style drawing for handles from AnimSys2. There's a minor bug that sometimes occurs, where a distorted handle gets drawn at the origin of the grid on the first run. Hints anyone?
* Removed most of the old data from SpaceIpo struct, as the new code uses that. Maybe later, the directories/files at least should get renamed.
* Removed ancient hack for NVidia/TNT drivers. It is probably no longer needed, but could be restored if someone needs it.
2009-01-26 11:33:16 +00:00
|
|
|
ANIMFILTER_CURVEVISIBLE = (1<<6), /* F-Curve is visible for editing/viewing in Graph Editor */
|
2009-02-21 11:22:06 +00:00
|
|
|
ANIMFILTER_ACTIVE = (1<<7), /* channel should be 'active' */ // FIXME: this is only relevant for F-Curves for now
|
2008-12-20 08:24:24 +00:00
|
|
|
} eAnimFilter_Flags;
|
|
|
|
|
|
|
|
|
2008-12-21 04:11:19 +00:00
|
|
|
/* ---------- Flag Checking Macros ------------ */
|
2009-01-20 11:07:42 +00:00
|
|
|
// xxx check on all of these flags again...
|
2008-12-21 04:11:19 +00:00
|
|
|
|
|
|
|
/* Dopesheet only */
|
2009-02-13 06:33:07 +00:00
|
|
|
/* 'Scene' channels */
|
|
|
|
#define SEL_SCEC(sce) ((sce->flag & SCE_DS_SELECTED))
|
|
|
|
#define EXPANDED_SCEC(sce) ((sce->flag & SCE_DS_COLLAPSED)==0)
|
|
|
|
/* 'Sub-Scene' channels (flags stored in Data block) */
|
|
|
|
#define FILTER_WOR_SCED(wo) ((wo->flag & WO_DS_EXPAND))
|
2008-12-21 04:11:19 +00:00
|
|
|
/* 'Object' channels */
|
|
|
|
#define SEL_OBJC(base) ((base->flag & SELECT))
|
|
|
|
#define EXPANDED_OBJC(ob) ((ob->nlaflag & OB_ADS_COLLAPSED)==0)
|
|
|
|
/* 'Sub-object' channels (flags stored in Object block) */
|
|
|
|
#define FILTER_MAT_OBJC(ob) ((ob->nlaflag & OB_ADS_SHOWMATS))
|
|
|
|
/* 'Sub-object' channels (flags stored in Data block) */
|
|
|
|
#define FILTER_SKE_OBJD(key) ((key->flag & KEYBLOCK_DS_EXPAND))
|
|
|
|
#define FILTER_MAT_OBJD(ma) ((ma->flag & MA_DS_EXPAND))
|
|
|
|
#define FILTER_LAM_OBJD(la) ((la->flag & LA_DS_EXPAND))
|
|
|
|
#define FILTER_CAM_OBJD(ca) ((ca->flag & CAM_DS_EXPAND))
|
|
|
|
#define FILTER_CUR_OBJD(cu) ((cu->flag & CU_DS_EXPAND))
|
|
|
|
/* 'Sub-object/Action' channels (flags stored in Action) */
|
2009-01-20 11:07:42 +00:00
|
|
|
#define SEL_ACTC(actc) ((actc->flag & ACT_SELECTED))
|
2009-01-28 00:50:56 +00:00
|
|
|
#define EXPANDED_ACTC(actc) ((actc->flag & ACT_COLLAPSED)==0)
|
2009-01-30 08:10:31 +00:00
|
|
|
/* 'Sub-AnimData' chanenls */
|
|
|
|
#define EXPANDED_DRVD(adt) ((adt->flag & ADT_DRIVERS_COLLAPSED)==0)
|
2008-12-21 04:11:19 +00:00
|
|
|
|
|
|
|
/* Actions (also used for Dopesheet) */
|
|
|
|
/* Action Channel Group */
|
|
|
|
#define EDITABLE_AGRP(agrp) ((agrp->flag & AGRP_PROTECTED)==0)
|
|
|
|
#define EXPANDED_AGRP(agrp) (agrp->flag & AGRP_EXPANDED)
|
|
|
|
#define SEL_AGRP(agrp) ((agrp->flag & AGRP_SELECTED) || (agrp->flag & AGRP_ACTIVE))
|
2009-01-20 11:07:42 +00:00
|
|
|
/* F-Curve Channels */
|
|
|
|
#define EDITABLE_FCU(fcu) ((fcu->flag & FCURVE_PROTECTED)==0)
|
|
|
|
#define SEL_FCU(fcu) (fcu->flag & (FCURVE_ACTIVE|FCURVE_SELECTED))
|
2008-12-21 04:11:19 +00:00
|
|
|
|
|
|
|
/* Grease Pencil only */
|
|
|
|
/* Grease Pencil datablock settings */
|
|
|
|
#define EXPANDED_GPD(gpd) (gpd->flag & GP_DATA_EXPAND)
|
|
|
|
/* Grease Pencil Layer settings */
|
|
|
|
#define EDITABLE_GPL(gpl) ((gpl->flag & GP_LAYER_LOCKED)==0)
|
|
|
|
#define SEL_GPL(gpl) ((gpl->flag & GP_LAYER_ACTIVE) || (gpl->flag & GP_LAYER_SELECT))
|
|
|
|
|
2008-12-22 08:13:25 +00:00
|
|
|
/* -------------- Channel Defines -------------- */
|
|
|
|
|
|
|
|
/* channel heights */
|
2009-01-01 00:18:23 +00:00
|
|
|
#define ACHANNEL_FIRST -16
|
2008-12-22 08:13:25 +00:00
|
|
|
#define ACHANNEL_HEIGHT 16
|
|
|
|
#define ACHANNEL_HEIGHT_HALF 8
|
|
|
|
#define ACHANNEL_SKIP 2
|
|
|
|
#define ACHANNEL_STEP (ACHANNEL_HEIGHT + ACHANNEL_SKIP)
|
2009-01-01 01:47:36 +00:00
|
|
|
|
|
|
|
/* channel widths */
|
2008-12-22 09:43:54 +00:00
|
|
|
#define ACHANNEL_NAMEWIDTH 200
|
2008-12-22 08:13:25 +00:00
|
|
|
|
2009-01-01 01:47:36 +00:00
|
|
|
/* channel toggle-buttons */
|
|
|
|
#define ACHANNEL_BUTTON_WIDTH 16
|
|
|
|
|
2008-12-20 08:24:24 +00:00
|
|
|
/* ---------------- API -------------------- */
|
|
|
|
|
2.5 - Action Editor: All Keyframe Selection Tools Ported
User Notes (for using tools whose behaviour has changed):
* Mouse Selection Tools:
1) Click on keyframe to modify its selection. Holding the 'Shift' modifier when doing so, will result in keyframe selection being toggled instead of replacing existing selections.
2) Click on either side of the current frame indicator while holding the 'Alt' modifier. This will select only all the keyframes on the relevant side of the current frame indicator.
3) Click on a keyframe while holding the 'Ctrl' modifier. This will select all the keyframes that fall on that frame.
* Borderselect Tools
1) BKEY selects all the keyframes within the specified range (as per normal)
2) ALT-BKEY will select either all the keyframes in the frame-range specified or the channel range specified, depending on which axis of the select region was larger. This method is prejudiced towards frame-range selection.
Code Notes:
* Finished porting over all of the remaining keyframe selection tools, and recoded the ported ones to make them easier to use (after running into some technical limitations)
* Simplified the way to check if 'animation context' is valid by moving a necessary check into that function.
* Refactored internal keyframe-looping tools to reduce the amount of code needed per tool to edit keyframes, removing a lot of the unnecessary bulk. Now, the ipo/icu_keys_bezier_loop functions recieve a few more arguments (1st arg is pointer to generic customdata, and another defines a validation callback which makes it easier to reuse some of the select callbacks).
* Added 'totrect' adjustment for number of channels being shown in Action Editor, so that scrolling will be limited to where there is data (and also so that scroller displays more relevant context info).
For this to work, filtering channels now returns the number of channels extracted. This may come into use for other tools if there's such a need.
* I still need to port over some code for markers, which is required for some of the tools which use them. For now, those tools do nothing.
* Grease-Pencil editing mode in Action Editor is currently non-functional (code is commented out due to missing dependencies). This is currently pending the re-implementation of Grease Pencil in 2.5
2008-12-26 10:55:07 +00:00
|
|
|
/* Obtain list of filtered Animation channels to operate on.
|
|
|
|
* Returns the number of channels in the list
|
|
|
|
*/
|
2009-01-26 04:13:38 +00:00
|
|
|
int ANIM_animdata_filter(bAnimContext *ac, ListBase *anim_data, int filter_mode, void *data, short datatype);
|
2.5 - Action Editor: All Keyframe Selection Tools Ported
User Notes (for using tools whose behaviour has changed):
* Mouse Selection Tools:
1) Click on keyframe to modify its selection. Holding the 'Shift' modifier when doing so, will result in keyframe selection being toggled instead of replacing existing selections.
2) Click on either side of the current frame indicator while holding the 'Alt' modifier. This will select only all the keyframes on the relevant side of the current frame indicator.
3) Click on a keyframe while holding the 'Ctrl' modifier. This will select all the keyframes that fall on that frame.
* Borderselect Tools
1) BKEY selects all the keyframes within the specified range (as per normal)
2) ALT-BKEY will select either all the keyframes in the frame-range specified or the channel range specified, depending on which axis of the select region was larger. This method is prejudiced towards frame-range selection.
Code Notes:
* Finished porting over all of the remaining keyframe selection tools, and recoded the ported ones to make them easier to use (after running into some technical limitations)
* Simplified the way to check if 'animation context' is valid by moving a necessary check into that function.
* Refactored internal keyframe-looping tools to reduce the amount of code needed per tool to edit keyframes, removing a lot of the unnecessary bulk. Now, the ipo/icu_keys_bezier_loop functions recieve a few more arguments (1st arg is pointer to generic customdata, and another defines a validation callback which makes it easier to reuse some of the select callbacks).
* Added 'totrect' adjustment for number of channels being shown in Action Editor, so that scrolling will be limited to where there is data (and also so that scroller displays more relevant context info).
For this to work, filtering channels now returns the number of channels extracted. This may come into use for other tools if there's such a need.
* I still need to port over some code for markers, which is required for some of the tools which use them. For now, those tools do nothing.
* Grease-Pencil editing mode in Action Editor is currently non-functional (code is commented out due to missing dependencies). This is currently pending the re-implementation of Grease Pencil in 2.5
2008-12-26 10:55:07 +00:00
|
|
|
|
|
|
|
/* Obtain current anim-data context from Blender Context info.
|
|
|
|
* Returns whether the operation was successful.
|
2008-12-22 08:13:25 +00:00
|
|
|
*/
|
|
|
|
short ANIM_animdata_get_context(const struct bContext *C, bAnimContext *ac);
|
2008-12-20 08:24:24 +00:00
|
|
|
|
2008-12-30 00:28:11 +00:00
|
|
|
/* Obtain current anim-data context (from Animation Editor) given
|
|
|
|
* that Blender Context info has already been set.
|
|
|
|
* Returns whether the operation was successful.
|
|
|
|
*/
|
|
|
|
short ANIM_animdata_context_getdata(bAnimContext *ac);
|
|
|
|
|
2009-01-01 00:18:23 +00:00
|
|
|
/* ************************************************ */
|
|
|
|
/* ANIMATION CHANNELS LIST */
|
2009-01-02 00:56:48 +00:00
|
|
|
/* anim_channels.c */
|
2009-01-01 00:18:23 +00:00
|
|
|
|
2009-01-02 00:56:48 +00:00
|
|
|
/* ------------------------ API -------------------------- */
|
2009-01-01 00:18:23 +00:00
|
|
|
|
2009-01-02 00:56:48 +00:00
|
|
|
/* Deselect all animation channels */
|
|
|
|
void ANIM_deselect_anim_channels(void *data, short datatype, short test, short sel);
|
|
|
|
|
2009-01-05 00:38:17 +00:00
|
|
|
/* Set the 'active' channel of type channel_type, in the given action */
|
|
|
|
void ANIM_action_set_active_channel(void *data, short datatype, void *channel_data, short channel_type);
|
|
|
|
|
2009-01-02 00:56:48 +00:00
|
|
|
/* --------------- Settings and/or Defines -------------- */
|
|
|
|
|
|
|
|
/* flag-setting behaviour */
|
|
|
|
enum {
|
|
|
|
ACHANNEL_SETFLAG_CLEAR = 0,
|
|
|
|
ACHANNEL_SETFLAG_ADD,
|
|
|
|
ACHANNEL_SETFLAG_TOGGLE
|
|
|
|
} eAnimChannels_SetFlag;
|
2009-01-01 00:18:23 +00:00
|
|
|
|
2008-12-20 08:24:24 +00:00
|
|
|
/* ************************************************ */
|
|
|
|
/* DRAWING API */
|
2009-01-02 00:56:48 +00:00
|
|
|
/* anim_draw.c */
|
2008-12-20 08:24:24 +00:00
|
|
|
|
|
|
|
/* ---------- Current Frame Drawing ---------------- */
|
|
|
|
|
|
|
|
/* flags for Current Frame Drawing */
|
|
|
|
enum {
|
|
|
|
/* plain time indicator with no special indicators */
|
|
|
|
DRAWCFRA_PLAIN = 0,
|
|
|
|
/* draw box indicating current frame number */
|
|
|
|
DRAWCFRA_SHOW_NUMBOX = (1<<0),
|
|
|
|
/* time indication in seconds or frames */
|
|
|
|
DRAWCFRA_UNIT_SECONDS = (1<<1),
|
|
|
|
/* show time-offset line */
|
|
|
|
DRAWCFRA_SHOW_TIMEOFS = (1<<2),
|
|
|
|
} eAnimEditDraw_CurrentFrame;
|
|
|
|
|
|
|
|
/* main call to draw current-frame indicator in an Animation Editor */
|
2008-12-22 10:15:02 +00:00
|
|
|
void ANIM_draw_cfra(const struct bContext *C, struct View2D *v2d, short flag);
|
2008-12-20 08:24:24 +00:00
|
|
|
|
|
|
|
/* ------------- Preview Range Drawing -------------- */
|
|
|
|
|
|
|
|
/* main call to draw preview range curtains */
|
2008-12-22 10:15:02 +00:00
|
|
|
void ANIM_draw_previewrange(const struct bContext *C, struct View2D *v2d);
|
2008-12-20 08:24:24 +00:00
|
|
|
|
2008-12-22 08:13:25 +00:00
|
|
|
/* ************************************************* */
|
|
|
|
/* ASSORTED TOOLS */
|
|
|
|
|
2009-01-25 04:02:31 +00:00
|
|
|
/* ------------ Animation F-Curves <-> Icons/Names Mapping ------------ */
|
2009-01-02 00:56:48 +00:00
|
|
|
/* anim_ipo_utils.c */
|
2008-12-22 10:15:02 +00:00
|
|
|
|
2009-01-25 04:02:31 +00:00
|
|
|
int geticon_anim_blocktype(short blocktype);
|
|
|
|
|
|
|
|
void getname_anim_fcurve(char *name, struct ID *id, struct FCurve *fcu);
|
|
|
|
|
2008-12-22 10:15:02 +00:00
|
|
|
|
2009-02-15 10:58:24 +00:00
|
|
|
void ipo_rainbow(int cur, int tot, float *out);
|
2008-12-22 10:15:02 +00:00
|
|
|
|
|
|
|
|
2008-12-22 08:13:25 +00:00
|
|
|
/* ------------- NLA-Mapping ----------------------- */
|
2009-01-02 00:56:48 +00:00
|
|
|
/* anim_draw.c */
|
2008-12-22 08:13:25 +00:00
|
|
|
|
|
|
|
/* Obtain the Object providing NLA-scaling for the given channel if applicable */
|
|
|
|
struct Object *ANIM_nla_mapping_get(bAnimContext *ac, bAnimListElem *ale);
|
|
|
|
|
2008-12-23 11:02:39 +00:00
|
|
|
/* Set/clear temporary mapping of coordinates from 'local-action' time to 'global-nla-scaled' time */
|
2008-12-22 08:13:25 +00:00
|
|
|
void ANIM_nla_mapping_draw(struct gla2DDrawInfo *di, struct Object *ob, short restore);
|
|
|
|
|
2008-12-23 11:02:39 +00:00
|
|
|
/* Apply/Unapply NLA mapping to all keyframes in the nominated IPO block */
|
2009-01-20 11:07:42 +00:00
|
|
|
void ANIM_nla_mapping_apply_fcurve(struct Object *ob, struct FCurve *fcu, short restore, short only_keys);
|
2008-12-23 11:02:39 +00:00
|
|
|
|
2008-12-22 08:13:25 +00:00
|
|
|
/* ------------- xxx macros ----------------------- */
|
2009-01-02 00:56:48 +00:00
|
|
|
|
2008-12-22 08:13:25 +00:00
|
|
|
#define BEZSELECTED(bezt) ((bezt->f2 & SELECT) || (bezt->f1 & SELECT) || (bezt->f3 & SELECT))
|
|
|
|
|
2008-12-23 19:47:33 +00:00
|
|
|
|
|
|
|
/* --------- anim_deps.c, animation updates -------- */
|
|
|
|
|
2009-02-04 17:40:50 +00:00
|
|
|
/* generic update flush, does tagged objects only, reads from Context screen (layers) and scene */
|
2008-12-29 01:19:25 +00:00
|
|
|
void ED_anim_dag_flush_update(const struct bContext *C);
|
2009-01-10 14:19:14 +00:00
|
|
|
/* only flush object */
|
|
|
|
void ED_anim_object_flush_update(const struct bContext *C, struct Object *ob);
|
2008-12-23 19:47:33 +00:00
|
|
|
|
2009-01-03 11:35:39 +00:00
|
|
|
/* pose <-> action syncing */
|
|
|
|
void ANIM_action_to_pose_sync(struct Object *ob);
|
2009-01-05 09:54:39 +00:00
|
|
|
void ANIM_pose_to_action_sync(struct Object *ob, struct ScrArea *sa);
|
|
|
|
|
|
|
|
|
|
|
|
/* what types of animation data was changed (for sending notifiers from animation tools) */
|
|
|
|
enum {
|
|
|
|
ANIM_CHANGED_BOTH= 0,
|
|
|
|
ANIM_CHANGED_KEYFRAMES_VALUES,
|
|
|
|
ANIM_CHANGED_KEYFRAMES_SELECT,
|
|
|
|
ANIM_CHANGED_CHANNELS
|
|
|
|
} eAnimData_Changed;
|
|
|
|
|
|
|
|
/* Send notifiers on behalf of animation editing tools, based on various context info */
|
|
|
|
void ANIM_animdata_send_notifiers(struct bContext *C, bAnimContext *ac, short data_changed);
|
2009-01-03 11:35:39 +00:00
|
|
|
|
2008-12-20 08:24:24 +00:00
|
|
|
/* ************************************************* */
|
2008-12-21 08:02:24 +00:00
|
|
|
/* OPERATORS */
|
2009-01-01 00:18:23 +00:00
|
|
|
|
|
|
|
/* generic animation channels */
|
|
|
|
void ED_operatortypes_animchannels(void);
|
|
|
|
void ED_keymap_animchannels(struct wmWindowManager *wm);
|
2008-12-21 08:02:24 +00:00
|
|
|
|
2009-01-01 00:18:23 +00:00
|
|
|
/* generic time editing */
|
2008-12-21 08:02:24 +00:00
|
|
|
void ED_operatortypes_anim(void);
|
|
|
|
void ED_keymap_anim(struct wmWindowManager *wm);
|
|
|
|
|
|
|
|
/* ************************************************ */
|
2008-12-20 08:24:24 +00:00
|
|
|
|
|
|
|
#endif /* ED_ANIM_API_H */
|
|
|
|
|