
Go to the source code of this file.
Classes | |
| struct | bbox_shape |
| class | edge_node |
| struct | it_shape |
| class | lmt_node |
| class | polygon_node |
| struct | sbt_t_shape |
| struct | st_shape |
| struct | v_shape |
Macros | |
| #define | ABOVE 0 |
| #define | BELOW 1 |
| #define | CLIP 0 |
| #define | EQ(a, b) (fabs((a) - (b)) <= GPC_EPSILON) |
| #define | FALSE 0 |
| #define | FREE(p) {if (p) {free(p); (p)= NULL;}} |
| #define | FWD_MIN(v, i, n) |
| #define | INVERT_TRISTRIPS FALSE |
| #define | LEFT 0 |
| #define | MALLOC(p, b, s, t) |
| #define | N_EDGE(d, e, p, i, j) |
| #define | NEXT_INDEX(i, n) ((i + 1 ) % n) |
| #define | NOT_FMAX(v, i, n) (v[NEXT_INDEX(i, n)].vertex.y > v[i].vertex.y) |
| #define | NOT_RMAX(v, i, n) (v[PREV_INDEX(i, n)].vertex.y > v[i].vertex.y) |
| #define | OPTIMAL(v, i, n) |
| #define | P_EDGE(d, e, p, i, j) |
| #define | PREV_INDEX(i, n) ((i - 1 + n) % n) |
| #define | REV_MIN(v, i, n) |
| #define | RIGHT 1 |
| #define | SUBJ 1 |
| #define | TRUE 1 |
| #define | VERTEX(e, p, s, x, y) |
Typedefs | |
| typedef struct bbox_shape | bbox |
| typedef struct it_shape | it_node |
| typedef struct sbt_t_shape | sb_tree |
| typedef struct st_shape | st_node |
| typedef struct v_shape | vertex_node |
Enumerations | |
| enum | bundle_state { UNBUNDLED, BUNDLE_HEAD, BUNDLE_TAIL } |
| enum | h_state { NH, BH, TH } |
| enum | vertex_type { NUL, EMX, ELI, TED, ERI, RED, IMM, IMN, EMN, EMM, LED, ILI, BED, IRI, IMX, FUL } |
Functions | |
| static void | add_edge_to_aet (edge_node **aet, edge_node *edge, edge_node *prev) |
| static void | add_intersection (it_node **it, edge_node *edge0, edge_node *edge1, double x, double y) |
| static void | add_left (polygon_node *p, double x, double y) |
| static void | add_local_min (polygon_node **p, edge_node *edge, double x, double y) |
| static void | add_right (polygon_node *p, double x, double y) |
| static void | add_st_edge (st_node **st, it_node **it, edge_node *edge, double dy) |
| static void | add_to_sbtree (int *entries, sb_tree **sbtree, double y) |
| static void | add_vertex (vertex_node **t, double x, double y) |
| static edge_node ** | bound_list (lmt_node **lmt, double y) |
| static void | build_intersection_table (it_node **it, edge_node *aet, double dy) |
| static edge_node * | build_lmt (lmt_node **lmt, sb_tree **sbtree, int *sbt_entries, gpc_polygon *p, int type, gpc_op op) |
| static void | build_sbt (int *entries, double *sbt, sb_tree *sbtree) |
| static int | count_contours (polygon_node *polygon) |
| static int | count_optimal_vertices (gpc_vertex_list c) |
| static int | count_tristrips (polygon_node *tn) |
| static bbox * | create_contour_bboxes (gpc_polygon *p) |
| static void | free_sbtree (sb_tree **sbtree) |
| void | gpc_add_contour (gpc_polygon *p, gpc_vertex_list *new_contour, int hole) |
| void | gpc_free_polygon (gpc_polygon *p) |
| void | gpc_free_tristrip (gpc_tristrip *t) |
| void | gpc_polygon_clip (gpc_op op, gpc_polygon *subj, gpc_polygon *clip, gpc_polygon *result) |
| void | gpc_polygon_to_tristrip (gpc_polygon *s, gpc_tristrip *t) |
| void | gpc_tristrip_clip (gpc_op op, gpc_polygon *subj, gpc_polygon *clip, gpc_tristrip *result) |
| void | gpc_write_polygon (FILE *fp, int write_hole_flags, gpc_polygon *p) |
| static void | insert_bound (edge_node **b, edge_node *e) |
| static void | merge_left (polygon_node *p, polygon_node *q, polygon_node *list) |
| static void | merge_right (polygon_node *p, polygon_node *q, polygon_node *list) |
| static void | minimax_test (gpc_polygon *subj, gpc_polygon *clip, gpc_op op) |
| static void | new_tristrip (polygon_node **tn, edge_node *edge, double x, double y) |
| static void | reset_it (it_node **it) |
| static void | reset_lmt (lmt_node **lmt) |
Variables | |
| const h_state | next_h_state [3][6] |
| #define EQ | ( | a, | |
| b | |||
| ) | (fabs((a) - (b)) <= GPC_EPSILON) |
| #define FWD_MIN | ( | v, | |
| i, | |||
| n | |||
| ) |
| #define MALLOC | ( | p, | |
| b, | |||
| s, | |||
| t | |||
| ) |
| #define N_EDGE | ( | d, | |
| e, | |||
| p, | |||
| i, | |||
| j | |||
| ) |
| #define NOT_FMAX | ( | v, | |
| i, | |||
| n | |||
| ) | (v[NEXT_INDEX(i, n)].vertex.y > v[i].vertex.y) |
| #define NOT_RMAX | ( | v, | |
| i, | |||
| n | |||
| ) | (v[PREV_INDEX(i, n)].vertex.y > v[i].vertex.y) |
| #define OPTIMAL | ( | v, | |
| i, | |||
| n | |||
| ) |
| #define P_EDGE | ( | d, | |
| e, | |||
| p, | |||
| i, | |||
| j | |||
| ) |
| #define REV_MIN | ( | v, | |
| i, | |||
| n | |||
| ) |
| #define VERTEX | ( | e, | |
| p, | |||
| s, | |||
| x, | |||
| y | |||
| ) |
| typedef struct bbox_shape bbox |
| typedef struct sbt_t_shape sb_tree |
| typedef struct v_shape vertex_node |
| enum bundle_state |
| enum vertex_type |
|
static |
|
static |
|
static |
|
static |
|
static |
|
static |
|
static |
|
static |
|
static |
|
static |
|
static |
| void gpc_add_contour | ( | gpc_polygon * | p, |
| gpc_vertex_list * | new_contour, | ||
| int | hole | ||
| ) |
| void gpc_free_polygon | ( | gpc_polygon * | p | ) |
| void gpc_free_tristrip | ( | gpc_tristrip * | t | ) |
| void gpc_polygon_clip | ( | gpc_op | op, |
| gpc_polygon * | subj, | ||
| gpc_polygon * | clip, | ||
| gpc_polygon * | result | ||
| ) |
| void gpc_polygon_to_tristrip | ( | gpc_polygon * | s, |
| gpc_tristrip * | t | ||
| ) |
| void gpc_tristrip_clip | ( | gpc_op | op, |
| gpc_polygon * | subj, | ||
| gpc_polygon * | clip, | ||
| gpc_tristrip * | result | ||
| ) |
| void gpc_write_polygon | ( | FILE * | fp, |
| int | write_hole_flags, | ||
| gpc_polygon * | p | ||
| ) |
|
static |
|
static |
|
static |
|
static |