Changeset View
Changeset View
Standalone View
Standalone View
source/blender/editors/uvedit/uvedit_ops.c
| Context not available. | |||||
| SpaceImage *sima = CTX_wm_space_image(C); | SpaceImage *sima = CTX_wm_space_image(C); | ||||
| Scene *scene = CTX_data_scene(C); | Scene *scene = CTX_data_scene(C); | ||||
| ToolSettings *ts = scene->toolsettings; | ToolSettings *ts = scene->toolsettings; | ||||
| Object *obedit = CTX_data_edit_object(C); | ViewLayer *view_layer = CTX_data_view_layer(C); | ||||
| BMEditMesh *em = BKE_editmesh_from_object(obedit); | |||||
| ARegion *ar = CTX_wm_region(C); | ARegion *ar = CTX_wm_region(C); | ||||
| BMFace *efa; | BMFace *efa; | ||||
| BMLoop *l; | BMLoop *l; | ||||
| Context not available. | |||||
| (ts->selectmode == SCE_SELECT_FACE) : | (ts->selectmode == SCE_SELECT_FACE) : | ||||
| (ts->uv_selectmode == UV_SELECT_FACE)); | (ts->uv_selectmode == UV_SELECT_FACE)); | ||||
| const int cd_loop_uv_offset = CustomData_get_offset(&em->bm->ldata, CD_MLOOPUV); | |||||
| /* get operator properties */ | /* get operator properties */ | ||||
| x = RNA_int_get(op->ptr, "x"); | x = RNA_int_get(op->ptr, "x"); | ||||
| Context not available. | |||||
| ellipse[1] = height * zoomy / radius; | ellipse[1] = height * zoomy / radius; | ||||
| UI_view2d_region_to_view(&ar->v2d, x, y, &offset[0], &offset[1]); | UI_view2d_region_to_view(&ar->v2d, x, y, &offset[0], &offset[1]); | ||||
| /* do selection */ | uint objects_len = 0; | ||||
| if (use_face_center) { | Object **objects = BKE_view_layer_array_from_objects_in_edit_mode_unique_data_with_uvs(view_layer, &objects_len); | ||||
| changed = false; | |||||
| BM_ITER_MESH (efa, &iter, em->bm, BM_FACES_OF_MESH) { | for (uint ob_index = 0; ob_index < objects_len; ob_index++) { | ||||
| BM_elem_flag_disable(efa, BM_ELEM_TAG); | Object *obedit = objects[ob_index]; | ||||
| /* assume not touched */ | BMEditMesh *em = BKE_editmesh_from_object(obedit); | ||||
| if (select != uvedit_face_select_test(scene, efa, cd_loop_uv_offset)) { | const int cd_loop_uv_offset = CustomData_get_offset(&em->bm->ldata, CD_MLOOPUV); | ||||
| float cent[2]; | |||||
| uv_poly_center(efa, cent, cd_loop_uv_offset); | /* do selection */ | ||||
| if (uv_inside_circle(cent, offset, ellipse)) { | if (use_face_center) { | ||||
| BM_elem_flag_enable(efa, BM_ELEM_TAG); | changed = false; | ||||
| changed = true; | BM_ITER_MESH (efa, &iter, em->bm, BM_FACES_OF_MESH) { | ||||
| } | BM_elem_flag_disable(efa, BM_ELEM_TAG); | ||||
| } | /* assume not touched */ | ||||
| } | if (select != uvedit_face_select_test(scene, efa, cd_loop_uv_offset)) { | ||||
| float cent[2]; | |||||
| /* (de)selects all tagged faces and deals with sticky modes */ | uv_poly_center(efa, cent, cd_loop_uv_offset); | ||||
| if (changed) { | if (uv_inside_circle(cent, offset, ellipse)) { | ||||
| uv_select_flush_from_tag_face(sima, scene, obedit, select); | BM_elem_flag_enable(efa, BM_ELEM_TAG); | ||||
| } | changed = true; | ||||
| } | } | ||||
| else { | } | ||||
| BM_mesh_elem_hflag_disable_all(em->bm, BM_VERT, BM_ELEM_TAG, false); | } | ||||
| BM_ITER_MESH (efa, &iter, em->bm, BM_FACES_OF_MESH) { | /* (de)selects all tagged faces and deals with sticky modes */ | ||||
| BM_ITER_ELEM (l, &liter, efa, BM_LOOPS_OF_FACE) { | if (changed) { | ||||
| luv = BM_ELEM_CD_GET_VOID_P(l, cd_loop_uv_offset); | uv_select_flush_from_tag_face(sima, scene, obedit, select); | ||||
| if (uv_inside_circle(luv->uv, offset, ellipse)) { | } | ||||
| changed = true; | } | ||||
| uvedit_uv_select_set(em, scene, l, select, false, cd_loop_uv_offset); | else { | ||||
| BM_elem_flag_enable(l->v, BM_ELEM_TAG); | BM_mesh_elem_hflag_disable_all(em->bm, BM_VERT, BM_ELEM_TAG, false); | ||||
| } | |||||
| } | BM_ITER_MESH (efa, &iter, em->bm, BM_FACES_OF_MESH) { | ||||
| } | BM_ITER_ELEM (l, &liter, efa, BM_LOOPS_OF_FACE) { | ||||
| luv = BM_ELEM_CD_GET_VOID_P(l, cd_loop_uv_offset); | |||||
| if (sima->sticky == SI_STICKY_VERTEX) { | if (uv_inside_circle(luv->uv, offset, ellipse)) { | ||||
| uvedit_vertex_select_tagged(em, scene, select, cd_loop_uv_offset); | changed = true; | ||||
| } | uvedit_uv_select_set(em, scene, l, select, false, cd_loop_uv_offset); | ||||
| } | BM_elem_flag_enable(l->v, BM_ELEM_TAG); | ||||
| } | |||||
| if (changed) { | } | ||||
| uv_select_sync_flush(ts, em, select); | } | ||||
| WM_event_add_notifier(C, NC_GEOM | ND_SELECT, obedit->data); | if (sima->sticky == SI_STICKY_VERTEX) { | ||||
| } | uvedit_vertex_select_tagged(em, scene, select, cd_loop_uv_offset); | ||||
| } | |||||
| } | |||||
| if (changed) { | |||||
| uv_select_sync_flush(ts, em, select); | |||||
| WM_event_add_notifier(C, NC_GEOM | ND_SELECT, obedit->data); | |||||
| } | |||||
| } | |||||
| MEM_SAFE_FREE(objects); | |||||
| return OPERATOR_FINISHED; | return OPERATOR_FINISHED; | ||||
| } | } | ||||
| Context not available. | |||||