20 if (
format.attr_len == 0) {
34 const BMesh &bm = *mr.bm;
35 threading::parallel_for(IndexRange(bm.totface), 2048, [&](const IndexRange range) {
36 for (const int face_index : range) {
37 const BMFace &face = *BM_face_at_index(&const_cast<BMesh &>(bm), face_index);
38 const BMLoop *loop = BM_FACE_FIRST_LOOP(&face);
39 for ([[maybe_unused]] const int i : IndexRange(face.len)) {
40 const int index = BM_elem_index_get(loop);
41 vbo_data[index] = float4(orco_data[BM_elem_index_get(loop->v)], 0.0f);
50 for (const int corner : range) {
51 vbo_data[corner] = float4(orco_data[corner_verts[corner]], 0.0f);
const void * CustomData_get_layer(const CustomData *data, eCustomDataType type)
#define GPU_vertbuf_init_with_format(verts, format)
void GPU_vertbuf_data_alloc(blender::gpu::VertBuf &verts, uint v_len)
constexpr int64_t size_in_bytes() const
constexpr int64_t size_in_bytes() const
constexpr IndexRange index_range() const
void extract_orco(const MeshRenderData &mr, gpu::VertBuf &vbo)
void parallel_for(const IndexRange range, const int64_t grain_size, const Function &function, const TaskSizeHints &size_hints=detail::TaskSizeHints_Static(1))
void memory_bandwidth_bound_task(const int64_t approximate_bytes_touched, const Function &function)
eMRExtractType extract_type