Cycles: svn merge -r36495:36747 https://svn.blender.org/svnroot/bf-blender/trunk...
[blender.git] / source / blender / blenkernel / BKE_sketch.h
1 /*
2  * $Id$ 
3  *
4  * ***** BEGIN GPL LICENSE BLOCK *****
5  *
6  * This program is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU General Public License
8  * as published by the Free Software Foundation; either version 2
9  * of the License, or (at your option) any later version.
10  *
11  * This program is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with this program; if not, write to the Free Software Foundation,
18  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
19  *
20  * Contributor(s): none yet.
21  *
22  * ***** END GPL LICENSE BLOCK *****
23  */
24 #ifndef BKE_SKETCH_H
25 #define BKE_SKETCH_H
26
27 /** \file BKE_sketch.h
28  *  \ingroup bke
29  */
30
31 typedef enum SK_PType
32 {
33         PT_CONTINUOUS,
34         PT_EXACT,
35 } SK_PType;
36
37 typedef enum SK_PMode
38 {
39         PT_SNAP,
40         PT_PROJECT,
41 } SK_PMode;
42
43 typedef struct SK_Point
44 {
45         float p[3];
46         short p2d[2];
47         float no[3];
48         float size;
49         SK_PType type;
50         SK_PMode mode;
51 } SK_Point;
52
53 typedef struct SK_Stroke
54 {
55         struct SK_Stroke *next, *prev;
56
57         SK_Point *points;
58         int nb_points;
59         int buf_size;
60         int selected;
61 } SK_Stroke;
62
63 #define SK_OVERDRAW_LIMIT       5
64
65 typedef struct SK_Overdraw
66 {
67         SK_Stroke *target;
68         int     start, end;
69         int count;
70 } SK_Overdraw;
71
72 #define SK_Stroke_BUFFER_INIT_SIZE 20
73
74 typedef struct SK_DrawData
75 {
76         int mval[2];
77         int previous_mval[2];
78         SK_PType type;
79 } SK_DrawData;
80
81 typedef struct SK_Intersection
82 {
83         struct SK_Intersection *next, *prev;
84         SK_Stroke *stroke;
85         int                     before;
86         int                     after;
87         int                     gesture_index;
88         float           p[3];
89         float           lambda; /* used for sorting intersection points */
90 } SK_Intersection;
91
92 typedef struct SK_Sketch
93 {
94         ListBase        strokes;
95         ListBase        depth_peels;
96         SK_Stroke       *active_stroke;
97         SK_Stroke       *gesture;
98         SK_Point        next_point;
99         SK_Overdraw over;
100 } SK_Sketch;
101
102
103 typedef struct SK_Gesture {
104         SK_Stroke       *stk;
105         SK_Stroke       *segments;
106
107         ListBase        intersections;
108         ListBase        self_intersections;
109
110         int                     nb_self_intersections;
111         int                     nb_intersections;
112         int                     nb_segments;
113 } SK_Gesture;
114
115
116 /************************************************/
117
118 void freeSketch(SK_Sketch *sketch);
119 SK_Sketch* createSketch(void);
120
121 void sk_removeStroke(SK_Sketch *sketch, SK_Stroke *stk);
122
123 void sk_freeStroke(SK_Stroke *stk);
124 SK_Stroke* sk_createStroke(void);
125
126 SK_Point *sk_lastStrokePoint(SK_Stroke *stk);
127
128 void sk_allocStrokeBuffer(SK_Stroke *stk);
129 void sk_shrinkStrokeBuffer(SK_Stroke *stk);
130 void sk_growStrokeBuffer(SK_Stroke *stk);
131 void sk_growStrokeBufferN(SK_Stroke *stk, int n);
132
133 void sk_replaceStrokePoint(SK_Stroke *stk, SK_Point *pt, int n);
134 void sk_insertStrokePoint(SK_Stroke *stk, SK_Point *pt, int n);
135 void sk_appendStrokePoint(SK_Stroke *stk, SK_Point *pt);
136 void sk_insertStrokePoints(SK_Stroke *stk, SK_Point *pts, int len, int start, int end);
137
138 void sk_trimStroke(SK_Stroke *stk, int start, int end);
139 void sk_straightenStroke(SK_Stroke *stk, int start, int end, float p_start[3], float p_end[3]);
140 void sk_polygonizeStroke(SK_Stroke *stk, int start, int end);
141 void sk_flattenStroke(SK_Stroke *stk, int start, int end);
142 void sk_reverseStroke(SK_Stroke *stk);
143
144 void sk_filterLastContinuousStroke(SK_Stroke *stk);
145 void sk_filterStroke(SK_Stroke *stk, int start, int end);
146
147 void sk_initPoint(SK_Point *pt, SK_DrawData *dd, float *no);
148 void sk_copyPoint(SK_Point *dst, SK_Point *src);
149
150 int sk_stroke_filtermval(SK_DrawData *dd);
151 void sk_endContinuousStroke(SK_Stroke *stk);
152
153 void sk_updateNextPoint(SK_Sketch *sketch, SK_Stroke *stk);
154
155 void sk_initDrawData(SK_DrawData *dd, const int mval[2]);
156
157 void sk_deleteSelectedStrokes(SK_Sketch *sketch);
158 void sk_selectAllSketch(SK_Sketch *sketch, int mode);
159
160 #endif