Go to the documentation of this file.
11 #include <ros/console.h>
28 if (old_depth == 0.0 || depth < old_depth)
30 ROS_DEBUG_STREAM(
"Using " <<
active_entity_ <<
" as active entity, depth from " << old_depth <<
" to " << depth);
67 if ((!e->collision() && !e->visual()) || !e->has_pose())
71 for (
const auto& volume : e->volumes())
75 if (name ==
"on_top_of")
77 ROS_DEBUG(
"Raytrace on_top_of array of %s included", e->id().c_str());
79 opt.
setMesh(shape->getMesh(), raytrace_pose_inv * e->pose());
85 ROS_DEBUG_STREAM(
"Raytracing to " << e->id() <<
" " << (e->collision() ?
"collision" :
"visual") <<
" mesh");
88 opt.
setMesh(shape->getMesh(), raytrace_pose_inv * e->pose());
99 ROS_DEBUG(
"Did not raytrace through any entity");
void setAngleLimits(double min, double max)
void setRangeLimits(double min, double max)
void render(const geo::LaserRangeFinder::RenderOptions &options, geo::LaserRangeFinder::RenderResult &res) const
const_iterator begin() const
EntityIterator const_iterator
RayTraceResult ray_trace(const ed::WorldModel &world, const geo::Pose3D &raytrace_pose)
geo::Vector3 intersection_point_
shared_ptr< const Entity > EntityConstPtr
const_iterator end() const
void setMesh(const geo::Mesh &mesh, const geo::Pose3D &pose)
std::string active_entity_
void renderPoint(uint, float depth)
std::vector< double > dummy_ranges_
RenderResult(std::vector< double > &ranges_)