Revision: 56958
          
http://projects.blender.org/scm/viewvc.php?view=rev&root=bf-blender&revision=56958
Author:   campbellbarton
Date:     2013-05-22 06:00:26 +0000 (Wed, 22 May 2013)
Log Message:
-----------
utility bmesh functions, for edge loop creation, optionally pass array 
BM_edge_split_n() to get verts created.

Modified Paths:
--------------
    trunk/blender/source/blender/bmesh/intern/bmesh_edgeloop.c
    trunk/blender/source/blender/bmesh/intern/bmesh_edgeloop.h
    trunk/blender/source/blender/bmesh/intern/bmesh_mods.c
    trunk/blender/source/blender/bmesh/intern/bmesh_mods.h

Modified: trunk/blender/source/blender/bmesh/intern/bmesh_edgeloop.c
===================================================================
--- trunk/blender/source/blender/bmesh/intern/bmesh_edgeloop.c  2013-05-22 
05:41:39 UTC (rev 56957)
+++ trunk/blender/source/blender/bmesh/intern/bmesh_edgeloop.c  2013-05-22 
06:00:26 UTC (rev 56958)
@@ -448,6 +448,7 @@
 /* -------------------------------------------------------------------- */
 /* BM_edgeloop_*** functions */
 
+/* return new edgeloops */
 BMEdgeLoopStore *BM_edgeloop_copy(BMEdgeLoopStore *el_store)
 {
        BMEdgeLoopStore *el_store_copy = MEM_mallocN(sizeof(*el_store), 
__func__);
@@ -456,6 +457,22 @@
        return el_store_copy;
 }
 
+BMEdgeLoopStore *BM_edgeloop_from_verts(BMVert **v_arr, const int v_arr_tot, 
bool is_closed)
+{
+       BMEdgeLoopStore *el_store = MEM_callocN(sizeof(*el_store), __func__);
+       int i;
+       for (i = 0; i < v_arr_tot; i++) {
+               LinkData *node = MEM_callocN(sizeof(*node), __func__);
+               node->data = v_arr[i];
+               BLI_addtail(&el_store->verts, node);
+       }
+       el_store->len = v_arr_tot;
+       if (is_closed) {
+               el_store->flag |= BM_EDGELOOP_IS_CLOSED;
+       }
+       return el_store;
+}
+
 void BM_edgeloop_free(BMEdgeLoopStore *el_store)
 {
        BLI_freelistN(&el_store->verts);

Modified: trunk/blender/source/blender/bmesh/intern/bmesh_edgeloop.h
===================================================================
--- trunk/blender/source/blender/bmesh/intern/bmesh_edgeloop.h  2013-05-22 
05:41:39 UTC (rev 56957)
+++ trunk/blender/source/blender/bmesh/intern/bmesh_edgeloop.h  2013-05-22 
06:00:26 UTC (rev 56958)
@@ -46,6 +46,8 @@
 
 /* single edgeloop */
 struct BMEdgeLoopStore *BM_edgeloop_copy(struct BMEdgeLoopStore *el_store);
+struct BMEdgeLoopStore *BM_edgeloop_from_verts(BMVert **v_arr, const int 
v_arr_tot, bool is_closed);
+
 void                BM_edgeloop_free(struct BMEdgeLoopStore *el_store);
 bool                BM_edgeloop_is_closed(struct BMEdgeLoopStore *el_store);
 int                 BM_edgeloop_length_get(struct BMEdgeLoopStore *el_store);

Modified: trunk/blender/source/blender/bmesh/intern/bmesh_mods.c
===================================================================
--- trunk/blender/source/blender/bmesh/intern/bmesh_mods.c      2013-05-22 
05:41:39 UTC (rev 56957)
+++ trunk/blender/source/blender/bmesh/intern/bmesh_mods.c      2013-05-22 
06:00:26 UTC (rev 56958)
@@ -747,8 +747,10 @@
 
 /**
  * \brief Split an edge multiple times evenly
+ *
+ * \param r_varr  Optional array, verts in between (v1 -> v2)
  */
-BMVert  *BM_edge_split_n(BMesh *bm, BMEdge *e, int numcuts)
+BMVert  *BM_edge_split_n(BMesh *bm, BMEdge *e, int numcuts, BMVert **r_varr)
 {
        int i;
        float percent;
@@ -757,6 +759,10 @@
        for (i = 0; i < numcuts; i++) {
                percent = 1.0f / (float)(numcuts + 1 - i);
                v_new = BM_edge_split(bm, e, e->v2, NULL, percent);
+               if (r_varr) {
+                       /* fill in reverse order (v1 -> v2) */
+                       r_varr[numcuts - i - 1] = v_new;
+               }
        }
        return v_new;
 }

Modified: trunk/blender/source/blender/bmesh/intern/bmesh_mods.h
===================================================================
--- trunk/blender/source/blender/bmesh/intern/bmesh_mods.h      2013-05-22 
05:41:39 UTC (rev 56957)
+++ trunk/blender/source/blender/bmesh/intern/bmesh_mods.h      2013-05-22 
06:00:26 UTC (rev 56958)
@@ -55,7 +55,7 @@
 
 BMVert *BM_edge_split(BMesh *bm, BMEdge *e, BMVert *v, BMEdge **r_e, float 
percent);
 
-BMVert *BM_edge_split_n(BMesh *bm, BMEdge *e, int numcuts);
+BMVert *BM_edge_split_n(BMesh *bm, BMEdge *e, int numcuts, BMVert **r_varr);
 
 bool    BM_face_validate(BMFace *face, FILE *err);
 

_______________________________________________
Bf-blender-cvs mailing list
[email protected]
http://lists.blender.org/mailman/listinfo/bf-blender-cvs

Reply via email to