Skip to content

Commit

Permalink
Fix transparency of RobotLinks
Browse files Browse the repository at this point in the history
If a RobotLink has multiple visuals with different alpha values,
only the last one was actually used (stored in material_alpha_).
Instead, store the original material and use alpha from there.
  • Loading branch information
rhaschke committed Jun 4, 2022
1 parent d8df909 commit 08c272b
Show file tree
Hide file tree
Showing 2 changed files with 10 additions and 18 deletions.
24 changes: 9 additions & 15 deletions src/rviz/robot/robot_link.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -163,7 +163,6 @@ RobotLink::RobotLink(Robot* robot,
, collision_node_(nullptr)
, trail_(nullptr)
, axes_(nullptr)
, material_alpha_(1.0)
, robot_alpha_(1.0)
, only_render_depth_(false)
, is_selectable_(true)
Expand Down Expand Up @@ -396,7 +395,8 @@ void RobotLink::updateAlpha()
else
{
Ogre::ColourValue color = active->getTechnique(0)->getPass(0)->getDiffuse();
color.a = robot_alpha_ * material_alpha_ * link_alpha;
const float material_alpha = original->getTechnique(0)->getPass(0)->getDiffuse().a;
color.a = robot_alpha_ * material_alpha * link_alpha;
active->setDiffuse(color);

if (color.a < 0.9998) // transparent
Expand Down Expand Up @@ -491,8 +491,6 @@ Ogre::MaterialPtr RobotLink::getMaterialForLink(const urdf::LinkConstSharedPtr&
const urdf::Color& col = material->color;
mat->getTechnique(0)->setAmbient(col.r * 0.5, col.g * 0.5, col.b * 0.5);
mat->getTechnique(0)->setDiffuse(col.r, col.g, col.b, col.a);

material_alpha_ = col.a;
}
else
{
Expand Down Expand Up @@ -660,19 +658,15 @@ void RobotLink::createEntityForGeometryElement(const urdf::LinkConstSharedPtr& l

Ogre::MaterialPtr active, original;
if (material_name == "BaseWhite" || material_name == "BaseWhiteNoLighting")
{
sub->setMaterial(active = default_material_);
original = active; // we don't need a backup copy of the default material
}
original = default_material_;
else
{
original = sub->getMaterial();
// create a new material copy for each instance of a RobotLink to allow modification per link
active = Ogre::MaterialPtr(new Ogre::Material(
nullptr, material_name, 0, Ogre::ResourceGroupManager::DEFAULT_RESOURCE_GROUP_NAME));
*active = *original;
sub->setMaterial(active);
}

// create a new material copy for each instance of a RobotLink to allow modification per link
active = Ogre::MaterialPtr(new Ogre::Material(
nullptr, material_name, 0, Ogre::ResourceGroupManager::DEFAULT_RESOURCE_GROUP_NAME));
*active = *original;
sub->setMaterial(active);
materials_[sub] = std::make_pair(active, original);
}
}
Expand Down
4 changes: 1 addition & 3 deletions src/rviz/robot/robot_link.h
Original file line number Diff line number Diff line change
Expand Up @@ -242,9 +242,7 @@ private Q_SLOTS:

Axes* axes_;

float material_alpha_; ///< If material is not a texture, this saves the alpha value set in the URDF,
/// otherwise is 1.0.
float robot_alpha_; ///< Alpha value from top-level robot alpha Property (set via setRobotAlpha()).
float robot_alpha_; ///< Alpha value from top-level robot alpha Property (set via setRobotAlpha()).

bool only_render_depth_;
bool is_selectable_;
Expand Down

0 comments on commit 08c272b

Please sign in to comment.