Cleanup: warning & whitespace
[blender.git] / source / blender / editors / gpencil / gpencil_intern.h
1 /*
2  * ***** BEGIN GPL LICENSE BLOCK *****
3  *
4  * This program is free software; you can redistribute it and/or
5  * modify it under the terms of the GNU General Public License
6  * as published by the Free Software Foundation; either version 2
7  * of the License, or (at your option) any later version. 
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program; if not, write to the Free Software Foundation,
16  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
17  *
18  * The Original Code is Copyright (C) 2009 Blender Foundation.
19  * All rights reserved.
20  *
21  * 
22  * Contributor(s): Blender Foundation
23  *
24  * ***** END GPL LICENSE BLOCK *****
25  */
26
27 /** \file blender/editors/gpencil/gpencil_intern.h
28  *  \ingroup edgpencil
29  */
30
31 #ifndef __GPENCIL_INTERN_H__
32 #define __GPENCIL_INTERN_H__
33
34
35 #include "DNA_vec_types.h"
36
37
38 /* internal exports only */
39 struct bGPdata;
40 struct bGPDstroke;
41 struct bGPDspoint;
42
43 struct ARegion;
44 struct View2D;
45 struct wmOperatorType;
46
47
48 /* ***************************************************** */
49 /* Internal API */
50
51 /* Stroke Coordinates API ------------------------------ */
52 /* gpencil_utils.c */
53
54 typedef struct GP_SpaceConversion {
55         struct bGPdata *gpd;
56         struct bGPDlayer *gpl;
57
58         struct ScrArea *sa;
59         struct ARegion *ar;
60         struct View2D *v2d;
61
62         rctf *subrect;       /* for using the camera rect within the 3d view */
63         rctf subrect_data;
64
65         float mat[4][4];     /* transform matrix on the strokes (introduced in [b770964]) */
66 } GP_SpaceConversion;
67
68
69 /**
70  * Check whether a given stroke segment is inside a circular brush
71  *
72  * \param mval     The current screen-space coordinates (midpoint) of the brush
73  * \param mvalo    The previous screen-space coordinates (midpoint) of the brush (NOT CURRENTLY USED)
74  * \param rad      The radius of the brush
75  *
76  * \param x0, y0   The screen-space x and y coordinates of the start of the stroke segment
77  * \param x1, y1   The screen-space x and y coordinates of the end of the stroke segment
78  */
79 bool gp_stroke_inside_circle(const int mval[2], const int UNUSED(mvalo[2]),
80                              int rad, int x0, int y0, int x1, int y1);
81
82
83 /**
84  * Init settings for stroke point space conversions
85  *
86  * \param[out] r_gsc  The space conversion settings struct, populated with necessary params
87  */
88 void gp_point_conversion_init(struct bContext *C, GP_SpaceConversion *r_gsc);
89
90 /**
91  * Convert a Grease Pencil coordinate (i.e. can be 2D or 3D) to screenspace (2D)
92  *
93  * \param[out] r_x  The screen-space x-coordinate of the point
94  * \param[out] r_y  The screen-space y-coordinate of the point
95  */
96 void gp_point_to_xy(GP_SpaceConversion *settings, struct bGPDstroke *gps, struct bGPDspoint *pt,
97                     int *r_x, int *r_y);
98
99 /* Poll Callbacks ------------------------------------ */
100 /* gpencil_utils.c */
101
102 int gp_add_poll(struct bContext *C);
103 int gp_active_layer_poll(struct bContext *C);
104
105 /* ***************************************************** */
106 /* Operator Defines */
107
108 /* drawing ---------- */
109
110 void GPENCIL_OT_draw(struct wmOperatorType *ot);
111
112 /* Paint Modes for operator*/
113 typedef enum eGPencil_PaintModes {
114         GP_PAINTMODE_DRAW = 0,
115         GP_PAINTMODE_ERASER,
116         GP_PAINTMODE_DRAW_STRAIGHT,
117         GP_PAINTMODE_DRAW_POLY
118 } eGPencil_PaintModes;
119
120 /* stroke editing ----- */
121
122 void GPENCIL_OT_select(struct wmOperatorType *ot);
123 void GPENCIL_OT_select_all(struct wmOperatorType *ot);
124 void GPENCIL_OT_select_circle(struct wmOperatorType *ot);
125 void GPENCIL_OT_select_border(struct wmOperatorType *ot);
126 void GPENCIL_OT_select_lasso(struct wmOperatorType *ot);
127
128 void GPENCIL_OT_select_linked(struct wmOperatorType *ot);
129 void GPENCIL_OT_select_more(struct wmOperatorType *ot);
130 void GPENCIL_OT_select_less(struct wmOperatorType *ot);
131
132 void GPENCIL_OT_duplicate(struct wmOperatorType *ot);
133 void GPENCIL_OT_delete(struct wmOperatorType *ot);
134 void GPENCIL_OT_dissolve(struct wmOperatorType *ot);
135 void GPENCIL_OT_copy(struct wmOperatorType *ot);
136 void GPENCIL_OT_paste(struct wmOperatorType *ot);
137
138 /* buttons editing --- */
139
140 void GPENCIL_OT_data_add(struct wmOperatorType *ot);
141 void GPENCIL_OT_data_unlink(struct wmOperatorType *ot);
142
143 void GPENCIL_OT_layer_add(struct wmOperatorType *ot);
144 void GPENCIL_OT_layer_remove(struct wmOperatorType *ot);
145 void GPENCIL_OT_layer_move(struct wmOperatorType *ot);
146 void GPENCIL_OT_layer_duplicate(struct wmOperatorType *ot);
147
148 void GPENCIL_OT_hide(struct wmOperatorType *ot);
149 void GPENCIL_OT_reveal(struct wmOperatorType *ot);
150
151 void GPENCIL_OT_active_frame_delete(struct wmOperatorType *ot);
152
153 void GPENCIL_OT_convert(struct wmOperatorType *ot);
154
155 /* undo stack ---------- */
156
157 void gpencil_undo_init(struct bGPdata *gpd);
158 void gpencil_undo_push(struct bGPdata *gpd);
159 void gpencil_undo_finish(void);
160
161 /******************************************************* */
162 /* FILTERED ACTION DATA - TYPES  ---> XXX DEPRECEATED OLD ANIM SYSTEM CODE! */
163
164 /* XXX - TODO: replace this with the modern bAnimListElem... */
165 /* This struct defines a structure used for quick access */
166 typedef struct bActListElem {
167         struct bActListElem *next, *prev;
168
169         void *data;   /* source data this elem represents */
170         int   type;   /* one of the ACTTYPE_* values */
171         int   flag;   /* copy of elem's flags for quick access */
172         int   index;  /* copy of adrcode where applicable */
173
174         void  *key_data;  /* motion data - ipo or ipo-curve */
175         short  datatype;  /* type of motion data to expect */
176
177         struct bActionGroup *grp;   /* action group that owns the channel */
178
179         void  *owner;      /* will either be an action channel or fake ipo-channel (for keys) */
180         short  ownertype;  /* type of owner */
181 } bActListElem;
182
183 /******************************************************* */
184 /* FILTER ACTION DATA - METHODS/TYPES */
185
186 /* filtering flags  - under what circumstances should a channel be added */
187 typedef enum ACTFILTER_FLAGS {
188         ACTFILTER_VISIBLE       = (1 << 0),   /* should channels be visible */
189         ACTFILTER_SEL           = (1 << 1),   /* should channels be selected */
190         ACTFILTER_FOREDIT       = (1 << 2),   /* does editable status matter */
191         ACTFILTER_CHANNELS      = (1 << 3),   /* do we only care that it is a channel */
192         ACTFILTER_IPOKEYS       = (1 << 4),   /* only channels referencing ipo's */
193         ACTFILTER_ONLYICU       = (1 << 5),   /* only reference ipo-curves */
194         ACTFILTER_FORDRAWING    = (1 << 6),   /* make list for interface drawing */
195         ACTFILTER_ACTGROUPED    = (1 << 7)    /* belongs to the active group */
196 } ACTFILTER_FLAGS;
197
198 /* Action Editor - Main Data types */
199 typedef enum ACTCONT_TYPES {
200         ACTCONT_NONE = 0,
201         ACTCONT_ACTION,
202         ACTCONT_SHAPEKEY,
203         ACTCONT_GPENCIL
204 } ACTCONT_TYPES;
205
206 #endif /* __GPENCIL_INTERN_H__ */