RNA
[blender.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
147 /* data type, 256 entries is enough, it can overlap */
148 #define NOTE_DATA                       0x00FF0000
149
150         /* Scene */
151 #define ND_MARKERS                      (2<<16)
152 #define ND_FRAME                        (3<<16)
153 #define ND_RENDER_OPTIONS       (4<<16)
154 #define ND_NODES                        (5<<16)
155 #define ND_SEQUENCER            (6<<16)
156 #define ND_OB_ACTIVE            (7<<16)
157 #define ND_OB_SELECT            (8<<16)
158 #define ND_MODE                         (9<<16)
159
160         /* Object */
161 #define ND_TRANSFORM            (16<<16)
162 #define ND_SHADING                      (17<<16)
163 #define ND_POSE                         (18<<16)
164 #define ND_BONE_ACTIVE          (19<<16)
165 #define ND_BONE_SELECT          (20<<16)
166 #define ND_GEOM_SELECT          (21<<16)
167
168 /* subtype, 256 entries too */
169 #define NOTE_SUBTYPE            0x0000FF00
170
171 /* subtype scene mode */
172 #define NS_MODE_OBJECT          (1<<8)
173
174 #define NS_EDITMODE_MESH        (2<<8)
175 #define NS_EDITMODE_CURVE       (3<<8)
176 #define NS_EDITMODE_SURFACE     (4<<8)
177 #define NS_EDITMODE_TEXT        (5<<8)
178 #define NS_EDITMODE_MBALL       (6<<8)
179 #define NS_EDITMODE_LATTICE     (7<<8)
180 #define NS_EDITMODE_ARMATURE    (8<<8)
181
182
183 /* action classification */
184 #define NOTE_ACTION                     (0x000000FF)
185 #define NA_EDITED                       1
186 #define NA_EVALUATED            2
187 #define NA_ADDED                        3
188 #define NA_REMOVED                      4
189
190
191 /* ************** Gesture Manager data ************** */
192
193 /* wmGesture->type */
194 #define WM_GESTURE_TWEAK                0
195 #define WM_GESTURE_LINE                 1
196 #define WM_GESTURE_RECT                 2
197 #define WM_GESTURE_CROSS_RECT   3
198 #define WM_GESTURE_LASSO                4
199 #define WM_GESTURE_CIRCLE               5
200
201 /* wmGesture is registered to window listbase, handled by operator callbacks */
202 typedef struct wmGesture {
203         struct wmGesture *next, *prev;
204         int event_type; /* event->type */
205         int mode;               /* for modal callback */
206         int type;               /* gesture type define */
207         int swinid;             /* initial subwindow id where it started */
208         
209         void *customdata;
210         /* customdata for border is a recti */
211         /* customdata for circle is recti, (xmin, ymin) is center, xmax radius */
212         
213 } wmGesture;
214
215
216 /* ************** custom wmEvent data ************** */
217
218 #define DEV_STYLUS      1
219 #define DEV_ERASER  2
220
221 typedef struct wmTabletData {
222         int Active;                     /* 0=None, 1=Stylus, 2=Eraser */
223         float Pressure;         /* range 0.0 (not touching) to 1.0 (full pressure) */
224         float Xtilt;            /* range 0.0 (upright) to 1.0 (tilted fully against the tablet surface) */
225         float Ytilt;            /* as above */
226 } wmTabletData;
227
228 typedef struct wmTimer {
229         struct wmTimer *next, *prev;
230         double timestep;                /* set by timer user */
231         int event_type;                 /* set by timer user */
232         
233         double duration;                /* total running time in seconds */
234         double delta;                   /* time since previous step in seconds */
235         
236         double ltime;                   /* internal, last time timer was activated */
237         int sleep;                              /* internal, put timers to sleep when needed */
238 } wmTimer;
239
240
241 /* ****************** Messages ********************* */
242
243 enum {
244         WM_LOG_DEBUG                            = 0,
245         WM_LOG_INFO                                     = 1000,
246         WM_LOG_WARNING                          = 2000,
247         WM_ERROR_UNDEFINED                      = 3000,
248         WM_ERROR_INVALID_INPUT          = 3001,
249         WM_ERROR_INVALID_CONTEXT        = 3002,
250         WM_ERROR_OUT_OF_MEMORY          = 3003
251 };
252
253 typedef struct wmReport {
254         struct wmReport *next, *prev;
255         int type;
256         const char *typestr;
257         char *message;
258 } wmReport;
259
260 /* *************** migrated stuff, clean later? ******************************** */
261
262 typedef struct RecentFile {
263         struct RecentFile *next, *prev;
264         char *filename;
265 } RecentFile;
266
267
268 #endif /* WM_TYPES_H */
269