diff options
Diffstat (limited to 'app/cornu/bezctx_xtrkcad.c')
-rw-r--r-- | app/cornu/bezctx_xtrkcad.c | 36 |
1 files changed, 13 insertions, 23 deletions
diff --git a/app/cornu/bezctx_xtrkcad.c b/app/cornu/bezctx_xtrkcad.c index f30e1c2..2e0d8f4 100644 --- a/app/cornu/bezctx_xtrkcad.c +++ b/app/cornu/bezctx_xtrkcad.c @@ -26,6 +26,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA #include "bezctx.h" #include "bezctx_xtrkcad.h" #include "track.h" +#include "draw.h" #include "tbezier.h" #include "i18n.h" #include "math.h" @@ -71,19 +72,16 @@ bezctx_xtrkcad_lineto(bezctx *z, double x, double y) { return; } DYNARR_APPEND(trkSeg_t,* bc->segsArray,10); - trkSeg_p seg = &trkSeg(bc->segsArray->cnt-1); + trkSeg_p seg = &DYNARR_LAST( trkSeg_t, *bc->segsArray); seg->u.l.pos[0].x = bc->last_pos.x; seg->u.l.pos[0].y = bc->last_pos.y; seg->u.l.pos[1].x = x; seg->u.l.pos[1].y = y; seg->u.l.option = 0; - seg->width = 0.0; + seg->lineWidth = 0.0; seg->color = wDrawColorBlack; seg->type = SEG_STRTRK; - if (seg->bezSegs.ptr) MyFree(seg->bezSegs.ptr); - seg->bezSegs.max =0; - seg->bezSegs.cnt = 0; - seg->bezSegs.ptr = NULL; + DYNARR_FREE( trkSeg_t, seg->bezSegs ); seg->u.l.angle = FindAngle(seg->u.l.pos[0],seg->u.l.pos[1]); bc->last_pos.x = x; bc->last_pos.y = y; @@ -105,7 +103,7 @@ bezctx_xtrkcad_quadto(bezctx *z, double x1, double y1, double x2, double y2) return; } DYNARR_APPEND(trkSeg_t,* bc->segsArray,10); - trkSeg_p seg = &trkSeg(bc->segsArray->cnt-1); + trkSeg_p seg = &DYNARR_LAST( trkSeg_t, *bc->segsArray); seg->u.b.pos[0] = bc->last_pos; seg->u.b.pos[1].x = x1; seg->u.b.pos[1].y = y1; @@ -113,13 +111,10 @@ bezctx_xtrkcad_quadto(bezctx *z, double x1, double y1, double x2, double y2) seg->u.b.pos[2].y = y1; seg->u.b.pos[3].x = x2; seg->u.b.pos[3].y = y2; - seg->width = 0.0; + seg->lineWidth = 0.0; seg->color = wDrawColorBlack; seg->type = SEG_BEZTRK; - if (seg->bezSegs.ptr) MyFree(seg->bezSegs.ptr); - seg->bezSegs.max =0; - seg->bezSegs.cnt = 0; - seg->bezSegs.ptr = NULL; + DYNARR_FREE( trkSeg_t, seg->bezSegs ); bc->last_pos.x = x2; bc->last_pos.y = y2; @@ -142,7 +137,7 @@ static void return; } DYNARR_APPEND(trkSeg_t,* bc->segsArray,10); - trkSeg_p seg = &trkSeg(bc->segsArray->cnt-1); + trkSeg_p seg = &DYNARR_LAST(trkSeg_t, *bc->segsArray); seg->u.b.pos[0].x = bc->last_pos.x; seg->u.b.pos[0].y = bc->last_pos.y; seg->u.b.pos[1].x = x1; @@ -151,13 +146,10 @@ static void seg->u.b.pos[2].y = y2; seg->u.b.pos[3].x = x3; seg->u.b.pos[3].y = y3; - seg->width = 0.0; + seg->lineWidth = 0.0; seg->color = wDrawColorBlack; seg->type = SEG_BEZTRK; - if (seg->bezSegs.ptr) MyFree(seg->bezSegs.ptr); - seg->bezSegs.max = 0; - seg->bezSegs.cnt = 0; - seg->bezSegs.ptr = NULL; + DYNARR_FREE( trkSegs_t, seg->bezSegs ); bc->last_pos.x = x3; bc->last_pos.y = y3; @@ -165,12 +157,12 @@ static void if (bc->draw_spots) { DYNARR_APPEND(trkSeg_t,* bc->segsArray,10); - seg = &trkSeg(bc->segsArray->cnt-1); + seg = &DYNARR_LAST( trkSeg_t, *bc->segsArray ); seg->type=SEG_FILCRCL; seg->u.c.center.x = bc->last_pos.x; seg->u.c.center.y = bc->last_pos.y; seg->u.c.radius = bc->spot_size; - seg->width = 0.0; + seg->lineWidth = 0.0; seg->color = wDrawColorGrey40; } @@ -207,9 +199,7 @@ new_bezctx_xtrkcad(dynArr_t * segArray, int ends[2], BOOL_T spots, DIST_T spot_s result->spot_size = spot_size; result->track = TRUE; - result->segsArray->cnt =0; - result->segsArray->ptr =0; - result->segsArray->max =0; + DYNARR_INIT( trkSeg_t, *result->segsArray ); return &result->base; |