]> git.tdb.fi Git - r2c2.git/blob - source/libmarklin/geometry.h
Fix a segfault in removing vehicles when creating a new train
[r2c2.git] / source / libmarklin / geometry.h
1 /* $Id$
2
3 This file is part of the MSP Märklin suite
4 Copyright © 2006-2010  Mikkosoft Productions, Mikko Rasa
5 Distributed under the GPL
6 */
7
8 #ifndef LIBMARKLIN_GEOMETRY_H_
9 #define LIBMARKLIN_GEOMETRY_H_
10
11 #include <cmath>
12 #include <vector>
13
14 namespace Marklin {
15
16 struct Point
17 {
18         float x, y, z;
19
20         Point(): x(0), y(0), z(0) { }
21         Point(float x_, float y_): x(x_), y(y_), z(0) { }
22         Point(float x_, float y_, float z_): x(x_), y(y_), z(z_) { }
23 };
24
25 inline float distance(const Point &p, const Point &q)
26 { return sqrt((p.x-q.x)*(p.x-q.x) + (p.y-q.y)*(p.y-q.y) + (p.z-q.z)*(p.z-q.z)); }
27
28 struct TrackPoint
29 {
30         Point pos;
31         float dir;
32         float grade;
33
34         TrackPoint(): dir(0), grade(0) { }
35 };
36
37 } // namespace Marklin
38
39 #endif