cfb56417d978be0d82cff6a2a614a6b5400d88d6
[blender-staging.git] / source / blender / windowmanager / WM_types.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., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
19  *
20  * The Original Code is Copyright (C) 2007 Blender Foundation.
21  * All rights reserved.
22  *
23  * 
24  * Contributor(s): Blender Foundation
25  *
26  * ***** END GPL LICENSE BLOCK *****
27  */
28 #ifndef WM_TYPES_H
29 #define WM_TYPES_H
30
31 struct bContext;
32 struct wmEvent;
33 struct wmWindowManager;
34
35 /* exported types for WM */
36
37 #include "wm_cursors.h"
38 #include "wm_event_types.h"
39
40 /* ************** wmOperatorType ************************ */
41
42 /* flag */
43 #define OPTYPE_REGISTER         1
44
45 /* context to call operator in for WM_operator_name_call */
46 enum {
47         WM_OP_INVOKE_DEFAULT,
48         WM_OP_INVOKE_REGION_WIN,
49         WM_OP_INVOKE_AREA,
50         WM_OP_INVOKE_SCREEN,
51         WM_OP_EXEC_DEFAULT,
52         WM_OP_EXEC_REGION_WIN,
53         WM_OP_EXEC_AREA,
54         WM_OP_EXEC_SCREEN
55 };
56
57 /* ************** wmEvent ************************ */
58
59 /* each event should have full modifier state */
60 /* event comes from eventmanager and from keymap */
61 typedef struct wmEvent {
62         struct wmEvent *next, *prev;
63         
64         short type;             /* event code itself (short, is also in keymap) */
65         short val;              /* press, release, scrollvalue */
66         short x, y;                             /* mouse pointer position */
67         short prevx, prevy;             /* previous mouse pointer position */
68         short unicode;  /* future, ghost? */
69         char ascii;             /* from ghost */
70         char pad1;              
71         
72         /* modifier states */
73         short shift, ctrl, alt, oskey;  /* oskey is apple or windowskey, value denotes order of pressed */
74         short keymodifier;                              /* rawkey modifier */
75         
76         /* keymap item, set by handler (weak?) */
77         const char *keymap_idname;
78         
79         /* custom data */
80         short custom;   /* custom data type, stylus, 6dof, see wm_event_types.h */
81         void *customdata;       /* ascii, unicode, mouse coords, angles, vectors, dragdrop info */
82         short customdatafree;
83         
84 } wmEvent;
85
86
87 /* ************** wmKeyMap ************************ */
88
89 /* modifier */
90 #define KM_SHIFT        1
91 #define KM_CTRL         2
92 #define KM_ALT          4
93 #define KM_OSKEY        8
94         /* means modifier should be pressed 2nd */
95 #define KM_SHIFT2       16
96 #define KM_CTRL2        32
97 #define KM_ALT2         64
98 #define KM_OSKEY2       128
99
100 /* val */
101 #define KM_ANY          -1
102 #define KM_RELEASE      0
103 #define KM_PRESS        1
104
105
106 /* ************** UI Handler ***************** */
107
108 #define WM_UI_HANDLER_CONTINUE  0
109 #define WM_UI_HANDLER_BREAK             1
110
111 typedef int (*wmUIHandlerFunc)(struct bContext *C, struct wmEvent *event, void *userdata);
112 typedef void (*wmUIHandlerRemoveFunc)(struct bContext *C, void *userdata);
113
114 /* ************** Notifiers ****************** */
115
116 typedef struct wmNotifier {
117         struct wmNotifier *prev, *next;
118         
119         struct wmWindowManager *wm;
120         struct wmWindow *window;
121         
122         int swinid;
123         unsigned int category, data, subtype, action;
124         
125         void *reference;
126         
127 } wmNotifier;
128
129
130 /* 4 levels 
131
132 0xFF000000; category
133 0x00FF0000; data
134 0x0000FF00; data subtype (unused?)
135 0x000000FF; action
136 */
137
138 /* category */
139 #define NOTE_CATEGORY           0xFF000000
140 #define NC_WINDOW                       (1<<24)
141 #define NC_SCREEN                       (2<<24)
142 #define NC_SCENE                        (3<<24)
143 #define NC_OBJECT                       (4<<24)
144 #define NC_MATERIAL                     (5<<24)
145 #define NC_TEXTURE                      (6<<24)
146 #define NC_LAMP                         (7<<24)
147
148 /* data type, 256 entries is enough, it can overlap */
149 #define NOTE_DATA                       0x00FF0000
150
151         /* Scene */
152 #define ND_MARKERS                      (2<<16)
153 #define ND_FRAME                        (3<<16)
154 #define ND_RENDER_OPTIONS       (4<<16)
155 #define ND_NODES                        (5<<16)
156 #define ND_SEQUENCER            (6<<16)
157 #define ND_OB_ACTIVE            (7<<16)
158 #define ND_OB_SELECT            (8<<16)
159 #define ND_MODE                         (9<<16)
160
161         /* Object */
162 #define ND_TRANSFORM            (16<<16)
163 #define ND_OB_SHADING           (17<<16)
164 #define ND_POSE                         (18<<16)
165 #define ND_BONE_ACTIVE          (19<<16)
166 #define ND_BONE_SELECT          (20<<16)
167 #define ND_GEOM_SELECT          (21<<16)
168 #define ND_DRAW                         (22<<16)
169 #define ND_MODIFIER                     (23<<16)
170
171         /* Material */
172 #define ND_SHADING                      (30<<16)
173 #define ND_SHADING_DRAW         (31<<16)
174
175         /* Lamp */
176 #define ND_LIGHTING                     (44<<16)
177 #define ND_LIGHTING_DRAW        (45<<16)
178 #define ND_SKY                          (46<<16)
179
180 /* subtype, 256 entries too */
181 #define NOTE_SUBTYPE            0x0000FF00
182
183 /* subtype scene mode */
184 #define NS_MODE_OBJECT          (1<<8)
185
186 #define NS_EDITMODE_MESH        (2<<8)
187 #define NS_EDITMODE_CURVE       (3<<8)
188 #define NS_EDITMODE_SURFACE     (4<<8)
189 #define NS_EDITMODE_TEXT        (5<<8)
190 #define NS_EDITMODE_MBALL       (6<<8)
191 #define NS_EDITMODE_LATTICE     (7<<8)
192 #define NS_EDITMODE_ARMATURE    (8<<8)
193
194
195 /* action classification */
196 #define NOTE_ACTION                     (0x000000FF)
197 #define NA_EDITED                       1
198 #define NA_EVALUATED            2
199 #define NA_ADDED                        3
200 #define NA_REMOVED                      4
201
202
203 /* ************** Gesture Manager data ************** */
204
205 /* wmGesture->type */
206 #define WM_GESTURE_TWEAK                0
207 #define WM_GESTURE_LINE                 1
208 #define WM_GESTURE_RECT                 2
209 #define WM_GESTURE_CROSS_RECT   3
210 #define WM_GESTURE_LASSO                4
211 #define WM_GESTURE_CIRCLE               5
212
213 /* wmGesture is registered to window listbase, handled by operator callbacks */
214 typedef struct wmGesture {
215         struct wmGesture *next, *prev;
216         int event_type; /* event->type */
217         int mode;               /* for modal callback */
218         int type;               /* gesture type define */
219         int swinid;             /* initial subwindow id where it started */
220         int points;             /* optional, amount of points stored */
221         
222         void *customdata;
223         /* customdata for border is a recti */
224         /* customdata for circle is recti, (xmin, ymin) is center, xmax radius */
225         /* customdata for lasso is short array */
226 } wmGesture;
227
228
229 /* ************** custom wmEvent data ************** */
230
231 #define DEV_STYLUS      1
232 #define DEV_ERASER  2
233
234 typedef struct wmTabletData {
235         int Active;                     /* 0=None, 1=Stylus, 2=Eraser */
236         float Pressure;         /* range 0.0 (not touching) to 1.0 (full pressure) */
237         float Xtilt;            /* range 0.0 (upright) to 1.0 (tilted fully against the tablet surface) */
238         float Ytilt;            /* as above */
239 } wmTabletData;
240
241 typedef struct wmTimer {
242         struct wmTimer *next, *prev;
243         double timestep;                /* set by timer user */
244         int event_type;                 /* set by timer user */
245         
246         double duration;                /* total running time in seconds */
247         double delta;                   /* time since previous step in seconds */
248         
249         double ltime;                   /* internal, last time timer was activated */
250         int sleep;                              /* internal, put timers to sleep when needed */
251 } wmTimer;
252
253
254 /* ****************** Messages ********************* */
255
256 enum {
257         WM_LOG_DEBUG                            = 0,
258         WM_LOG_INFO                                     = 1000,
259         WM_LOG_WARNING                          = 2000,
260         WM_ERROR_UNDEFINED                      = 3000,
261         WM_ERROR_INVALID_INPUT          = 3001,
262         WM_ERROR_INVALID_CONTEXT        = 3002,
263         WM_ERROR_OUT_OF_MEMORY          = 3003
264 };
265
266 typedef struct wmReport {
267         struct wmReport *next, *prev;
268         int type;
269         const char *typestr;
270         char *message;
271 } wmReport;
272
273 /* *************** migrated stuff, clean later? ******************************** */
274
275 typedef struct RecentFile {
276         struct RecentFile *next, *prev;
277         char *filename;
278 } RecentFile;
279
280
281 #endif /* WM_TYPES_H */
282