GPencil: Fix unreported problem when use Onion Skin in several windows
[blender.git] / source / blender / modifiers / intern / MOD_mirror.c
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) 2005 by the Blender Foundation.
17  * All rights reserved.
18  */
19
20 /** \file
21  * \ingroup modifiers
22  */
23
24 #include "BLI_math.h"
25
26 #include "DNA_mesh_types.h"
27 #include "DNA_meshdata_types.h"
28 #include "DNA_object_types.h"
29
30 #include "BKE_library.h"
31 #include "BKE_library_query.h"
32 #include "BKE_mesh.h"
33 #include "BKE_mirror.h"
34 #include "BKE_modifier.h"
35 #include "BKE_deform.h"
36
37 #include "bmesh.h"
38 #include "bmesh_tools.h"
39
40 #include "MEM_guardedalloc.h"
41
42 #include "DEG_depsgraph_build.h"
43 #include "DEG_depsgraph_query.h"
44
45 #include "MOD_modifiertypes.h"
46
47 static void initData(ModifierData *md)
48 {
49   MirrorModifierData *mmd = (MirrorModifierData *)md;
50
51   mmd->flag |= (MOD_MIR_AXIS_X | MOD_MIR_VGROUP);
52   mmd->tolerance = 0.001;
53   mmd->mirror_ob = NULL;
54 }
55
56 static void foreachObjectLink(ModifierData *md, Object *ob, ObjectWalkFunc walk, void *userData)
57 {
58   MirrorModifierData *mmd = (MirrorModifierData *)md;
59
60   walk(userData, ob, &mmd->mirror_ob, IDWALK_CB_NOP);
61 }
62
63 static void updateDepsgraph(ModifierData *md, const ModifierUpdateDepsgraphContext *ctx)
64 {
65   MirrorModifierData *mmd = (MirrorModifierData *)md;
66   if (mmd->mirror_ob != NULL) {
67     DEG_add_object_relation(ctx->node, mmd->mirror_ob, DEG_OB_COMP_TRANSFORM, "Mirror Modifier");
68     DEG_add_modifier_to_transform_relation(ctx->node, "Mirror Modifier");
69   }
70 }
71
72 static Mesh *mirrorModifier__doMirror(MirrorModifierData *mmd,
73                                       const ModifierEvalContext *ctx,
74                                       Object *ob,
75                                       Mesh *mesh)
76 {
77   Mesh *result = mesh;
78
79   /* check which axes have been toggled and mirror accordingly */
80   if (mmd->flag & MOD_MIR_AXIS_X) {
81     result = BKE_mirror_apply_mirror_on_axis(mmd, ctx, ob, result, 0);
82   }
83   if (mmd->flag & MOD_MIR_AXIS_Y) {
84     Mesh *tmp = result;
85     result = BKE_mirror_apply_mirror_on_axis(mmd, ctx, ob, result, 1);
86     if (tmp != mesh) {
87       /* free intermediate results */
88       BKE_id_free(NULL, tmp);
89     }
90   }
91   if (mmd->flag & MOD_MIR_AXIS_Z) {
92     Mesh *tmp = result;
93     result = BKE_mirror_apply_mirror_on_axis(mmd, ctx, ob, result, 2);
94     if (tmp != mesh) {
95       /* free intermediate results */
96       BKE_id_free(NULL, tmp);
97     }
98   }
99
100   return result;
101 }
102
103 static Mesh *applyModifier(ModifierData *md, const ModifierEvalContext *ctx, Mesh *mesh)
104 {
105   Mesh *result;
106   MirrorModifierData *mmd = (MirrorModifierData *)md;
107
108   result = mirrorModifier__doMirror(mmd, ctx, ctx->object, mesh);
109
110   if (result != mesh) {
111     result->runtime.cd_dirty_vert |= CD_MASK_NORMAL;
112   }
113   return result;
114 }
115
116 ModifierTypeInfo modifierType_Mirror = {
117     /* name */ "Mirror",
118     /* structName */ "MirrorModifierData",
119     /* structSize */ sizeof(MirrorModifierData),
120     /* type */ eModifierTypeType_Constructive,
121     /* flags */ eModifierTypeFlag_AcceptsMesh | eModifierTypeFlag_SupportsMapping |
122         eModifierTypeFlag_SupportsEditmode | eModifierTypeFlag_EnableInEditmode |
123         eModifierTypeFlag_AcceptsCVs |
124         /* this is only the case when 'MOD_MIR_VGROUP' is used */
125         eModifierTypeFlag_UsesPreview,
126
127     /* copyData */ modifier_copyData_generic,
128
129     /* deformVerts */ NULL,
130     /* deformMatrices */ NULL,
131     /* deformVertsEM */ NULL,
132     /* deformMatricesEM */ NULL,
133     /* applyModifier */ applyModifier,
134
135     /* initData */ initData,
136     /* requiredDataMask */ NULL,
137     /* freeData */ NULL,
138     /* isDisabled */ NULL,
139     /* updateDepsgraph */ updateDepsgraph,
140     /* dependsOnTime */ NULL,
141     /* dependsOnNormals */ NULL,
142     /* foreachObjectLink */ foreachObjectLink,
143     /* foreachIDLink */ NULL,
144     /* foreachTexLink */ NULL,
145     /* freeRuntimeData */ NULL,
146 };