29 const int subdiv_vertex_index)
45 const int subdiv_vertex_index)
55 const int num_corners = reshape_context->
base_faces[face_index].size();
57 const int corner = grid_coord.
grid_index - start_grid_index;
59 if (grid_coord.
u == 0.0f && grid_coord.
v == 0.0f) {
60 for (
int current_corner = 0; current_corner < num_corners; ++current_corner) {
62 corner_grid_coord.
grid_index = start_grid_index + current_corner;
64 foreach_context, &corner_grid_coord, subdiv_vertex_index);
70 foreach_context, &grid_coord, subdiv_vertex_index);
72 if (grid_coord.
u == 0.0f) {
74 prev_grid_coord.
grid_index = start_grid_index + ((corner + num_corners - 1) % num_corners);
75 prev_grid_coord.
u = grid_coord.
v;
76 prev_grid_coord.
v = 0.0f;
79 foreach_context, &prev_grid_coord, subdiv_vertex_index);
82 if (grid_coord.
v == 0.0f) {
84 next_grid_coord.
grid_index = start_grid_index + ((corner + 1) % num_corners);
85 next_grid_coord.
u = 0.0f;
86 next_grid_coord.
v = grid_coord.
u;
89 foreach_context, &next_grid_coord, subdiv_vertex_index);
96 const int num_vertices,
104 if (num_vertices != reshape_vertcos_context->
positions.size()) {
114 const int ptex_face_index,
115 const float ptex_face_u,
116 const float ptex_face_v,
119 const int subdiv_vertex_index)
123 ptex_coord.
u = ptex_face_u;
124 ptex_coord.
v = ptex_face_v;
132 const int ptex_face_index,
133 const float ptex_face_u,
134 const float ptex_face_v,
138 const int subdiv_vertex_index)
142 ptex_coord.
u = ptex_face_u;
143 ptex_coord.
v = ptex_face_v;
151 const int ptex_face_index,
152 const float ptex_face_u,
153 const float ptex_face_v,
157 const int subdiv_vertex_index)
161 ptex_coord.
u = ptex_face_u;
162 ptex_coord.
v = ptex_face_v;
171 reshape_vertcos_context.
positions = positions;
178 foreach_context.
user_data = &reshape_vertcos_context;
185 reshape_context->
subdiv, &foreach_context, &mesh_settings, reshape_context->
base_mesh);
int multires_reshape_grid_to_face_index(const MultiresReshapeContext *reshape_context, int grid_index)
ReshapeGridElement multires_reshape_grid_element_for_grid_coord(const MultiresReshapeContext *reshape_context, const GridCoord *grid_coord)
GridCoord multires_reshape_ptex_coord_to_grid(const MultiresReshapeContext *reshape_context, const PTexCoord *ptex_coord)
static void multires_reshape_vertcos_foreach_vertex_every_edge(const blender::bke::subdiv::ForeachContext *foreach_context, void *, const int ptex_face_index, const float ptex_face_u, const float ptex_face_v, const int, const int, const int, const int subdiv_vertex_index)
static void multires_reshape_vertcos_foreach_vertex_inner(const blender::bke::subdiv::ForeachContext *foreach_context, void *, const int ptex_face_index, const float ptex_face_u, const float ptex_face_v, const int, const int, const int subdiv_vertex_index)
static void multires_reshape_vertcos_foreach_vertex(const blender::bke::subdiv::ForeachContext *foreach_context, const PTexCoord *ptex_coord, const int subdiv_vertex_index)
static void multires_reshape_vertcos_foreach_single_vertex(const blender::bke::subdiv::ForeachContext *foreach_context, const GridCoord *grid_coord, const int subdiv_vertex_index)
bool multires_reshape_assign_final_coords_from_vertcos(const MultiresReshapeContext *reshape_context, const blender::Span< blender::float3 > positions)
static void multires_reshape_vertcos_foreach_vertex_every_corner(const blender::bke::subdiv::ForeachContext *foreach_context, void *, const int ptex_face_index, const float ptex_face_u, const float ptex_face_v, const int, const int, const int, const int subdiv_vertex_index)
static bool multires_reshape_vertcos_foreach_topology_info(const blender::bke::subdiv::ForeachContext *foreach_context, const int num_vertices, const int, const int, const int, const int *)
bool foreach_subdiv_geometry(Subdiv *subdiv, const ForeachContext *context, const ToMeshSettings *mesh_settings, const Mesh *coarse_mesh)
VecBase< float, 3 > float3
blender::Span< blender::float3 > positions
const MultiresReshapeContext * reshape_context
struct MultiresReshapeContext::@114377305000353127144042327223234020156043120202 reshape
blender::bke::subdiv::Subdiv * subdiv
blender::OffsetIndices< int > base_faces
blender::Array< int > face_start_grid_index
blender::float3 * displacement
ForeachVertexFromEdgeCb vertex_every_edge
ForeachTopologyInformationCb topology_info
ForeachVertexFromCornerCb vertex_every_corner
ForeachVertexInnerCb vertex_inner