Classes |
struct | bbox_shape |
struct | edge_shape |
struct | it_shape |
struct | lmt_shape |
struct | p_shape |
struct | sbt_t_shape |
struct | st_shape |
struct | v_shape |
Defines |
#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 edge_shape | edge_node |
typedef struct it_shape | it_node |
typedef struct lmt_shape | lmt_node |
typedef struct p_shape | polygon_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_read_polygon (FILE *fp, int read_hole_flags, gpc_polygon *p) |
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] |