Skip to content

Commit

Permalink
Optimize rendering sensor pose updates (gazebosim#2425)
Browse files Browse the repository at this point in the history
---------

Signed-off-by: Ian Chen <[email protected]>
  • Loading branch information
iche033 authored Jun 5, 2024
1 parent ce09c04 commit 9e60fdc
Showing 1 changed file with 13 additions and 80 deletions.
93 changes: 13 additions & 80 deletions src/rendering/RenderUtil.cc
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@
#include <vector>

#include <sdf/Actor.hh>
#include <sdf/Camera.hh>
#include <sdf/Collision.hh>
#include <sdf/Element.hh>
#include <sdf/Joint.hh>
Expand Down Expand Up @@ -1323,6 +1324,18 @@ void RenderUtil::Update()
gzerr << "Failed to create sensor [" << sensorName << "]"
<< std::endl;
}
else
{
auto sensorNode = this->dataPtr->sceneManager.NodeById(entity);
auto semPose = dataSdf.SemanticPose();
math::Pose3d sensorPose;
sdf::Errors errors = semPose.Resolve(sensorPose);
if (!errors.empty())
{
sensorPose = dataSdf.RawPose();
}
sensorNode->SetLocalPose(sensorPose);
}
}
}
}
Expand Down Expand Up @@ -2388,86 +2401,6 @@ void RenderUtilPrivate::UpdateRenderingEntities(
this->entityPoses[_entity] = _pose->Data();
return true;
});

// Update cameras
_ecm.Each<components::Camera, components::Pose>(
[&](const Entity &_entity,
const components::Camera *,
const components::Pose *_pose)->bool
{
this->entityPoses[_entity] = _pose->Data();
return true;
});

// Update depth cameras
_ecm.Each<components::DepthCamera, components::Pose>(
[&](const Entity &_entity,
const components::DepthCamera *,
const components::Pose *_pose)->bool
{
this->entityPoses[_entity] = _pose->Data();
return true;
});

// Update RGBD cameras
_ecm.Each<components::RgbdCamera, components::Pose>(
[&](const Entity &_entity,
const components::RgbdCamera *,
const components::Pose *_pose)->bool
{
this->entityPoses[_entity] = _pose->Data();
return true;
});

// Update gpu_lidar
_ecm.Each<components::GpuLidar, components::Pose>(
[&](const Entity &_entity,
const components::GpuLidar *,
const components::Pose *_pose)->bool
{
this->entityPoses[_entity] = _pose->Data();
return true;
});

// Update thermal cameras
_ecm.Each<components::ThermalCamera, components::Pose>(
[&](const Entity &_entity,
const components::ThermalCamera *,
const components::Pose *_pose)->bool
{
this->entityPoses[_entity] = _pose->Data();
return true;
});

// Update segmentation cameras
_ecm.Each<components::SegmentationCamera, components::Pose>(
[&](const Entity &_entity,
const components::SegmentationCamera *,
const components::Pose *_pose)->bool
{
this->entityPoses[_entity] = _pose->Data();
return true;
});

// Update bounding box cameras
_ecm.Each<components::BoundingBoxCamera, components::Pose>(
[&](const Entity &_entity,
const components::BoundingBoxCamera *,
const components::Pose *_pose)->bool
{
this->entityPoses[_entity] = _pose->Data();
return true;
});

// Update wide angle cameras
_ecm.Each<components::WideAngleCamera, components::Pose>(
[&](const Entity &_entity,
const components::WideAngleCamera *,
const components::Pose *_pose)->bool
{
this->entityPoses[_entity] = _pose->Data();
return true;
});
}

//////////////////////////////////////////////////
Expand Down

0 comments on commit 9e60fdc

Please sign in to comment.