Merge remote-tracking branch 'origin/master' into blender2.8
[blender.git] / source / blender / editors / space_outliner / outliner_intern.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) 2008 Blender Foundation.
19  * All rights reserved.
20  *
21  * 
22  * Contributor(s): Blender Foundation
23  *
24  * ***** END GPL LICENSE BLOCK *****
25  */
26
27 /** \file blender/editors/space_outliner/outliner_intern.h
28  *  \ingroup spoutliner
29  */
30
31
32 #ifndef __OUTLINER_INTERN_H__
33 #define __OUTLINER_INTERN_H__
34
35 #include "RNA_types.h"
36
37 /* internal exports only */
38
39 struct ARegion;
40 struct ListBase;
41 struct wmOperatorType;
42 struct TreeElement;
43 struct TreeStoreElem;
44 struct Main;
45 struct bContext;
46 struct Scene;
47 struct ViewLayer;
48 struct ID;
49 struct Object;
50 struct bPoseChannel;
51 struct EditBone;
52 struct wmEvent;
53 struct wmKeyConfig;
54
55 typedef enum TreeElementInsertType {
56         TE_INSERT_BEFORE,
57         TE_INSERT_AFTER,
58         TE_INSERT_INTO,
59 } TreeElementInsertType;
60
61 typedef enum TreeTraversalAction {
62         /* Continue traversal regularly, don't skip children. */
63         TRAVERSE_CONTINUE = 0,
64         /* Stop traversal */
65         TRAVERSE_BREAK,
66         /* Continue traversal, but skip childs of traversed element */
67         TRAVERSE_SKIP_CHILDS,
68 } TreeTraversalAction;
69
70 /**
71  * Callback type for reinserting elements at a different position, used to allow user customizable element order.
72  */
73 typedef void (*TreeElementReinsertFunc)(struct Main *bmain,
74                                         struct SpaceOops *soops,
75                                         struct TreeElement *insert_element,
76                                         struct TreeElement *insert_handle,
77                                         TreeElementInsertType action,
78                                         const struct wmEvent *event);
79 /**
80  * Executed on (almost) each mouse move while dragging. It's supposed to give info
81  * if reinserting insert_element before/after/into insert_handle would be allowed.
82  * It's allowed to change the reinsert info here for non const pointers.
83  */
84 typedef bool (*TreeElementReinsertPollFunc)(const struct TreeElement *insert_element,
85                                             struct TreeElement **io_insert_handle, TreeElementInsertType *io_action);
86 typedef TreeTraversalAction (*TreeTraversalFunc)(struct TreeElement *te, void *customdata);
87
88
89 typedef struct TreeElement {
90         struct TreeElement *next, *prev, *parent;
91         ListBase subtree;
92         int xs, ys;                // do selection
93         TreeStoreElem *store_elem; // element in tree store
94         short flag;                // flag for non-saved stuff
95         short index;               // index for data arrays
96         short idcode;              // from TreeStore id
97         short xend;                // width of item display, for select
98         const char *name;
99         void *directdata;          // Armature Bones, Base, Sequence, Strip...
100         PointerRNA rnaptr;         // RNA Pointer
101
102         /* callbacks - TODO should be moved into a type (like TreeElementType) */
103         TreeElementReinsertFunc reinsert;
104         TreeElementReinsertPollFunc reinsert_poll;
105
106         struct {
107                 TreeElementInsertType insert_type;
108                 /* the element before/after/into which we may insert the dragged one (NULL to insert at top) */
109                 struct TreeElement *insert_handle;
110                 void *tooltip_draw_handle;
111         } *drag_data;
112 } TreeElement;
113
114 #define TREESTORE_ID_TYPE(_id) \
115         (ELEM(GS((_id)->name), ID_SCE, ID_LI, ID_OB, ID_ME, ID_CU, ID_MB, ID_NT, ID_MA, ID_TE, ID_IM, ID_LT, ID_LA, ID_CA) || \
116          ELEM(GS((_id)->name), ID_KE, ID_WO, ID_SPK, ID_GR, ID_AR, ID_AC, ID_BR, ID_PA, ID_GD, ID_LS, ID_LP) || \
117          ELEM(GS((_id)->name), ID_SCR, ID_WM, ID_TXT, ID_VF, ID_SO, ID_CF, ID_PAL, ID_WS))  /* Only in 'blendfile' mode ... :/ */
118
119 /* TreeElement->flag */
120 enum {
121         TE_ACTIVE      = (1 << 0),
122         /* Closed items display their children as icon within the row. TE_ICONROW is for
123          * these child-items that are visible but only within the row of the closed parent. */
124         TE_ICONROW     = (1 << 1),
125         TE_LAZY_CLOSED = (1 << 2),
126         TE_FREE_NAME   = (1 << 3),
127 };
128
129 /* button events */
130 #define OL_NAMEBUTTON       1
131
132 typedef enum {
133         OL_DRAWSEL_NONE    = 0,  /* inactive (regular black text) */
134         OL_DRAWSEL_NORMAL  = 1,  /* active object (draws white text) */
135         OL_DRAWSEL_ACTIVE  = 2,  /* active obdata (draws a circle around the icon) */
136 } eOLDrawState;
137
138 typedef enum {
139         OL_SETSEL_NONE     = 0,  /* don't change the selection state */
140         OL_SETSEL_NORMAL   = 1,  /* select the item */
141         OL_SETSEL_EXTEND   = 2,  /* select the item and extend (also toggles selection) */
142 } eOLSetState;
143
144 /* get TreeStoreElem associated with a TreeElement 
145  * < a: (TreeElement) tree element to find stored element for
146  */
147 #define TREESTORE(a) ((a)->store_elem)
148
149 /* size constants */
150 #define OL_Y_OFFSET 2
151
152 #define OL_TOG_RESTRICT_VIEWX   (UI_UNIT_X * 3.0f)
153 #define OL_TOG_RESTRICT_SELECTX (UI_UNIT_X * 2.0f)
154 #define OL_TOG_RESTRICT_RENDERX UI_UNIT_X
155
156 #define OL_TOGW OL_TOG_RESTRICT_VIEWX
157
158 #define OL_RNA_COLX         (UI_UNIT_X * 15)
159 #define OL_RNA_COL_SIZEX    (UI_UNIT_X * 7.5f)
160 #define OL_RNA_COL_SPACEX   (UI_UNIT_X * 2.5f)
161
162 /* The outliner display modes that support the filter system.
163  * Note: keep it synced with space_outliner.py */
164 #define SUPPORT_FILTER_OUTLINER(soops_) ELEM((soops_)->outlinevis, SO_VIEW_LAYER, SO_COLLECTIONS)
165
166 /* Outliner Searching --
167  *
168  * Are we looking for something in the outliner?
169  * If so finding matches in child items makes it more useful
170  *
171  * - We want to flag parents to act as being open to filter child matches 
172  * - and also flag matches so we can highlight them
173  * - Flags are stored in TreeStoreElem->flag
174  * - Flag options defined in DNA_outliner_types.h
175  * - SO_SEARCH_RECURSIVE defined in DNA_space_types.h
176  *
177  * - NOT in datablocks view - searching all datablocks takes way too long 
178  *   to be useful
179  * - not searching into RNA items helps but isn't the complete solution
180  */
181
182 #define SEARCHING_OUTLINER(sov)   ((sov->search_flags & SO_SEARCH_RECURSIVE) && (sov->filter & SO_FILTER_SEARCH))
183
184 /* is the currrent element open? if so we also show children */
185 #define TSELEM_OPEN(telm, sv)    ( (telm->flag & TSE_CLOSED) == 0 || (SEARCHING_OUTLINER(sv) && (telm->flag & TSE_CHILDSEARCH)) )
186
187 /* outliner_tree.c ----------------------------------------------- */
188
189 void outliner_free_tree(ListBase *tree);
190 void outliner_cleanup_tree(struct SpaceOops *soops);
191 void outliner_free_tree_element(TreeElement *element, ListBase *parent_subtree);
192 void outliner_remove_treestore_element(struct SpaceOops *soops, TreeStoreElem *tselem);
193
194 void outliner_build_tree(
195         struct Main *mainvar,
196         struct Scene *scene, struct ViewLayer *view_layer,
197         struct SpaceOops *soops, struct ARegion *ar);
198
199 typedef struct ObjectsSelectedData {
200         struct ListBase objects_selected_array;
201 } ObjectsSelectedData;
202
203 TreeTraversalAction outliner_find_selected_objects(struct TreeElement *te, void *customdata);
204
205 /* outliner_draw.c ---------------------------------------------- */
206
207 void draw_outliner(const struct bContext *C);
208 void restrictbutton_gr_restrict_flag(void *poin, void *poin2, int flag);
209
210 /* outliner_select.c -------------------------------------------- */
211 eOLDrawState tree_element_type_active(
212         struct bContext *C, struct Scene *scene, struct ViewLayer *view_layer, struct SpaceOops *soops,
213         TreeElement *te, TreeStoreElem *tselem, const eOLSetState set, bool recursive);
214 eOLDrawState tree_element_active(struct bContext *C, struct Scene *scene, struct ViewLayer *view_layer, SpaceOops *soops,
215                                  TreeElement *te, const eOLSetState set, const bool handle_all_types);
216
217 void outliner_item_do_activate_from_tree_element(
218         struct bContext *C, TreeElement *te, TreeStoreElem *tselem,
219         bool extend, bool recursive);
220 int outliner_item_do_activate_from_cursor(
221         struct bContext *C, const int mval[2],
222         bool extend, bool recursive);
223
224 void outliner_item_select(
225         struct SpaceOops *soops, const struct TreeElement *te,
226         const bool extend, const bool toggle);
227
228 /* outliner_edit.c ---------------------------------------------- */
229 typedef void (*outliner_operation_cb)(
230         struct bContext *C, struct ReportList *, struct Scene *scene,
231         struct TreeElement *, struct TreeStoreElem *, TreeStoreElem *, void *);
232
233 void outliner_do_object_operation_ex(
234         struct bContext *C, struct ReportList *reports, struct Scene *scene, struct SpaceOops *soops,
235         struct ListBase *lb, outliner_operation_cb operation_cb, bool recurse_selected);
236 void outliner_do_object_operation(
237         struct bContext *C, struct ReportList *reports, struct Scene *scene, struct SpaceOops *soops,
238         struct ListBase *lb, outliner_operation_cb operation_cb);
239
240 int common_restrict_check(struct bContext *C, struct Object *ob);
241
242 int outliner_has_one_flag(ListBase *lb, short flag, const int curlevel);
243 bool outliner_set_flag(ListBase *lb, short flag, short set);
244
245 void object_toggle_visibility_cb(
246         struct bContext *C, struct ReportList *reports, struct Scene *scene,
247         TreeElement *te, struct TreeStoreElem *tsep, struct TreeStoreElem *tselem, void *user_data);
248 void object_toggle_selectability_cb(
249         struct bContext *C, struct ReportList *reports, struct Scene *scene,
250         TreeElement *te, struct TreeStoreElem *tsep, struct TreeStoreElem *tselem, void *user_data);
251 void object_toggle_renderability_cb(
252         struct bContext *C, struct ReportList *reports, struct Scene *scene,
253         TreeElement *te, struct TreeStoreElem *tsep, struct TreeStoreElem *tselem, void *user_data);
254
255
256 void group_toggle_visibility_cb(
257         struct bContext *C, struct ReportList *reports, struct Scene *scene,
258         TreeElement *te, struct TreeStoreElem *tsep, struct TreeStoreElem *tselem, void *user_data);
259 void group_toggle_selectability_cb(
260         struct bContext *C, struct ReportList *reports, struct Scene *scene,
261         TreeElement *te, struct TreeStoreElem *tsep, struct TreeStoreElem *tselem, void *user_data);
262 void group_toggle_renderability_cb(
263         struct bContext *C, struct ReportList *reports, struct Scene *scene,
264         TreeElement *te, struct TreeStoreElem *tsep, struct TreeStoreElem *tselem, void *user_data);
265
266 void item_rename_cb(
267         struct bContext *C, struct ReportList *reports, struct Scene *scene,
268         TreeElement *te, struct TreeStoreElem *tsep, struct TreeStoreElem *tselem, void *user_data);
269 void lib_relocate_cb(
270         struct bContext *C, struct ReportList *reports, struct Scene *scene, struct TreeElement *te,
271         struct TreeStoreElem *tsep, struct TreeStoreElem *tselem, void *user_data);
272 void lib_reload_cb(
273         struct bContext *C, struct ReportList *reports, struct Scene *scene, struct TreeElement *te,
274         struct TreeStoreElem *tsep, struct TreeStoreElem *tselem, void *user_data);
275
276 void id_delete_cb(
277         struct bContext *C, struct ReportList *reports, struct Scene *scene, struct TreeElement *te,
278         struct TreeStoreElem *tsep, struct TreeStoreElem *tselem, void *user_data);
279 void id_remap_cb(
280         struct bContext *C, struct ReportList *reports, struct Scene *scene, struct TreeElement *te,
281         struct TreeStoreElem *tsep, struct TreeStoreElem *tselem, void *user_data);
282
283 TreeElement *outliner_dropzone_find(const struct SpaceOops *soops, const float fmval[2], const bool children);
284
285 void outliner_set_coordinates(struct ARegion *ar, struct SpaceOops *soops);
286
287 /* ...................................................... */
288
289 void OUTLINER_OT_highlight_update(struct wmOperatorType *ot);
290
291 void OUTLINER_OT_item_activate(struct wmOperatorType *ot);
292 void OUTLINER_OT_item_openclose(struct wmOperatorType *ot);
293 void OUTLINER_OT_item_rename(struct wmOperatorType *ot);
294 void OUTLINER_OT_lib_relocate(struct wmOperatorType *ot);
295 void OUTLINER_OT_lib_reload(struct wmOperatorType *ot);
296
297 void OUTLINER_OT_id_delete(struct wmOperatorType *ot);
298
299 void OUTLINER_OT_show_one_level(struct wmOperatorType *ot);
300 void OUTLINER_OT_show_active(struct wmOperatorType *ot);
301 void OUTLINER_OT_show_hierarchy(struct wmOperatorType *ot);
302
303 void OUTLINER_OT_select_border(struct wmOperatorType *ot);
304
305 void OUTLINER_OT_selected_toggle(struct wmOperatorType *ot);
306 void OUTLINER_OT_expanded_toggle(struct wmOperatorType *ot);
307
308 void OUTLINER_OT_scroll_page(struct wmOperatorType *ot);
309
310 void OUTLINER_OT_keyingset_add_selected(struct wmOperatorType *ot);
311 void OUTLINER_OT_keyingset_remove_selected(struct wmOperatorType *ot);
312
313 void OUTLINER_OT_drivers_add_selected(struct wmOperatorType *ot);
314 void OUTLINER_OT_drivers_delete_selected(struct wmOperatorType *ot);
315
316 void OUTLINER_OT_orphans_purge(struct wmOperatorType *ot);
317
318 void OUTLINER_OT_parent_drop(struct wmOperatorType *ot);
319 void OUTLINER_OT_parent_clear(struct wmOperatorType *ot);
320 void OUTLINER_OT_scene_drop(struct wmOperatorType *ot);
321 void OUTLINER_OT_material_drop(struct wmOperatorType *ot);
322 void OUTLINER_OT_group_link(struct wmOperatorType *ot);
323
324 /* outliner_tools.c ---------------------------------------------- */
325
326 void OUTLINER_OT_operation(struct wmOperatorType *ot);
327 void OUTLINER_OT_scene_operation(struct wmOperatorType *ot);
328 void OUTLINER_OT_object_operation(struct wmOperatorType *ot);
329 void OUTLINER_OT_group_operation(struct wmOperatorType *ot);
330 void OUTLINER_OT_lib_operation(struct wmOperatorType *ot);
331 void OUTLINER_OT_id_operation(struct wmOperatorType *ot);
332 void OUTLINER_OT_id_remap(struct wmOperatorType *ot);
333 void OUTLINER_OT_data_operation(struct wmOperatorType *ot);
334 void OUTLINER_OT_animdata_operation(struct wmOperatorType *ot);
335 void OUTLINER_OT_action_set(struct wmOperatorType *ot);
336 void OUTLINER_OT_constraint_operation(struct wmOperatorType *ot);
337 void OUTLINER_OT_modifier_operation(struct wmOperatorType *ot);
338 void OUTLINER_OT_collection_operation(struct wmOperatorType *ot);
339 /* ---------------------------------------------------------------- */
340
341 /* outliner_ops.c */
342 void outliner_operatortypes(void);
343 void outliner_keymap(struct wmKeyConfig *keyconf);
344
345 /* outliner_collections.c */
346
347 struct SceneCollection *outliner_scene_collection_from_tree_element(TreeElement *te);
348
349 void OUTLINER_OT_collections_delete(struct wmOperatorType *ot);
350 void OUTLINER_OT_collection_select(struct wmOperatorType *ot);
351 void OUTLINER_OT_collection_toggle(struct wmOperatorType *ot);
352 void OUTLINER_OT_collection_link(struct wmOperatorType *ot);
353 void OUTLINER_OT_collection_unlink(struct wmOperatorType *ot);
354 void OUTLINER_OT_collection_new(struct wmOperatorType *ot);
355 void OUTLINER_OT_collection_duplicate(struct wmOperatorType *ot);
356 void OUTLINER_OT_collection_objects_remove(struct wmOperatorType *ot);
357 void OUTLINER_OT_collection_objects_select(struct wmOperatorType *ot);
358 void OUTLINER_OT_object_add_to_new_collection(struct wmOperatorType *ot);
359 void OUTLINER_OT_object_remove_from_collection(struct wmOperatorType *ot);
360
361 void OUTLINER_OT_collection_objects_add(struct wmOperatorType *ot);
362 void OUTLINER_OT_collection_nested_new(struct wmOperatorType *ot);
363 void OUTLINER_OT_collection_delete_selected(struct wmOperatorType *ot);
364
365 /* outliner_utils.c ---------------------------------------------- */
366
367 TreeElement *outliner_find_item_at_y(const SpaceOops *soops, const ListBase *tree, float view_co_y);
368 TreeElement *outliner_find_item_at_x_in_row(const SpaceOops *soops, const TreeElement *parent_te, float view_co_x);
369 TreeElement *outliner_find_tse(struct SpaceOops *soops, const TreeStoreElem *tse);
370 TreeElement *outliner_find_tree_element(ListBase *lb, const TreeStoreElem *store_elem);
371 TreeElement *outliner_find_id(struct SpaceOops *soops, ListBase *lb, const struct ID *id);
372 TreeElement *outliner_find_posechannel(ListBase *lb, const struct bPoseChannel *pchan);
373 TreeElement *outliner_find_editbone(ListBase *lb, const struct EditBone *ebone);
374 struct ID *outliner_search_back(SpaceOops *soops, TreeElement *te, short idcode);
375 bool outliner_tree_traverse(const SpaceOops *soops, ListBase *tree, int filter_te_flag, int filter_tselem_flag,
376                             TreeTraversalFunc func, void *customdata);
377
378
379 #endif /* __OUTLINER_INTERN_H__ */