Main MRPT website > C++ reference for MRPT 1.9.9
CRovio.h
Go to the documentation of this file.
1 /* +------------------------------------------------------------------------+
2  | Mobile Robot Programming Toolkit (MRPT) |
3  | http://www.mrpt.org/ |
4  | |
5  | Copyright (c) 2005-2017, Individual contributors, see AUTHORS file |
6  | See: http://www.mrpt.org/Authors - All rights reserved. |
7  | Released under BSD License. See details in http://www.mrpt.org/License |
8  +------------------------------------------------------------------------+ */
9 
10 #ifndef CROVIO_H
11 #define CROVIO_H
12 
13 #include <mrpt/utils/TCamera.h>
15 
17 
18 #include <thread>
19 
20 namespace mrpt
21 {
22 namespace hwdrivers
23 {
24 /** A class to interface a Rovio robot (manufactured by WowWee).
25  * Supports: Simple motion commands, video streaming.
26  * \ingroup mrpt_hwdrivers_grp
27  */
28 class CRovio
29 {
30  private:
31  std::thread m_videoThread;
36 
38  std::mutex buffer_img_cs;
39 
40  /** This function takes a frame and waits until getLastImage ask for it, and
41  * so on.
42  */
43  void thread_video();
44 
45  bool send_cmd_action(int act, int speed);
46 
47  bool path_management(int act);
48 
49  bool path_management(int act, const std::string& path_name);
50 
51  bool general_command(int act, std::string& response, std::string& errormsg);
52 
53  public:
54  struct TOptions
55  {
59 
60  mrpt::utils::TCamera cameraParams; // Mat. cam. preguntar paco
61 
62  TOptions();
63  } options;
64 
65  enum status
66  {
72  };
73 
74  struct TRovioState
75  {
77  unsigned int nss; // Navigation Signal Strength
78  unsigned int wss; // Wifi Signal Strength
79  };
80 
81  struct TEncoders
82  {
83  int left;
84  int right;
85  int rear;
87  {
88  left = 0;
89  right = 0;
90  rear = 0;
91  }
92  } encoders;
93 
94  /** Establish Connection with Rovio and log in its system: Important, fill
95  * out "options" members *BEFORE* calling this method.
96  * \exception std::runtime On errors
97  */
98  void initialize(); // string &errormsg_out, std::string
99  // url_out="150.214.109.134", std::string
100  // user_out="admin", std::string
101  // password_out="investigacion");
102 
103  /** move send Rovio the command to move in the specified direcction
104  * \param direction 'f'->forward, 'b'->backward, 'r'->right, 'l'->left
105  * \return False on error
106  */
107  bool move(char direction, int speed = 5);
108 
109  /** rotate send Rovio the command to rotate in the specified direcction
110  * 'r'->right, 'l'->left
111  * \return False on error
112  */
113  bool rotate(char direction, int speed = 5);
114 
115  /** Head positions
116  * \return False on error
117  */
118  bool takeHeadUp();
119  bool takeHeadMiddle();
120  bool takeHeadDown();
121 
122  /* Path commands */
123  bool pathRecord();
124  bool pathRecordAbort();
125  bool pathRecordSave(const std::string& path_name); // Repasar const
126  bool pathDelete(const std::string& path_name);
127  /** Get list of saved paths
128  */
129  bool pathGetList(std::string& path_list);
130  bool pathRunForward();
131  bool pathRunBackward();
132  bool pathRunStop();
133  bool pathRunPause();
134  bool pathRename(const std::string& old_name, const std::string& new_name);
135 
136  /** goHome(bool dock) drives Rovio in front of charging station if the
137  * paremeter dock is set to false, otherwise it also docks
138  * \return False on error
139  */
140  bool goHome(bool dock, int speed = 5);
141 
142  /** Loads the rovio camera calibration parameters (of leave the default ones
143  * if not found) (See CGenericSensor), then call to
144  * "loadConfig_sensorSpecific"
145  * \exception This method throws an exception with a descriptive message
146  * if some critical parameter is missing or has an invalid value.
147  */
148  void loadConfig(
149  const mrpt::utils::CConfigFileBase& configSource,
150  const std::string& section);
151 
152  /** This function launchs a thread with the function "thread_video()" which
153  * gets frames into a buffer.
154  * After calling this method, images can be obtained with
155  * getNextImageSync()
156  * \return False on error
157  * \sa getNextImageSync
158  */
159  bool retrieve_video(); // como la protejo para que no se llame dos
160  // veces??????????????????????????????????????????????
161 
162  /** This function stops and joins the thread launched by "retrieve_video()".
163  * \return False on error
164  */
165  bool stop_video();
166 
167  /** Returns the next frame from Rovio's live video stream, after starting
168  * the live streaming with retrieve_video()
169  * \return False on error
170  * \sa retrieve_video, captureImageAsync
171  */
173 
174  /** Returns a snapshot from Rovio, if rectified is set true, the returned
175  * image is rectified with the parameters of intrinsic_matrix and
176  * distortion_matrix.
177  * This function works asynchronously and does not need to have enabled the
178  * live video streaming.
179  * \return False on error
180  * \sa captureImageSync
181  */
182  bool captureImageAsync(
183  mrpt::utils::CImage& out_img, bool recttified); // string pict_name,
184 
185  /** Return true if video is streaming correctly \sa retrieve_video */
186  bool isVideoStreamming() const;
187 
188  // Rovio State
189  /** Returns a TRovioState with internal information of Rovio (State,
190  * Navigation Signal Strength, Wifi Signal Strength)
191  * \return False on error
192  */
193  bool getRovioState(TRovioState& state);
194 
195  /** Returns a TEncoders with information of Rovio encoders (since last read,
196  * it seems Rovio is continuously reading with unknown sample time)
197  * \return False on error
198  */
199  bool getEncoders(TEncoders& encoders);
200 
201  /** Returns the Rovio's pose
202  * \return False on error
203  */
204  bool getPosition(mrpt::math::TPose2D& out_pose);
205 
206  CRovio();
207  virtual ~CRovio();
208 
209 }; // End of class
210 
211 } // End of namespace
212 
213 } // End of namespace
214 
215 #endif
std::thread m_videoThread
Definition: CRovio.h:31
bool getNextImageSync(mrpt::obs::CObservationImage::Ptr &lastImage)
Returns the next frame from Rovio&#39;s live video stream, after starting the live streaming with retriev...
Definition: CRovio.cpp:324
bool getEncoders(TEncoders &encoders)
Returns a TEncoders with information of Rovio encoders (since last read, it seems Rovio is continuous...
Definition: CRovio.cpp:407
bool send_cmd_action(int act, int speed)
Definition: CRovio.cpp:67
bool path_management(int act)
Definition: CRovio.cpp:80
A class for storing images as grayscale or RGB bitmaps.
Definition: CImage.h:118
bool rotate(char direction, int speed=5)
rotate send Rovio the command to rotate in the specified direcction &#39;r&#39;->right, &#39;l&#39;->left ...
Definition: CRovio.cpp:134
bool pathDelete(const std::string &path_name)
Definition: CRovio.cpp:162
bool m_videothread_initialized_error
Definition: CRovio.h:34
bool m_videothread_initialized_done
Definition: CRovio.h:33
bool getPosition(mrpt::math::TPose2D &out_pose)
Returns the Rovio&#39;s pose.
Definition: CRovio.cpp:475
bool pathGetList(std::string &path_list)
Get list of saved paths.
Definition: CRovio.cpp:166
bool m_videothread_finished
Definition: CRovio.h:35
A class to interface a Rovio robot (manufactured by WowWee).
Definition: CRovio.h:28
This class allows loading and storing values and vectors of different types from a configuration text...
bool captureImageAsync(mrpt::utils::CImage &out_img, bool recttified)
Returns a snapshot from Rovio, if rectified is set true, the returned image is rectified with the par...
Definition: CRovio.cpp:343
bool move(char direction, int speed=5)
move send Rovio the command to move in the specified direcction
Definition: CRovio.cpp:116
mrpt::utils::TCamera cameraParams
Definition: CRovio.h:60
void initialize()
Establish Connection with Rovio and log in its system: Important, fill out "options" members BEFORE c...
Definition: CRovio.cpp:49
void thread_video()
This function takes a frame and waits until getLastImage ask for it, and so on.
Definition: CRovio.cpp:211
bool isVideoStreamming() const
Return true if video is streaming correctly.
Definition: CRovio.cpp:306
bool retrieve_video()
This function launchs a thread with the function "thread_video()" which gets frames into a buffer...
Definition: CRovio.cpp:277
GLsizei const GLchar ** string
Definition: glext.h:4101
struct mrpt::hwdrivers::CRovio::TEncoders encoders
This is the global namespace for all Mobile Robot Programming Toolkit (MRPT) libraries.
bool stop_video()
This function stops and joins the thread launched by "retrieve_video()".
Definition: CRovio.cpp:311
bool getRovioState(TRovioState &state)
Returns a TRovioState with internal information of Rovio (State, Navigation Signal Strength...
Definition: CRovio.cpp:372
bool m_videothread_must_exit
Definition: CRovio.h:32
std::shared_ptr< CObservationImage > Ptr
bool takeHeadUp()
Head positions.
Definition: CRovio.cpp:150
Lightweight 2D pose.
bool pathRecordSave(const std::string &path_name)
Definition: CRovio.cpp:158
bool goHome(bool dock, int speed=5)
goHome(bool dock) drives Rovio in front of charging station if the paremeter dock is set to false...
Definition: CRovio.cpp:189
struct mrpt::hwdrivers::CRovio::TOptions options
std::mutex buffer_img_cs
Definition: CRovio.h:38
bool general_command(int act, std::string &response, std::string &errormsg)
Definition: CRovio.cpp:104
Structure to hold the parameters of a pinhole camera model.
Definition: TCamera.h:32
bool pathRename(const std::string &old_name, const std::string &new_name)
Definition: CRovio.cpp:176
mrpt::obs::CObservationImage::Ptr buffer_img
Definition: CRovio.h:37
void loadConfig(const mrpt::utils::CConfigFileBase &configSource, const std::string &section)
Loads the rovio camera calibration parameters (of leave the default ones if not found) (See CGenericS...
Definition: CRovio.cpp:200



Page generated by Doxygen 1.8.14 for MRPT 1.9.9 Git: ae4571287 Thu Nov 23 00:06:53 2017 +0100 at dom oct 27 23:51:55 CET 2019