Mesh Remap: Face Corner Data: Do not use large epsilon values to create bvhtrees.
[blender.git] / source / blender / blenkernel / BKE_data_transfer.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) 2014 Blender Foundation.
19  * All rights reserved.
20  *
21  * The Original Code is: all of this file.
22  *
23  * Contributor(s): Bastien Montagne
24  *
25  * ***** END GPL LICENSE BLOCK *****
26  */
27
28 /** \file blender/blenkernel/BKE_data_transfer.h
29  *  \ingroup bke
30  */
31
32 #ifndef __BKE_DATA_TRANSFER_H__
33 #define __BKE_DATA_TRANSFER_H__
34
35 #ifdef __cplusplus
36 extern "C" {
37 #endif
38
39 #include "BKE_customdata.h"
40
41 struct Object;
42 struct Scene;
43 struct SpaceTransform;
44 struct ReportList;
45
46 /* Warning, those def are stored in files (TransferData modifier), *DO NOT* modify those values. */
47 enum {
48         DT_TYPE_MDEFORMVERT             = 1 << 0,
49         DT_TYPE_SHAPEKEY                = 1 << 1,
50         DT_TYPE_SKIN                    = 1 << 2,
51         DT_TYPE_BWEIGHT_VERT            = 1 << 3,
52
53         DT_TYPE_SHARP_EDGE              = 1 << 8,
54         DT_TYPE_SEAM                    = 1 << 9,
55         DT_TYPE_CREASE                  = 1 << 10,
56         DT_TYPE_BWEIGHT_EDGE            = 1 << 11,
57         DT_TYPE_FREESTYLE_EDGE          = 1 << 12,
58
59         DT_TYPE_VCOL                    = 1 << 16,
60         DT_TYPE_LNOR                    = 1 << 17,
61
62         DT_TYPE_UV                      = 1 << 24,
63         DT_TYPE_SHARP_FACE              = 1 << 25,
64         DT_TYPE_FREESTYLE_FACE          = 1 << 26,
65 #define \
66         DT_TYPE_MAX                            27
67
68         DT_TYPE_VERT_ALL                = DT_TYPE_MDEFORMVERT | DT_TYPE_SHAPEKEY | DT_TYPE_SKIN | DT_TYPE_BWEIGHT_VERT,
69         DT_TYPE_EDGE_ALL                = DT_TYPE_SHARP_EDGE | DT_TYPE_SEAM | DT_TYPE_CREASE | DT_TYPE_BWEIGHT_EDGE |
70                                           DT_TYPE_FREESTYLE_EDGE,
71         DT_TYPE_LOOP_ALL                = DT_TYPE_VCOL | DT_TYPE_LNOR | DT_TYPE_UV,
72         DT_TYPE_POLY_ALL                = DT_TYPE_UV | DT_TYPE_SHARP_FACE | DT_TYPE_FREESTYLE_FACE,
73 };
74
75
76 CustomDataMask BKE_object_data_transfer_dttypes_to_cdmask(const int dtdata_types);
77 bool BKE_object_data_transfer_get_dttypes_capacity(
78         const int dtdata_types, bool *r_advanced_mixing, bool *r_threshold);
79 int BKE_object_data_transfer_get_dttypes_item_types(const int dtdata_types);
80
81 int BKE_object_data_transfer_dttype_to_cdtype(const int dtdata_type);
82 int BKE_object_data_transfer_dttype_to_srcdst_index(const int dtdata_type);
83
84 #define DT_DATATYPE_IS_VERT(_dt) \
85         ELEM(_dt, DT_TYPE_MDEFORMVERT, DT_TYPE_SHAPEKEY, DT_TYPE_SKIN, DT_TYPE_BWEIGHT_VERT)
86 #define DT_DATATYPE_IS_EDGE(_dt) \
87         ELEM(_dt, DT_TYPE_CREASE, DT_TYPE_SHARP_EDGE, DT_TYPE_SEAM, DT_TYPE_BWEIGHT_EDGE, DT_TYPE_FREESTYLE_EDGE)
88 #define DT_DATATYPE_IS_LOOP(_dt) \
89         ELEM(_dt, DT_TYPE_UV, DT_TYPE_VCOL, DT_TYPE_LNOR)
90 #define DT_DATATYPE_IS_POLY(_dt) \
91         ELEM(_dt, DT_TYPE_UV, DT_TYPE_SHARP_FACE, DT_TYPE_FREESTYLE_FACE)
92
93 #define DT_DATATYPE_IS_MULTILAYERS(_dt) \
94         ELEM(_dt, DT_TYPE_MDEFORMVERT, DT_TYPE_SHAPEKEY, DT_TYPE_VCOL, DT_TYPE_UV)
95
96
97 enum {
98         DT_MULTILAYER_INDEX_INVALID         = -1,
99         DT_MULTILAYER_INDEX_MDEFORMVERT     = 0,
100         DT_MULTILAYER_INDEX_SHAPEKEY        = 1,
101         DT_MULTILAYER_INDEX_VCOL            = 2,
102         DT_MULTILAYER_INDEX_UV              = 3,
103         DT_MULTILAYER_INDEX_MAX             = 4,
104 };
105
106 /* Below we keep positive values for real layers idx (generated dynamically). */
107
108 /* How to select data layers, for types supporting multi-layers.
109  * Here too, some options are highly dependent on type of transferred data! */
110 enum {
111         DT_LAYERS_ACTIVE_SRC                 = -1,
112         DT_LAYERS_ALL_SRC                    = -2,
113         /* Datatype-specific. */
114         DT_LAYERS_VGROUP_SRC                 = 1 << 8,
115         DT_LAYERS_VGROUP_SRC_BONE_SELECT     = -(DT_LAYERS_VGROUP_SRC | 1),
116         DT_LAYERS_VGROUP_SRC_BONE_DEFORM     = -(DT_LAYERS_VGROUP_SRC | 2),
117         /* Other types-related modes... */
118 };
119
120 /* How to map a source layer to a destination layer, for types supporting multi-layers.
121  * Note: if no matching layer can be found, it will be created. */
122 enum {
123         DT_LAYERS_ACTIVE_DST                 = -1,  /* Only for DT_LAYERS_FROMSEL_ACTIVE. */
124         DT_LAYERS_NAME_DST                   = -2,
125         DT_LAYERS_INDEX_DST                  = -3,
126 #if 0  /* TODO */
127         DT_LAYERS_CREATE_DST                 = -4,  /* Never replace existing data in dst, always create new layers. */
128 #endif
129 };
130
131 void BKE_object_data_transfer_layout(
132         struct Scene *scene, struct Object *ob_src, struct Object *ob_dst, const int data_types, const bool use_delete,
133         const int fromlayers_select[DT_MULTILAYER_INDEX_MAX], const int tolayers_select[DT_MULTILAYER_INDEX_MAX]);
134
135 bool BKE_object_data_transfer_mesh(
136         struct Scene *scene,
137         struct Object *ob_src, struct Object *ob_dst, const int data_types, const bool use_create,
138         const int map_vert_mode, const int map_edge_mode, const int map_loop_mode, const int map_poly_mode,
139         struct SpaceTransform *space_transform, const bool auto_transform,
140         const float max_distance, const float ray_radius, const float islands_handling_precision,
141         const int fromlayers_select[DT_MULTILAYER_INDEX_MAX], const int tolayers_select[DT_MULTILAYER_INDEX_MAX],
142         const int mix_mode, const float mix_factor, const char *vgroup_name, const bool invert_vgroup,
143         struct ReportList *reports);
144 bool BKE_object_data_transfer_dm(
145         struct Scene *scene,
146         struct Object *ob_src, struct Object *ob_dst, struct DerivedMesh *dm_dst,
147         const int data_types, bool use_create,
148         const int map_vert_mode, const int map_edge_mode, const int map_loop_mode, const int map_poly_mode,
149         struct SpaceTransform *space_transform, const bool auto_transform,
150         const float max_distance, const float ray_radius, const float islands_handling_precision,
151         const int fromlayers_select[DT_MULTILAYER_INDEX_MAX], const int tolayers_select[DT_MULTILAYER_INDEX_MAX],
152         const int mix_mode, const float mix_factor, const char *vgroup_name, const bool invert_vgroup,
153         struct ReportList *reports);
154
155 #ifdef __cplusplus
156 }
157 #endif
158
159 #endif  /* __BKE_DATA_TRANSFER_H__ */