diff options
author | Campbell Barton <ideasman42@gmail.com> | 2010-02-01 16:48:13 +0300 |
---|---|---|
committer | Campbell Barton <ideasman42@gmail.com> | 2010-02-01 16:48:13 +0300 |
commit | d5fadfdf40cfa9dc804507e215875d05ede82045 (patch) | |
tree | 7881dd71c24a0953bbdc7621ab47d41493414715 /source | |
parent | c8e8057ada8318688f9b520d3610456116a2eae2 (diff) |
added extrude enum function, cant be used yet because macros have no way to expose in a way that lets transform run after.
Diffstat (limited to 'source')
-rw-r--r-- | source/blender/editors/mesh/editmesh_tools.c | 79 |
1 files changed, 79 insertions, 0 deletions
diff --git a/source/blender/editors/mesh/editmesh_tools.c b/source/blender/editors/mesh/editmesh_tools.c index 3539079591d..38c3565d67a 100644 --- a/source/blender/editors/mesh/editmesh_tools.c +++ b/source/blender/editors/mesh/editmesh_tools.c @@ -732,9 +732,81 @@ static int mesh_extrude_exec(bContext *C, wmOperator *op) return OPERATOR_FINISHED; } +/* extrude options */ +EnumPropertyItem extrude_item_region = {1, "REGION", 0, "Region", ""}; +EnumPropertyItem extrude_item_faces = {2, "FACES", 0, "Individual Faces", ""}; +EnumPropertyItem extrude_item_edges = {3, "EDGES", 0, "Only Edges", ""}; +EnumPropertyItem extrude_item_verts = {4, "VERTS", 0, "Only Vertices", ""}; + +static EnumPropertyItem *extrude_itemf(bContext *C, PointerRNA *ptr, int *free) +{ + EnumPropertyItem *item= NULL; + Object *obedit= CTX_data_edit_object(C); + EditMesh *em= BKE_mesh_get_editmesh(obedit->data); + + int totitem= 0; + + if(!obedit) + return NULL; + + if(em->selectmode & SCE_SELECT_VERTEX) { + if(em->totvertsel==0) {} + else if(em->totvertsel==1) { RNA_enum_item_add(&item, &totitem, &extrude_item_verts); } + else if(em->totedgesel==0) { RNA_enum_item_add(&item, &totitem, &extrude_item_verts); } + else if(em->totfacesel==0) { + RNA_enum_item_add(&item, &totitem, &extrude_item_edges); + RNA_enum_item_add(&item, &totitem, &extrude_item_verts); + } + else if(em->totfacesel==1) { + RNA_enum_item_add(&item, &totitem, &extrude_item_region); + RNA_enum_item_add(&item, &totitem, &extrude_item_edges); + RNA_enum_item_add(&item, &totitem, &extrude_item_verts); + } + else { + RNA_enum_item_add(&item, &totitem, &extrude_item_region); + RNA_enum_item_add(&item, &totitem, &extrude_item_edges); + RNA_enum_item_add(&item, &totitem, &extrude_item_verts); + } + } + else if(em->selectmode & SCE_SELECT_EDGE) { + if (em->totedgesel==0) {} + else if (em->totedgesel==1) { RNA_enum_item_add(&item, &totitem, &extrude_item_edges); } + else if(em->totfacesel==0) { RNA_enum_item_add(&item, &totitem, &extrude_item_edges); } + else if(em->totfacesel==1) { + RNA_enum_item_add(&item, &totitem, &extrude_item_region); + RNA_enum_item_add(&item, &totitem, &extrude_item_edges); + } + else { + RNA_enum_item_add(&item, &totitem, &extrude_item_region); + RNA_enum_item_add(&item, &totitem, &extrude_item_faces); + RNA_enum_item_add(&item, &totitem, &extrude_item_edges); + } + } + else { + if (em->totfacesel == 0) {} + else if (em->totfacesel == 1) { RNA_enum_item_add(&item, &totitem, &extrude_item_region); } + else { + RNA_enum_item_add(&item, &totitem, &extrude_item_region); + RNA_enum_item_add(&item, &totitem, &extrude_item_faces); + } + } + + if(item) { + RNA_enum_item_end(&item, &totitem); + *free= 1; + return item; + } + else { + return NULL; + } +} void MESH_OT_extrude(wmOperatorType *ot) { +#if 0 + PropertyRNA *prop; +#endif + /* identifiers */ ot->name= "Extrude"; ot->description= "Extrude selected vertices, edges or faces."; @@ -747,6 +819,13 @@ void MESH_OT_extrude(wmOperatorType *ot) /* flags */ ot->flag= OPTYPE_REGISTER|OPTYPE_UNDO; + +#if 0 + /* properties */ + prop= RNA_def_enum(ot->srna, "type", DummyRNA_NULL_items, 0, "Type", ""); + RNA_def_enum_funcs(prop, extrude_itemf); + ot->prop= prop; +#endif } static int split_mesh(bContext *C, wmOperator *op) |