merge with/from trunk at r35190
[blender.git] / source / blender / editors / include / UI_interface.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  * The Original Code is Copyright (C) 2001-2002 by NaN Holding BV.
21  * All rights reserved.
22  *
23  * The Original Code is: all of this file.
24  *
25  * Contributor(s): none yet.
26  *
27  * ***** END GPL LICENSE BLOCK *****
28  */
29
30 /** \file UI_interface.h
31  *  \ingroup editorui
32  */
33
34 #ifndef UI_INTERFACE_H
35 #define UI_INTERFACE_H
36
37 #include "RNA_types.h"
38
39 /* Struct Declarations */
40
41 struct ID;
42 struct Main;
43 struct ListBase;
44 struct ARegion;
45 struct ScrArea;
46 struct wmWindow;
47 struct wmWindowManager;
48 struct wmOperator;
49 struct AutoComplete;
50 struct bContext;
51 struct Panel;
52 struct PanelType;
53 struct PointerRNA;
54 struct PropertyRNA;
55 struct ReportList;
56 struct rcti;
57 struct rctf;
58 struct uiStyle;
59 struct uiFontStyle;
60 struct uiWidgetColors;
61 struct ColorBand;
62 struct CurveMapping;
63 struct Image;
64 struct ImageUser;
65 struct uiWidgetColors;
66 struct Tex;
67 struct MTex;
68 struct ImBuf;
69
70 typedef struct uiBut uiBut;
71 typedef struct uiBlock uiBlock;
72 typedef struct uiPopupBlockHandle uiPopupBlockHandle;
73 typedef struct uiLayout uiLayout;
74
75 /* Defines */
76
77 /* uiBlock->dt */
78 #define UI_EMBOSS               0       /* use widget style for drawing */
79 #define UI_EMBOSSN              1       /* Nothing, only icon and/or text */
80 #define UI_EMBOSSP              2       /* Pulldown menu style */
81 #define UI_EMBOSST              3       /* Table */
82
83 /* uiBlock->direction */
84 #define UI_DIRECTION    (UI_TOP|UI_DOWN|UI_LEFT|UI_RIGHT)
85 #define UI_TOP          1
86 #define UI_DOWN         2
87 #define UI_LEFT         4
88 #define UI_RIGHT        8
89
90 #define UI_CENTER               16
91 #define UI_SHIFT_FLIPPED        32
92
93 /* uiBlock->autofill (not yet used) */
94 // #define UI_BLOCK_COLLUMNS    1
95 // #define UI_BLOCK_ROWS                2
96
97 /* uiBlock->flag (controls) */
98 #define UI_BLOCK_LOOP                   1
99 #define UI_BLOCK_REDRAW                 2
100 #define UI_BLOCK_RET_1                  4               /* XXX 2.5 not implemented */
101 #define UI_BLOCK_NUMSELECT              8
102 /*#define UI_BLOCK_ENTER_OK             16*/ /*UNUSED*/
103 /*#define UI_BLOCK_NOSHADOW             32*/ /*UNUSED*/
104 /*#define UI_BLOCK_UNUSED                       64*/ /*UNUSED*/
105 #define UI_BLOCK_MOVEMOUSE_QUIT 128
106 #define UI_BLOCK_KEEP_OPEN              256
107 #define UI_BLOCK_POPUP                  512
108 #define UI_BLOCK_OUT_1                  1024
109 #define UI_BLOCK_NO_FLIP                2048
110 #define UI_BLOCK_POPUP_MEMORY   4096
111
112 /* uiPopupBlockHandle->menuretval */
113 #define UI_RETURN_CANCEL        1       /* cancel all menus cascading */
114 #define UI_RETURN_OK        2       /* choice made */
115 #define UI_RETURN_OUT       4       /* left the menu */
116 #define UI_RETURN_UPDATE    8       /* update the button that opened */
117
118         /* block->flag bits 12-15 are identical to but->flag bits */
119
120 /* panel controls */
121 #define UI_PNL_SOLID    2
122 #define UI_PNL_CLOSE    32
123 #define UI_PNL_SCALE    512
124
125 /* warning the first 6 flags are internal */
126 /* but->flag */
127 #define UI_TEXT_LEFT    64
128 #define UI_ICON_LEFT    128
129 #define UI_ICON_SUBMENU 256
130 #define UI_ICON_PREVIEW 512
131         /* control for button type block */
132 #define UI_MAKE_TOP             1024
133 #define UI_MAKE_DOWN    2048
134 #define UI_MAKE_LEFT    4096
135 #define UI_MAKE_RIGHT   8192
136
137         /* button align flag, for drawing groups together */
138 #define UI_BUT_ALIGN            (UI_BUT_ALIGN_TOP|UI_BUT_ALIGN_LEFT|UI_BUT_ALIGN_RIGHT|UI_BUT_ALIGN_DOWN)
139 #define UI_BUT_ALIGN_TOP        (1<<14)
140 #define UI_BUT_ALIGN_LEFT       (1<<15)
141 #define UI_BUT_ALIGN_RIGHT      (1<<16)
142 #define UI_BUT_ALIGN_DOWN       (1<<17)
143
144 #define UI_BUT_DISABLED         (1<<18)
145 #define UI_BUT_COLOR_LOCK       (1<<19)
146 #define UI_BUT_ANIMATED         (1<<20)
147 #define UI_BUT_ANIMATED_KEY     (1<<21)
148 #define UI_BUT_DRIVEN           (1<<22)
149 #define UI_BUT_REDALERT         (1<<23)
150 #define UI_BUT_INACTIVE         (1<<24)
151 #define UI_BUT_LAST_ACTIVE      (1<<25)
152 #define UI_BUT_UNDO                     (1<<26)
153 #define UI_BUT_IMMEDIATE        (1<<27)
154 #define UI_BUT_NO_TOOLTIP       (1<<28)
155 #define UI_BUT_NO_UTF8          (1<<29)
156 #define UI_BUT_NO_UTF8          (1<<28)
157
158 #define UI_BUT_VEC_SIZE_LOCK (1<<30) /* used to flag if color hsv-circle should keep luminance */
159 #define UI_BUT_COLOR_CUBIC      (1<<31) /* cubic saturation for the color wheel */
160
161 #define UI_PANEL_WIDTH                  340
162 #define UI_COMPACT_PANEL_WIDTH  160
163
164 /* Button types, bits stored in 1 value... and a short even!
165 - bits 0-4:  bitnr (0-31)
166 - bits 5-7:  pointer type
167 - bit  8:    for 'bit'
168 - bit  9-15: button type (now 6 bits, 64 types)
169 */
170
171 #define CHA     32
172 #define SHO     64
173 #define INT     96
174 #define FLO     128
175 /*#define FUN   192*/ /*UNUSED*/
176 #define BIT     256
177
178 #define BUTPOIN (128+64+32)
179
180 #define BUT     (1<<9)
181 #define ROW     (2<<9)
182 #define TOG     (3<<9)
183 #define SLI     (4<<9)
184 #define NUM     (5<<9)
185 #define TEX     (6<<9)
186 #define TOG3    (7<<9)
187 #define TOGR    (8<<9)
188 #define TOGN    (9<<9)
189 #define LABEL   (10<<9)
190 #define MENU    (11<<9)
191 #define ICONROW (12<<9)
192 #define ICONTOG (13<<9)
193 #define NUMSLI  (14<<9)
194 #define COL             (15<<9)
195 #define IDPOIN  (16<<9)
196 #define HSVSLI  (17<<9)
197 #define SCROLL  (18<<9)
198 #define BLOCK   (19<<9)
199 #define BUTM    (20<<9)
200 #define SEPR    (21<<9)
201 #define LINK    (22<<9)
202 #define INLINK  (23<<9)
203 #define KEYEVT  (24<<9)
204 #define ICONTEXTROW (25<<9)
205 #define HSVCUBE         (26<<9)
206 #define PULLDOWN        (27<<9)
207 #define ROUNDBOX        (28<<9)
208 #define CHARTAB         (29<<9)
209 #define BUT_COLORBAND (30<<9)
210 #define BUT_NORMAL      (31<<9)
211 #define BUT_CURVE       (32<<9)
212 #define BUT_TOGDUAL (33<<9)
213 #define ICONTOGN        (34<<9)
214 #define FTPREVIEW       (35<<9)
215 #define NUMABS          (36<<9)
216 #define TOGBUT          (37<<9)
217 #define OPTION          (38<<9)
218 #define OPTIONN         (39<<9)
219                 /* buttons with value >= SEARCH_MENU don't get undo pushes */
220 #define SEARCH_MENU     (40<<9)
221 #define BUT_EXTRA       (41<<9)
222 #define HSVCIRCLE       (42<<9)
223 #define LISTBOX         (43<<9)
224 #define LISTROW         (44<<9)
225 #define HOTKEYEVT       (45<<9)
226 #define BUT_IMAGE       (46<<9)
227 #define HISTOGRAM       (47<<9)
228 #define WAVEFORM        (48<<9)
229 #define VECTORSCOPE     (49<<9)
230 #define PROGRESSBAR     (50<<9)
231
232 #define BUTTYPE         (63<<9)
233
234 /* gradient types, for color picker HSVCUBE etc */
235 #define UI_GRAD_SV              0
236 #define UI_GRAD_HV              1
237 #define UI_GRAD_HS              2
238 #define UI_GRAD_H               3
239 #define UI_GRAD_S               4
240 #define UI_GRAD_V               5
241
242 #define UI_GRAD_V_ALT   9
243
244 /* Drawing
245  *
246  * Functions to draw various shapes, taking theme settings into account.
247  * Used for code that draws its own UI style elements. */
248
249 void uiEmboss(float x1, float y1, float x2, float y2, int sel);
250 void uiRoundBox(float minx, float miny, float maxx, float maxy, float rad);
251 void uiSetRoundBox(int type);
252 int uiGetRoundBox(void);
253 void uiRoundRect(float minx, float miny, float maxx, float maxy, float rad);
254 void uiDrawMenuBox(float minx, float miny, float maxx, float maxy, short flag, short direction);
255 void uiDrawBoxShadow(unsigned char alpha, float minx, float miny, float maxx, float maxy);
256 void uiDrawBox(int mode, float minx, float miny, float maxx, float maxy, float rad);
257 void uiDrawBoxShade(int mode, float minx, float miny, float maxx, float maxy, float rad, float shadetop, float shadedown);
258 void uiDrawBoxVerticalShade(int mode, float minx, float miny, float maxx, float maxy, float rad, float shadeLeft, float shadeRight);
259
260 /* state for scrolldrawing */
261 #define UI_SCROLL_PRESSED               1
262 #define UI_SCROLL_ARROWS                2
263 #define UI_SCROLL_NO_OUTLINE    4
264 void uiWidgetScrollDraw(struct uiWidgetColors *wcol, struct rcti *rect, struct rcti *slider, int state);
265
266 /* Menu Callbacks */
267
268 typedef void (*uiMenuCreateFunc)(struct bContext *C, struct uiLayout *layout, void *arg1);
269 typedef void (*uiMenuHandleFunc)(struct bContext *C, void *arg, int event);
270
271 /* Popup Menus
272  *
273  * Functions used to create popup menus. For more extended menus the
274  * uiPupMenuBegin/End functions can be used to define own items with
275  * the uiItem functions in between. If it is a simple confirmation menu
276  * or similar, popups can be created with a single function call. */
277
278 typedef struct uiPopupMenu uiPopupMenu;
279
280 uiPopupMenu *uiPupMenuBegin(struct bContext *C, const char *title, int icon);
281 void uiPupMenuEnd(struct bContext *C, struct uiPopupMenu *head);
282 struct uiLayout *uiPupMenuLayout(uiPopupMenu *head);
283
284 void uiPupMenuOkee(struct bContext *C, const char *opname, const char *str, ...);
285 void uiPupMenuSaveOver(struct bContext *C, struct wmOperator *op, const char *filename);
286 void uiPupMenuNotice(struct bContext *C, const char *str, ...);
287 void uiPupMenuError(struct bContext *C, const char *str, ...);
288 void uiPupMenuReports(struct bContext *C, struct ReportList *reports);
289 void uiPupMenuInvoke(struct bContext *C, const char *idname); /* popup registered menu */
290
291 /* Popup Blocks
292  *
293  * Functions used to create popup blocks. These are like popup menus
294  * but allow using all button types and creating an own layout. */
295
296 typedef uiBlock* (*uiBlockCreateFunc)(struct bContext *C, struct ARegion *ar, void *arg1);
297
298 void uiPupBlock(struct bContext *C, uiBlockCreateFunc func, void *arg);
299 void uiPupBlockO(struct bContext *C, uiBlockCreateFunc func, void *arg, const char *opname, int opcontext);
300 void uiPupBlockOperator(struct bContext *C, uiBlockCreateFunc func, struct wmOperator *op, int opcontext);
301
302 void uiPupBlockClose(struct bContext *C, uiBlock *block);
303
304 /* Blocks
305  *
306  * Functions for creating, drawing and freeing blocks. A Block is a
307  * container of buttons and used for various purposes.
308  * 
309  * Begin/Define Buttons/End/Draw is the typical order in which these
310  * function should be called, though for popup blocks Draw is left out.
311  * Freeing blocks is done by the screen/ module automatically.
312  *
313  * */
314
315 uiBlock *uiBeginBlock(const struct bContext *C, struct ARegion *region, const char *name, short dt);
316 void uiEndBlock(const struct bContext *C, uiBlock *block);
317 void uiDrawBlock(const struct bContext *C, struct uiBlock *block);
318
319 uiBlock *uiGetBlock(const char *name, struct ARegion *ar);
320
321 void uiBlockSetEmboss(uiBlock *block, char dt);
322
323 void uiFreeBlock(const struct bContext *C, uiBlock *block);
324 void uiFreeBlocks(const struct bContext *C, struct ListBase *lb);
325 void uiFreeInactiveBlocks(const struct bContext *C, struct ListBase *lb);
326
327 void uiBlockSetRegion(uiBlock *block, struct ARegion *region);
328
329 void uiBlockSetButLock(uiBlock *block, int val, const char *lockstr);
330 void uiBlockClearButLock(uiBlock *block);
331
332 /* automatic aligning, horiz or verical */
333 void uiBlockBeginAlign(uiBlock *block);
334 void uiBlockEndAlign(uiBlock *block);
335
336 /* block bounds/position calculation */
337 enum {
338         UI_BLOCK_BOUNDS=1,
339         UI_BLOCK_BOUNDS_TEXT,
340         UI_BLOCK_BOUNDS_POPUP_MOUSE,
341         UI_BLOCK_BOUNDS_POPUP_MENU,
342         UI_BLOCK_BOUNDS_POPUP_CENTER
343 } eBlockBoundsCalc;
344
345 void uiBoundsBlock(struct uiBlock *block, int addval);
346 void uiTextBoundsBlock(uiBlock *block, int addval);
347 void uiPopupBoundsBlock(uiBlock *block, int addval, int mx, int my);
348 void uiMenuPopupBoundsBlock(uiBlock *block, int addvall, int mx, int my);
349 void uiCenteredBoundsBlock(uiBlock *block, int addval);
350
351 int             uiBlocksGetYMin         (struct ListBase *lb);
352
353 void    uiBlockSetDirection     (uiBlock *block, int direction);
354 void    uiBlockFlipOrder        (uiBlock *block);
355 void    uiBlockSetFlag          (uiBlock *block, int flag);
356 void    uiBlockClearFlag        (uiBlock *block, int flag);
357 void    uiBlockSetXOfs          (uiBlock *block, int xofs);
358
359 int             uiButGetRetVal          (uiBut *but);
360
361 void    uiButSetDragID(uiBut *but, struct ID *id);
362 void    uiButSetDragRNA(uiBut *but, struct PointerRNA *ptr);
363 void    uiButSetDragPath(uiBut *but, const char *path);
364 void    uiButSetDragName(uiBut *but, const char *name);
365 void    uiButSetDragValue(uiBut *but);
366 void    uiButSetDragImage(uiBut *but, const char *path, int icon, struct ImBuf *ima, float scale);
367
368 int             UI_but_active_drop_name(struct bContext *C);
369
370 void    uiButSetFlag            (uiBut *but, int flag);
371 void    uiButClearFlag          (uiBut *but, int flag);
372
373 /* special button case, only draw it when used actively, for outliner etc */
374 int             uiButActiveOnly         (const struct bContext *C, uiBlock *block, uiBut *but);
375
376
377 /* Buttons
378  *
379  * Functions to define various types of buttons in a block. Postfixes:
380  * - F: float
381  * - I: int
382  * - S: short
383  * - C: char
384  * - R: RNA
385  * - O: operator */
386
387 uiBut *uiDefBut(uiBlock *block, 
388                                            int type, int retval, const char *str, 
389                                            int x1, int y1, 
390                                            short x2, short y2, 
391                                            void *poin, 
392                                            float min, float max, 
393                                            float a1, float a2, const char *tip);
394 uiBut *uiDefButF(uiBlock *block, int type, int retval, const char *str, int x1, int y1, short x2, short y2, float *poin, float min, float max, float a1, float a2, const char *tip);
395 uiBut *uiDefButBitF(uiBlock *block, int type, int bit, int retval, const char *str, int x1, int y1, short x2, short y2, float *poin, float min, float max, float a1, float a2, const char *tip);
396 uiBut *uiDefButI(uiBlock *block, int type, int retval, const char *str, int x1, int y1, short x2, short y2, int *poin, float min, float max, float a1, float a2, const char *tip);
397 uiBut *uiDefButBitI(uiBlock *block, int type, int bit, int retval, const char *str, int x1, int y1, short x2, short y2, int *poin, float min, float max, float a1, float a2, const char *tip);
398 uiBut *uiDefButS(uiBlock *block, int type, int retval, const char *str, int x1, int y1, short x2, short y2, short *poin, float min, float max, float a1, float a2, const char *tip);
399 uiBut *uiDefButBitS(uiBlock *block, int type, int bit, int retval, const char *str, int x1, int y1, short x2, short y2, short *poin, float min, float max, float a1, float a2, const char *tip);
400 uiBut *uiDefButC(uiBlock *block, int type, int retval, const char *str, int x1, int y1, short x2, short y2, char *poin, float min, float max, float a1, float a2, const char *tip);
401 uiBut *uiDefButBitC(uiBlock *block, int type, int bit, int retval, const char *str, int x1, int y1, short x2, short y2, char *poin, float min, float max, float a1, float a2, const char *tip);
402 uiBut *uiDefButR(uiBlock *block, int type, int retval, const char *str, int x1, int y1, short x2, short y2, struct PointerRNA *ptr, const char *propname, int index, float min, float max, float a1, float a2, const char *tip);
403 uiBut *uiDefButO(uiBlock *block, int type, const char *opname, int opcontext, const char *str, int x1, int y1, short x2, short y2, const char *tip);
404 uiBut *uiDefButTextO(uiBlock *block, int type, const char *opname, int opcontext, const char *str, int x1, int y1, short x2, short y2, void *poin, float min, float max, float a1, float a2, const char *tip);
405
406 uiBut *uiDefIconBut(uiBlock *block, 
407                                            int type, int retval, int icon, 
408                                            int x1, int y1, 
409                                            short x2, short y2, 
410                                            void *poin, 
411                                            float min, float max, 
412                                            float a1, float a2,  const char *tip);
413 uiBut *uiDefIconButF(uiBlock *block, int type, int retval, int icon, int x1, int y1, short x2, short y2, float *poin, float min, float max, float a1, float a2, const char *tip);
414 uiBut *uiDefIconButBitF(uiBlock *block, int type, int bit, int retval, int icon, int x1, int y1, short x2, short y2, float *poin, float min, float max, float a1, float a2, const char *tip);
415 uiBut *uiDefIconButI(uiBlock *block, int type, int retval, int icon, int x1, int y1, short x2, short y2, int *poin, float min, float max, float a1, float a2, const char *tip);
416 uiBut *uiDefIconButBitI(uiBlock *block, int type, int bit, int retval, int icon, int x1, int y1, short x2, short y2, int *poin, float min, float max, float a1, float a2, const char *tip);
417 uiBut *uiDefIconButS(uiBlock *block, int type, int retval, int icon, int x1, int y1, short x2, short y2, short *poin, float min, float max, float a1, float a2, const char *tip);
418 uiBut *uiDefIconButBitS(uiBlock *block, int type, int bit, int retval, int icon, int x1, int y1, short x2, short y2, short *poin, float min, float max, float a1, float a2, const char *tip);
419 uiBut *uiDefIconButC(uiBlock *block, int type, int retval, int icon, int x1, int y1, short x2, short y2, char *poin, float min, float max, float a1, float a2, const char *tip);
420 uiBut *uiDefIconButBitC(uiBlock *block, int type, int bit, int retval, int icon, int x1, int y1, short x2, short y2, char *poin, float min, float max, float a1, float a2, const char *tip);
421 uiBut *uiDefIconButR(uiBlock *block, int type, int retval, int icon, int x1, int y1, short x2, short y2, struct PointerRNA *ptr, const char *propname, int index, float min, float max, float a1, float a2, const char *tip);
422 uiBut *uiDefIconButO(uiBlock *block, int type, const char *opname, int opcontext, int icon, int x1, int y1, short x2, short y2, const char *tip);
423
424 uiBut *uiDefIconTextBut(uiBlock *block,
425                                                 int type, int retval, int icon, const char *str, 
426                                                 int x1, int y1,
427                                                 short x2, short y2,
428                                                 void *poin,
429                                                 float min, float max,
430                                                 float a1, float a2, const char *tip);
431 uiBut *uiDefIconTextButF(uiBlock *block, int type, int retval, int icon, const char *str, int x1, int y1, short x2, short y2, float *poin, float min, float max, float a1, float a2, const char *tip);
432 uiBut *uiDefIconTextButBitF(uiBlock *block, int type, int bit, int retval, int icon, const char *str, int x1, int y1, short x2, short y2, float *poin, float min, float max, float a1, float a2, const char *tip);
433 uiBut *uiDefIconTextButI(uiBlock *block, int type, int retval, int icon, const char *str, int x1, int y1, short x2, short y2, int *poin, float min, float max, float a1, float a2, const char *tip);
434 uiBut *uiDefIconTextButBitI(uiBlock *block, int type, int bit, int retval, int icon, const char *str, int x1, int y1, short x2, short y2, int *poin, float min, float max, float a1, float a2, const char *tip);
435 uiBut *uiDefIconTextButS(uiBlock *block, int type, int retval, int icon, const char *str, int x1, int y1, short x2, short y2, short *poin, float min, float max, float a1, float a2, const char *tip);
436 uiBut *uiDefIconTextButBitS(uiBlock *block, int type, int bit, int retval, int icon, const char *str, int x1, int y1, short x2, short y2, short *poin, float min, float max, float a1, float a2, const char *tip);
437 uiBut *uiDefIconTextButC(uiBlock *block, int type, int retval, int icon, const char *str, int x1, int y1, short x2, short y2, char *poin, float min, float max, float a1, float a2, const char *tip);
438 uiBut *uiDefIconTextButBitC(uiBlock *block, int type, int bit, int retval, int icon, const char *str, int x1, int y1, short x2, short y2, char *poin, float min, float max, float a1, float a2, const char *tip);
439 uiBut *uiDefIconTextButR(uiBlock *block, int type, int retval, int icon, const char *str, int x1, int y1, short x2, short y2, struct PointerRNA *ptr, const char *propname, int index, float min, float max, float a1, float a2, const char *tip);
440 uiBut *uiDefIconTextButO(uiBlock *block, int type, const char *opname, int opcontext, int icon, const char *str, int x1, int y1, short x2, short y2, const char *tip);
441
442 /* for passing inputs to ButO buttons */
443 struct PointerRNA *uiButGetOperatorPtrRNA(uiBut *but);
444
445 void uiButSetUnitType(uiBut *but, const int unit_type);
446 int uiButGetUnitType(uiBut *but);
447
448 /* Special Buttons
449  *
450  * Butons with a more specific purpose:
451  * - IDPoinBut: for creating buttons that work on a pointer to an ID block.
452  * - MenuBut: buttons that popup a menu (in headers usually).
453  * - PulldownBut: like MenuBut, but creating a uiBlock (for compatibility).
454  * - BlockBut: buttons that popup a block with more buttons.
455  * - KeyevtBut: buttons that can be used to turn key events into values.
456  * - PickerButtons: buttons like the color picker (for code sharing).
457  * - AutoButR: RNA property button with type automatically defined. */
458
459 #define UI_ID_RENAME            1
460 #define UI_ID_BROWSE            2
461 #define UI_ID_ADD_NEW           4
462 #define UI_ID_OPEN                      8
463 #define UI_ID_ALONE                     16
464 #define UI_ID_DELETE            32
465 #define UI_ID_LOCAL                     64
466 #define UI_ID_AUTO_NAME         128
467 #define UI_ID_FAKE_USER         256
468 #define UI_ID_PIN                       512
469 #define UI_ID_BROWSE_RENDER     1024
470 #define UI_ID_PREVIEWS          2048
471 #define UI_ID_FULL                      (UI_ID_RENAME|UI_ID_BROWSE|UI_ID_ADD_NEW|UI_ID_OPEN|UI_ID_ALONE|UI_ID_DELETE|UI_ID_LOCAL)
472
473 typedef void (*uiIDPoinFuncFP)(struct bContext *C, const char *str, struct ID **idpp);
474 typedef void (*uiIDPoinFunc)(struct bContext *C, struct ID *id, int event);
475
476 uiBut *uiDefIDPoinBut(uiBlock *block, uiIDPoinFuncFP func, short blocktype, int retval, const char *str,
477                                                 int x1, int y1, short x2, short y2, void *idpp, const char *tip);
478
479 int uiIconFromID(struct ID *id);
480
481 uiBut *uiDefPulldownBut(uiBlock *block, uiBlockCreateFunc func, void *arg, const char *str, int x1, int y1, short x2, short y2, const char *tip);
482 uiBut *uiDefMenuBut(uiBlock *block, uiMenuCreateFunc func, void *arg, const char *str, int x1, int y1, short x2, short y2, const char *tip);
483 uiBut *uiDefIconTextMenuBut(uiBlock *block, uiMenuCreateFunc func, void *arg, int icon, const char *str, int x1, int y1, short x2, short y2, const char *tip);
484 uiBut *uiDefIconMenuBut(uiBlock *block, uiMenuCreateFunc func, void *arg, int icon, int x1, int y1, short x2, short y2, const char *tip);
485
486 uiBut *uiDefBlockBut(uiBlock *block, uiBlockCreateFunc func, void *func_arg1, const char *str, int x1, int y1, short x2, short y2, const char *tip);
487 uiBut *uiDefBlockButN(uiBlock *block, uiBlockCreateFunc func, void *argN, const char *str, int x1, int y1, short x2, short y2, const char *tip);
488
489 uiBut *uiDefIconBlockBut(uiBlock *block, uiBlockCreateFunc func, void *arg, int retval, int icon, int x1, int y1, short x2, short y2, const char *tip);
490 uiBut *uiDefIconTextBlockBut(uiBlock *block, uiBlockCreateFunc func, void *arg, int icon, const char *str, int x1, int y1, short x2, short y2, const char *tip);
491
492 uiBut *uiDefKeyevtButS(uiBlock *block, int retval, const char *str, int x1, int y1, short x2, short y2, short *spoin, const char *tip);
493 uiBut *uiDefHotKeyevtButS(uiBlock *block, int retval, const char *str, int x1, int y1, short x2, short y2, short *keypoin, short *modkeypoin, const char *tip);
494
495 uiBut *uiDefSearchBut(uiBlock *block, void *arg, int retval, int icon, int maxlen, int x1, int y1, short x2, short y2, float a1, float a2, const char *tip);
496
497 void uiBlockPickerButtons(struct uiBlock *block, float *col, float *hsv, float *old, char *hexcol, char mode, short retval);
498
499 uiBut *uiDefAutoButR(uiBlock *block, struct PointerRNA *ptr, struct PropertyRNA *prop, int index, const char *name, int icon, int x1, int y1, int x2, int y2);
500 int uiDefAutoButsRNA(uiLayout *layout, struct PointerRNA *ptr, int (*check_prop)(struct PropertyRNA *), const char label_align);
501
502 /* Links
503  *
504  * Game engine logic brick links. Non-functional currently in 2.5,
505  * code to handle and draw these is disabled internally. */
506
507 void uiSetButLink(struct uiBut *but,  void **poin,  void ***ppoin,  short *tot,  int from, int to);
508
509 void uiComposeLinks(uiBlock *block);
510 uiBut *uiFindInlink(uiBlock *block, void *poin);
511
512 /* Callbacks
513  *
514  * uiBlockSetHandleFunc/ButmFunc are for handling events through a callback.
515  * HandleFunc gets the retval passed on, and ButmFunc gets a2. The latter is
516  * mostly for compatibility with older code.
517  *
518  * uiButSetCompleteFunc is for tab completion.
519  *
520  * uiButSearchFunc is for name buttons, showing a popup with matches
521  *
522  * uiBlockSetFunc and uiButSetFunc are callbacks run when a button is used,
523  * in case events, operators or RNA are not sufficient to handle the button.
524  *
525  * uiButSetNFunc will free the argument with MEM_freeN. */
526
527 typedef struct uiSearchItems uiSearchItems;
528
529 typedef void (*uiButHandleFunc)(struct bContext *C, void *arg1, void *arg2);
530 typedef void (*uiButHandleRenameFunc)(struct bContext *C, void *arg, char *origstr);
531 typedef void (*uiButHandleNFunc)(struct bContext *C, void *argN, void *arg2);
532 typedef void (*uiButCompleteFunc)(struct bContext *C, char *str, void *arg);
533 typedef void (*uiButSearchFunc)(const struct bContext *C, void *arg, const char *str, uiSearchItems *items);
534 typedef void (*uiBlockHandleFunc)(struct bContext *C, void *arg, int event);
535                 
536                 /* use inside searchfunc to add items */
537 int             uiSearchItemAdd(uiSearchItems *items, const char *name, void *poin, int iconid);
538                 /* bfunc gets search item *poin as arg2, or if NULL the old string */
539 void    uiButSetSearchFunc      (uiBut *but,            uiButSearchFunc sfunc, void *arg1, uiButHandleFunc bfunc, void *active);
540                 /* height in pixels, it's using hardcoded values still */
541 int             uiSearchBoxhHeight(void);
542
543 void    uiBlockSetHandleFunc(uiBlock *block,    uiBlockHandleFunc func, void *arg);
544 void    uiBlockSetButmFunc      (uiBlock *block,        uiMenuHandleFunc func, void *arg);
545 void    uiBlockSetFunc          (uiBlock *block,        uiButHandleFunc func, void *arg1, void *arg2);
546 void    uiBlockSetNFunc         (uiBlock *block,        uiButHandleFunc func, void *argN, void *arg2);
547
548 void    uiButSetRenameFunc      (uiBut *but,            uiButHandleRenameFunc func, void *arg1);
549 void    uiButSetFunc            (uiBut *but,            uiButHandleFunc func, void *arg1, void *arg2);
550 void    uiButSetNFunc           (uiBut *but,            uiButHandleNFunc func, void *argN, void *arg2);
551
552 void    uiButSetCompleteFunc(uiBut *but,                uiButCompleteFunc func, void *arg);
553
554 void    uiBlockSetDrawExtraFunc(uiBlock *block, void (*func)(const struct bContext *C, void *, void *, void *, struct rcti *rect), void *arg1, void *arg2);
555
556 void uiButSetFocusOnEnter       (struct wmWindow *win, uiBut *but);
557
558 /* Autocomplete
559  *
560  * Tab complete helper functions, for use in uiButCompleteFunc callbacks.
561  * Call begin once, then multiple times do_name with all possibilities,
562  * and finally end to finish and get the completed name. */
563
564 typedef struct AutoComplete AutoComplete;
565
566 AutoComplete *autocomplete_begin(const char *startname, int maxlen);
567 void autocomplete_do_name(AutoComplete *autocpl, const char *name);
568 void autocomplete_end(AutoComplete *autocpl, char *autoname);
569
570 /* Panels
571  *
572  * Functions for creating, freeing and drawing panels. The API here
573  * could use a good cleanup, though how they will function in 2.5 is
574  * not clear yet so we postpone that. */
575
576 void uiBeginPanels(const struct bContext *C, struct ARegion *ar);
577 void uiEndPanels(const struct bContext *C, struct ARegion *ar);
578
579 struct Panel *uiBeginPanel(struct ScrArea *sa, struct ARegion *ar, uiBlock *block, struct PanelType *pt, int *open);
580 void uiEndPanel(uiBlock *block, int width, int height);
581
582 /* Handlers
583  *
584  * Handlers that can be registered in regions, areas and windows for
585  * handling WM events. Mostly this is done automatic by modules such
586  * as screen/ if ED_KEYMAP_UI is set, or internally in popup functions. */
587
588 void UI_add_region_handlers(struct ListBase *handlers);
589 void UI_add_area_handlers(struct ListBase *handlers);
590 void UI_add_popup_handlers(struct bContext *C, struct ListBase *handlers, uiPopupBlockHandle *popup);
591 void UI_remove_popup_handlers(struct ListBase *handlers, uiPopupBlockHandle *popup);
592
593 /* Module
594  *
595  * init and exit should be called before using this module. init_userdef must
596  * be used to reinitialize some internal state if user preferences change. */
597
598 void UI_init(void);
599 void UI_init_userdef(void);
600 void UI_exit(void);
601
602 /* Layout
603  *
604  * More automated layout of buttons. Has three levels:
605  * - Layout: contains a number templates, within a bounded width or height.
606  * - Template: predefined layouts for buttons with a number of slots, each
607  *   slot can contain multiple items.
608  * - Item: item to put in a template slot, being either an RNA property,
609  *   operator, label or menu. Also regular buttons can be used when setting
610  *   uiBlockCurLayout. */
611
612 /* layout */
613 #define UI_LAYOUT_HORIZONTAL    0
614 #define UI_LAYOUT_VERTICAL              1
615
616 #define UI_LAYOUT_PANEL                 0
617 #define UI_LAYOUT_HEADER                1
618 #define UI_LAYOUT_MENU                  2
619 #define UI_LAYOUT_TOOLBAR               3
620  
621 #define UI_UNIT_X                               20
622 #define UI_UNIT_Y                               20
623
624 #define UI_LAYOUT_ALIGN_EXPAND  0
625 #define UI_LAYOUT_ALIGN_LEFT    1
626 #define UI_LAYOUT_ALIGN_CENTER  2
627 #define UI_LAYOUT_ALIGN_RIGHT   3
628
629 #define UI_ITEM_O_RETURN_PROPS  1
630 #define UI_ITEM_R_EXPAND                2
631 #define UI_ITEM_R_SLIDER                4
632 #define UI_ITEM_R_TOGGLE                8
633 #define UI_ITEM_R_ICON_ONLY             16
634 #define UI_ITEM_R_EVENT                 32
635 #define UI_ITEM_R_FULL_EVENT    64
636 #define UI_ITEM_R_NO_BG                 128
637 #define UI_ITEM_R_IMMEDIATE             256
638
639 /* uiLayoutOperatorButs flags */
640 #define UI_LAYOUT_OP_SHOW_TITLE 1
641 #define UI_LAYOUT_OP_SHOW_EMPTY 2
642
643 /* for more readable function names */
644 #define ICON_NULL 0
645
646 uiLayout *uiBlockLayout(uiBlock *block, int dir, int type, int x, int y, int size, int em, struct uiStyle *style);
647 void uiBlockSetCurLayout(uiBlock *block, uiLayout *layout);
648 void uiBlockLayoutResolve(uiBlock *block, int *x, int *y);
649
650 uiBlock *uiLayoutGetBlock(uiLayout *layout);
651
652 void uiLayoutSetFunc(uiLayout *layout, uiMenuHandleFunc handlefunc, void *argv);
653 void uiLayoutSetContextPointer(uiLayout *layout, const char *name, struct PointerRNA *ptr);
654 const char *uiLayoutIntrospect(uiLayout *layout); // XXX - testing
655 void uiLayoutOperatorButs(const struct bContext *C, struct uiLayout *layout, struct wmOperator *op, int (*check_prop)(struct PropertyRNA *), const char label_align, const short flag);
656
657 void uiLayoutSetOperatorContext(uiLayout *layout, int opcontext);
658 void uiLayoutSetActive(uiLayout *layout, int active);
659 void uiLayoutSetEnabled(uiLayout *layout, int enabled);
660 void uiLayoutSetRedAlert(uiLayout *layout, int redalert);
661 void uiLayoutSetAlignment(uiLayout *layout, int alignment);
662 void uiLayoutSetKeepAspect(uiLayout *layout, int keepaspect);
663 void uiLayoutSetScaleX(uiLayout *layout, float scale);
664 void uiLayoutSetScaleY(uiLayout *layout, float scale);
665
666 int uiLayoutGetOperatorContext(uiLayout *layout);
667 int uiLayoutGetActive(uiLayout *layout);
668 int uiLayoutGetEnabled(uiLayout *layout);
669 int uiLayoutGetRedAlert(uiLayout *layout);
670 int uiLayoutGetAlignment(uiLayout *layout);
671 int uiLayoutGetKeepAspect(uiLayout *layout);
672 int uiLayoutGetWidth(uiLayout *layout);
673 float uiLayoutGetScaleX(uiLayout *layout);
674 float uiLayoutGetScaleY(uiLayout *layout);
675
676 /* layout specifiers */
677 uiLayout *uiLayoutRow(uiLayout *layout, int align);
678 uiLayout *uiLayoutColumn(uiLayout *layout, int align);
679 uiLayout *uiLayoutColumnFlow(uiLayout *layout, int number, int align);
680 uiLayout *uiLayoutBox(uiLayout *layout);
681 uiLayout *uiLayoutListBox(uiLayout *layout, struct PointerRNA *ptr, struct PropertyRNA *prop,
682         struct PointerRNA *actptr, struct PropertyRNA *actprop);
683 uiLayout *uiLayoutAbsolute(uiLayout *layout, int align);
684 uiLayout *uiLayoutSplit(uiLayout *layout, float percentage, int align);
685 uiLayout *uiLayoutOverlap(uiLayout *layout);
686
687 uiBlock *uiLayoutAbsoluteBlock(uiLayout *layout);
688
689 /* templates */
690 void uiTemplateHeader(uiLayout *layout, struct bContext *C, int menus);
691 void uiTemplateDopeSheetFilter(uiLayout *layout, struct bContext *C, struct PointerRNA *ptr);
692 void uiTemplateID(uiLayout *layout, struct bContext *C, struct PointerRNA *ptr, const char *propname,
693         const char *newop, const char *openop, const char *unlinkop);
694 void uiTemplateIDBrowse(uiLayout *layout, struct bContext *C, struct PointerRNA *ptr, const char *propname,
695                                   const char *newop, const char *openop, const char *unlinkop);
696 void uiTemplateIDPreview(uiLayout *layout, struct bContext *C, struct PointerRNA *ptr, const char *propname,
697         const char *newop, const char *openop, const char *unlinkop, int rows, int cols);
698 void uiTemplateAnyID(uiLayout *layout, struct PointerRNA *ptr, const char *propname, 
699         const char *proptypename, const char *text);
700 void uiTemplatePathBuilder(uiLayout *layout, struct PointerRNA *ptr, const char *propname, 
701         struct PointerRNA *root_ptr, const char *text);
702 uiLayout *uiTemplateModifier(uiLayout *layout, struct bContext *C, struct PointerRNA *ptr);
703 uiLayout *uiTemplateConstraint(uiLayout *layout, struct PointerRNA *ptr);
704 void uiTemplatePreview(uiLayout *layout, struct ID *id, int show_buttons, struct ID *parent, struct MTex *slot);
705 void uiTemplateColorRamp(uiLayout *layout, struct PointerRNA *ptr, const char *propname, int expand);
706 void uiTemplateHistogram(uiLayout *layout, struct PointerRNA *ptr, const char *propname);
707 void uiTemplateWaveform(uiLayout *layout, struct PointerRNA *ptr, const char *propname);
708 void uiTemplateVectorscope(uiLayout *layout, struct PointerRNA *ptr, const char *propname);
709 void uiTemplateCurveMapping(uiLayout *layout, struct PointerRNA *ptr, const char *propname, int type, int levels, int brush);
710 void uiTemplateColorWheel(uiLayout *layout, struct PointerRNA *ptr, const char *propname, int value_slider, int lock, int lock_luminosity, int cubic);
711 void uiTemplateLayers(uiLayout *layout, struct PointerRNA *ptr, const char *propname,
712                           PointerRNA *used_ptr, const char *used_propname, int active_layer);
713 void uiTemplateImage(uiLayout *layout, struct bContext *C, struct PointerRNA *ptr, const char *propname, struct PointerRNA *userptr, int compact);
714 void uiTemplateImageLayers(uiLayout *layout, struct bContext *C, struct Image *ima, struct ImageUser *iuser);
715 void uiTemplateRunningJobs(uiLayout *layout, struct bContext *C);
716 void uiTemplateOperatorSearch(uiLayout *layout);
717 void uiTemplateHeader3D(uiLayout *layout, struct bContext *C);
718 void uiTemplateTextureImage(uiLayout *layout, struct bContext *C, struct Tex *tex);
719 void uiTemplateReportsBanner(uiLayout *layout, struct bContext *C);
720
721 void uiTemplateList(uiLayout *layout, struct bContext *C, struct PointerRNA *ptr, const char *propname, struct PointerRNA *activeptr, const char *activeprop, int rows, int maxrows, int type);
722
723 /* items */
724 void uiItemO(uiLayout *layout, const char *name, int icon, const char *opname);
725 void uiItemEnumO(uiLayout *layout, const char *opname, const char *name, int icon, const char *propname, int value);
726 void uiItemEnumO_string(uiLayout *layout, const char *name, int icon, const char *opname, const char *propname, const char *value);
727 void uiItemsEnumO(uiLayout *layout, const char *opname, const char *propname);
728 void uiItemBooleanO(uiLayout *layout, const char *name, int icon, const char *opname, const char *propname, int value);
729 void uiItemIntO(uiLayout *layout, const char *name, int icon, const char *opname, const char *propname, int value);
730 void uiItemFloatO(uiLayout *layout, const char *name, int icon, const char *opname, const char *propname, float value);
731 void uiItemStringO(uiLayout *layout, const char *name, int icon, const char *opname, const char *propname, const char *value);
732 PointerRNA uiItemFullO(uiLayout *layout, const char *idname, const char *name, int icon, struct IDProperty *properties, int context, int flag);
733
734 void uiItemR(uiLayout *layout, struct PointerRNA *ptr, const char *propname, int flag, const char *name, int icon);
735 void uiItemFullR(uiLayout *layout, struct PointerRNA *ptr, struct PropertyRNA *prop, int index, int value, int flag, const char *name, int icon);
736 void uiItemEnumR(uiLayout *layout, const char *name, int icon, struct PointerRNA *ptr, const char *propname, int value);
737 void uiItemEnumR_string(uiLayout *layout, struct PointerRNA *ptr, const char *propname, const char *value, const char *name, int icon);
738 void uiItemsEnumR(uiLayout *layout, struct PointerRNA *ptr, const char *propname);
739 void uiItemPointerR(uiLayout *layout, struct PointerRNA *ptr, const char *propname, struct PointerRNA *searchptr, const char *searchpropname, const char *name, int icon);
740 void uiItemsFullEnumO(uiLayout *layout, const char *opname, const char *propname, struct IDProperty *properties, int context, int flag);
741
742 void uiItemL(uiLayout *layout, const char *name, int icon); /* label */
743 void uiItemLDrag(uiLayout *layout, struct PointerRNA *ptr, const char *name, int icon); /* label icon for dragging */
744 void uiItemM(uiLayout *layout, struct bContext *C, const char *menuname, const char *name, int icon); /* menu */
745 void uiItemV(uiLayout *layout, const char *name, int icon, int argval); /* value */
746 void uiItemS(uiLayout *layout); /* separator */
747
748 void uiItemMenuF(uiLayout *layout, const char *name, int icon, uiMenuCreateFunc func, void *arg);
749 void uiItemMenuEnumO(uiLayout *layout, const char *opname, const char *propname, const char *name, int icon);
750 void uiItemMenuEnumR(uiLayout *layout, struct PointerRNA *ptr, const char *propname, const char *name, int icon);
751
752 /* UI Operators */
753 void UI_buttons_operatortypes(void);
754
755 /* Helpers for Operators */
756 void uiContextActiveProperty(const struct bContext *C, struct PointerRNA *ptr, struct PropertyRNA **prop, int *index);
757 void uiContextAnimUpdate(const struct bContext *C);
758 void uiFileBrowseContextProperty(const struct bContext *C, struct PointerRNA *ptr, struct PropertyRNA **prop);
759 void uiIDContextProperty(struct bContext *C, struct PointerRNA *ptr, struct PropertyRNA **prop);
760
761 /* Styled text draw */
762 void uiStyleFontSet(struct uiFontStyle *fs);
763 void uiStyleFontDrawExt(struct uiFontStyle *fs, struct rcti *rect, const char *str,
764         float *r_xofs, float *r_yofs);
765 void uiStyleFontDraw(struct uiFontStyle *fs, struct rcti *rect, const char *str);
766 void uiStyleFontDrawRotated(struct uiFontStyle *fs, struct rcti *rect, const char *str);
767
768 int UI_GetStringWidth(const char *str); // XXX temp
769 void UI_DrawString(float x, float y, const char *str); // XXX temp
770 void UI_DrawTriIcon(float x, float y, char dir);
771
772 /* linker workaround ack! */
773 void UI_template_fix_linking(void);
774
775 #endif /*  UI_INTERFACE_H */
776