While \file doesn't need an argument, it can't have another doxy command after it.
		
			
				
	
	
		
			196 lines
		
	
	
		
			7.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			196 lines
		
	
	
		
			7.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
 | |
|  *
 | |
|  * The Original Code is Copyright (C) (C) 2009 Blender Foundation, Joshua Leung
 | |
|  * All rights reserved.
 | |
|  */
 | |
| 
 | |
| /** \file
 | |
|  * \ingroup editors
 | |
|  */
 | |
| 
 | |
| #ifndef __ED_KEYFRAMES_DRAW_H__
 | |
| #define __ED_KEYFRAMES_DRAW_H__
 | |
| 
 | |
| struct AnimData;
 | |
| struct CacheFile;
 | |
| struct DLRBT_Tree;
 | |
| struct FCurve;
 | |
| struct ListBase;
 | |
| struct MaskLayer;
 | |
| struct Object;
 | |
| struct Palette;
 | |
| struct Scene;
 | |
| struct View2D;
 | |
| struct bAction;
 | |
| struct bActionGroup;
 | |
| struct bAnimContext;
 | |
| struct bDopeSheet;
 | |
| struct bGPDlayer;
 | |
| 
 | |
| /* ****************************** Base Structs ****************************** */
 | |
| 
 | |
| /* Information about the stretch of time from current to the next column */
 | |
| typedef struct ActKeyBlockInfo {
 | |
| 	/* Combination of flags from all curves. */
 | |
| 	short flag;
 | |
| 	/* Mask of flags that differ between curves. */
 | |
| 	short conflict;
 | |
| 
 | |
| 	/* Selection flag. */
 | |
| 	char sel;
 | |
| } ActKeyBlockInfo;
 | |
| 
 | |
| /* Keyframe Column Struct */
 | |
| typedef struct ActKeyColumn {
 | |
| 	/* ListBase linkage */
 | |
| 	struct ActKeyColumn *next, *prev;
 | |
| 
 | |
| 	/* sorting-tree linkage */
 | |
| 	/** 'children' of this node, less than and greater than it (respectively) */
 | |
| 	struct ActKeyColumn *left, *right;
 | |
| 	/** parent of this node in the tree */
 | |
| 	struct ActKeyColumn *parent;
 | |
| 	/** DLRB_BLACK or DLRB_RED */
 | |
| 	char tree_col;
 | |
| 
 | |
| 	/* keyframe info */
 | |
| 	/** eBezTripe_KeyframeType */
 | |
| 	char key_type;
 | |
| 	/** eKeyframeHandleDrawOpts */
 | |
| 	char handle_type;
 | |
| 	/** eKeyframeExtremeDrawOpts */
 | |
| 	char extreme_type;
 | |
| 	short sel;
 | |
| 	float cfra;
 | |
| 
 | |
| 	/* key-block info */
 | |
| 	ActKeyBlockInfo block;
 | |
| 
 | |
| 	/* number of curves and keys in this column */
 | |
| 	short totcurve, totkey, totblock;
 | |
| } ActKeyColumn;
 | |
| 
 | |
| /* ActKeyBlockInfo - Flag */
 | |
| typedef enum eActKeyBlock_Hold {
 | |
| 	/* Key block represents a moving hold */
 | |
| 	ACTKEYBLOCK_FLAG_MOVING_HOLD     = (1 << 0),
 | |
| 	/* Key block represents a static hold */
 | |
| 	ACTKEYBLOCK_FLAG_STATIC_HOLD     = (1 << 1),
 | |
| 	/* Key block represents any kind of hold */
 | |
| 	ACTKEYBLOCK_FLAG_ANY_HOLD        = (1 << 2),
 | |
| 	/* The curve segment uses non-bezier interpolation */
 | |
| 	ACTKEYBLOCK_FLAG_NON_BEZIER      = (1 << 3),
 | |
| } eActKeyBlock_Flag;
 | |
| 
 | |
| /* *********************** Keyframe Drawing ****************************** */
 | |
| 
 | |
| /* options for keyframe shape drawing */
 | |
| typedef enum eKeyframeShapeDrawOpts {
 | |
| 	/* only the border */
 | |
| 	KEYFRAME_SHAPE_FRAME = 0,
 | |
| 	/* only the inside filling */
 | |
| 	KEYFRAME_SHAPE_INSIDE,
 | |
| 	/* the whole thing */
 | |
| 	KEYFRAME_SHAPE_BOTH
 | |
| } eKeyframeShapeDrawOpts;
 | |
| 
 | |
| /* Handle type. */
 | |
| typedef enum eKeyframeHandleDrawOpts {
 | |
| 	/* Don't draw */
 | |
| 	KEYFRAME_HANDLE_NONE = 0,
 | |
| 	/* Various marks in order of increasing display priority. */
 | |
| 	KEYFRAME_HANDLE_AUTO_CLAMP,
 | |
| 	KEYFRAME_HANDLE_AUTO,
 | |
| 	KEYFRAME_HANDLE_VECTOR,
 | |
| 	KEYFRAME_HANDLE_ALIGNED,
 | |
| 	KEYFRAME_HANDLE_FREE,
 | |
| } eKeyframeHandleDrawOpts;
 | |
| 
 | |
| /* Extreme type. */
 | |
| typedef enum eKeyframeExtremeDrawOpts {
 | |
| 	KEYFRAME_EXTREME_NONE  = 0,
 | |
| 	/* Minimum/maximum present. */
 | |
| 	KEYFRAME_EXTREME_MIN   = (1 << 0),
 | |
| 	KEYFRAME_EXTREME_MAX   = (1 << 1),
 | |
| 	/* Grouped keys have different states. */
 | |
| 	KEYFRAME_EXTREME_MIXED = (1 << 2),
 | |
| 	/* Both neigbors are equal to this key. */
 | |
| 	KEYFRAME_EXTREME_FLAT  = (1 << 3),
 | |
| } eKeyframeExtremeDrawOpts;
 | |
| 
 | |
| /* draw simple diamond-shape keyframe */
 | |
| /* caller should set up vertex format, bind GPU_SHADER_KEYFRAME_DIAMOND,
 | |
|  * immBegin(GPU_PRIM_POINTS, n), then call this n times */
 | |
| void draw_keyframe_shape(float x, float y, float size, bool sel, short key_type, short mode, float alpha,
 | |
|                          unsigned int pos_id, unsigned int size_id, unsigned int color_id, unsigned int outline_color_id,
 | |
|                          unsigned int linemask_id, short ipo_type, short extreme_type);
 | |
| 
 | |
| /* ******************************* Methods ****************************** */
 | |
| 
 | |
| /* Channel Drawing ------------------ */
 | |
| /* F-Curve */
 | |
| void draw_fcurve_channel(struct View2D *v2d, struct AnimData *adt, struct FCurve *fcu, float ypos, float yscale_fac, int saction_flag);
 | |
| /* Action Group Summary */
 | |
| void draw_agroup_channel(struct View2D *v2d, struct AnimData *adt, struct bActionGroup *agrp, float ypos, float yscale_fac, int saction_flag);
 | |
| /* Action Summary */
 | |
| void draw_action_channel(struct View2D *v2d, struct AnimData *adt, struct bAction *act, float ypos, float yscale_fac, int saction_flag);
 | |
| /* Object Summary */
 | |
| void draw_object_channel(struct View2D *v2d, struct bDopeSheet *ads, struct Object *ob, float ypos, float yscale_fac, int saction_flag);
 | |
| /* Scene Summary */
 | |
| void draw_scene_channel(struct View2D *v2d, struct bDopeSheet *ads, struct Scene *sce, float ypos, float yscale_fac, int saction_flag);
 | |
| /* DopeSheet Summary */
 | |
| void draw_summary_channel(struct View2D *v2d, struct bAnimContext *ac, float ypos, float yscale_fac, int saction_flag);
 | |
| /* Grease Pencil datablock summary */
 | |
| void draw_gpencil_channel(struct View2D *v2d, struct bDopeSheet *ads, struct bGPdata *gpd, float ypos, float yscale_fac, int saction_flag);
 | |
| /* Grease Pencil Layer */
 | |
| void draw_gpl_channel(struct View2D *v2d, struct bDopeSheet *ads, struct bGPDlayer *gpl, float ypos, float yscale_fac, int saction_flag);
 | |
| /* Mask Layer */
 | |
| void draw_masklay_channel(struct View2D *v2d, struct bDopeSheet *ads, struct MaskLayer *masklay, float ypos, float yscale_fac, int saction_flag);
 | |
| 
 | |
| /* Keydata Generation --------------- */
 | |
| /* F-Curve */
 | |
| void fcurve_to_keylist(struct AnimData *adt, struct FCurve *fcu, struct DLRBT_Tree *keys, int saction_flag);
 | |
| /* Action Group */
 | |
| void agroup_to_keylist(struct AnimData *adt, struct bActionGroup *agrp, struct DLRBT_Tree *keys, int saction_flag);
 | |
| /* Action */
 | |
| void action_to_keylist(struct AnimData *adt, struct bAction *act, struct DLRBT_Tree *keys, int saction_flag);
 | |
| /* Object */
 | |
| void ob_to_keylist(struct bDopeSheet *ads, struct Object *ob, struct DLRBT_Tree *keys, int saction_flag);
 | |
| /* Cache File */
 | |
| void cachefile_to_keylist(struct bDopeSheet *ads, struct CacheFile *cache_file, struct DLRBT_Tree *keys, int saction_flag);
 | |
| /* Scene */
 | |
| void scene_to_keylist(struct bDopeSheet *ads, struct Scene *sce, struct DLRBT_Tree *keys, int saction_flag);
 | |
| /* DopeSheet Summary */
 | |
| void summary_to_keylist(struct bAnimContext *ac, struct DLRBT_Tree *keys, int saction_flag);
 | |
| /* Grease Pencil datablock summary */
 | |
| void gpencil_to_keylist(struct bDopeSheet *ads, struct bGPdata *gpd, struct DLRBT_Tree *keys, const bool active);
 | |
| /* Grease Pencil Layer */
 | |
| void gpl_to_keylist(struct bDopeSheet *ads, struct bGPDlayer *gpl, struct DLRBT_Tree *keys);
 | |
| /* Mask */
 | |
| void mask_to_keylist(struct bDopeSheet *UNUSED(ads), struct MaskLayer *masklay, struct DLRBT_Tree *keys);
 | |
| 
 | |
| /* ActKeyColumn API ---------------- */
 | |
| /* Comparator callback used for ActKeyColumns and cframe float-value pointer */
 | |
| short compare_ak_cfraPtr(void *node, void *data);
 | |
| 
 | |
| /* Checks if ActKeyColumn has any block data */
 | |
| bool actkeyblock_is_valid(ActKeyColumn *ab);
 | |
| 
 | |
| /* Checks if ActKeyColumn can be used as a block (i.e. drawn/used to detect "holds") */
 | |
| int actkeyblock_get_valid_hold(ActKeyColumn *ab);
 | |
| 
 | |
| #endif  /*  __ED_KEYFRAMES_DRAW_H__ */
 |