Blender  V2.93
BKE_multires.h
Go to the documentation of this file.
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) 2007 by Nicholas Bishop
17  * All rights reserved.
18  */
19 
20 #pragma once
21 
26 #include "BKE_subsurf.h"
27 #include "BLI_compiler_compat.h"
28 
29 #ifdef __cplusplus
30 extern "C" {
31 #endif
32 
33 struct Depsgraph;
34 struct DerivedMesh;
35 struct MDisps;
36 struct Mesh;
37 struct ModifierData;
39 struct Object;
40 struct Scene;
41 struct SubdivCCG;
42 
43 struct MLoop;
44 struct MLoopTri;
45 struct MPoly;
46 struct MVert;
47 
48 /* Delete mesh mdisps and grid paint masks */
49 void multires_customdata_delete(struct Mesh *me);
50 
51 void multires_set_tot_level(struct Object *ob, struct MultiresModifierData *mmd, int lvl);
52 
54  struct Object *object,
55  enum MultiresModifiedFlags flags);
56 
57 void multires_flush_sculpt_updates(struct Object *object);
58 void multires_force_sculpt_rebuild(struct Object *object);
59 void multires_force_external_reload(struct Object *object);
60 
61 /* internal, only called in subsurf_ccg.c */
62 void multires_modifier_update_mdisps(struct DerivedMesh *dm, struct Scene *scene);
64 
66 
67 typedef enum {
73 
75  struct MultiresModifierData *mmd,
76  struct Scene *scene,
77  struct Object *ob,
78  MultiresFlags flags);
79 
81  struct ModifierData *lastmd);
83  struct Object *ob,
84  bool use_first);
85 int multires_get_level(const struct Scene *scene,
86  const struct Object *ob,
87  const struct MultiresModifierData *mmd,
88  bool render,
89  bool ignore_simplify);
90 
91 /* Creates mesh with multires modifier applied on current object's deform mesh. */
93  struct Object *object,
94  struct MultiresModifierData *mmd);
95 
96 /* Get coordinates of a deformed base mesh which is an input to the given multires modifier.
97  * NOTE: The modifiers will be re-evaluated. */
99  struct Object *object,
100  struct MultiresModifierData *mmd,
101  int *r_num_deformed_verts))[3];
102 
104  struct Scene *scene,
105  struct Object *object,
106  int direction);
108  struct Object *object,
109  struct MultiresModifierData *mmd);
111  struct Object *object,
112  struct MultiresModifierData *mmd,
113  int rebuild_limit,
114  bool switch_view_to_lower_level);
115 void multiresModifier_sync_levels_ex(struct Object *ob_dst,
116  struct MultiresModifierData *mmd_src,
117  struct MultiresModifierData *mmd_dst);
118 
119 void multires_stitch_grids(struct Object *);
120 
122  struct Scene *scene,
123  struct Object *ob);
125  struct Scene *scene,
126  struct Object *ob,
127  struct Object *to_ob);
128 
129 int multires_mdisp_corners(struct MDisps *s);
130 
131 /* update multires data after topology changing */
132 void multires_topology_changed(struct Mesh *me);
133 
134 void multires_ensure_external_read(struct Mesh *mesh, int top_level);
136  const struct MultiresModifierData *mmd);
137 
138 /**** interpolation stuff ****/
139 void old_mdisps_bilinear(float out[3], float (*disps)[3], const int st, float u, float v);
141  struct MPoly *mpoly,
142  struct MLoop *mloop,
143  const struct MLoopTri *lt,
144  const int face_side,
145  const float u,
146  const float v,
147  float *x,
148  float *y);
149 
150 /* Reshaping, define in multires_reshape.c */
151 
153  struct Object *object,
154  struct MultiresModifierData *mmd,
155  const float (*vert_coords)[3],
156  const int num_vert_coords);
158  struct MultiresModifierData *mmd,
159  struct Object *dst,
160  struct Object *src);
162  struct Object *ob,
163  struct MultiresModifierData *mmd,
164  struct ModifierData *deform_md);
165 bool multiresModifier_reshapeFromCCG(const int tot_level,
166  struct Mesh *coarse_mesh,
167  struct SubdivCCG *subdiv_ccg);
168 
169 /* Subdivide multires displacement once. */
170 
176 
177 void multiresModifier_subdivide(struct Object *object,
178  struct MultiresModifierData *mmd,
179  const eMultiresSubdivideModeType mode);
181  struct MultiresModifierData *mmd);
182 
183 /* Subdivide displacement to the given level.
184  * If level is lower than the current top level nothing happens. */
185 void multiresModifier_subdivide_to_level(struct Object *object,
186  struct MultiresModifierData *mmd,
187  const int top_level,
188  const eMultiresSubdivideModeType mode);
189 
190 /* Subdivision integration, defined in multires_subdiv.c */
191 
192 struct SubdivSettings;
193 struct SubdivToMeshSettings;
194 
196  const struct MultiresModifierData *mmd);
197 
198 /* TODO(sergey): Replace this set of boolean flags with bitmask. */
200  const struct Scene *scene,
201  const struct Object *object,
202  const struct MultiresModifierData *mmd,
203  const bool use_render_params,
204  const bool ignore_simplify,
205  const bool ignore_control_edges);
206 
207 /* General helpers. */
208 
209 /* For a given partial derivatives of a ptex face get tangent matrix for
210  * displacement.
211  *
212  * Corner needs to be known to properly "rotate" partial derivatives when the
213  * matrix is being constructed for quad. For non-quad the corner is to be set
214  * to 0. */
215 BLI_INLINE void BKE_multires_construct_tangent_matrix(float tangent_matrix[3][3],
216  const float dPdu[3],
217  const float dPdv[3],
218  const int corner);
219 
220 /* Versioning. */
221 
222 /* Convert displacement which is stored for simply-subdivided mesh to a Catmull-Clark
223  * subdivided mesh. */
225  struct MultiresModifierData *mmd);
226 
227 #ifdef __cplusplus
228 }
229 #endif
230 
231 #include "intern/multires_inline.h"
typedef float(TangentPoint)[2]
void multires_set_tot_level(struct Object *ob, struct MultiresModifierData *mmd, int lvl)
Definition: multires.c:384
void multiresModifier_prepare_join(struct Depsgraph *depsgraph, struct Scene *scene, struct Object *ob, struct Object *to_ob)
Definition: multires.c:1461
void multiresModifier_subdivide_to_level(struct Object *object, struct MultiresModifierData *mmd, const int top_level, const eMultiresSubdivideModeType mode)
void multires_force_external_reload(struct Object *object)
Definition: multires.c:482
void multiresModifier_subdivide(struct Object *object, struct MultiresModifierData *mmd, const eMultiresSubdivideModeType mode)
void multiresModifier_sync_levels_ex(struct Object *ob_dst, struct MultiresModifierData *mmd_src, struct MultiresModifierData *mmd_dst)
Definition: multires.c:1360
bool multiresModifier_reshapeFromCCG(const int tot_level, struct Mesh *coarse_mesh, struct SubdivCCG *subdiv_ccg)
void multires_modifier_update_mdisps(struct DerivedMesh *dm, struct Scene *scene)
Definition: multires.c:1046
void multiresModifier_del_levels(struct MultiresModifierData *mmd, struct Scene *scene, struct Object *object, int direction)
Definition: multires.c:722
void multires_stitch_grids(struct Object *)
Definition: multires.c:1205
void multires_force_sculpt_rebuild(struct Object *object)
Definition: multires.c:456
struct MultiresModifierData * get_multires_modifier(struct Scene *scene, struct Object *ob, bool use_first)
Definition: multires.c:336
struct MultiresModifierData * find_multires_modifier_before(struct Scene *scene, struct ModifierData *lastmd)
Definition: multires.c:318
void multires_do_versions_simple_to_catmull_clark(struct Object *object, struct MultiresModifierData *mmd)
void multires_topology_changed(struct Mesh *me)
Definition: multires.c:1479
void multiresModifier_set_levels_from_disps(struct MultiresModifierData *mmd, struct Object *ob)
Definition: multires.c:529
void old_mdisps_bilinear(float out[3], float(*disps)[3], const int st, float u, float v)
Definition: multires.c:1305
void BKE_multires_subdiv_settings_init(struct SubdivSettings *settings, const struct MultiresModifierData *mmd)
int multires_get_level(const struct Scene *scene, const struct Object *ob, const struct MultiresModifierData *mmd, bool render, bool ignore_simplify)
void multiresModifier_base_apply(struct Depsgraph *depsgraph, struct Object *object, struct MultiresModifierData *mmd)
void multires_customdata_delete(struct Mesh *me)
Definition: multires.c:83
MultiresFlags
Definition: BKE_multires.h:67
@ MULTIRES_USE_RENDER_PARAMS
Definition: BKE_multires.h:69
@ MULTIRES_ALLOC_PAINT_MASK
Definition: BKE_multires.h:70
@ MULTIRES_USE_LOCAL_MMD
Definition: BKE_multires.h:68
@ MULTIRES_IGNORE_SIMPLIFY
Definition: BKE_multires.h:71
int multires_mdisp_corners(struct MDisps *s)
Definition: multires.c:1436
BLI_INLINE void BKE_multires_construct_tangent_matrix(float tangent_matrix[3][3], const float dPdu[3], const float dPdv[3], const int corner)
bool multiresModifier_reshapeFromObject(struct Depsgraph *depsgraph, struct MultiresModifierData *mmd, struct Object *dst, struct Object *src)
void multires_ensure_external_read(struct Mesh *mesh, int top_level)
Definition: multires.c:1518
void multiresModifier_ensure_external_read(struct Mesh *mesh, const struct MultiresModifierData *mmd)
int multiresModifier_rebuild_subdiv(struct Depsgraph *depsgraph, struct Object *object, struct MultiresModifierData *mmd, int rebuild_limit, bool switch_view_to_lower_level)
float(* BKE_multires_create_deformed_base_mesh_vert_coords(struct Depsgraph *depsgraph, struct Object *object, struct MultiresModifierData *mmd, int *r_num_deformed_verts))[3]
Definition: multires.c:265
struct DerivedMesh * multires_make_derived_from_derived(struct DerivedMesh *dm, struct MultiresModifierData *mmd, struct Scene *scene, struct Object *ob, MultiresFlags flags)
Definition: multires.c:1232
bool multiresModifier_reshapeFromVertcos(struct Depsgraph *depsgraph, struct Object *object, struct MultiresModifierData *mmd, const float(*vert_coords)[3], const int num_vert_coords)
eMultiresSubdivideModeType
Definition: BKE_multires.h:171
@ MULTIRES_SUBDIVIDE_LINEAR
Definition: BKE_multires.h:174
@ MULTIRES_SUBDIVIDE_CATMULL_CLARK
Definition: BKE_multires.h:172
@ MULTIRES_SUBDIVIDE_SIMPLE
Definition: BKE_multires.h:173
void multiresModifier_scale_disp(struct Depsgraph *depsgraph, struct Scene *scene, struct Object *ob)
Definition: multires.c:1451
void BKE_multires_subdiv_mesh_settings_init(struct SubdivToMeshSettings *mesh_settings, const struct Scene *scene, const struct Object *object, const struct MultiresModifierData *mmd, const bool use_render_params, const bool ignore_simplify, const bool ignore_control_edges)
bool multiresModifier_reshapeFromDeformModifier(struct Depsgraph *depsgraph, struct Object *ob, struct MultiresModifierData *mmd, struct ModifierData *deform_md)
void multires_modifier_update_hidden(struct DerivedMesh *dm)
Definition: multires.c:1173
void multires_subdivide_create_tangent_displacement_linear_grids(struct Object *object, struct MultiresModifierData *mmd)
void multires_flush_sculpt_updates(struct Object *object)
Definition: multires.c:427
void multires_mark_as_modified(struct Depsgraph *depsgraph, struct Object *object, enum MultiresModifiedFlags flags)
Definition: multires.c:406
struct Mesh * BKE_multires_create_mesh(struct Depsgraph *depsgraph, struct Object *object, struct MultiresModifierData *mmd)
Definition: multires.c:242
int mdisp_rot_face_to_crn(struct MVert *mvert, struct MPoly *mpoly, struct MLoop *mloop, const struct MLoopTri *lt, const int face_side, const float u, const float v, float *x, float *y)
MultiresModifiedFlags
Definition: BKE_subsurf.h:89
#define BLI_INLINE
struct Depsgraph Depsgraph
Definition: DEG_depsgraph.h:51
_GL_VOID GLfloat value _GL_VOID_RET _GL_VOID const GLuint GLboolean *residences _GL_BOOL_RET _GL_VOID GLsizei GLfloat GLfloat GLfloat GLfloat const GLubyte *bitmap _GL_VOID_RET _GL_VOID GLenum const void *lists _GL_VOID_RET _GL_VOID const GLdouble *equation _GL_VOID_RET _GL_VOID GLdouble GLdouble blue _GL_VOID_RET _GL_VOID GLfloat GLfloat blue _GL_VOID_RET _GL_VOID GLint GLint blue _GL_VOID_RET _GL_VOID GLshort GLshort blue _GL_VOID_RET _GL_VOID GLubyte GLubyte blue _GL_VOID_RET _GL_VOID GLuint GLuint blue _GL_VOID_RET _GL_VOID GLushort GLushort blue _GL_VOID_RET _GL_VOID GLbyte GLbyte GLbyte alpha _GL_VOID_RET _GL_VOID GLdouble GLdouble GLdouble alpha _GL_VOID_RET _GL_VOID GLfloat GLfloat GLfloat alpha _GL_VOID_RET _GL_VOID GLint GLint GLint alpha _GL_VOID_RET _GL_VOID GLshort GLshort GLshort alpha _GL_VOID_RET _GL_VOID GLubyte GLubyte GLubyte alpha _GL_VOID_RET _GL_VOID GLuint GLuint GLuint alpha _GL_VOID_RET _GL_VOID GLushort GLushort GLushort alpha _GL_VOID_RET _GL_VOID GLenum mode _GL_VOID_RET _GL_VOID GLint y
ATTR_WARN_UNUSED_RESULT const BMVert * v
Scene scene
const Depsgraph * depsgraph
struct MVert * mvert
struct MLoop * mloop
struct MPoly * mpoly