class mrpt::hwdrivers::CDUO3DCamera

This “software driver” implements the communication protocol for interfacing a DUO3D Stereo Camera.

See also the example configuration file for rawlog-grabber in “share/mrpt/config_files/rawlog-grabber”.

 PARAMETERS IN THE ".INI"-LIKE CONFIGURATION STRINGS:
-------------------------------------------------------
  [supplied_section_name]
       image_width             = 640           // [int]    x Resolution
       image_height            = 480           // [int]    y Resolution
       fps                     = 30            // [int]    Frames per second (<=30)
       exposure                = 50            // [int]    Exposure value (1..100)
       led                     = 0             // [int]    Led intensity (only for some device models) (1..100).
       gain                    = 50            // [int]    Camera gain (1..100)
       capture_rectified       = false         // [bool]   Rectify captured images
       capture_imu             = true          // [bool]   Capture IMU data from DUO3D device (if available)
       calibration_from_file   = true          // [bool]   Use YML calibration files provided by calibration application supplied with DUO3D device
       intrinsic_filename      = ""            // [string] Intrinsic parameters file.  This filename should contain a substring _RWWWxHHH_ with WWW being the image width and HHH the image height, as provided by the calibration application.
       extrinsic_filename      = ""            // [string] Extrinsic parameters file. This filename should contain a substring _RWWWxHHH_ with WWW being the image width and HHH the image height, as provided by the calibration application.
       rectify_map_filename    = ""            // [string] Rectification map file.  This filename should contain a substring _RWWWxHHH_ with WWW being the image width and HHH the image height, as provided by the calibration application.

  pose_x=0.21  // camera 3D position in the robot (meters)
  pose_y=0
  pose_z=0.34
  pose_yaw=0   // Angles in degrees
  pose_pitch=0
  pose_roll=0
#include <mrpt/hwdrivers/CDUO3DCamera.h>

class CDUO3DCamera
{
public:
    // construction

    CDUO3DCamera();
    CDUO3DCamera(const TCaptureOptions_DUO3D& options);
    CDUO3DCamera(const CDUO3DCamera&);

    //
methods

    CDUO3DCamera& operator = (const CDUO3DCamera&);
    const TCaptureOptions_DUO3D& getCameraOptions() const;
    void open(const TCaptureOptions_DUO3D& options, const bool startCapture = true);
    void startCapture();
    void stopCapture();
    void close();

    void getObservations(
        mrpt::obs::CObservationStereoImages& outObservation_img,
        mrpt::obs::CObservationIMU& outObservation_imu,
        bool& there_is_img,
        bool& there_is_imu
        );

    bool captureIMUIsSet();
    void* getEvent();
    void setDataFrame(void* frame);
};

Construction

CDUO3DCamera()

Default Constructor (does not open the camera)

Default constructor.

CDUO3DCamera(const TCaptureOptions_DUO3D& options)

Constructor: tries to open the camera with the given options.

Custom initialization and start grabbing constructor.

Raises an exception on error.

See also:

open()

Methods

const TCaptureOptions_DUO3D& getCameraOptions() const

Returns the current settings of the camera.

void open(const TCaptureOptions_DUO3D& options, const bool startCapture = true)

Tries to open the camera with the given options, and starts capturing.

Tries to open the camera with the given options.

Raises an exception on error. Raises an exception on error.

Parameters:

startCapture

If set to false, the camera is only opened and configured, but a posterior call to startCapture() is required to start grabbing data.

See also:

close(), startCapture()

close()

void startCapture()

Start the actual data capture of the camera.

Must be called after open(), only when “startCapture” was set to false.

void stopCapture()

Stop capture.

void close()

Stop capture and closes the opened camera, if any.

Closes DUO camera.

Called automatically on object destruction.

void getObservations(
    mrpt::obs::CObservationStereoImages& outObservation_img,
    mrpt::obs::CObservationIMU& outObservation_imu,
    bool& there_is_img,
    bool& there_is_imu
    )

Specific laser scanner “software drivers” must process here new data from the I/O stream, and, if a whole scan has arrived, return it.

This method will be typically called in a different thread than other methods, and will be called in a timely fashion.

bool captureIMUIsSet()

Indicates if the camera is grabbing IMU data.

void* getEvent()

Returned pointer to be reinterpreted as DUO3D’s “HANDLE”.

void setDataFrame(void* frame)

frame is a reinterpreted PDUOFrame