2010-11-01 14:58:29 -03:00
|
|
|
/*
|
|
|
|
* path.h - Toolpath operations
|
|
|
|
*
|
2012-06-12 12:32:08 -03:00
|
|
|
* Written 2010-2012 by Werner Almesberger
|
|
|
|
* Copyright 2010-2012 Werner Almesberger
|
2010-11-01 14:58:29 -03:00
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
#ifndef PATH_H
|
|
|
|
#define PATH_H
|
|
|
|
|
2015-01-16 08:49:07 -03:00
|
|
|
#include <math.h>
|
|
|
|
|
2010-11-01 14:58:29 -03:00
|
|
|
|
|
|
|
struct point {
|
|
|
|
double x, y, z; /* mm */
|
|
|
|
struct point *next;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct path {
|
|
|
|
struct point *first, *last;
|
|
|
|
double r_tool; /* mm */
|
2010-11-01 18:50:24 -03:00
|
|
|
int outside; /* non-zero to mark path as an outside edge */
|
2010-11-01 19:15:35 -03:00
|
|
|
int notch; /* non-zero to enable dog-boning for path */
|
2011-09-05 05:46:25 -03:00
|
|
|
const char *id; /* identifier assigned by generator */
|
2010-11-01 14:58:29 -03:00
|
|
|
struct path *next;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2015-01-16 08:49:07 -03:00
|
|
|
/*
|
|
|
|
* We allow for a bit of tolerance, to absorb the rounding errors KiCad
|
|
|
|
* produces with designs using a metric grid.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#define EPSILON_MM 0.006 /* 6 um */
|
|
|
|
|
|
|
|
|
|
|
|
static inline int points_eq(const struct point *a, const struct point *b)
|
|
|
|
{
|
|
|
|
if (hypot(a->x-b->x, a->y-b->y) > EPSILON_MM)
|
|
|
|
return 0;
|
|
|
|
if (fabs(a->z-b->z) > EPSILON_MM)
|
|
|
|
return 0;
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2011-09-05 05:46:25 -03:00
|
|
|
struct path *path_new(double r_tool, const char *id);
|
2010-11-01 14:58:29 -03:00
|
|
|
void path_add(struct path *path, double x, double y, double z);
|
|
|
|
struct path *path_reverse(const struct path *path);
|
2012-06-12 12:32:08 -03:00
|
|
|
struct path *path_clone(const struct path *path);
|
2012-06-12 14:24:50 -03:00
|
|
|
int path_is_closed(const struct path *path);
|
2010-11-01 15:43:37 -03:00
|
|
|
int path_tool_is_left(const struct path *path);
|
|
|
|
struct path *path_offset(const struct path *path, int left, int notch);
|
2011-09-05 07:54:29 -03:00
|
|
|
const struct path *path_find_leftmost(const struct path *path);
|
2012-06-12 15:04:59 -03:00
|
|
|
int path_is_inside(const struct path *a, const struct path *b);
|
2010-11-01 14:58:29 -03:00
|
|
|
void path_free(struct path *path);
|
2010-12-13 17:45:33 -03:00
|
|
|
struct path *path_connect(struct path *path);
|
2011-02-13 02:25:32 -03:00
|
|
|
void path_stats(const struct path *path);
|
2010-11-01 14:58:29 -03:00
|
|
|
|
|
|
|
#endif /* !PATH_H */
|