[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