Skip to content

Commit

Permalink
Fix a potential crash in the new translucent VdW & licorice code
Browse files Browse the repository at this point in the history
The code needed to look up the layers for each atom correctly

Signed-off-by: Geoff Hutchison <[email protected]>
  • Loading branch information
ghutchis committed Nov 18, 2024
1 parent 857f011 commit bf1229a
Show file tree
Hide file tree
Showing 2 changed files with 6 additions and 2 deletions.
4 changes: 3 additions & 1 deletion avogadro/qtplugins/licorice/licorice.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -124,7 +124,9 @@ void Licorice::process(const Molecule& molecule, Rendering::GroupNode& node)
}
Vector3ub color = atom.color();

opacity = m_layerManager.getSetting<LayerLicorice>(i)->opacity;
auto* interface =
m_layerManager.getSetting<LayerLicorice>(m_layerManager.getLayerID(i));
opacity = interface->opacity;
if (opacity < 1.0f) {
translucentSpheres->addSphere(atom.position3d().cast<float>(), color,
radius, i);
Expand Down
4 changes: 3 additions & 1 deletion avogadro/qtplugins/vanderwaals/vanderwaals.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -121,7 +121,9 @@ void VanDerWaals::process(const QtGui::Molecule& molecule,

Vector3ub color = atom.color();
auto radius = static_cast<float>(Elements::radiusVDW(atomicNumber));
float opacity = m_layerManager.getSetting<LayerVdW>(i)->opacity;
auto* interface =
m_layerManager.getSetting<LayerVdW>(m_layerManager.getLayerID(i));
float opacity = interface->opacity;
if (opacity < 1.0f) {
translucentSpheres->addSphere(atom.position3d().cast<float>(), color,
radius, i);
Expand Down

0 comments on commit bf1229a

Please sign in to comment.