[Bf-blender-cvs] [52421e9ace7] master: View3D: Circle Select optimization
mano-wii
noreply at git.blender.org
Mon Aug 12 03:14:25 CEST 2019
Commit: 52421e9ace745985a88dd61ee903502d4039f595
Author: mano-wii
Date: Sun Aug 11 22:12:11 2019 -0300
Branches: master
https://developer.blender.org/rB52421e9ace745985a88dd61ee903502d4039f595
View3D: Circle Select optimization
Don't recreate `select_bitmap` for each edited object.
===================================================================
M source/blender/editors/space_view3d/view3d_select.c
===================================================================
diff --git a/source/blender/editors/space_view3d/view3d_select.c b/source/blender/editors/space_view3d/view3d_select.c
index d20a854c022..3e2d387bcec 100644
--- a/source/blender/editors/space_view3d/view3d_select.c
+++ b/source/blender/editors/space_view3d/view3d_select.c
@@ -3392,7 +3392,9 @@ static bool mesh_circle_select(ViewContext *vc,
struct EditSelectBuf_Cache *esel = wm_userdata->data;
if (use_zbuf) {
- esel->select_bitmap = DRW_select_buffer_bitmap_from_circle(mval, (int)(rad + 1.0f), NULL);
+ if (esel->select_bitmap == NULL) {
+ esel->select_bitmap = DRW_select_buffer_bitmap_from_circle(mval, (int)(rad + 1.0f), NULL);
+ }
}
if (ts->selectmode & SCE_SELECT_VERTEX) {
@@ -3432,13 +3434,6 @@ static bool mesh_circle_select(ViewContext *vc,
}
}
- if (use_zbuf) {
- if (esel->select_bitmap != NULL) {
- MEM_freeN(esel->select_bitmap);
- esel->select_bitmap = NULL;
- }
- }
-
changed |= data.is_changed;
if (changed) {
@@ -4020,6 +4015,13 @@ static int view3d_circle_select_exec(bContext *C, wmOperator *op)
if (wm_userdata == &wm_userdata_buf) {
WM_generic_user_data_free(wm_userdata);
}
+ else {
+ struct EditSelectBuf_Cache *esel = wm_userdata->data;
+ if (esel && esel->select_bitmap) {
+ MEM_freeN(esel->select_bitmap);
+ esel->select_bitmap = NULL;
+ }
+ }
return OPERATOR_FINISHED;
}
More information about the Bf-blender-cvs
mailing list