lwline_crossing_direction: returns the kind of CG_LINE_CROSS_TYPE behavior of 2 linestrings 
Given two lines, characterize how (and if) they cross each other.
- Parameters
- 
  
    | l1 | first line string |  | l2 | second line string |  
 
- Returns
- a CG_LINE_CROSS_TYPE LINE_NO_CROSS = 0 LINE_CROSS_LEFT = -1 LINE_CROSS_RIGHT = 1 LINE_MULTICROSS_END_LEFT = -2 LINE_MULTICROSS_END_RIGHT = 2 LINE_MULTICROSS_END_SAME_FIRST_LEFT = -3 LINE_MULTICROSS_END_SAME_FIRST_RIGHT = 3 
Definition at line 459 of file lwalgorithm.c.
  461         uint32_t i = 0, j = 0;
 
  462         const POINT2D *p1, *p2, *q1, *q2;
 
  468 #if POSTGIS_DEBUG_LEVEL >= 4 
  476         if ( pa1->
npoints < 2 || pa2->npoints < 2 )
 
  484 #if POSTGIS_DEBUG_LEVEL >= 4 
  496         for ( i = 1; i < pa2->npoints; i++ )
 
  505                 for ( j = 1; j < pa1->
npoints; j++ )
 
  513                         LWDEBUGF(4, 
"i=%d, j=%d (%.8g %.8g, %.8g %.8g)", this_cross, i, j, p1->
x, p1->
y, p2->
x, p2->
y);
 
  517                                 LWDEBUG(4,
"this_cross == SEG_CROSS_LEFT");
 
  525                                 LWDEBUG(4,
"this_cross == SEG_CROSS_RIGHT");
 
  538                                 LWDEBUG(4,
"this_cross == SEG_COLINEAR");
 
  544                         LWDEBUG(4,
"this_cross == SEG_NO_INTERSECTION");
 
  556         LWDEBUGF(4, 
"first_cross=%d, cross_left=%d, cross_right=%d", first_cross, cross_left, cross_right);
 
  558         if ( !cross_left && !cross_right )
 
  561         if ( !cross_left && cross_right == 1 )
 
  564         if ( !cross_right && cross_left == 1 )
 
  567         if ( cross_left - cross_right == 1 )
 
  570         if ( cross_left - cross_right == -1 )
 
  573         if ( cross_left - cross_right == 0 && first_cross == 
SEG_CROSS_LEFT )
 
double ptarray_length_2d(const POINTARRAY *pts)
Find the 2d length of the given POINTARRAY (even if it's 3d)
char * lwgeom_to_ewkt(const LWGEOM *lwgeom)
Return an alloced string.
@ LINE_MULTICROSS_END_RIGHT
@ LINE_MULTICROSS_END_SAME_FIRST_LEFT
@ LINE_MULTICROSS_END_LEFT
@ LINE_MULTICROSS_END_SAME_FIRST_RIGHT
int lw_segment_intersects(const POINT2D *p1, const POINT2D *p2, const POINT2D *q1, const POINT2D *q2)
returns the kind of CG_SEGMENT_INTERSECTION_TYPE behavior of lineseg 1 (constructed from p1 and p2) a...
#define LWDEBUG(level, msg)
#define LWDEBUGF(level, msg,...)
static const POINT2D * getPoint2d_cp(const POINTARRAY *pa, uint32_t n)
Returns a POINT2D pointer into the POINTARRAY serialized_ptlist, suitable for reading from.
 
References getPoint2d_cp(), LINE_CROSS_LEFT, LINE_CROSS_RIGHT, LINE_MULTICROSS_END_LEFT, LINE_MULTICROSS_END_RIGHT, LINE_MULTICROSS_END_SAME_FIRST_LEFT, LINE_MULTICROSS_END_SAME_FIRST_RIGHT, LINE_NO_CROSS, lw_segment_intersects(), LWDEBUG, LWDEBUGF, lwfree(), lwgeom_to_ewkt(), POINTARRAY::npoints, LWLINE::points, ptarray_length_2d(), SEG_COLINEAR, SEG_CROSS_LEFT, SEG_CROSS_RIGHT, POINT2D::x, and POINT2D::y.
Referenced by ST_LineCrossingDirection(), test_lwline_crossing_bugs(), test_lwline_crossing_long_lines(), and test_lwline_crossing_short_lines().