forked from CauldronDevelopmentLLC/CAMotics
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathSweep.cpp
More file actions
57 lines (43 loc) · 2.08 KB
/
Sweep.cpp
File metadata and controls
57 lines (43 loc) · 2.08 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
/******************************************************************************\
CAMotics is an Open-Source simulation and CAM software.
Copyright (C) 2011-2019 Joseph Coffland <joseph@cauldrondevelopment.com>
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.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
\******************************************************************************/
#include "Sweep.h"
#include <gcode/Move.h>
using namespace std;
using namespace cb;
using namespace CAMotics;
void Sweep::getBBoxes(const Vector3D &start, const Vector3D &end,
vector<Rectangle3D> &bboxes, double radius,
double length, double zOffset, double tolerance) const {
const unsigned maxLen = radius * 16;
double len = start.distance(end);
unsigned steps = (len <= maxLen) ? 1 : (len / maxLen);
double stride = 1.0 / steps;
Vector3D p1 = start;
Vector3D p2;
for (unsigned i = 0; i < steps; i++) {
for (unsigned j = 0; j < 3; j++)
p2[j] = start[j] + (end[j] - start[j]) * stride * (i + 1);
double minX = std::min(p1.x(), p2.x()) - radius - tolerance;
double minY = std::min(p1.y(), p2.y()) - radius - tolerance;
double minZ = std::min(p1.z(), p2.z()) + zOffset - tolerance;
double maxX = std::max(p1.x(), p2.x()) + radius + tolerance;
double maxY = std::max(p1.y(), p2.y()) + radius + tolerance;
double maxZ = std::max(p1.z(), p2.z()) + length + tolerance;
bboxes.push_back
(Rectangle3D(Vector3D(minX, minY, minZ),
Vector3D(maxX, maxY, maxZ)));
p1 = p2;
}
}