@d1 start location (distance from start / total distance) @d2 end location (distance from start / total distance)
1066 double length, slength, tlength;
1079 LWDEBUGF(3,
"Total length: %g", length);
1087 LWDEBUGF(3,
"From/To: %g/%g", from, to);
1092 nsegs = ipa->npoints - 1;
1093 for ( i = 0; i < nsegs; i++ )
1100 LWDEBUGF(3 ,
"Segment %d: (%g,%g,%g,%g)-(%g,%g,%g,%g)",
1101 i, p1.
x, p1.
y, p1.
z, p1.
m, p2.
x, p2.
y, p2.
z, p2.
m);
1115 if ( fabs ( from - ( tlength + slength ) ) <= tolerance )
1118 LWDEBUG(3,
" Second point is our start");
1128 else if ( fabs(from - tlength) <= tolerance )
1131 LWDEBUG(3,
" First point is our start");
1149 else if ( from > tlength + slength )
goto END;
1154 LWDEBUG(3,
" Seg contains first point");
1160 dseg = (from - tlength) / slength;
1182 if ( fabs(to - ( tlength + slength ) ) <= tolerance )
1185 LWDEBUG(3,
" Second point is our end");
1195 else if ( fabs(to - tlength) <= tolerance )
1198 LWDEBUG(3,
" First point is our end");
1209 else if ( to > tlength + slength )
1219 else if ( to < tlength + slength )
1222 LWDEBUG(3,
" Seg contains our end");
1224 dseg = (to - tlength) / slength;
1242 memcpy(&p1, &p2,
sizeof(
POINT4D));
double distance2d_pt_pt(const POINT2D *p1, const POINT2D *p2)
void interpolate_point4d(const POINT4D *A, const POINT4D *B, POINT4D *I, double F)
Find interpolation point I between point A and point B so that the len(AI) == len(AB)*F and I falls o...
#define FLAGS_GET_Z(flags)
#define FLAGS_GET_M(flags)
int getPoint4d_p(const POINTARRAY *pa, uint32_t n, POINT4D *point)
#define LWDEBUG(level, msg)
#define LWDEBUGF(level, msg,...)
double ptarray_length_2d(const POINTARRAY *pts)
Find the 2d length of the given POINTARRAY (even if it's 3d)
POINTARRAY * ptarray_construct_empty(char hasz, char hasm, uint32_t maxpoints)
Create a new POINTARRAY with no points.
int ptarray_append_point(POINTARRAY *pa, const POINT4D *pt, int repeated_points)
Append a point to the end of an existing POINTARRAY If allow_duplicate is LW_FALSE,...