BitmapToolkit Scol plugin
ArTkDetector.h
Go to the documentation of this file.
1/*
2-----------------------------------------------------------------------------
3This source file is part of OpenSpace3D
4For the latest info, see http://www.openspace3d.com
5
6Copyright (c) 2012 I-maginer
7
8This program is free software; you can redistribute it and/or modify it under
9the terms of the GNU Lesser General Public License as published by the Free Software
10Foundation; either version 2 of the License, or (at your option) any later
11version.
12
13This program is distributed in the hope that it will be useful, but WITHOUT
14ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
15FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.
16
17You should have received a copy of the GNU Lesser General Public License along with
18this program; if not, write to the Free Software Foundation, Inc., 59 Temple
19Place - Suite 330, Boston, MA 02111-1307, USA, or go to
20http://www.gnu.org/copyleft/lesser.txt
21
22-----------------------------------------------------------------------------
23*/
24
25#ifndef __BTK_ARTKDETECTOR_H__
26#define __BTK_ARTKDETECTOR_H__
27
28#include "Prerequisites.h"
29#include <aruco.h>
30#include <set>
31#include "ArTkMarker.h"
32#include "ArCameraParam.h"
33#include "ArManager.h"
34#include "BitmapToolkitThread.h"
35
36#include <AR/ar.h>
37#include <AR/arFilterTransMat.h>
38#include <AR2/tracking.h>
39#include <KPM/kpm.h>
40
42{
43 public:
46 protected:
47
48 private:
49 LASTDATA mLastData;
50 boost::recursive_mutex mUpdateMutex;
51 boost::mutex mDetectMutex;
52 std::set<ArTkMarker*> mMarkerList;
53 std::vector<AR2SurfaceSetT*> mSurfaceSet;
54 KpmHandle* mKpmHandle;
55 AR2HandleT* mAr2Handle;
56 ARParamLT* mArCamParam;
57 int mSkippage[1024];
58 int mNumSkip;
59 cv::Mat mDetectorFrame;
60 cv::Mat mDetectorColorFrame;
61 float mScale;
62 ArCameraParam mCamparam;
63 bool mReverse;
64
65 bool mIsDirty;
66 bool mDetectionInProgress;
67
68 void BuildCameraParam(ArCameraParam &camparam);
69 void InitDetector();
70 void NFTDetect();
71
72 public:
74 void GoThread();
75 void SetDirty();
76 void AddMarker(ArMarker* marker);
77 void RemoveMarker(ArMarker* marker);
78 protected:
79
80 private:
81};
82
83#endif
void RemoveMarker(ArMarker *marker)
void AddMarker(ArMarker *marker)