-
Notifications
You must be signed in to change notification settings - Fork 23
/
LineTool.h
95 lines (77 loc) · 3.01 KB
/
LineTool.h
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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
/***********************************************************************
LineTool - Calibration tool for RawKinectViewer.
Copyright (c) 2010-2012 Oliver Kreylos
This file is part of the Kinect 3D Video Capture Project (Kinect).
The Kinect 3D Video Capture Project 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.
The Kinect 3D Video Capture Project 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 the Kinect 3D Video Capture Project; if not, write to the Free
Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
02111-1307 USA
***********************************************************************/
#ifndef LINETOOL_INCLUDED
#define LINETOOL_INCLUDED
#include <utility>
#include <vector>
#include <Geometry/Point.h>
#include <Geometry/Vector.h>
#include <Vrui/Tool.h>
#include <Vrui/GenericToolFactory.h>
#include <Vrui/Application.h>
/* Forward declarations: */
class RawKinectViewer;
class LineTool;
typedef Vrui::GenericToolFactory<LineTool> LineToolFactory;
class LineTool:public Vrui::Tool,public Vrui::Application::Tool<RawKinectViewer>
{
friend class Vrui::GenericToolFactory<LineTool>;
/* Embedded classes: */
private:
typedef Geometry::Point<double,2> Point;
typedef Geometry::Vector<double,2> Vector;
struct Line
{
/* Elements: */
public:
Point start;
Point end;
};
typedef std::vector<Line> LineSet;
/* Elements: */
private:
static LineToolFactory* factory; // Pointer to the factory object for this class
LineSet lines;
bool dragging;
int dragMode;
Line current;
LineSet::iterator draggedLine;
Vector startOffset;
Vector endOffset;
bool haveGrid;
std::vector<Point> gridSquares;
/* Private methods: */
Point getPoint(void) const;
std::pair<LineSet::iterator,int> findLine(const Point& p);
static std::vector<LineSet::iterator> getIntersectingLines(LineSet::iterator base,LineSet& lines);
static void makeCell(const Line& l0,const Line& l1,Vector n[2],double o[2]);
static Point intersectLines(const Line& l0,const Line& l1);
static bool inside(unsigned int x,unsigned int y,const Vector ln[4],const double lo[4]);
void constructGrid(void);
/* Constructors and destructors: */
public:
static LineToolFactory* initClass(Vrui::ToolManager& toolManager);
LineTool(const Vrui::ToolFactory* factory,const Vrui::ToolInputAssignment& inputAssignment);
virtual ~LineTool(void);
/* Methods from class Vrui::Tool: */
virtual const Vrui::ToolFactory* getFactory(void) const;
virtual void buttonCallback(int buttonSlotIndex,Vrui::InputDevice::ButtonCallbackData* cbData);
virtual void frame(void);
virtual void display(GLContextData& contextData) const;
};
#endif