Welcome to mirror list, hosted at ThFree Co, Russian Federation.

git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCampbell Barton <ideasman42@gmail.com>2017-08-17 00:13:02 +0300
committerCampbell Barton <ideasman42@gmail.com>2017-08-17 00:13:02 +0300
commit4b6c482d69cd35b9527dfe0d0ad7c73dfa8fb1ff (patch)
tree669057ab2a9b21501a603aea8e5a8a1c98eec862 /source/blender/draw/intern/draw_cache_impl_mesh.c
parent7c96f613e4d05f67f5cd9bf0cec29ca7ce51a3e4 (diff)
DwM: use batch select for vertex paint mode
Diffstat (limited to 'source/blender/draw/intern/draw_cache_impl_mesh.c')
-rw-r--r--source/blender/draw/intern/draw_cache_impl_mesh.c21
1 files changed, 17 insertions, 4 deletions
diff --git a/source/blender/draw/intern/draw_cache_impl_mesh.c b/source/blender/draw/intern/draw_cache_impl_mesh.c
index eddf2dc2fa4..f77411c91e8 100644
--- a/source/blender/draw/intern/draw_cache_impl_mesh.c
+++ b/source/blender/draw/intern/draw_cache_impl_mesh.c
@@ -2202,8 +2202,13 @@ static Gwn_VertBuf *mesh_batch_cache_get_verts_visible(
}
}
else {
- /* not yet done! */
- BLI_assert(0);
+ for (int i = 0; i < vbo_len_capacity; i++) {
+ const MVert *mv = &rdata->mvert[i];
+ if (!(mv->flag & ME_HIDE)) {
+ GWN_vertbuf_attr_set(vbo, attr_id.pos, vidx, mv->co);
+ vidx += 1;
+ }
+ }
}
const uint vbo_len_used = vidx;
if (vbo_len_used != vbo_len_capacity) {
@@ -2350,8 +2355,16 @@ static Gwn_VertBuf *mesh_create_verts_select_id(
}
}
else {
- /* not yet done! */
- BLI_assert(0);
+ for (int i = 0; i < vbo_len_capacity; i++) {
+ const MVert *mv = &rdata->mvert[i];
+ if (!(mv->flag & ME_HIDE)) {
+ int select_id;
+ GPU_select_index_get(select_index, &select_id);
+ GWN_vertbuf_attr_set(vbo, attr_id.col, vidx, &select_id);
+ vidx += 1;
+ }
+ select_index += 1;
+ }
}
const int vbo_len_used = vidx;
if (vbo_len_used != vbo_len_capacity) {