ARX  1.0
The next-generation open source augmented reality toolkit.
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Macros
TrackingPointSelector.h
Go to the documentation of this file.
1/*
2 * TrackingPointSelector.h
3 * artoolkitX
4 *
5 * This file is part of artoolkitX.
6 *
7 * artoolkitX is free software: you can redistribute it and/or modify
8 * it under the terms of the GNU Lesser General Public License as published by
9 * the Free Software Foundation, either version 3 of the License, or
10 * (at your option) any later version.
11 *
12 * artoolkitX is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU Lesser General Public License for more details.
16 *
17 * You should have received a copy of the GNU Lesser General Public License
18 * along with artoolkitX. If not, see <http://www.gnu.org/licenses/>.
19 *
20 * As a special exception, the copyright holders of this library give you
21 * permission to link this library with independent modules to produce an
22 * executable, regardless of the license terms of these independent modules, and to
23 * copy and distribute the resulting executable under terms of your choice,
24 * provided that you also meet, for each linked independent module, the terms and
25 * conditions of the license of that module. An independent module is a module
26 * which is neither derived from nor based on this library. If you modify this
27 * library, you may extend this exception to your version of the library, but you
28 * are not obligated to do so. If you do not wish to do so, delete this exception
29 * statement from your version.
30 *
31 * Copyright 2018 Realmax, Inc.
32 * Copyright 2015 Daqri, LLC.
33 * Copyright 2010-2015 ARToolworks, Inc.
34 *
35 * Author(s): Philip Lamb, Daniel Bell.
36 *
37 */
38
39#ifndef TRACKINGPOINTSELECTOR_H
40#define TRACKINGPOINTSELECTOR_H
41#include <vector>
42#include <map>
43#include "OCVConfig.h"
44#include "TrackedPoint.h"
45
47{
48public:
50
51 TrackingPointSelector(std::vector<cv::Point2f> pts, int width, int height, int markerTemplateWidth);
52
53 std::vector<TrackedPoint> _selectedPts;
54 std::vector<cv::Point2f> _pts;
55 std::map<int, std::vector<TrackedPoint> > trackingPointBin;
56 cv::Mat homography;
57
58 void DistributeBins(int width, int height, int markerTemplateWidth);
59
60 void SetHomography(cv::Mat newHomography);
61
62 cv::Mat GetHomography();
63
64 void UpdatePointStatus(std::vector<uchar> status);
65
66 void SelectPoints();
67
68 std::vector<cv::Point2f> GetSelectedFeatures();
69
70 std::vector<cv::Point2f> GetTrackedFeatures();
71
72 std::vector<cv::Point3f> GetSelectedFeatures3d();
73
74 std::vector<cv::Point2f> GetSelectedFeaturesWarped();
75
76 std::vector<cv::Point2f> GetAllFeatures();
77
78 void CleanUp();
79
80};
81#endif //TRACKINGPOINTSELECTOR
int markerTemplateWidth
Definition: OCVConfig.cpp:40
Definition: TrackingPointSelector.h:47
TrackingPointSelector()
Definition: TrackingPointSelector.cpp:43
std::vector< cv::Point2f > _pts
Definition: TrackingPointSelector.h:54
std::map< int, std::vector< TrackedPoint > > trackingPointBin
Definition: TrackingPointSelector.h:55
void SelectPoints()
Definition: TrackingPointSelector.cpp:104
std::vector< cv::Point2f > GetSelectedFeatures()
Definition: TrackingPointSelector.cpp:124
std::vector< cv::Point3f > GetSelectedFeatures3d()
Definition: TrackingPointSelector.cpp:146
void SetHomography(cv::Mat newHomography)
Definition: TrackingPointSelector.cpp:84
void DistributeBins(int width, int height, int markerTemplateWidth)
Definition: TrackingPointSelector.cpp:54
cv::Mat homography
Definition: TrackingPointSelector.h:56
cv::Mat GetHomography()
Definition: TrackingPointSelector.cpp:89
std::vector< TrackedPoint > _selectedPts
Definition: TrackingPointSelector.h:53
std::vector< cv::Point2f > GetAllFeatures()
Definition: TrackingPointSelector.cpp:170
void CleanUp()
Definition: TrackingPointSelector.cpp:179
std::vector< cv::Point2f > GetTrackedFeatures()
Definition: TrackingPointSelector.cpp:135
std::vector< cv::Point2f > GetSelectedFeaturesWarped()
Definition: TrackingPointSelector.cpp:157
void UpdatePointStatus(std::vector< uchar > status)
Definition: TrackingPointSelector.cpp:94