doxygen: add newline after \file
[blender.git] / source / blender / editors / include / ED_screen.h
1 /*
2  * This program is free software; you can redistribute it and/or
3  * modify it under the terms of the GNU General Public License
4  * as published by the Free Software Foundation; either version 2
5  * of the License, or (at your option) any later version.
6  *
7  * This program is distributed in the hope that it will be useful,
8  * but WITHOUT ANY WARRANTY; without even the implied warranty of
9  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
10  * GNU General Public License for more details.
11  *
12  * You should have received a copy of the GNU General Public License
13  * along with this program; if not, write to the Free Software Foundation,
14  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
15  *
16  * The Original Code is Copyright (C) 2008 Blender Foundation.
17  * All rights reserved.
18  */
19
20 /** \file
21  * \ingroup editors
22  */
23
24 #ifndef __ED_SCREEN_H__
25 #define __ED_SCREEN_H__
26
27 #include "DNA_screen_types.h"
28 #include "DNA_space_types.h"
29 #include "DNA_view2d_types.h"
30 #include "DNA_view3d_types.h"
31 #include "DNA_workspace_types.h"
32
33 #include "DNA_object_enums.h"
34
35 #include "BLI_compiler_attrs.h"
36
37 struct ARegion;
38 struct Depsgraph;
39 struct IDProperty;
40 struct Main;
41 struct MenuType;
42 struct PropertyRNA;
43 struct Scene;
44 struct ViewLayer;
45 struct WorkSpace;
46 struct WorkSpaceInstanceHook;
47 struct bContext;
48 struct bScreen;
49 struct rcti;
50 struct uiBlock;
51 struct uiLayout;
52 struct wmEvent;
53 struct wmKeyConfig;
54 struct wmMsgBus;
55 struct wmMsgSubscribeKey;
56 struct wmMsgSubscribeValue;
57 struct wmNotifier;
58 struct wmOperatorType;
59 struct wmWindow;
60 struct wmWindowManager;
61
62 /* regions */
63 void    ED_region_do_listen(
64         struct wmWindow *win, struct ScrArea *sa, struct ARegion *ar,
65         struct wmNotifier *note, const Scene *scene);
66 void    ED_region_do_layout(struct bContext *C, struct ARegion *ar);
67 void    ED_region_do_draw(struct bContext *C, struct ARegion *ar);
68 void    ED_region_exit(struct bContext *C, struct ARegion *ar);
69 void    ED_region_pixelspace(struct ARegion *ar);
70 void    ED_region_update_rect(struct ARegion *ar);
71 void    ED_region_init(struct ARegion *ar);
72 void    ED_region_tag_redraw(struct ARegion *ar);
73 void    ED_region_tag_redraw_partial(struct ARegion *ar, const struct rcti *rct);
74 void    ED_region_tag_redraw_overlay(struct ARegion *ar);
75 void    ED_region_tag_redraw_no_rebuild(struct ARegion *ar);
76 void    ED_region_tag_refresh_ui(struct ARegion *ar);
77
78 void ED_region_panels_init(struct wmWindowManager *wm, struct ARegion *ar);
79 void ED_region_panels_ex(
80         const struct bContext *C, struct ARegion *ar,
81         const char *contexts[], int contextnr, const bool vertical);
82 void ED_region_panels(
83         const struct bContext *C, struct ARegion *ar);
84 void ED_region_panels_layout_ex(
85         const struct bContext *C, struct ARegion *ar,
86         const char *contexts[], int contextnr, const bool vertical);
87 void ED_region_panels_layout(
88         const struct bContext *C, struct ARegion *ar);
89 void ED_region_panels_draw(
90         const struct bContext *C, struct ARegion *ar);
91
92 void ED_region_header_init(struct ARegion *ar);
93 void ED_region_header(const struct bContext *C, struct ARegion *ar);
94 void ED_region_header_layout(const struct bContext *C, struct ARegion *ar);
95 void ED_region_header_draw(const struct bContext *C, struct ARegion *ar);
96
97 void    ED_region_cursor_set(struct wmWindow *win, struct ScrArea *sa, struct ARegion *ar);
98 void    ED_region_toggle_hidden(struct bContext *C, struct ARegion *ar);
99 void    ED_region_visibility_change_update(struct bContext *C, struct ARegion *ar);
100 void    ED_region_info_draw(struct ARegion *ar, const char *text, float fill_color[4], const bool full_redraw);
101 void    ED_region_info_draw_multiline(ARegion *ar, const char *text_array[], float fill_color[4], const bool full_redraw);
102 void    ED_region_image_metadata_draw(int x, int y, struct ImBuf *ibuf, const rctf *frame, float zoomx, float zoomy);
103 void    ED_region_image_metadata_panel_draw(struct ImBuf *ibuf, struct uiLayout *layout);
104 void    ED_region_grid_draw(struct ARegion *ar, float zoomx, float zoomy);
105 float   ED_region_blend_alpha(struct ARegion *ar);
106 void    ED_region_visible_rect(struct ARegion *ar, struct rcti *rect);
107 bool    ED_region_is_overlap(int spacetype, int regiontype);
108
109 int     ED_region_snap_size_test(const struct ARegion *ar);
110 bool    ED_region_snap_size_apply(struct ARegion *ar, int snap_flag);
111
112 /* message_bus callbacks */
113 void ED_region_do_msg_notify_tag_redraw(
114         struct bContext *C, struct wmMsgSubscribeKey *msg_key, struct wmMsgSubscribeValue *msg_val);
115 void ED_area_do_msg_notify_tag_refresh(
116         struct bContext *C, struct wmMsgSubscribeKey *msg_key, struct wmMsgSubscribeValue *msg_val);
117
118 /* message bus */
119 void ED_region_message_subscribe(
120         struct bContext *C,
121         struct WorkSpace *workspace, struct Scene *scene,
122         struct bScreen *screen, struct ScrArea *sa, struct ARegion *ar,
123         struct wmMsgBus *mbus);
124
125 /* spaces */
126 void    ED_spacetypes_keymap(struct wmKeyConfig *keyconf);
127 int     ED_area_header_switchbutton(const struct bContext *C, struct uiBlock *block, int yco);
128
129 /* areas */
130 void    ED_area_initialize(struct wmWindowManager *wm, struct wmWindow *win, struct ScrArea *sa);
131 void    ED_area_exit(struct bContext *C, struct ScrArea *sa);
132 int     ED_screen_area_active(const struct bContext *C);
133 void    ED_screen_global_areas_refresh(struct wmWindow *win);
134 void    ED_screen_global_areas_sync(struct wmWindow *win);
135 void    ED_area_do_listen(struct wmWindow *win, ScrArea *sa, struct wmNotifier *note, Scene *scene);
136 void    ED_area_tag_redraw(ScrArea *sa);
137 void    ED_area_tag_redraw_no_rebuild(ScrArea *sa);
138 void    ED_area_tag_redraw_regiontype(ScrArea *sa, int type);
139 void    ED_area_tag_refresh(ScrArea *sa);
140 void    ED_area_do_refresh(struct bContext *C, ScrArea *sa);
141 struct AZone *ED_area_azones_update(ScrArea *sa, const int mouse_xy[]);
142 void    ED_area_status_text(ScrArea *sa, const char *str);
143 void    ED_area_newspace(struct bContext *C, ScrArea *sa, int type, const bool skip_ar_exit);
144 void    ED_area_prevspace(struct bContext *C, ScrArea *sa);
145 void    ED_area_swapspace(struct bContext *C, ScrArea *sa1, ScrArea *sa2);
146 int     ED_area_headersize(void);
147 int     ED_area_header_alignment_or_fallback(const ScrArea *area, int fallback);
148 int     ED_area_header_alignment(const ScrArea *area);
149 int     ED_area_global_size_y(const ScrArea *area);
150 int     ED_area_global_min_size_y(const ScrArea *area);
151 int     ED_area_global_max_size_y(const ScrArea *area);
152 bool    ED_area_is_global(const ScrArea *area);
153 int     ED_region_global_size_y(void);
154 void    ED_area_update_region_sizes(struct wmWindowManager *wm, struct wmWindow *win, struct ScrArea *area);
155
156 ScrArea *ED_screen_areas_iter_first(const struct wmWindow *win, const bScreen *screen);
157 ScrArea *ED_screen_areas_iter_next(const bScreen *screen, const ScrArea *area);
158 /**
159  * Iterate over all areas visible in the screen (screen as in everything
160  * visible in the window, not just bScreen).
161  * \note Skips global areas with flag GLOBAL_AREA_IS_HIDDEN.
162  */
163 #define ED_screen_areas_iter(win, screen, area_name)                       \
164         for (ScrArea *area_name = ED_screen_areas_iter_first(win, screen);     \
165              area_name != NULL;                                                \
166              area_name = ED_screen_areas_iter_next(screen, area_name))
167 #define ED_screen_verts_iter(win, screen, vert_name)                       \
168         for (ScrVert *vert_name = (win)->global_areas.vertbase.first ?         \
169                                           (win)->global_areas.vertbase.first : \
170                                           screen->vertbase.first;              \
171              vert_name != NULL;                                                \
172              vert_name = (vert_name == (win)->global_areas.vertbase.last) ? (screen)->vertbase.first : vert_name->next)
173
174 /* screens */
175 void    ED_screens_initialize(struct Main *bmain, struct wmWindowManager *wm);
176 void    ED_screen_draw_edges(struct wmWindow *win);
177 void    ED_screen_draw_join_shape(struct ScrArea *sa1, struct ScrArea *sa2);
178 void    ED_screen_draw_split_preview(struct ScrArea *sa, const int dir, const float fac);
179 void    ED_screen_refresh(struct wmWindowManager *wm, struct wmWindow *win);
180 void    ED_screen_ensure_updated(struct wmWindowManager *wm, struct wmWindow *win, struct bScreen *screen);
181 void    ED_screen_do_listen(struct bContext *C, struct wmNotifier *note);
182 bool    ED_screen_change(struct bContext *C, struct bScreen *sc);
183 void    ED_screen_scene_change(struct bContext *C, struct wmWindow *win, struct Scene *scene);
184 void    ED_screen_set_active_region(struct bContext *C, struct wmWindow *win, const int xy[2]);
185 void    ED_screen_exit(struct bContext *C, struct wmWindow *window, struct bScreen *screen);
186 void    ED_screen_animation_timer(struct bContext *C, int redraws, int refresh, int sync, int enable);
187 void    ED_screen_animation_timer_update(struct bScreen *screen, int redraws, int refresh);
188 void    ED_screen_restore_temp_type(struct bContext *C, ScrArea *sa);
189 ScrArea *ED_screen_full_newspace(struct bContext *C, ScrArea *sa, int type);
190 void    ED_screen_full_prevspace(struct bContext *C, ScrArea *sa);
191 void    ED_screen_full_restore(struct bContext *C, ScrArea *sa);
192 struct ScrArea *ED_screen_state_toggle(struct bContext *C, struct wmWindow *win, struct ScrArea *sa, const short state);
193 void    ED_screens_header_tools_menu_create(struct bContext *C, struct uiLayout *layout, void *arg);
194 void    ED_screens_navigation_bar_tools_menu_create(struct bContext *C, struct uiLayout *layout, void *arg);
195 bool    ED_screen_stereo3d_required(const struct bScreen *screen, const struct Scene *scene);
196 Scene   *ED_screen_scene_find(const struct bScreen *screen, const struct wmWindowManager *wm);
197 Scene   *ED_screen_scene_find_with_window(const struct bScreen *screen, const struct wmWindowManager *wm, struct wmWindow **r_window);
198 struct wmWindow *ED_screen_window_find(const struct bScreen *screen, const struct wmWindowManager *wm);
199 void    ED_screen_preview_render(const struct bScreen *screen, int size_x, int size_y, unsigned int *r_rect) ATTR_NONNULL();
200
201 /* workspaces */
202 struct WorkSpace *ED_workspace_add(
203         struct Main *bmain,
204         const char *name) ATTR_NONNULL();
205 bool ED_workspace_change(
206         struct WorkSpace *workspace_new,
207         struct bContext *C,
208         struct wmWindowManager *wm, struct wmWindow *win) ATTR_NONNULL();
209 struct WorkSpace *ED_workspace_duplicate(
210         struct WorkSpace *workspace_old,
211         struct Main *bmain, struct wmWindow *win);
212 bool ED_workspace_delete(
213         struct WorkSpace *workspace,
214         struct Main *bmain, struct bContext *C,
215         struct wmWindowManager *wm) ATTR_NONNULL();
216 void ED_workspace_scene_data_sync(
217         struct WorkSpaceInstanceHook *hook, Scene *scene) ATTR_NONNULL();
218 struct WorkSpaceLayout *ED_workspace_layout_add(
219         struct Main *bmain,
220         struct WorkSpace *workspace,
221         struct wmWindow *win,
222         const char *name) ATTR_NONNULL();
223 struct WorkSpaceLayout *ED_workspace_layout_duplicate(
224         struct Main *bmain,
225         struct WorkSpace *workspace, const struct WorkSpaceLayout *layout_old,
226         struct wmWindow *win) ATTR_NONNULL();
227 bool ED_workspace_layout_delete(
228         struct WorkSpace *workspace, struct WorkSpaceLayout *layout_old,
229         struct bContext *C) ATTR_NONNULL();
230 bool ED_workspace_layout_cycle(
231         struct WorkSpace *workspace, const short direction,
232         struct bContext *C) ATTR_NONNULL();
233
234 void    ED_workspace_status_text(struct bContext *C, const char *str);
235
236 /* anim */
237 void    ED_update_for_newframe(struct Main *bmain, struct Depsgraph *depsgraph);
238
239 void    ED_refresh_viewport_fps(struct bContext *C);
240 int             ED_screen_animation_play(struct bContext *C, int sync, int mode);
241 bScreen *ED_screen_animation_playing(const struct wmWindowManager *wm);
242 bScreen *ED_screen_animation_no_scrub(const struct wmWindowManager *wm);
243
244 /* screen keymaps */
245 void    ED_operatortypes_screen(void);
246 void    ED_keymap_screen(struct wmKeyConfig *keyconf);
247 /* workspace keymaps */
248 void    ED_operatortypes_workspace(void);
249
250 /* operators; context poll callbacks */
251 bool ED_operator_screenactive(struct bContext *C);
252 bool ED_operator_screen_mainwinactive(struct bContext *C);
253 bool ED_operator_areaactive(struct bContext *C);
254 bool ED_operator_regionactive(struct bContext *C);
255
256 bool ED_operator_scene(struct bContext *C);
257 bool ED_operator_scene_editable(struct bContext *C);
258 bool ED_operator_objectmode(struct bContext *C);
259
260 bool ED_operator_view3d_active(struct bContext *C);
261 bool ED_operator_region_view3d_active(struct bContext *C);
262 bool ED_operator_animview_active(struct bContext *C);
263 bool ED_operator_outliner_active(struct bContext *C);
264 bool ED_operator_outliner_active_no_editobject(struct bContext *C);
265 bool ED_operator_file_active(struct bContext *C);
266 bool ED_operator_action_active(struct bContext *C);
267 bool ED_operator_buttons_active(struct bContext *C);
268 bool ED_operator_node_active(struct bContext *C);
269 bool ED_operator_node_editable(struct bContext *C);
270 bool ED_operator_graphedit_active(struct bContext *C);
271 bool ED_operator_sequencer_active(struct bContext *C);
272 bool ED_operator_sequencer_active_editable(struct bContext *C);
273 bool ED_operator_image_active(struct bContext *C);
274 bool ED_operator_nla_active(struct bContext *C);
275 bool ED_operator_info_active(struct bContext *C);
276 bool ED_operator_console_active(struct bContext *C);
277
278
279 bool ED_operator_object_active(struct bContext *C);
280 bool ED_operator_object_active_editable(struct bContext *C);
281 bool ED_operator_object_active_editable_mesh(struct bContext *C);
282 bool ED_operator_object_active_editable_font(struct bContext *C);
283 bool ED_operator_editmesh(struct bContext *C);
284 bool ED_operator_editmesh_view3d(struct bContext *C);
285 bool ED_operator_editmesh_region_view3d(struct bContext *C);
286 bool ED_operator_editmesh_auto_smooth(struct bContext *C);
287 bool ED_operator_editarmature(struct bContext *C);
288 bool ED_operator_editcurve(struct bContext *C);
289 bool ED_operator_editcurve_3d(struct bContext *C);
290 bool ED_operator_editsurf(struct bContext *C);
291 bool ED_operator_editsurfcurve(struct bContext *C);
292 bool ED_operator_editsurfcurve_region_view3d(struct bContext *C);
293 bool ED_operator_editfont(struct bContext *C);
294 bool ED_operator_editlattice(struct bContext *C);
295 bool ED_operator_editmball(struct bContext *C);
296 bool ED_operator_uvedit(struct bContext *C);
297 bool ED_operator_uvedit_space_image(struct bContext *C);
298 bool ED_operator_uvmap(struct bContext *C);
299 bool ED_operator_posemode_exclusive(struct bContext *C);
300 bool ED_operator_posemode_context(struct bContext *C);
301 bool ED_operator_posemode(struct bContext *C);
302 bool ED_operator_posemode_local(struct bContext *C);
303 bool ED_operator_mask(struct bContext *C);
304 bool ED_operator_camera(struct bContext *C);
305
306 /* screen_user_menu.c */
307
308 bUserMenu **ED_screen_user_menus_find(const struct bContext *C, uint *r_len);
309 struct bUserMenu *ED_screen_user_menu_ensure(struct bContext *C);
310
311
312 struct bUserMenuItem_Op *ED_screen_user_menu_item_find_operator(
313         struct ListBase *lb,
314         const struct wmOperatorType *ot, struct IDProperty *prop, short opcontext);
315 struct bUserMenuItem_Menu *ED_screen_user_menu_item_find_menu(
316         struct ListBase *lb,
317         const struct MenuType *mt);
318 struct bUserMenuItem_Prop *ED_screen_user_menu_item_find_prop(
319         struct ListBase *lb,
320         const char *context_data_path, const char *prop_id, int prop_index);
321
322 void ED_screen_user_menu_item_add_operator(
323         struct ListBase *lb, const char *ui_name,
324         const struct wmOperatorType *ot, const struct IDProperty *prop, short opcontext);
325 void ED_screen_user_menu_item_add_menu(
326         struct ListBase *lb, const char *ui_name,
327         const struct MenuType *mt);
328 void ED_screen_user_menu_item_add_prop(
329         ListBase *lb, const char *ui_name,
330         const char *context_data_path, const char *prop_id, int prop_index);
331
332 void ED_screen_user_menu_item_remove(
333         struct ListBase *lb, struct bUserMenuItem *umi);
334 void ED_screen_user_menu_register(void);
335
336 /* Cache display helpers */
337
338 void ED_region_cache_draw_background(const struct ARegion *ar);
339 void ED_region_cache_draw_curfra_label(const int framenr, const float x, const float y);
340 void ED_region_cache_draw_cached_segments(const struct ARegion *ar, const int num_segments, const int *points, const int sfra, const int efra);
341
342 /* area_utils.c */
343 void ED_region_generic_tools_region_message_subscribe(
344         const struct bContext *C,
345         struct WorkSpace *workspace, struct Scene *scene,
346         struct bScreen *screen, struct ScrArea *sa, struct ARegion *ar,
347         struct wmMsgBus *mbus);
348 int ED_region_generic_tools_region_snap_size(const struct ARegion *ar, int size, int axis);
349
350 /* interface_region_hud.c */
351 struct ARegionType *ED_area_type_hud(int space_type);
352 void ED_area_type_hud_clear(struct wmWindowManager *wm, ScrArea *sa_keep);
353 void ED_area_type_hud_ensure(struct bContext *C, struct ScrArea *sa);
354
355 /* default keymaps, bitflags (matches order of evaluation). */
356 enum {
357         ED_KEYMAP_UI        = (1 << 1),
358         ED_KEYMAP_GIZMO     = (1 << 2),
359         ED_KEYMAP_VIEW2D    = (1 << 3),
360         ED_KEYMAP_MARKERS   = (1 << 4),
361         ED_KEYMAP_ANIMATION = (1 << 5),
362         ED_KEYMAP_FRAMES    = (1 << 6),
363         ED_KEYMAP_HEADER    = (1 << 7),
364         ED_KEYMAP_GPENCIL   = (1 << 8),
365 };
366
367 /* SCREEN_OT_space_context_cycle direction */
368 enum {
369         SPACE_CONTEXT_CYCLE_PREV,
370         SPACE_CONTEXT_CYCLE_NEXT,
371 };
372
373 #endif /* __ED_SCREEN_H__ */