mirror of
git://projects.qi-hardware.com/cae-tools.git
synced 2025-01-09 11:20:15 +02:00
cameo/: new commands "remove" and "keep" for path filtering (untested)
This commit is contained in:
parent
3ee5b1aa31
commit
e69fa24133
10
cameo/README
10
cameo/README
@ -82,6 +82,16 @@ Note that "mm" and "mil" only affect dimensions in the command file
|
|||||||
and have no effect on the interpretation of toolpath files.
|
and have no effect on the interpretation of toolpath files.
|
||||||
|
|
||||||
|
|
||||||
|
Filtering:
|
||||||
|
|
||||||
|
remove <x0> <y0> <x1> <y1>
|
||||||
|
keep <x0> <y0> <x1> <y1>
|
||||||
|
|
||||||
|
"remove" removes all paths that have at least one vertex inside the
|
||||||
|
specified rectangle. "keep" keeps only paths that have all vertices
|
||||||
|
in the rectangle.
|
||||||
|
|
||||||
|
|
||||||
Horizontal adjustments:
|
Horizontal adjustments:
|
||||||
|
|
||||||
align <ref> <x> <y>
|
align <ref> <x> <y>
|
||||||
|
@ -40,15 +40,17 @@ NUM -?[0-9]+\.?[0-9]*
|
|||||||
|
|
||||||
<INITIAL>align { BEGIN(DIGIT);
|
<INITIAL>align { BEGIN(DIGIT);
|
||||||
return TOK_ALIGN; }
|
return TOK_ALIGN; }
|
||||||
|
<INITIAL>area return TOK_AREA;
|
||||||
<INITIAL>array return TOK_ARRAY;
|
<INITIAL>array return TOK_ARRAY;
|
||||||
<INITIAL>clear return TOK_CLEAR;
|
<INITIAL>clear return TOK_CLEAR;
|
||||||
<INITIAL>drill return TOK_DRILL;
|
<INITIAL>drill return TOK_DRILL;
|
||||||
<INITIAL>empty return TOK_EMPTY;
|
<INITIAL>empty return TOK_EMPTY;
|
||||||
<INITIAL>area return TOK_AREA;
|
<INITIAL>keep return TOK_KEEP;
|
||||||
<INITIAL>mill return TOK_MILL;
|
<INITIAL>mill return TOK_MILL;
|
||||||
<INITIAL>offset return TOK_OFFSET;
|
<INITIAL>offset return TOK_OFFSET;
|
||||||
<INITIAL>optimize return TOK_OPTIMIZE;
|
<INITIAL>optimize return TOK_OPTIMIZE;
|
||||||
<INITIAL>remainder return TOK_REMAINDER;
|
<INITIAL>remainder return TOK_REMAINDER;
|
||||||
|
<INITIAL>remore return TOK_REMOVE;
|
||||||
<INITIAL>reset return TOK_RESET;
|
<INITIAL>reset return TOK_RESET;
|
||||||
<INITIAL>reverse return TOK_REVERSE;
|
<INITIAL>reverse return TOK_REVERSE;
|
||||||
<INITIAL>rotate return TOK_ROTATE;
|
<INITIAL>rotate return TOK_ROTATE;
|
||||||
|
21
cameo/lang.y
21
cameo/lang.y
@ -187,8 +187,9 @@ static struct path **classify(struct path **anchor, struct path *path)
|
|||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
%token TOK_ALIGN TOK_ARRAY TOK_CLEAR TOK_DRILL TOK_EMPTY TOK_AREA
|
%token TOK_ALIGN TOK_AREA TOK_ARRAY TOK_CLEAR TOK_DRILL TOK_EMPTY
|
||||||
%token TOK_MILL TOK_OFFSET TOK_OPTIMIZE TOK_REMAINDER TOK_RESET
|
%token TOK_KEEP TOK_MILL TOK_OFFSET TOK_OPTIMIZE TOK_REMAINDER
|
||||||
|
%token TOK_REMOVE TOK_RESET
|
||||||
%token TOK_REVERSE TOK_ROTATE TOK_STATS TOK_TRANSLATE TOK_Z
|
%token TOK_REVERSE TOK_ROTATE TOK_STATS TOK_TRANSLATE TOK_Z
|
||||||
%token TOK_APPEND TOK_GERBER TOK_GNUPLOT TOK_EXCELLON TOK_WRITE
|
%token TOK_APPEND TOK_GERBER TOK_GNUPLOT TOK_EXCELLON TOK_WRITE
|
||||||
%token TOK_DOG TOK_INSIDE TOK_ANY
|
%token TOK_DOG TOK_INSIDE TOK_ANY
|
||||||
@ -366,6 +367,22 @@ command:
|
|||||||
if (paths)
|
if (paths)
|
||||||
yyerror("path list is not empty");
|
yyerror("path list is not empty");
|
||||||
}
|
}
|
||||||
|
| TOK_KEEP dimen dimen dimen dimen
|
||||||
|
{
|
||||||
|
struct path *tmp;
|
||||||
|
|
||||||
|
tmp = select_paths(paths, $2, $3, $4, $5, 1);
|
||||||
|
clear_paths();
|
||||||
|
paths = tmp;
|
||||||
|
}
|
||||||
|
| TOK_REMOVE dimen dimen dimen dimen
|
||||||
|
{
|
||||||
|
struct path *tmp;
|
||||||
|
|
||||||
|
tmp = select_paths(paths, $2, $3, $4, $5, 0);
|
||||||
|
clear_paths();
|
||||||
|
paths = tmp;
|
||||||
|
}
|
||||||
;
|
;
|
||||||
|
|
||||||
opt_filename:
|
opt_filename:
|
||||||
|
38
cameo/ops.c
38
cameo/ops.c
@ -153,3 +153,41 @@ struct path *reverse_paths(const struct path *paths)
|
|||||||
}
|
}
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static int select_path(const struct path *path, double xa, double ya,
|
||||||
|
double xb, double yb, int inside)
|
||||||
|
{
|
||||||
|
const struct point *p;
|
||||||
|
|
||||||
|
for (p = path->first; p; p = p->next) {
|
||||||
|
if (p->x >= xa && p->x <= xb && p->y >= ya && p->y <= yb) {
|
||||||
|
if (!inside)
|
||||||
|
return 0;
|
||||||
|
} else {
|
||||||
|
if (inside)
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
struct path *select_paths(const struct path *paths, double xa, double ya,
|
||||||
|
double xb, double yb, int inside)
|
||||||
|
{
|
||||||
|
struct path *res = NULL, **last = &res;
|
||||||
|
|
||||||
|
if (xa > xb)
|
||||||
|
return select_paths(paths, xb, ya, xa, yb, inside);
|
||||||
|
if (ya > yb)
|
||||||
|
return select_paths(paths, xa, yb, xb, ya, inside);
|
||||||
|
while (paths) {
|
||||||
|
if (select_path(paths, xa, ya, xb, yb, inside)) {
|
||||||
|
*last = path_clone(paths);
|
||||||
|
last = &(*last)->next;
|
||||||
|
}
|
||||||
|
paths = paths->next;
|
||||||
|
}
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
@ -23,5 +23,7 @@ struct path *try_drill(struct path *path, double d_min, double d_max);
|
|||||||
struct path *try_mill(struct path *path, double diam, double step, int any);
|
struct path *try_mill(struct path *path, double diam, double step, int any);
|
||||||
struct path *optimize_paths(struct path *paths);
|
struct path *optimize_paths(struct path *paths);
|
||||||
struct path *reverse_paths(const struct path *paths);
|
struct path *reverse_paths(const struct path *paths);
|
||||||
|
struct path *select_paths(const struct path *paths, double xa, double ya,
|
||||||
|
double xb, double yb, int inside);
|
||||||
|
|
||||||
#endif /* !OPS_H */
|
#endif /* !OPS_H */
|
||||||
|
21
cameo/path.c
21
cameo/path.c
@ -75,7 +75,7 @@ static struct path *path_from(const struct path *old)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static struct point *clone_point(struct point *p)
|
static struct point *clone_point(const struct point *p)
|
||||||
{
|
{
|
||||||
struct point *n;
|
struct point *n;
|
||||||
|
|
||||||
@ -156,6 +156,25 @@ struct path *path_reverse(const struct path *path)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
struct path *path_clone(const struct path *path)
|
||||||
|
{
|
||||||
|
struct path *new;
|
||||||
|
const struct point *p;
|
||||||
|
struct point *n;
|
||||||
|
|
||||||
|
new = path_from(path);
|
||||||
|
for (p = path->first; p; p = p->next) {
|
||||||
|
n = clone_point(p);
|
||||||
|
if (new->first)
|
||||||
|
new->last->next = n;
|
||||||
|
else
|
||||||
|
new->first = n;
|
||||||
|
new->last = n;
|
||||||
|
}
|
||||||
|
return new;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
static void path_reverse_inplace(struct path *path)
|
static void path_reverse_inplace(struct path *path)
|
||||||
{
|
{
|
||||||
struct point *points = NULL, *p, *next;
|
struct point *points = NULL, *p, *next;
|
||||||
|
@ -1,8 +1,8 @@
|
|||||||
/*
|
/*
|
||||||
* path.h - Toolpath operations
|
* path.h - Toolpath operations
|
||||||
*
|
*
|
||||||
* Written 2010-2011 by Werner Almesberger
|
* Written 2010-2012 by Werner Almesberger
|
||||||
* Copyright 2010-2011 Werner Almesberger
|
* Copyright 2010-2012 Werner Almesberger
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify
|
* 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
|
* it under the terms of the GNU General Public License as published by
|
||||||
@ -33,6 +33,7 @@ struct path {
|
|||||||
struct path *path_new(double r_tool, const char *id);
|
struct path *path_new(double r_tool, const char *id);
|
||||||
void path_add(struct path *path, double x, double y, double z);
|
void path_add(struct path *path, double x, double y, double z);
|
||||||
struct path *path_reverse(const struct path *path);
|
struct path *path_reverse(const struct path *path);
|
||||||
|
struct path *path_clone(const struct path *path);
|
||||||
int path_tool_is_left(const struct path *path);
|
int path_tool_is_left(const struct path *path);
|
||||||
struct path *path_offset(const struct path *path, int left, int notch);
|
struct path *path_offset(const struct path *path, int left, int notch);
|
||||||
const struct path *path_find_leftmost(const struct path *path);
|
const struct path *path_find_leftmost(const struct path *path);
|
||||||
|
Loading…
Reference in New Issue
Block a user