Gazebo Sensors

API Reference

10.0.0
DepthCameraSensor Class Reference

Depth camera sensor class. More...

#include <DepthCameraSensor.hh>

Public Member Functions

 DepthCameraSensor ()
 constructor
 
virtual ~DepthCameraSensor ()
 destructor
 
gz::common::ConnectionPtr ConnectImageCallback (std::function< void(const gz::msgs::Image &)> _callback)
 Set a callback to be called when image frame data is generated.
 
virtual rendering::DepthCameraPtr DepthCamera () const
 Get a pointer to the rendering depth camera.
 
virtual double FarClip () const
 Get image width.
 
virtual bool HasConnections () const override
 Check if there are any subscribers.
 
virtual bool HasDepthConnections () const
 Check if there are any depth subscribers.
 
virtual bool HasPointConnections () const
 Check if there are any point subscribers.
 
virtual unsigned int ImageHeight () const override
 Get image height.
 
virtual unsigned int ImageWidth () const override
 Get image width.
 
virtual bool Init () override
 Initialize values in the sensor.
 
virtual bool Load (const sdf::Sensor &_sdf) override
 Load the sensor based on data from an sdf::Sensor object.
 
virtual bool Load (sdf::ElementPtr _sdf) override
 Load the sensor with SDF parameters.
 
virtual double NearClip () const
 Get image height.
 
void OnNewDepthFrame (const float *_scan, unsigned int _width, unsigned int _height, unsigned int _channel, const std::string &_format)
 Depth data callback used to get the data from the sensor.
 
void OnNewRgbPointCloud (const float *_scan, unsigned int _width, unsigned int _height, unsigned int _channels, const std::string &_format)
 Point cloud data callback used to get the data from the sensor.
 
virtual void SetScene (gz::rendering::ScenePtr _scene) override
 Set the rendering scene.
 
virtual bool Update (const std::chrono::steady_clock::duration &_now) override
 Force the sensor to generate data.
 
- Public Member Functions inherited from CameraSensor
 CameraSensor ()
 constructor
 
virtual ~CameraSensor ()
 destructor
 
double Baseline () const
 Get baseline for stereo cameras.
 
gz::common::ConnectionPtr ConnectImageCallback (std::function< void(const gz::msgs::Image &)> _callback)
 Set a callback to be called when image frame data is generated.
 
virtual bool HasImageConnections () const
 Check if there are any image subscribers.
 
virtual bool HasInfoConnections () const
 Check if there are any info subscribers.
 
const std::stringInfoTopic () const
 Topic where camera info is published.
 
const std::stringOpticalFrameId () const
 Get the camera optical frame.
 
virtual rendering::CameraPtr RenderingCamera () const
 Get pointer to rendering camera object.
 
void SetBaseline (double _baseline)
 Set baseline for stereo cameras. This is used to populate the projection matrix in the camera info message.
 
bool Update (const std::chrono::steady_clock::duration &_now, const bool _force)
 Update the sensor.
 
void UpdateLensIntrinsicsAndProjection (rendering::CameraPtr _camera, sdf::Camera &_cameraSdf)
 Set camera lens intrinsics and projection based on values from SDF. If the camera SDF does not contain intrinsic or projection parameters, the camera will not be updated. Instead, the camera SDF will be updated with intrinsic and projection values computed manually from current camera intrinsic properties.
 
- Public Member Functions inherited from RenderingSensor
virtual ~RenderingSensor ()
 destructor
 
bool ManualSceneUpdate () const
 Get whether the scene graph is updated manually. Defaults to false.
 
void Render ()
 Render update. This performs the actual render operation.
 
rendering::ScenePtr Scene () const
 Get the rendering scene.
 
void SetManualSceneUpdate (bool _manual)
 Set whether to update the scene graph manually. If set to true, it is expected that rendering::Scene::PreRender is called manually before calling Render()
 
virtual void SetScene (rendering::ScenePtr _scene)
 Set the rendering scene.
 
- Public Member Functions inherited from Sensor
virtual ~Sensor ()
 destructor
 
void AddSequence (gz::msgs::Header *_msg, const std::string &_seqKey="default")
 Add a sequence number to a gz::msgs::Header. This function can be called by a sensor that wants to add a sequence number to a sensor message in order to have improved accountability for generated sensor data.
 
bool EnableMetrics () const
 Get flag state for enabling performance metrics publication.
 
const std::stringFrameId () const
 FrameId.
 
bool HasPendingTrigger () const
 Whether the sensor has a pending trigger.
 
SensorId Id () const
 Get the sensor's ID.
 
bool IsActive () const
 Get whether the sensor is enabled or not.
 
bool IsTriggered () const
 Whether the sensor trigger mode is enabled.
 
const std::stringName () const
 Get name.
 
std::chrono::steady_clock::duration NextDataUpdateTime () const
 Return the next time the sensor will generate data.
 
const std::stringParent () const
 Get parent link of the sensor.
 
gz::math::Pose3d Pose () const
 Get the current pose.
 
void PublishMetrics (const std::chrono::duration< double > &_now)
 Publishes information about the performance of the sensor. This method is called by Update().
 
sdf::ElementPtr SDF () const
 Get the SDF used to load this sensor.
 
void SetActive (bool _active)
 Enable or disable the sensor. Disabled sensors will not generate or publish data unless Update is called with the '_force' argument set to true.
 
void SetEnableMetrics (bool _enableMetrics)
 Set flag to enable publishing performance metrics.
 
void SetFrameId (const std::string &_frameId)
 Set Frame ID of the sensor.
 
void SetNextDataUpdateTime (const std::chrono::steady_clock::duration &_time)
 Manually set the next time the sensor will generate data Useful for accomodating jumps backwards in time as well as specifying updates for non-uniformly updating sensors.
 
virtual void SetParent (const std::string &_parent)
 Set the parent of the sensor.
 
void SetPose (const gz::math::Pose3d &_pose)
 Update the pose of the sensor.
 
bool SetTopic (const std::string &_topic)
 Set topic where sensor data is published.
 
bool SetTriggered (bool _triggered, const std::string &_triggerTopic="")
 Enable or disable triggered mode. In this mode,.
 
void SetUpdateRate (const double _hz)
 Set the update rate of the sensor. An update rate of zero means that the sensor is updated every cycle. It's zero by default.
 
const std::stringTopic () const
 Get topic where sensor data is published.
 
bool Update (const std::chrono::steady_clock::duration &_now, const bool _force)
 Update the sensor.
 
double UpdateRate () const
 Get the update rate of the sensor.
 

Additional Inherited Members

- Protected Member Functions inherited from CameraSensor
bool AdvertiseInfo ()
 Advertise camera info topic.
 
bool AdvertiseInfo (const std::string &_topic)
 Advertise camera info topic. This version takes a string that allows one to override the camera_info topic.
 
void PopulateInfo (const sdf::Camera *_cameraSdf)
 Populate camera info message.
 
void PublishInfo (const std::chrono::steady_clock::duration &_now)
 Publish camera info message.
 
- Protected Member Functions inherited from RenderingSensor
 RenderingSensor ()
 constructor
 
void AddSensor (rendering::SensorPtr _sensor)
 Add a rendering::Sensor. Its render updates will be handled by this base class.
 
- Protected Member Functions inherited from Sensor
 Sensor ()
 constructor
 

Detailed Description

Depth camera sensor class.

This class creates depth image from a Gazebo Rendering scene. The scene must be created in advance and given to Manager::Init(). It offers both a gz-transport interface and a direct C++ API to access the image data. The API works by setting a callback to be called with image data.

Constructor & Destructor Documentation

◆ DepthCameraSensor()

constructor

◆ ~DepthCameraSensor()

virtual ~DepthCameraSensor ( )
virtual

destructor

Member Function Documentation

◆ ConnectImageCallback()

gz::common::ConnectionPtr ConnectImageCallback ( std::function< void(const gz::msgs::Image &)>  _callback)

Set a callback to be called when image frame data is generated.

Parameters
[in]_callbackThis callback will be called every time the camera produces image data. The Update function will be blocked while the callbacks are executed.
Remarks
Do not block inside of the callback.
Returns
A connection pointer that must remain in scope. When the connection pointer falls out of scope, the connection is broken.

◆ DepthCamera()

virtual rendering::DepthCameraPtr DepthCamera ( ) const
virtual

Get a pointer to the rendering depth camera.

Returns
Rendering depth camera

◆ FarClip()

virtual double FarClip ( ) const
virtual

Get image width.

Returns
width of the image

◆ HasConnections()

virtual bool HasConnections ( ) const
overridevirtual

Check if there are any subscribers.

Returns
True if there are subscribers, false otherwise

Reimplemented from CameraSensor.

◆ HasDepthConnections()

virtual bool HasDepthConnections ( ) const
virtual

Check if there are any depth subscribers.

Returns
True if there are subscribers, false otherwise

◆ HasPointConnections()

virtual bool HasPointConnections ( ) const
virtual

Check if there are any point subscribers.

Returns
True if there are subscribers, false otherwise

◆ ImageHeight()

virtual unsigned int ImageHeight ( ) const
overridevirtual

Get image height.

Returns
height of the image

Reimplemented from CameraSensor.

◆ ImageWidth()

virtual unsigned int ImageWidth ( ) const
overridevirtual

Get image width.

Returns
width of the image

Reimplemented from CameraSensor.

◆ Init()

virtual bool Init ( )
overridevirtual

Initialize values in the sensor.

Returns
True on success

Reimplemented from CameraSensor.

◆ Load() [1/2]

virtual bool Load ( const sdf::Sensor &  _sdf)
overridevirtual

Load the sensor based on data from an sdf::Sensor object.

Parameters
[in]_sdfSDF Sensor parameters.
Returns
true if loading was successful

Reimplemented from CameraSensor.

◆ Load() [2/2]

virtual bool Load ( sdf::ElementPtr  _sdf)
overridevirtual

Load the sensor with SDF parameters.

Parameters
[in]_sdfSDF Sensor parameters.
Returns
true if loading was successful

Reimplemented from CameraSensor.

◆ NearClip()

virtual double NearClip ( ) const
virtual

Get image height.

Returns
height of the image

◆ OnNewDepthFrame()

void OnNewDepthFrame ( const float *  _scan,
unsigned int  _width,
unsigned int  _height,
unsigned int  _channel,
const std::string _format 
)

Depth data callback used to get the data from the sensor.

Parameters
[in]_scanpointer to the data from the sensor
[in]_widthwidth of the depth image
[in]_heightheight of the depth image
[in]_channelbytes used for the depth data
[in]_formatstring with the format

◆ OnNewRgbPointCloud()

void OnNewRgbPointCloud ( const float *  _scan,
unsigned int  _width,
unsigned int  _height,
unsigned int  _channels,
const std::string _format 
)

Point cloud data callback used to get the data from the sensor.

Parameters
[in]_scanpointer to the data from the sensor
[in]_widthwidth of the point cloud image
[in]_heightheight of the point cloud image
[in]_channelsbytes used for the point cloud data
[in]_formatstring with the format

◆ SetScene()

virtual void SetScene ( gz::rendering::ScenePtr  _scene)
overridevirtual

Set the rendering scene.

Parameters
[in]_scenePointer to the scene

Reimplemented from CameraSensor.

◆ Update()

virtual bool Update ( const std::chrono::steady_clock::duration &  _now)
overridevirtual

Force the sensor to generate data.

Parameters
[in]_nowThe current time
Returns
true if the update was successfull

Reimplemented from CameraSensor.


The documentation for this class was generated from the following file: