[Bf-blender-cvs] [c0d2f8e] gsoc2016-improved_extrusion: Curves: Offset operator

João Araújo noreply at git.blender.org
Tue Jul 26 00:57:33 CEST 2016


Commit: c0d2f8e9a3e944e7ee177301414e4249c0d69183
Author: João Araújo
Date:   Mon Jul 25 23:57:01 2016 +0100
Branches: gsoc2016-improved_extrusion
https://developer.blender.org/rBc0d2f8e9a3e944e7ee177301414e4249c0d69183

Curves: Offset operator

===================================================================

M	source/blender/editors/curve/editcurve.c

===================================================================

diff --git a/source/blender/editors/curve/editcurve.c b/source/blender/editors/curve/editcurve.c
index c9b13af..6275328 100644
--- a/source/blender/editors/curve/editcurve.c
+++ b/source/blender/editors/curve/editcurve.c
@@ -7379,6 +7379,23 @@ void CURVE_OT_trim_curve(wmOperatorType *ot)
 
 /******************** Offset curve operator ********************/
 
+static void get_curve_centroid(Nurb *nu, float r_v[3])
+{
+	/* This function returns the average xyz coordinates of the spline. */
+	float a[3] = {0.0,0.0,0.0};
+	copy_v3_v3(r_v, a);
+	for (int i = 0; i < nu->pntsu; i++) {
+		add_v3_v3(r_v, nu->bezt[i].vec[1]);
+		if (i > 0) {
+			add_v3_v3(r_v, nu->bezt[i].vec[0]);
+		}
+		if (i < nu->pntsu - 1) {
+			add_v3_v3(r_v, nu->bezt[i].vec[2]);
+		}
+	}
+	mul_v3_fl(r_v, 1.0/(nu->pntsu * 3 - 2));
+}
+
 static void get_offset_vecs(BezTriple *bezt1, BezTriple *bezt2, float *r_v1, float *r_v2)
 {
 	int i = 0, dims = 3;
@@ -7434,24 +7451,10 @@ static void get_offset_vecs(BezTriple *bezt1, BezTriple *bezt2, float *r_v1, flo
 	MEM_freeN(helper);
 }
 
-/*def get_offset_vecs(bezt1, bezt2):
-    bezier = interpolate_bezier(bezt1.co,
-                                bezt1.handle_right,
-                                bezt2.handle_left,
-                                bezt2.co, 13)
-    vx = bezier[1] - bezier[0]
-    vy = bezier[-1] - bezier[-2]
-    
-    v1 = intersect_plane_plane(bezt1.co,
-                               vx,
-                               bezt1.co,
-                               (bezt1.handle_right - bezt1.co).cross(vx))
-    v2 = intersect_plane_plane(bezt2.co,
-                               vy,
-                               bezt2.co,
-                               -(bezt2.handle_left - bezt2.co).cross(vy))
-                               
-    return v1, v2*/
+static void get_handles_offset_vecs(float *p1, float *p2, float *r_v1)
+{
+
+}
 
 static int offset_curve_exec(bContext *C, wmOperator *op)
 {
@@ -7466,15 +7469,19 @@ static int offset_curve_exec(bContext *C, wmOperator *op)
 	bezt = nu->bezt;
 	new_nu = BKE_nurb_duplicate(nu);
 	new_bezt = new_nu->bezt;
+	float *centroid = MEM_callocN(3 * sizeof(float), "offset_curve_exec_get_centroid");
+	get_curve_centroid(nu, centroid);
 
 	float *v1, *v2;
 	v1 = MEM_callocN(3 * sizeof(float), "offset_curve_exec1");
 	v2 = MEM_callocN(3 * sizeof(float), "offset_curve_exec2");
 	for (int i = 0; i < nu->pntsu - 1; i++)
 	{
+		add_v3_v3(new_bezt->vec[0], v2);
 		add_v3_v3(new_bezt->vec[1], v2);
 		add_v3_v3(new_bezt->vec[2], v2);
 		get_offset_vecs(bezt, bezt + 1, v1, v2);
+		add_v3_v3(new_bezt->vec[0], v1);
 		add_v3_v3(new_bezt->vec[1], v1);
 		add_v3_v3(new_bezt->vec[2], v1);
 		bezt++;
@@ -7482,7 +7489,9 @@ static int offset_curve_exec(bContext *C, wmOperator *op)
 	}
 	MEM_freeN(v1);
 	MEM_freeN(v2);
+	MEM_freeN(centroid);
 
+	BKE_nurb_handles_calc(new_nu);
 	BLI_addtail(nubase, new_nu);
 
 	WM_event_add_notifier(C, NC_GEOM | ND_DATA, obedit->data);




More information about the Bf-blender-cvs mailing list