UI: alternate fix for empty context menu
[blender.git] / source / blender / editors / include / UI_interface.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) 2001-2002 by NaN Holding BV.
19  * All rights reserved.
20  *
21  * The Original Code is: all of this file.
22  *
23  * Contributor(s): none yet.
24  *
25  * ***** END GPL LICENSE BLOCK *****
26  */
27
28 /** \file UI_interface.h
29  *  \ingroup editorui
30  */
31
32 #ifndef __UI_INTERFACE_H__
33 #define __UI_INTERFACE_H__
34
35 #include "BLI_compiler_attrs.h"
36 #include "BLI_sys_types.h" /* size_t */
37 #include "RNA_types.h"
38
39 /* Struct Declarations */
40
41 struct ID;
42 struct IDProperty;
43 struct ListBase;
44 struct ARegion;
45 struct ScrArea;
46 struct bScreen;
47 struct wmEvent;
48 struct wmWindow;
49 struct wmOperator;
50 struct AutoComplete;
51 struct bContext;
52 struct bContextStore;
53 struct Panel;
54 struct PanelType;
55 struct PointerRNA;
56 struct PropertyRNA;
57 struct ReportList;
58 struct rcti;
59 struct uiList;
60 struct uiStyle;
61 struct uiFontStyle;
62 struct uiWidgetColors;
63 struct Image;
64 struct ImageUser;
65 struct wmKeyConfig;
66 struct wmOperatorType;
67 struct uiWidgetColors;
68 struct MTex;
69 struct ImBuf;
70 struct bNodeTree;
71 struct bNode;
72 struct bNodeSocket;
73 struct wmDropBox;
74 struct wmDrag;
75 struct wmEvent;
76
77 typedef struct uiBut uiBut;
78 typedef struct uiBlock uiBlock;
79 typedef struct uiPopupBlockHandle uiPopupBlockHandle;
80 typedef struct uiLayout uiLayout;
81
82 /* Defines */
83
84 /* char for splitting strings, aligning shortcuts in menus, users never see */
85 #define UI_SEP_CHAR   '|'
86 #define UI_SEP_CHAR_S "|"
87
88 /* names */
89 #define UI_MAX_DRAW_STR 400
90 #define UI_MAX_NAME_STR 128
91 #define UI_MAX_SHORTCUT_STR 64
92
93 /* use for clamping popups within the screen */
94 #define UI_SCREEN_MARGIN 10
95
96 /* uiBlock->dt and uiBut->dt */
97 enum {
98         UI_EMBOSS               = 0,  /* use widget style for drawing */
99         UI_EMBOSS_NONE          = 1,  /* Nothing, only icon and/or text */
100         UI_EMBOSS_PULLDOWN      = 2,  /* Pulldown menu style */
101         UI_EMBOSS_RADIAL        = 3,  /* Pie Menu */
102 };
103
104 /* uiBlock->direction */
105 enum {
106         UI_DIR_UP           = (1 << 0),
107         UI_DIR_DOWN         = (1 << 1),
108         UI_DIR_LEFT         = (1 << 2),
109         UI_DIR_RIGHT        = (1 << 3),
110         UI_DIR_CENTER_Y     = (1 << 4),
111
112         UI_DIR_ALL          = (UI_DIR_UP | UI_DIR_DOWN | UI_DIR_LEFT | UI_DIR_RIGHT),
113 };
114
115 #if 0
116 /* uiBlock->autofill (not yet used) */
117 #define UI_BLOCK_COLLUMNS  1
118 #define UI_BLOCK_ROWS      2
119 #endif
120
121 /* uiBlock->flag (controls) */
122 #define UI_BLOCK_LOOP           (1 << 0)
123 #define UI_BLOCK_IS_FLIP        (1 << 1)
124 #define UI_BLOCK_NO_FLIP        (1 << 2)
125 #define UI_BLOCK_NUMSELECT      (1 << 3)
126 #define UI_BLOCK_NO_WIN_CLIP    (1 << 4)   /* don't apply window clipping */ /* was UI_BLOCK_ENTER_OK */
127 #define UI_BLOCK_CLIPBOTTOM     (1 << 5)
128 #define UI_BLOCK_CLIPTOP        (1 << 6)
129 #define UI_BLOCK_MOVEMOUSE_QUIT (1 << 7)
130 #define UI_BLOCK_KEEP_OPEN      (1 << 8)
131 #define UI_BLOCK_POPUP          (1 << 9)
132 #define UI_BLOCK_OUT_1          (1 << 10)
133 #define UI_BLOCK_SEARCH_MENU    (1 << 11)
134 #define UI_BLOCK_POPUP_MEMORY   (1 << 12)
135 #define UI_BLOCK_CLIP_EVENTS    (1 << 13)  /* stop handling mouse events */
136
137 /* block->flag bits 14-17 are identical to but->drawflag bits */
138
139 #define UI_BLOCK_POPUP_HOLD  (1 << 18)
140 #define UI_BLOCK_LIST_ITEM   (1 << 19)
141 #define UI_BLOCK_RADIAL      (1 << 20)
142
143 /* uiPopupBlockHandle->menuretval */
144 #define UI_RETURN_CANCEL     (1 << 0)   /* cancel all menus cascading */
145 #define UI_RETURN_OK         (1 << 1)   /* choice made */
146 #define UI_RETURN_OUT        (1 << 2)   /* left the menu */
147 #define UI_RETURN_OUT_PARENT (1 << 3)   /* let the parent handle this event */
148 #define UI_RETURN_UPDATE     (1 << 4)   /* update the button that opened */
149 #define UI_RETURN_POPUP_OK   (1 << 5)   /* popup is ok to be handled */
150
151 /* panel controls */
152 #define UI_PNL_SOLID    (1 << 1)
153 #define UI_PNL_CLOSE    (1 << 5)
154 #define UI_PNL_SCALE    (1 << 9)
155
156 /* but->flag - general state flags. */
157 enum {
158         /* warning, the first 6 flags are internal */
159         UI_BUT_ICON_SUBMENU    = (1 << 6),
160         UI_BUT_ICON_PREVIEW    = (1 << 7),
161
162         UI_BUT_NODE_LINK       = (1 << 8),
163         UI_BUT_NODE_ACTIVE     = (1 << 9),
164         UI_BUT_DRAG_LOCK       = (1 << 10),
165         UI_BUT_DISABLED        = (1 << 11),  /* grayed out and uneditable */
166         UI_BUT_COLOR_LOCK      = (1 << 12),
167         UI_BUT_ANIMATED        = (1 << 13),
168         UI_BUT_ANIMATED_KEY    = (1 << 14),
169         UI_BUT_DRIVEN          = (1 << 15),
170         UI_BUT_REDALERT        = (1 << 16),
171         UI_BUT_INACTIVE        = (1 << 17),  /* grayed out but still editable */
172         UI_BUT_LAST_ACTIVE     = (1 << 18),
173         UI_BUT_UNDO            = (1 << 19),
174         UI_BUT_IMMEDIATE       = (1 << 20),
175         UI_BUT_NO_UTF8         = (1 << 21),
176
177         UI_BUT_VEC_SIZE_LOCK   = (1 << 22),  /* used to flag if color hsv-circle should keep luminance */
178         UI_BUT_COLOR_CUBIC     = (1 << 23),  /* cubic saturation for the color wheel */
179         UI_BUT_LIST_ITEM       = (1 << 24),  /* This but is "inside" a list item (currently used to change theme colors). */
180         UI_BUT_DRAG_MULTI      = (1 << 25),  /* edit this button as well as the active button (not just dragging) */
181         UI_BUT_SCA_LINK_GREY   = (1 << 26),  /* used to flag if sca links shoud be gray out */
182         UI_BUT_HAS_SEP_CHAR    = (1 << 27),  /* but->str contains UI_SEP_CHAR, used for key shortcuts */
183         UI_BUT_UPDATE_DELAY    = (1 << 28),  /* don't run updates while dragging (needed in rare cases). */
184         UI_BUT_TEXTEDIT_UPDATE = (1 << 29),  /* when widget is in textedit mode, update value on each char stroke */
185         UI_BUT_VALUE_CLEAR     = (1 << 30),  /* show 'x' icon to clear/unlink value of text or search button */
186 };
187
188 #define UI_PANEL_WIDTH          340
189 #define UI_COMPACT_PANEL_WIDTH  160
190
191 #define UI_PANEL_CATEGORY_MARGIN_WIDTH (U.widget_unit * 1.0f)
192
193 /* but->drawflag - these flags should only affect how the button is drawn. */
194 /* Note: currently, these flags _are not passed_ to the widget's state() or draw() functions
195  *       (except for the 'align' ones)!
196  */
197 enum {
198         /* Text and icon alignment (by default, they are centered). */
199         UI_BUT_TEXT_LEFT         = (1 << 1),
200         UI_BUT_ICON_LEFT         = (1 << 2),
201         UI_BUT_TEXT_RIGHT        = (1 << 3),
202         /* Prevent the button to show any tooltip. */
203         UI_BUT_NO_TOOLTIP        = (1 << 4),
204
205         /* Button align flag, for drawing groups together.
206          * Used in 'uiBlock.flag', take care! */
207         UI_BUT_ALIGN_TOP         = (1 << 14),
208         UI_BUT_ALIGN_LEFT        = (1 << 15),
209         UI_BUT_ALIGN_RIGHT       = (1 << 16),
210         UI_BUT_ALIGN_DOWN        = (1 << 17),
211         UI_BUT_ALIGN             = (UI_BUT_ALIGN_TOP | UI_BUT_ALIGN_LEFT | UI_BUT_ALIGN_RIGHT | UI_BUT_ALIGN_DOWN),
212         /* end bits shared with 'uiBlock.flag' */
213
214         /* Warning - HACK! Needed for buttons which are not TOP/LEFT aligned, but have some top/left corner stitched to some
215          *                 other TOP/LEFT-aligned button, because of 'corrective' hack in widget_roundbox_set()... */
216         UI_BUT_ALIGN_STITCH_TOP  = (1 << 18),
217         UI_BUT_ALIGN_STITCH_LEFT = (1 << 19),
218         UI_BUT_ALIGN_ALL         = (UI_BUT_ALIGN | UI_BUT_ALIGN_STITCH_TOP | UI_BUT_ALIGN_STITCH_LEFT),
219
220         UI_BUT_BOX_ITEM          = (1 << 20), /* This but is "inside" a box item (currently used to change theme colors). */
221 };
222
223 /* scale fixed button widths by this to account for DPI */
224
225 #define UI_DPI_FAC ((U.pixelsize * (float)U.dpi) / 72.0f)
226 /* 16 to copy ICON_DEFAULT_HEIGHT */
227 #define UI_DPI_ICON_SIZE ((float)16 * UI_DPI_FAC)
228
229 /* Button types, bits stored in 1 value... and a short even!
230  * - bits 0-4:  bitnr (0-31)
231  * - bits 5-7:  pointer type
232  * - bit  8:    for 'bit'
233  * - bit  9-15: button type (now 6 bits, 64 types)
234  * */
235 typedef enum {
236         UI_BUT_POIN_CHAR = 32,
237         UI_BUT_POIN_SHORT = 64,
238         UI_BUT_POIN_INT = 96,
239         UI_BUT_POIN_FLOAT = 128,
240 /*      UI_BUT_POIN_FUNCTION = 192, */ /*UNUSED*/
241         UI_BUT_POIN_BIT = 256  /* OR'd with a bit index*/
242 } eButPointerType;
243
244 /* requires (but->poin != NULL) */
245 #define UI_BUT_POIN_TYPES (UI_BUT_POIN_FLOAT | UI_BUT_POIN_SHORT | UI_BUT_POIN_CHAR)
246
247 /* assigned to but->type, OR'd with the flags above when passing args */
248 typedef enum {
249         UI_BTYPE_BUT                    = (1 << 9),
250         UI_BTYPE_ROW                    = (2 << 9),
251         UI_BTYPE_TEXT                   = (3 << 9),
252         UI_BTYPE_MENU                   = (4 << 9),  /* dropdown list */
253         UI_BTYPE_BUT_MENU               = (5 << 9),
254         UI_BTYPE_NUM                    = (6 << 9),  /* number button */
255         UI_BTYPE_NUM_SLIDER             = (7 << 9),  /* number slider */
256         UI_BTYPE_TOGGLE                 = (8 << 9),
257         UI_BTYPE_TOGGLE_N               = (9 << 9),
258         UI_BTYPE_ICON_TOGGLE            = (10 << 9),
259         UI_BTYPE_ICON_TOGGLE_N          = (11 << 9),
260         UI_BTYPE_BUT_TOGGLE             = (12 << 9),  /* same as regular toggle, but no on/off state displayed */
261         UI_BTYPE_CHECKBOX               = (13 << 9),  /* similar to toggle, display a 'tick' */
262         UI_BTYPE_CHECKBOX_N             = (14 << 9),
263         UI_BTYPE_COLOR                  = (15 << 9),
264         UI_BTYPE_SCROLL                 = (18 << 9),
265         UI_BTYPE_BLOCK                  = (19 << 9),
266         UI_BTYPE_LABEL                  = (20 << 9),
267         UI_BTYPE_LINK                   = (22 << 9),
268         UI_BTYPE_INLINK                 = (23 << 9),
269         UI_BTYPE_KEY_EVENT              = (24 << 9),
270         UI_BTYPE_HSVCUBE                = (26 << 9),
271         UI_BTYPE_PULLDOWN               = (27 << 9),  /* menu (often used in headers), **_MENU /w different draw-type */
272         UI_BTYPE_ROUNDBOX               = (28 << 9),
273         UI_BTYPE_COLORBAND              = (30 << 9),
274         UI_BTYPE_UNITVEC                = (31 << 9),  /* sphere widget (used to input a unit-vector, aka normal) */
275         UI_BTYPE_CURVE                  = (32 << 9),
276         UI_BTYPE_LISTBOX                = (36 << 9),
277         UI_BTYPE_LISTROW                = (37 << 9),
278         UI_BTYPE_HSVCIRCLE              = (38 << 9),
279         UI_BTYPE_TRACK_PREVIEW          = (40 << 9),
280
281         /* buttons with value >= UI_BTYPE_SEARCH_MENU don't get undo pushes */
282         UI_BTYPE_SEARCH_MENU            = (41 << 9),
283         UI_BTYPE_EXTRA                  = (42 << 9),
284         UI_BTYPE_HOTKEY_EVENT           = (46 << 9),
285         UI_BTYPE_IMAGE                  = (47 << 9),  /* non-interactive image, used for splash screen */
286         UI_BTYPE_HISTOGRAM              = (48 << 9),
287         UI_BTYPE_WAVEFORM               = (49 << 9),
288         UI_BTYPE_VECTORSCOPE            = (50 << 9),
289         UI_BTYPE_PROGRESS_BAR           = (51 << 9),
290         UI_BTYPE_NODE_SOCKET            = (53 << 9),
291         UI_BTYPE_SEPR                   = (54 << 9),
292         UI_BTYPE_SEPR_LINE              = (55 << 9),
293         UI_BTYPE_GRIP                   = (56 << 9),  /* resize handle (resize uilist) */
294 } eButType;
295
296 #define BUTTYPE     (63 << 9)
297
298 /* gradient types, for color picker UI_BTYPE_HSVCUBE etc */
299 #define UI_GRAD_SV      0
300 #define UI_GRAD_HV      1
301 #define UI_GRAD_HS      2
302 #define UI_GRAD_H       3
303 #define UI_GRAD_S       4
304 #define UI_GRAD_V       5
305
306 #define UI_GRAD_V_ALT   9
307 #define UI_GRAD_L_ALT   10
308
309 #define UI_PALETTE_COLOR 20
310
311 /* Drawing
312  *
313  * Functions to draw various shapes, taking theme settings into account.
314  * Used for code that draws its own UI style elements. */
315
316 void UI_draw_roundbox(float minx, float miny, float maxx, float maxy, float rad);
317 void UI_draw_roundbox_corner_set(int type);
318 int  UI_draw_roundbox_corner_get(void);
319 void UI_draw_roundbox_unfilled(float minx, float miny, float maxx, float maxy, float rad);
320 void UI_draw_box_shadow(unsigned char alpha, float minx, float miny, float maxx, float maxy);
321 void UI_draw_roundbox_gl_mode(int mode, float minx, float miny, float maxx, float maxy, float rad);
322 void UI_draw_roundbox_shade_x(int mode, float minx, float miny, float maxx, float maxy, float rad, float shadetop, float shadedown);
323 void UI_draw_roundbox_shade_y(int mode, float minx, float miny, float maxx, float maxy, float rad, float shadeLeft, float shadeRight);
324 void UI_draw_text_underline(int pos_x, int pos_y, int len, int height);
325
326 void UI_draw_safe_areas(
327         float x1, float x2, float y1, float y2,
328         const float title_aspect[2], const float action_aspect[2]);
329
330 /* state for scrolldrawing */
331 #define UI_SCROLL_PRESSED       (1 << 0)
332 #define UI_SCROLL_ARROWS        (1 << 1)
333 #define UI_SCROLL_NO_OUTLINE    (1 << 2)
334 void UI_draw_widget_scroll(struct uiWidgetColors *wcol, const struct rcti *rect, const struct rcti *slider, int state);
335
336 /* Shortening string helper. */
337 float UI_text_clip_middle_ex(
338         struct uiFontStyle *fstyle, char *str, float okwidth, const float minwidth,
339         const size_t max_len, const char rpart_sep);
340
341 /* Callbacks
342  *
343  * UI_block_func_handle_set/ButmFunc are for handling events through a callback.
344  * HandleFunc gets the retval passed on, and ButmFunc gets a2. The latter is
345  * mostly for compatibility with older code.
346  *
347  * UI_but_func_complete_set is for tab completion.
348  *
349  * uiButSearchFunc is for name buttons, showing a popup with matches
350  *
351  * UI_block_func_set and UI_but_func_set are callbacks run when a button is used,
352  * in case events, operators or RNA are not sufficient to handle the button.
353  *
354  * UI_but_funcN_set will free the argument with MEM_freeN. */
355
356 typedef struct uiSearchItems uiSearchItems;
357
358 typedef void (*uiButHandleFunc)(struct bContext *C, void *arg1, void *arg2);
359 typedef void (*uiButHandleRenameFunc)(struct bContext *C, void *arg, char *origstr);
360 typedef void (*uiButHandleNFunc)(struct bContext *C, void *argN, void *arg2);
361 typedef void (*uiButHandleHoldFunc)(struct bContext *C, struct ARegion *butregion, uiBut *but);
362 typedef int (*uiButCompleteFunc)(struct bContext *C, char *str, void *arg);
363 typedef struct ARegion *(*uiButSearchCreateFunc)(struct bContext *C, struct ARegion *butregion, uiBut *but);
364 typedef void (*uiButSearchFunc)(const struct bContext *C, void *arg, const char *str, uiSearchItems *items);
365 /* Must return allocated string. */
366 typedef char *(*uiButToolTipFunc)(struct bContext *C, void *argN, const char *tip);
367
368 typedef void (*uiBlockHandleFunc)(struct bContext *C, void *arg, int event);
369
370 /* Menu Callbacks */
371
372 typedef void (*uiMenuCreateFunc)(struct bContext *C, struct uiLayout *layout, void *arg1);
373 typedef void (*uiMenuHandleFunc)(struct bContext *C, void *arg, int event);
374 /**
375  * Used for cycling menu values without opening the menu (Ctrl-Wheel).
376  * \param direction: forward or backwards [1 / -1].
377  * \param arg1: uiBut.poin (as with #uiMenuCreateFunc).
378  * \return true when the button was changed.
379  */
380 typedef bool (*uiMenuStepFunc)(struct bContext *C, int direction, void *arg1);
381
382 /* interface_region_menu_popup.c */
383 /* Popup Menus
384  *
385  * Functions used to create popup menus. For more extended menus the
386  * UI_popup_menu_begin/End functions can be used to define own items with
387  * the uiItem functions in between. If it is a simple confirmation menu
388  * or similar, popups can be created with a single function call. */
389
390 typedef struct uiPopupMenu uiPopupMenu;
391
392 uiPopupMenu *UI_popup_menu_begin(
393         struct bContext *C, const char *title, int icon) ATTR_NONNULL();
394 uiPopupMenu *UI_popup_menu_begin_ex(
395         struct bContext *C, const char *title, const char *block_name,
396         int icon) ATTR_NONNULL();
397 void UI_popup_menu_end(struct bContext *C, struct uiPopupMenu *head);
398 bool UI_popup_menu_end_or_cancel(struct bContext *C, struct uiPopupMenu *head);
399 struct uiLayout *UI_popup_menu_layout(uiPopupMenu *head);
400
401 void UI_popup_menu_reports(struct bContext *C, struct ReportList *reports) ATTR_NONNULL();
402 int UI_popup_menu_invoke(struct bContext *C, const char *idname, struct ReportList *reports) ATTR_NONNULL(1, 2);
403
404 void UI_popup_menu_retval_set(const uiBlock *block, const int retval, const bool enable);
405 void UI_popup_menu_but_set(uiPopupMenu *pup, struct ARegion *butregion, uiBut *but);
406
407 /* interface_region_menu_pie.c */
408 /* Pie menus */
409 typedef struct uiPieMenu uiPieMenu;
410
411 int UI_pie_menu_invoke(struct bContext *C, const char *idname, const struct wmEvent *event);
412 int UI_pie_menu_invoke_from_operator_enum(
413         struct bContext *C, const char *title, const char *opname,
414         const char *propname, const struct wmEvent *event);
415 int UI_pie_menu_invoke_from_rna_enum(
416         struct bContext *C, const char *title,
417         const char *path, const struct wmEvent *event);
418
419 struct uiPieMenu *UI_pie_menu_begin(
420         struct bContext *C, const char *title, int icon,
421         const struct wmEvent *event) ATTR_NONNULL();
422 void UI_pie_menu_end(struct bContext *C, uiPieMenu *pie);
423 struct uiLayout *UI_pie_menu_layout(struct uiPieMenu *pie);
424
425 /* interface_region_menu_popup.c */
426
427 /* Popup Blocks
428  *
429  * Functions used to create popup blocks. These are like popup menus
430  * but allow using all button types and creating an own layout. */
431 typedef uiBlock * (*uiBlockCreateFunc)(struct bContext *C, struct ARegion *ar, void *arg1);
432 typedef void (*uiBlockCancelFunc)(struct bContext *C, void *arg1);
433
434 void UI_popup_block_invoke(struct bContext *C, uiBlockCreateFunc func, void *arg);
435 void UI_popup_block_invoke_ex(struct bContext *C, uiBlockCreateFunc func, void *arg, const char *opname, int opcontext);
436 void UI_popup_block_ex(struct bContext *C, uiBlockCreateFunc func, uiBlockHandleFunc popup_func, uiBlockCancelFunc cancel_func, void *arg, struct wmOperator *op);
437 /* void uiPupBlockOperator(struct bContext *C, uiBlockCreateFunc func, struct wmOperator *op, int opcontext); */ /* UNUSED */
438
439 void UI_popup_block_close(struct bContext *C, struct wmWindow *win, uiBlock *block);
440
441 /* Blocks
442  *
443  * Functions for creating, drawing and freeing blocks. A Block is a
444  * container of buttons and used for various purposes.
445  *
446  * Begin/Define Buttons/End/Draw is the typical order in which these
447  * function should be called, though for popup blocks Draw is left out.
448  * Freeing blocks is done by the screen/ module automatically.
449  *
450  * */
451
452 uiBlock *UI_block_begin(const struct bContext *C, struct ARegion *region, const char *name, short dt);
453 void UI_block_end_ex(const struct bContext *C, uiBlock *block, const int xy[2], int r_xy[2]);
454 void UI_block_end(const struct bContext *C, uiBlock *block);
455 void UI_block_draw(const struct bContext *C, struct uiBlock *block);
456 void UI_block_update_from_old(const struct bContext *C, struct uiBlock *block);
457
458 uiBlock *UI_block_find_in_region(const char *name, struct ARegion *ar);
459
460 void UI_block_emboss_set(uiBlock *block, char dt);
461
462 void UI_block_free(const struct bContext *C, uiBlock *block);
463 void UI_blocklist_free(const struct bContext *C, struct ListBase *lb);
464 void UI_blocklist_free_inactive(const struct bContext *C, struct ListBase *lb);
465 void UI_screen_free_active_but(const struct bContext *C, struct bScreen *screen);
466
467 void UI_block_region_set(uiBlock *block, struct ARegion *region);
468
469 void UI_block_lock_set(uiBlock *block, bool val, const char *lockstr);
470 void UI_block_lock_clear(uiBlock *block);
471
472 /* automatic aligning, horiz or verical */
473 void UI_block_align_begin(uiBlock *block);
474 void UI_block_align_end(uiBlock *block);
475
476 /* block bounds/position calculation */
477 typedef enum {
478         UI_BLOCK_BOUNDS_NONE = 0,
479         UI_BLOCK_BOUNDS = 1,
480         UI_BLOCK_BOUNDS_TEXT,
481         UI_BLOCK_BOUNDS_POPUP_MOUSE,
482         UI_BLOCK_BOUNDS_POPUP_MENU,
483         UI_BLOCK_BOUNDS_POPUP_CENTER,
484         UI_BLOCK_BOUNDS_PIE_CENTER,
485 } eBlockBoundsCalc;
486
487 void UI_block_bounds_set_normal(struct uiBlock *block, int addval);
488 void UI_block_bounds_set_text(uiBlock *block, int addval);
489 void UI_block_bounds_set_popup(uiBlock *block, int addval, int mx, int my);
490 void UI_block_bounds_set_menu(uiBlock *block, int addvall, int mx, int my);
491 void UI_block_bounds_set_centered(uiBlock *block, int addval);
492 void UI_block_bounds_set_explicit(uiBlock *block, int minx, int miny, int maxx, int maxy);
493
494 int     UI_blocklist_min_y_get(struct ListBase *lb);
495
496 void    UI_block_direction_set(uiBlock *block, char direction);
497 void    UI_block_order_flip(uiBlock *block);
498 void    UI_block_flag_enable(uiBlock *block, int flag);
499 void    UI_block_flag_disable(uiBlock *block, int flag);
500
501 bool    UI_block_is_empty(const uiBlock *block);
502
503 int     UI_but_return_value_get(uiBut *but);
504
505 void    UI_but_drag_set_id(uiBut *but, struct ID *id);
506 void    UI_but_drag_set_rna(uiBut *but, struct PointerRNA *ptr);
507 void    UI_but_drag_set_path(uiBut *but, const char *path, const bool use_free);
508 void    UI_but_drag_set_name(uiBut *but, const char *name);
509 void    UI_but_drag_set_value(uiBut *but);
510 void    UI_but_drag_set_image(
511                 uiBut *but, const char *path, int icon, struct ImBuf *ima, float scale, const bool use_free);
512
513 bool    UI_but_active_drop_name(struct bContext *C);
514 bool    UI_but_active_drop_color(struct bContext *C);
515
516 void    UI_but_flag_enable(uiBut *but, int flag);
517 void    UI_but_flag_disable(uiBut *but, int flag);
518 bool    UI_but_flag_is_set(uiBut *but, int flag);
519
520 void    UI_but_drawflag_enable(uiBut *but, int flag);
521 void    UI_but_drawflag_disable(uiBut *but, int flag);
522
523 void    UI_but_type_set_menu_from_pulldown(uiBut *but);
524
525 /* special button case, only draw it when used actively, for outliner etc */
526 bool    UI_but_active_only(const struct bContext *C, struct ARegion *ar, uiBlock *block, uiBut *but);
527
528 void    UI_but_execute(const struct bContext *C, uiBut *but);
529
530 bool UI_but_online_manual_id(
531         const uiBut *but,
532         char *r_str, size_t maxlength)
533         ATTR_WARN_UNUSED_RESULT;
534 bool UI_but_online_manual_id_from_active(
535         const struct bContext *C,
536         char *r_str, size_t maxlength)
537         ATTR_WARN_UNUSED_RESULT;
538
539 /* Buttons
540  *
541  * Functions to define various types of buttons in a block. Postfixes:
542  * - F: float
543  * - I: int
544  * - S: short
545  * - C: char
546  * - R: RNA
547  * - O: operator */
548
549 uiBut *uiDefBut(uiBlock *block,
550                 int type, int retval, const char *str,
551                 int x1, int y1,
552                 short x2, short y2,
553                 void *poin,
554                 float min, float max,
555                 float a1, float a2, const char *tip);
556 uiBut *uiDefButF(uiBlock *block, int type, int retval, const char *str, int x, int y, short width, short height, float *poin, float min, float max, float a1, float a2, const char *tip);
557 uiBut *uiDefButBitF(uiBlock *block, int type, int bit, int retval, const char *str, int x, int y, short width, short height, float *poin, float min, float max, float a1, float a2, const char *tip);
558 uiBut *uiDefButI(uiBlock *block, int type, int retval, const char *str, int x, int y, short width, short height, int *poin, float min, float max, float a1, float a2, const char *tip);
559 uiBut *uiDefButBitI(uiBlock *block, int type, int bit, int retval, const char *str, int x, int y, short width, short height, int *poin, float min, float max, float a1, float a2, const char *tip);
560 uiBut *uiDefButS(uiBlock *block, int type, int retval, const char *str, int x, int y, short width, short height, short *poin, float min, float max, float a1, float a2, const char *tip);
561 uiBut *uiDefButBitS(uiBlock *block, int type, int bit, int retval, const char *str, int x, int y, short width, short height, short *poin, float min, float max, float a1, float a2, const char *tip);
562 uiBut *uiDefButC(uiBlock *block, int type, int retval, const char *str, int x, int y, short width, short height, char *poin, float min, float max, float a1, float a2, const char *tip);
563 uiBut *uiDefButBitC(uiBlock *block, int type, int bit, int retval, const char *str, int x, int y, short width, short height, char *poin, float min, float max, float a1, float a2, const char *tip);
564 uiBut *uiDefButR(uiBlock *block, int type, int retval, const char *str, int x, int y, short width, short height, struct PointerRNA *ptr, const char *propname, int index, float min, float max, float a1, float a2, const char *tip);
565 uiBut *uiDefButR_prop(uiBlock *block, int type, int retval, const char *str, int x, int y, short width, short height, struct PointerRNA *ptr, struct PropertyRNA *prop, int index, float min, float max, float a1, float a2, const char *tip);
566 uiBut *uiDefButO(uiBlock *block, int type, const char *opname, int opcontext, const char *str, int x, int y, short width, short height, const char *tip);
567 uiBut *uiDefButO_ptr(uiBlock *block, int type, struct wmOperatorType *ot, int opcontext, const char *str, int x, int y, short width, short height, const char *tip);
568
569 uiBut *uiDefIconBut(uiBlock *block,
570                     int type, int retval, int icon,
571                     int x1, int y1,
572                     short x2, short y2,
573                     void *poin,
574                     float min, float max,
575                     float a1, float a2,  const char *tip);
576 uiBut *uiDefIconButF(uiBlock *block, int type, int retval, int icon, int x, int y, short width, short height, float *poin, float min, float max, float a1, float a2, const char *tip);
577 uiBut *uiDefIconButBitF(uiBlock *block, int type, int bit, int retval, int icon, int x, int y, short width, short height, float *poin, float min, float max, float a1, float a2, const char *tip);
578 uiBut *uiDefIconButI(uiBlock *block, int type, int retval, int icon, int x, int y, short width, short height, int *poin, float min, float max, float a1, float a2, const char *tip);
579 uiBut *uiDefIconButBitI(uiBlock *block, int type, int bit, int retval, int icon, int x, int y, short width, short height, int *poin, float min, float max, float a1, float a2, const char *tip);
580 uiBut *uiDefIconButS(uiBlock *block, int type, int retval, int icon, int x, int y, short width, short height, short *poin, float min, float max, float a1, float a2, const char *tip);
581 uiBut *uiDefIconButBitS(uiBlock *block, int type, int bit, int retval, int icon, int x, int y, short width, short height, short *poin, float min, float max, float a1, float a2, const char *tip);
582 uiBut *uiDefIconButC(uiBlock *block, int type, int retval, int icon, int x, int y, short width, short height, char *poin, float min, float max, float a1, float a2, const char *tip);
583 uiBut *uiDefIconButBitC(uiBlock *block, int type, int bit, int retval, int icon, int x, int y, short width, short height, char *poin, float min, float max, float a1, float a2, const char *tip);
584 uiBut *uiDefIconButR(uiBlock *block, int type, int retval, int icon, int x, int y, short width, short height, struct PointerRNA *ptr, const char *propname, int index, float min, float max, float a1, float a2, const char *tip);
585 uiBut *uiDefIconButR_prop(uiBlock *block, int type, int retval, int icon, int x, int y, short width, short height, struct PointerRNA *ptr, PropertyRNA *prop, int index, float min, float max, float a1, float a2, const char *tip);
586 uiBut *uiDefIconButO(uiBlock *block, int type, const char *opname, int opcontext, int icon, int x, int y, short width, short height, const char *tip);
587 uiBut *uiDefIconButO_ptr(uiBlock *block, int type, struct wmOperatorType *ot, int opcontext, int icon, int x, int y, short width, short height, const char *tip);
588
589 uiBut *uiDefIconTextBut(uiBlock *block,
590                         int type, int retval, int icon, const char *str,
591                         int x1, int y1,
592                         short x2, short y2,
593                         void *poin,
594                         float min, float max,
595                         float a1, float a2, const char *tip);
596 uiBut *uiDefIconTextButF(uiBlock *block, int type, int retval, int icon, const char *str, int x, int y, short width, short height, float *poin, float min, float max, float a1, float a2, const char *tip);
597 uiBut *uiDefIconTextButBitF(uiBlock *block, int type, int bit, int retval, int icon, const char *str, int x, int y, short width, short height, float *poin, float min, float max, float a1, float a2, const char *tip);
598 uiBut *uiDefIconTextButI(uiBlock *block, int type, int retval, int icon, const char *str, int x, int y, short width, short height, int *poin, float min, float max, float a1, float a2, const char *tip);
599 uiBut *uiDefIconTextButBitI(uiBlock *block, int type, int bit, int retval, int icon, const char *str, int x, int y, short width, short height, int *poin, float min, float max, float a1, float a2, const char *tip);
600 uiBut *uiDefIconTextButS(uiBlock *block, int type, int retval, int icon, const char *str, int x, int y, short width, short height, short *poin, float min, float max, float a1, float a2, const char *tip);
601 uiBut *uiDefIconTextButBitS(uiBlock *block, int type, int bit, int retval, int icon, const char *str, int x, int y, short width, short height, short *poin, float min, float max, float a1, float a2, const char *tip);
602 uiBut *uiDefIconTextButC(uiBlock *block, int type, int retval, int icon, const char *str, int x, int y, short width, short height, char *poin, float min, float max, float a1, float a2, const char *tip);
603 uiBut *uiDefIconTextButBitC(uiBlock *block, int type, int bit, int retval, int icon, const char *str, int x, int y, short width, short height, char *poin, float min, float max, float a1, float a2, const char *tip);
604 uiBut *uiDefIconTextButR(uiBlock *block, int type, int retval, int icon, const char *str, int x, int y, short width, short height, struct PointerRNA *ptr, const char *propname, int index, float min, float max, float a1, float a2, const char *tip);
605 uiBut *uiDefIconTextButR_prop(uiBlock *block, int type, int retval, int icon, const char *str, int x, int y, short width, short height, struct PointerRNA *ptr, struct PropertyRNA *prop, int index, float min, float max, float a1, float a2, const char *tip);
606 uiBut *uiDefIconTextButO(uiBlock *block, int type, const char *opname, int opcontext, int icon, const char *str, int x, int y, short width, short height, const char *tip);
607 uiBut *uiDefIconTextButO_ptr(uiBlock *block, int type, struct wmOperatorType *ot, int opcontext, int icon, const char *str, int x, int y, short width, short height, const char *tip);
608
609 /* for passing inputs to ButO buttons */
610 struct PointerRNA *UI_but_operator_ptr_get(uiBut *but);
611
612 void UI_but_unit_type_set(uiBut *but, const int unit_type);
613 int UI_but_unit_type_get(const uiBut *but);
614
615 enum {
616         BUT_GET_RNAPROP_IDENTIFIER = 1,
617         BUT_GET_RNASTRUCT_IDENTIFIER,
618         BUT_GET_RNAENUM_IDENTIFIER,
619         BUT_GET_LABEL,
620         BUT_GET_RNA_LABEL,
621         BUT_GET_RNAENUM_LABEL,
622         BUT_GET_RNA_LABEL_CONTEXT, /* Context specified in CTX_XXX_ macros are just unreachable! */
623         BUT_GET_TIP,
624         BUT_GET_RNA_TIP,
625         BUT_GET_RNAENUM_TIP,
626         BUT_GET_OP_KEYMAP,
627         BUT_GET_PROP_KEYMAP
628 };
629
630 typedef struct uiStringInfo {
631         int type;
632         char *strinfo;
633 } uiStringInfo;
634
635 /* Note: Expects pointers to uiStringInfo structs as parameters.
636  *       Will fill them with translated strings, when possible.
637  *       Strings in uiStringInfo must be MEM_freeN'ed by caller. */
638 void UI_but_string_info_get(struct bContext *C, uiBut *but, ...) ATTR_SENTINEL(0);
639
640 /* Edit i18n stuff. */
641 /* Name of the main py op from i18n addon. */
642 #define EDTSRC_I18N_OP_NAME "UI_OT_edittranslation"
643
644 /* Special Buttons
645  *
646  * Buttons with a more specific purpose:
647  * - MenuBut: buttons that popup a menu (in headers usually).
648  * - PulldownBut: like MenuBut, but creating a uiBlock (for compatibility).
649  * - BlockBut: buttons that popup a block with more buttons.
650  * - KeyevtBut: buttons that can be used to turn key events into values.
651  * - PickerButtons: buttons like the color picker (for code sharing).
652  * - AutoButR: RNA property button with type automatically defined. */
653
654 #define UI_ID_RENAME        (1 << 0)
655 #define UI_ID_BROWSE        (1 << 1)
656 #define UI_ID_ADD_NEW       (1 << 2)
657 #define UI_ID_OPEN          (1 << 3)
658 #define UI_ID_ALONE         (1 << 4)
659 #define UI_ID_DELETE        (1 << 5)
660 #define UI_ID_LOCAL         (1 << 6)
661 #define UI_ID_AUTO_NAME     (1 << 7)
662 #define UI_ID_FAKE_USER     (1 << 8)
663 #define UI_ID_PIN           (1 << 9)
664 #define UI_ID_PREVIEWS      (1 << 10)
665 #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)
666
667 /**
668  * Ways to limit what is displayed in ID-search popup.
669  * \note We may want to add LOCAL, LIBRARY ... as needed.
670  */
671 enum {
672         UI_TEMPLATE_ID_FILTER_ALL = 0,
673         UI_TEMPLATE_ID_FILTER_AVAILABLE = 1,
674 };
675
676 int UI_icon_from_id(struct ID *id);
677 int UI_icon_from_report_type(int type);
678
679 uiBut *uiDefPulldownBut(uiBlock *block, uiBlockCreateFunc func, void *arg, const char *str, int x, int y, short width, short height, const char *tip);
680 uiBut *uiDefMenuBut(uiBlock *block, uiMenuCreateFunc func, void *arg, const char *str, int x, int y, short width, short height, const char *tip);
681 uiBut *uiDefIconTextMenuBut(uiBlock *block, uiMenuCreateFunc func, void *arg, int icon, const char *str, int x, int y, short width, short height, const char *tip);
682 uiBut *uiDefIconMenuBut(uiBlock *block, uiMenuCreateFunc func, void *arg, int icon, int x, int y, short width, short height, const char *tip);
683
684 uiBut *uiDefBlockBut(uiBlock *block, uiBlockCreateFunc func, void *func_arg1, const char *str, int x, int y, short width, short height, const char *tip);
685 uiBut *uiDefBlockButN(uiBlock *block, uiBlockCreateFunc func, void *argN, const char *str, int x, int y, short width, short height, const char *tip);
686
687 uiBut *uiDefIconBlockBut(uiBlock *block, uiBlockCreateFunc func, void *arg, int retval, int icon, int x, int y, short width, short height, const char *tip);
688 uiBut *uiDefIconTextBlockBut(uiBlock *block, uiBlockCreateFunc func, void *arg, int icon, const char *str, int x, int y, short width, short height, const char *tip);
689
690 uiBut *uiDefKeyevtButS(uiBlock *block, int retval, const char *str, int x, int y, short width, short height, short *spoin, const char *tip);
691 uiBut *uiDefHotKeyevtButS(uiBlock *block, int retval, const char *str, int x, int y, short width, short height, short *keypoin, short *modkeypoin, const char *tip);
692
693 uiBut *uiDefSearchBut(uiBlock *block, void *arg, int retval, int icon, int maxlen, int x, int y, short width, short height, float a1, float a2, const char *tip);
694 uiBut *uiDefSearchButO_ptr(uiBlock *block, struct wmOperatorType *ot, struct IDProperty *properties,
695                            void *arg, int retval, int icon, int maxlen, int x, int y,
696                            short width, short height, float a1, float a2, const char *tip);
697
698 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);
699 int uiDefAutoButsRNA(uiLayout *layout, struct PointerRNA *ptr, bool (*check_prop)(struct PointerRNA *, struct PropertyRNA *), const char label_align);
700
701 /* Links
702  *
703  * Game engine logic brick links. Non-functional currently in 2.5,
704  * code to handle and draw these is disabled internally. */
705
706 void UI_but_link_set(struct uiBut *but,  void **poin,  void ***ppoin,  short *tot,  int from, int to);
707
708 void UI_block_links_compose(uiBlock *block);
709 uiBut *UI_block_links_find_inlink(uiBlock *block, void *poin);
710
711 /* use inside searchfunc to add items */
712 bool    UI_search_item_add(uiSearchItems *items, const char *name, void *poin, int iconid);
713 /* bfunc gets search item *poin as arg2, or if NULL the old string */
714 void    UI_but_func_search_set(
715         uiBut *but, uiButSearchCreateFunc cfunc, uiButSearchFunc sfunc,
716         void *arg1, uiButHandleFunc bfunc, void *active);
717 /* height in pixels, it's using hardcoded values still */
718 int     UI_searchbox_size_y(void);
719 int     UI_searchbox_size_x(void);
720 /* check if a string is in an existing search box */
721 int     UI_search_items_find_index(uiSearchItems *items, const char *name);
722
723 void    UI_block_func_handle_set(uiBlock *block, uiBlockHandleFunc func, void *arg);
724 void    UI_block_func_butmenu_set(uiBlock *block, uiMenuHandleFunc func, void *arg);
725 void    UI_block_func_set(uiBlock *block, uiButHandleFunc func, void *arg1, void *arg2);
726 void    UI_block_funcN_set(uiBlock *block, uiButHandleNFunc funcN, void *argN, void *arg2);
727
728 void    UI_but_func_rename_set(uiBut *but, uiButHandleRenameFunc func, void *arg1);
729 void    UI_but_func_set(uiBut *but, uiButHandleFunc func, void *arg1, void *arg2);
730 void    UI_but_funcN_set(uiBut *but, uiButHandleNFunc funcN, void *argN, void *arg2);
731
732 void    UI_but_func_complete_set(uiBut *but, uiButCompleteFunc func, void *arg);
733
734 void    UI_but_func_drawextra_set(
735         uiBlock *block,
736         void (*func)(const struct bContext *C, void *, void *, void *, struct rcti *rect),
737         void *arg1, void *arg2);
738
739 void    UI_but_func_menu_step_set(uiBut *but, uiMenuStepFunc func);
740
741 void    UI_but_func_tooltip_set(uiBut *but, uiButToolTipFunc func, void *argN);
742 void    UI_but_tooltip_refresh(struct bContext *C, uiBut *but);
743 void    UI_but_tooltip_timer_remove(struct bContext *C, uiBut *but);
744
745 bool UI_textbutton_activate_rna(const struct bContext *C, struct ARegion *ar,
746                                 const void *rna_poin_data, const char *rna_prop_id);
747 bool UI_textbutton_activate_but(const struct bContext *C, uiBut *but);
748
749 void UI_but_focus_on_enter_event(struct wmWindow *win, uiBut *but);
750
751 void UI_but_func_hold_set(uiBut *but, uiButHandleHoldFunc func, void *argN);
752
753 /* Autocomplete
754  *
755  * Tab complete helper functions, for use in uiButCompleteFunc callbacks.
756  * Call begin once, then multiple times do_name with all possibilities,
757  * and finally end to finish and get the completed name. */
758
759 typedef struct AutoComplete AutoComplete;
760
761 #define AUTOCOMPLETE_NO_MATCH 0
762 #define AUTOCOMPLETE_FULL_MATCH 1
763 #define AUTOCOMPLETE_PARTIAL_MATCH 2
764
765 AutoComplete *UI_autocomplete_begin(const char *startname, size_t maxlen);
766 void UI_autocomplete_update_name(AutoComplete *autocpl, const char *name);
767 int UI_autocomplete_end(AutoComplete *autocpl, char *autoname);
768
769 /* Panels
770  *
771  * Functions for creating, freeing and drawing panels. The API here
772  * could use a good cleanup, though how they will function in 2.5 is
773  * not clear yet so we postpone that. */
774
775 void UI_panels_begin(const struct bContext *C, struct ARegion *ar);
776 void UI_panels_end(const struct bContext *C, struct ARegion *ar, int *x, int *y);
777 void UI_panels_draw(const struct bContext *C, struct ARegion *ar);
778
779 struct Panel *UI_panel_find_by_type(struct ARegion *ar, struct PanelType *pt);
780 struct Panel *UI_panel_begin(struct ScrArea *sa, struct ARegion *ar, uiBlock *block,
781                              struct PanelType *pt, struct Panel *pa, bool *r_open);
782 void UI_panel_end(uiBlock *block, int width, int height);
783 void UI_panels_scale(struct ARegion *ar, float new_width);
784
785 bool                       UI_panel_category_is_visible(struct ARegion *ar);
786 void                       UI_panel_category_add(struct ARegion *ar, const char *name);
787 struct PanelCategoryDyn   *UI_panel_category_find(struct ARegion *ar, const char *idname);
788 struct PanelCategoryStack *UI_panel_category_active_find(struct ARegion *ar, const char *idname);
789 const char                *UI_panel_category_active_get(struct ARegion *ar, bool set_fallback);
790 void                       UI_panel_category_active_set(struct ARegion *ar, const char *idname);
791 struct PanelCategoryDyn   *UI_panel_category_find_mouse_over_ex(struct ARegion *ar, const int x, const int y);
792 struct PanelCategoryDyn   *UI_panel_category_find_mouse_over(struct ARegion *ar, const struct wmEvent *event);
793 void                       UI_panel_category_clear_all(struct ARegion *ar);
794 void                       UI_panel_category_draw_all(struct ARegion *ar, const char *category_id_active);
795
796 /* Handlers
797  *
798  * Handlers that can be registered in regions, areas and windows for
799  * handling WM events. Mostly this is done automatic by modules such
800  * as screen/ if ED_KEYMAP_UI is set, or internally in popup functions. */
801
802 void UI_region_handlers_add(struct ListBase *handlers);
803 void UI_popup_handlers_add(struct bContext *C, struct ListBase *handlers, uiPopupBlockHandle *popup, const char flag);
804 void UI_popup_handlers_remove(struct ListBase *handlers, uiPopupBlockHandle *popup);
805 void UI_popup_handlers_remove_all(struct bContext *C, struct ListBase *handlers);
806
807 /* Module
808  *
809  * init and exit should be called before using this module. init_userdef must
810  * be used to reinitialize some internal state if user preferences change. */
811
812 void UI_init(void);
813 void UI_init_userdef(struct Main *bmain);
814 void UI_reinit_font(void);
815 void UI_reinit_gl_state(void);
816 void UI_exit(void);
817
818 /* Layout
819  *
820  * More automated layout of buttons. Has three levels:
821  * - Layout: contains a number templates, within a bounded width or height.
822  * - Template: predefined layouts for buttons with a number of slots, each
823  *   slot can contain multiple items.
824  * - Item: item to put in a template slot, being either an RNA property,
825  *   operator, label or menu. Also regular buttons can be used when setting
826  *   uiBlockCurLayout. */
827
828 /* layout */
829 #define UI_LAYOUT_HORIZONTAL    0
830 #define UI_LAYOUT_VERTICAL      1
831
832 #define UI_LAYOUT_PANEL         0
833 #define UI_LAYOUT_HEADER        1
834 #define UI_LAYOUT_MENU          2
835 #define UI_LAYOUT_TOOLBAR       3
836 #define UI_LAYOUT_PIEMENU       4
837
838 #define UI_UNIT_X               ((void)0, U.widget_unit)
839 #define UI_UNIT_Y               ((void)0, U.widget_unit)
840
841 #define UI_LAYOUT_ALIGN_EXPAND  0
842 #define UI_LAYOUT_ALIGN_LEFT    1
843 #define UI_LAYOUT_ALIGN_CENTER  2
844 #define UI_LAYOUT_ALIGN_RIGHT   3
845
846 #define UI_ITEM_R_EXPAND        (1 << 1)
847 #define UI_ITEM_R_SLIDER        (1 << 2)
848 #define UI_ITEM_R_TOGGLE        (1 << 3)
849 #define UI_ITEM_R_ICON_ONLY     (1 << 4)
850 #define UI_ITEM_R_EVENT         (1 << 5)
851 #define UI_ITEM_R_FULL_EVENT    (1 << 6)
852 #define UI_ITEM_R_NO_BG         (1 << 7)
853 #define UI_ITEM_R_IMMEDIATE     (1 << 8)
854 #define UI_ITEM_O_DEPRESS       (1 << 9)
855
856 /* uiTemplateOperatorPropertyButs flags */
857 #define UI_TEMPLATE_OP_PROPS_SHOW_TITLE 1
858 #define UI_TEMPLATE_OP_PROPS_SHOW_EMPTY 2
859
860 /* used for transp checkers */
861 #define UI_ALPHA_CHECKER_DARK 100
862 #define UI_ALPHA_CHECKER_LIGHT 160
863
864 /* flags to set which corners will become rounded:
865  *
866  * 1------2
867  * |      |
868  * 8------4 */
869
870 enum {
871         UI_CNR_TOP_LEFT     = (1 << 0),
872         UI_CNR_TOP_RIGHT    = (1 << 1),
873         UI_CNR_BOTTOM_RIGHT = (1 << 2),
874         UI_CNR_BOTTOM_LEFT  = (1 << 3),
875         /* just for convenience */
876         UI_CNR_NONE         = 0,
877         UI_CNR_ALL          = (UI_CNR_TOP_LEFT | UI_CNR_TOP_RIGHT | UI_CNR_BOTTOM_RIGHT | UI_CNR_BOTTOM_LEFT)
878 };
879
880 /* not apart of the corner flags but mixed in some functions  */
881 #define UI_RB_ALPHA (UI_CNR_ALL + 1)
882
883 uiLayout *UI_block_layout(uiBlock *block, int dir, int type, int x, int y, int size, int em, int padding, struct uiStyle *style);
884 void UI_block_layout_set_current(uiBlock *block, uiLayout *layout);
885 void UI_block_layout_resolve(uiBlock *block, int *x, int *y);
886
887 uiBlock *uiLayoutGetBlock(uiLayout *layout);
888
889 void uiLayoutSetFunc(uiLayout *layout, uiMenuHandleFunc handlefunc, void *argv);
890 void uiLayoutSetContextPointer(uiLayout *layout, const char *name, struct PointerRNA *ptr);
891 void uiLayoutContextCopy(uiLayout *layout, struct bContextStore *context);
892 struct MenuType *UI_but_menutype_get(uiBut *but);
893 void UI_menutype_draw(struct bContext *C, struct MenuType *mt, struct uiLayout *layout);
894
895 /* Only for convenience. */
896 void uiLayoutSetContextFromBut(uiLayout *layout, uiBut *but);
897
898 void uiLayoutSetOperatorContext(uiLayout *layout, int opcontext);
899 void uiLayoutSetActive(uiLayout *layout, bool active);
900 void uiLayoutSetEnabled(uiLayout *layout, bool enabled);
901 void uiLayoutSetRedAlert(uiLayout *layout, bool redalert);
902 void uiLayoutSetAlignment(uiLayout *layout, char alignment);
903 void uiLayoutSetKeepAspect(uiLayout *layout, bool keepaspect);
904 void uiLayoutSetScaleX(uiLayout *layout, float scale);
905 void uiLayoutSetScaleY(uiLayout *layout, float scale);
906
907 int uiLayoutGetOperatorContext(uiLayout *layout);
908 bool uiLayoutGetActive(uiLayout *layout);
909 bool uiLayoutGetEnabled(uiLayout *layout);
910 bool uiLayoutGetRedAlert(uiLayout *layout);
911 int uiLayoutGetAlignment(uiLayout *layout);
912 bool uiLayoutGetKeepAspect(uiLayout *layout);
913 int uiLayoutGetWidth(uiLayout *layout);
914 float uiLayoutGetScaleX(uiLayout *layout);
915 float uiLayoutGetScaleY(uiLayout *layout);
916
917 /* layout specifiers */
918 uiLayout *uiLayoutRow(uiLayout *layout, int align);
919 uiLayout *uiLayoutColumn(uiLayout *layout, int align);
920 uiLayout *uiLayoutColumnFlow(uiLayout *layout, int number, int align);
921 uiLayout *uiLayoutBox(uiLayout *layout);
922 uiLayout *uiLayoutListBox(uiLayout *layout, struct uiList *ui_list, struct PointerRNA *ptr, struct PropertyRNA *prop,
923                           struct PointerRNA *actptr, struct PropertyRNA *actprop);
924 uiLayout *uiLayoutAbsolute(uiLayout *layout, int align);
925 uiLayout *uiLayoutSplit(uiLayout *layout, float percentage, int align);
926 uiLayout *uiLayoutOverlap(uiLayout *layout);
927 uiBlock *uiLayoutAbsoluteBlock(uiLayout *layout);
928 uiLayout *uiLayoutRadial(uiLayout *layout);
929
930 /* templates */
931 void uiTemplateHeader(uiLayout *layout, struct bContext *C);
932 void uiTemplateID(
933         uiLayout *layout, struct bContext *C, struct PointerRNA *ptr, const char *propname,
934         const char *newop, const char *openop, const char *unlinkop, int filter);
935 void uiTemplateIDBrowse(
936         uiLayout *layout, struct bContext *C, struct PointerRNA *ptr, const char *propname,
937         const char *newop, const char *openop, const char *unlinkop, int filter);
938 void uiTemplateIDPreview(
939         uiLayout *layout, struct bContext *C, struct PointerRNA *ptr, const char *propname,
940         const char *newop, const char *openop, const char *unlinkop, int rows, int cols, int filter);
941 void uiTemplateAnyID(uiLayout *layout, struct PointerRNA *ptr, const char *propname,
942                      const char *proptypename, const char *text);
943 void uiTemplatePathBuilder(uiLayout *layout, struct PointerRNA *ptr, const char *propname,
944                            struct PointerRNA *root_ptr, const char *text);
945 uiLayout *uiTemplateModifier(uiLayout *layout, struct bContext *C, struct PointerRNA *ptr);
946 uiLayout *uiTemplateConstraint(uiLayout *layout, struct PointerRNA *ptr);
947 void uiTemplatePreview(uiLayout *layout, struct bContext *C, struct ID *id, int show_buttons, struct ID *parent,
948                        struct MTex *slot, const char *preview_id);
949 void uiTemplateColorRamp(uiLayout *layout, struct PointerRNA *ptr, const char *propname, int expand);
950 void uiTemplateIconView(uiLayout *layout, struct PointerRNA *ptr, const char *propname, int show_labels, float icon_scale);
951 void uiTemplateHistogram(uiLayout *layout, struct PointerRNA *ptr, const char *propname);
952 void uiTemplateWaveform(uiLayout *layout, struct PointerRNA *ptr, const char *propname);
953 void uiTemplateVectorscope(uiLayout *layout, struct PointerRNA *ptr, const char *propname);
954 void uiTemplateCurveMapping(uiLayout *layout, struct PointerRNA *ptr, const char *propname, int type,
955                             int levels, int brush, int neg_slope);
956 void uiTemplateColorPicker(uiLayout *layout, struct PointerRNA *ptr, const char *propname, int value_slider, int lock, int lock_luminosity, int cubic);
957 void uiTemplatePalette(uiLayout *layout, struct PointerRNA *ptr, const char *propname, int color);
958 void uiTemplateLayers(uiLayout *layout, struct PointerRNA *ptr, const char *propname,
959                       PointerRNA *used_ptr, const char *used_propname, int active_layer);
960 void uiTemplateGameStates(uiLayout *layout, struct PointerRNA *ptr, const char *propname,
961                       PointerRNA *used_ptr, const char *used_propname, int active_state);
962 void uiTemplateImage(uiLayout *layout, struct bContext *C, struct PointerRNA *ptr, const char *propname, struct PointerRNA *userptr, int compact, int multiview);
963 void uiTemplateImageSettings(uiLayout *layout, struct PointerRNA *imfptr, int color_management);
964 void uiTemplateImageStereo3d(uiLayout *layout, struct PointerRNA *stereo3d_format_ptr);
965 void uiTemplateImageViews(uiLayout *layout, struct PointerRNA *imaptr);
966 void uiTemplateImageFormatViews(uiLayout *layout, PointerRNA *imfptr, PointerRNA *ptr);
967 void uiTemplateImageLayers(uiLayout *layout, struct bContext *C, struct Image *ima, struct ImageUser *iuser);
968 void uiTemplateImageInfo(uiLayout *layout, struct bContext *C, struct Image *ima, struct ImageUser *iuser);
969 void uiTemplateRunningJobs(uiLayout *layout, struct bContext *C);
970 void UI_but_func_operator_search(uiBut *but);
971 void uiTemplateOperatorSearch(uiLayout *layout);
972 void uiTemplateOperatorPropertyButs(const struct bContext *C, uiLayout *layout, struct wmOperator *op,
973                                     bool (*check_prop)(struct PointerRNA *, struct PropertyRNA *),
974                                     const char label_align, const short flag);
975 void uiTemplateHeader3D(uiLayout *layout, struct bContext *C);
976 void uiTemplateEditModeSelection(uiLayout *layout, struct bContext *C);
977 void uiTemplateReportsBanner(uiLayout *layout, struct bContext *C);
978 void uiTemplateKeymapItemProperties(uiLayout *layout, struct PointerRNA *ptr);
979 void uiTemplateComponentMenu(uiLayout *layout, struct PointerRNA *ptr, const char *propname, const char *name);
980 void uiTemplateNodeSocket(uiLayout *layout, struct bContext *C, float *color);
981 void uiTemplateCacheFile(uiLayout *layout, struct bContext *C, struct PointerRNA *ptr, const char *propname);
982
983 /* Default UIList class name, keep in sync with its declaration in bl_ui/__init__.py */
984 #define UI_UL_DEFAULT_CLASS_NAME "UI_UL_list"
985 void uiTemplateList(uiLayout *layout, struct bContext *C, const char *listtype_name, const char *list_id,
986                     struct PointerRNA *dataptr, const char *propname, struct PointerRNA *active_dataptr,
987                     const char *active_propname, const char *item_dyntip_propname,
988                     int rows, int maxrows, int layout_type, int columns);
989 void uiTemplateNodeLink(uiLayout *layout, struct bNodeTree *ntree, struct bNode *node, struct bNodeSocket *input);
990 void uiTemplateNodeView(uiLayout *layout, struct bContext *C, struct bNodeTree *ntree, struct bNode *node, struct bNodeSocket *input);
991 void uiTemplateTextureUser(uiLayout *layout, struct bContext *C);
992 void uiTemplateTextureShow(uiLayout *layout, struct bContext *C, struct PointerRNA *ptr, struct PropertyRNA *prop);
993
994 void uiTemplateMovieClip(struct uiLayout *layout, struct bContext *C, struct PointerRNA *ptr, const char *propname, int compact);
995 void uiTemplateTrack(struct uiLayout *layout, struct PointerRNA *ptr, const char *propname);
996 void uiTemplateMarker(struct uiLayout *layout, struct PointerRNA *ptr, const char *propname, PointerRNA *userptr, PointerRNA *trackptr, int cmpact);
997 void uiTemplateMovieclipInformation(struct uiLayout *layout, struct PointerRNA *ptr, const char *propname, struct PointerRNA *userptr);
998
999 void uiTemplateColorspaceSettings(struct uiLayout *layout, struct PointerRNA *ptr, const char *propname);
1000 void uiTemplateColormanagedViewSettings(struct uiLayout *layout, struct bContext *C, struct PointerRNA *ptr, const char *propname);
1001
1002 /* items */
1003 void uiItemO(uiLayout *layout, const char *name, int icon, const char *opname);
1004 void uiItemEnumO_ptr(uiLayout *layout, struct wmOperatorType *ot, const char *name, int icon, const char *propname, int value);
1005 void uiItemEnumO(uiLayout *layout, const char *opname, const char *name, int icon, const char *propname, int value);
1006 void uiItemEnumO_value(uiLayout *layout, const char *name, int icon, const char *opname, const char *propname, int value);
1007 void uiItemEnumO_string(uiLayout *layout, const char *name, int icon, const char *opname, const char *propname, const char *value);
1008 void uiItemsEnumO(uiLayout *layout, const char *opname, const char *propname);
1009 void uiItemBooleanO(uiLayout *layout, const char *name, int icon, const char *opname, const char *propname, int value);
1010 void uiItemIntO(uiLayout *layout, const char *name, int icon, const char *opname, const char *propname, int value);
1011 void uiItemFloatO(uiLayout *layout, const char *name, int icon, const char *opname, const char *propname, float value);
1012 void uiItemStringO(uiLayout *layout, const char *name, int icon, const char *opname, const char *propname, const char *value);
1013
1014 void uiItemFullO_ptr(
1015         uiLayout *layout, struct wmOperatorType *ot, const char *name, int icon,
1016         struct IDProperty *properties, int context, int flag,
1017         PointerRNA *r_opptr);
1018 void uiItemFullO(
1019         uiLayout *layout, const char *idname, const char *name, int icon,
1020         struct IDProperty *properties, int context, int flag,
1021         PointerRNA *r_opptr);
1022 void uiItemFullOMenuHold_ptr(
1023         uiLayout *layout, struct wmOperatorType *ot, const char *name, int icon,
1024         struct IDProperty *properties, int context, int flag,
1025         const char *menu_id,  /* extra menu arg. */
1026         PointerRNA *r_opptr);
1027
1028 void uiItemR(uiLayout *layout, struct PointerRNA *ptr, const char *propname, int flag, const char *name, int icon);
1029 void uiItemFullR(uiLayout *layout, struct PointerRNA *ptr, struct PropertyRNA *prop, int index, int value, int flag, const char *name, int icon);
1030 void uiItemEnumR_prop(uiLayout *layout, const char *name, int icon, struct PointerRNA *ptr, PropertyRNA *prop, int value);
1031 void uiItemEnumR(uiLayout *layout, const char *name, int icon, struct PointerRNA *ptr, const char *propname, int value);
1032 void uiItemEnumR_string(uiLayout *layout, struct PointerRNA *ptr, const char *propname, const char *value, const char *name, int icon);
1033 void uiItemsEnumR(uiLayout *layout, struct PointerRNA *ptr, const char *propname);
1034 void uiItemPointerR(uiLayout *layout, struct PointerRNA *ptr, const char *propname, struct PointerRNA *searchptr, const char *searchpropname, const char *name, int icon);
1035 void uiItemsFullEnumO(
1036         uiLayout *layout, const char *opname, const char *propname,
1037         struct IDProperty *properties, int context, int flag);
1038 void uiItemsFullEnumO_items(
1039         uiLayout *layout, struct wmOperatorType *ot, PointerRNA ptr, PropertyRNA *prop,
1040         struct IDProperty *properties, int context, int flag,
1041         const EnumPropertyItem *item_array, int totitem);
1042
1043 void uiItemL(uiLayout *layout, const char *name, int icon); /* label */
1044 void uiItemLDrag(uiLayout *layout, struct PointerRNA *ptr, const char *name, int icon); /* label icon for dragging */
1045 void uiItemM(uiLayout *layout, struct bContext *C, const char *menuname, const char *name, int icon); /* menu */
1046 void uiItemV(uiLayout *layout, const char *name, int icon, int argval); /* value */
1047 void uiItemS(uiLayout *layout); /* separator */
1048
1049 void uiItemMenuF(uiLayout *layout, const char *name, int icon, uiMenuCreateFunc func, void *arg);
1050 void uiItemMenuEnumO_ptr(uiLayout *layout, struct bContext *C, struct wmOperatorType *ot, const char *propname, const char *name, int icon);
1051 void uiItemMenuEnumO(uiLayout *layout, struct bContext *C, const char *opname, const char *propname, const char *name, int icon);
1052 void uiItemMenuEnumR_prop(uiLayout *layout, struct PointerRNA *ptr, PropertyRNA *prop, const char *name, int icon);
1053 void uiItemMenuEnumR(uiLayout *layout, struct PointerRNA *ptr, const char *propname, const char *name, int icon);
1054
1055 /* UI Operators */
1056 typedef struct uiDragColorHandle {
1057         float color[3];
1058         bool gamma_corrected;
1059 } uiDragColorHandle;
1060
1061 void ED_operatortypes_ui(void);
1062 void ED_keymap_ui(struct wmKeyConfig *keyconf);
1063
1064 void UI_drop_color_copy(struct wmDrag *drag, struct wmDropBox *drop);
1065 int UI_drop_color_poll(struct bContext *C, struct wmDrag *drag, const struct wmEvent *event);
1066
1067 bool UI_context_copy_to_selected_list(
1068         struct bContext *C, struct PointerRNA *ptr, struct PropertyRNA *prop,
1069         struct ListBase *r_lb, bool *r_use_path_from_id, char **r_path);
1070
1071 /* Helpers for Operators */
1072 uiBut *UI_context_active_but_get(const struct bContext *C);
1073 uiBut *UI_context_active_but_prop_get(
1074         const struct bContext *C,
1075         struct PointerRNA *r_ptr, struct PropertyRNA **r_prop, int *r_index);
1076 void UI_context_active_but_prop_handle(struct bContext *C);
1077 struct wmOperator *UI_context_active_operator_get(const struct bContext *C);
1078 void UI_context_update_anim_flag(const struct bContext *C);
1079 void UI_context_active_but_prop_get_filebrowser(
1080         const struct bContext *C,
1081         struct PointerRNA *r_ptr, struct PropertyRNA **r_prop, bool *r_is_undo);
1082 void UI_context_active_but_prop_get_templateID(
1083         struct bContext *C,
1084         struct PointerRNA *r_ptr, struct PropertyRNA **r_prop);
1085
1086 uiBut *UI_region_active_but_get(struct ARegion *ar);
1087
1088 /* Styled text draw */
1089 void UI_fontstyle_set(const struct uiFontStyle *fs);
1090 void UI_fontstyle_draw_ex(
1091         const struct uiFontStyle *fs, const struct rcti *rect, const char *str,
1092         size_t len, float *r_xofs, float *r_yofs);
1093 void UI_fontstyle_draw(const struct uiFontStyle *fs, const struct rcti *rect, const char *str);
1094 void UI_fontstyle_draw_rotated(const struct uiFontStyle *fs, const struct rcti *rect, const char *str);
1095 void UI_fontstyle_draw_simple(const struct uiFontStyle *fs, float x, float y, const char *str);
1096 void UI_fontstyle_draw_simple_backdrop(
1097         const struct uiFontStyle *fs, float x, float y, const char *str,
1098         const unsigned char fg[4], const unsigned char bg[4]);
1099
1100 int UI_fontstyle_string_width(const struct uiFontStyle *fs, const char *str);
1101 int UI_fontstyle_height_max(const struct uiFontStyle *fs);
1102
1103 void UI_draw_icon_tri(float x, float y, char dir);
1104
1105 struct uiStyle *UI_style_get(void);             /* use for fonts etc */
1106 struct uiStyle *UI_style_get_dpi(void); /* DPI scaled settings for drawing */
1107
1108 /* linker workaround ack! */
1109 void UI_template_fix_linking(void);
1110
1111 /* UI_OT_editsource helpers */
1112 bool UI_editsource_enable_check(void);
1113 void UI_editsource_active_but_test(uiBut *but);
1114
1115 /* UI_butstore_ helpers */
1116 typedef struct uiButStore uiButStore;
1117 typedef struct uiButStoreElem uiButStoreElem;
1118
1119 uiButStore *UI_butstore_create(uiBlock *block);
1120 void UI_butstore_clear(uiBlock *block);
1121 void UI_butstore_update(uiBlock *block);
1122 void UI_butstore_free(uiBlock *block, uiButStore *bs);
1123 bool UI_butstore_is_valid(uiButStore *bs);
1124 bool UI_butstore_is_registered(uiBlock *block, uiBut *but);
1125 void UI_butstore_register(uiButStore *bs_handle, uiBut **but_p);
1126 bool UI_butstore_register_update(uiBlock *block, uiBut *but_dst, const uiBut *but_src);
1127 void UI_butstore_unregister(uiButStore *bs_handle, uiBut **but_p);
1128
1129 /* ui_interface_region_tooltip.c */
1130 struct ARegion *UI_tooltip_create_from_button(struct bContext *C, struct ARegion *butregion, uiBut *but);
1131 void UI_tooltip_free(struct bContext *C, struct bScreen *sc, struct ARegion *ar);
1132
1133 /* How long before a tool-tip shows. */
1134 #define UI_TOOLTIP_DELAY 0.5
1135
1136 /* Float precision helpers */
1137 #define UI_PRECISION_FLOAT_MAX 6
1138 /* For float buttons the 'step' (or a1), is scaled */
1139 #define UI_PRECISION_FLOAT_SCALE 0.01f
1140
1141 /* Typical UI text */
1142 #define UI_FSTYLE_WIDGET (const uiFontStyle *)&(UI_style_get()->widget)
1143
1144 int UI_calc_float_precision(int prec, double value);
1145
1146 #endif  /* __UI_INTERFACE_H__ */