Navigation Menu

Skip to content

Commit

Permalink
Fix opacity slider crash
Browse files Browse the repository at this point in the history
Fixes a race condition introduced by the timer.
  • Loading branch information
m-kuhn authored and nyalldawson committed Jul 21, 2021
1 parent 96f2cdb commit 15d4196
Show file tree
Hide file tree
Showing 2 changed files with 6 additions and 1 deletion.
4 changes: 4 additions & 0 deletions src/gui/layertree/qgslayertreeembeddedwidgetsimpl.cpp
Expand Up @@ -71,13 +71,17 @@ void QgsLayerTreeOpacityWidget::sliderValueChanged( int value )

void QgsLayerTreeOpacityWidget::updateOpacityFromSlider()
{
if ( !mLayer )
return;
int value = mSlider->value();
mLayer->setOpacity( value / 1000.0 );
mLayer->triggerRepaint();
}

void QgsLayerTreeOpacityWidget::layerTrChanged()
{
if ( !mLayer )
return;
mSlider->blockSignals( true );
mSlider->setValue( mLayer->opacity() * 1000.0 );
mSlider->blockSignals( false );
Expand Down
3 changes: 2 additions & 1 deletion src/gui/layertree/qgslayertreeembeddedwidgetsimpl.h
Expand Up @@ -16,6 +16,7 @@
#ifndef QGSLAYERTREEEMBEDDEDWIDGETSIMPL_H
#define QGSLAYERTREEEMBEDDEDWIDGETSIMPL_H

#include <QPointer>
#include <QWidget>
#include "qgslayertreeembeddedwidgetregistry.h"

Expand Down Expand Up @@ -56,7 +57,7 @@ class QgsLayerTreeOpacityWidget : public QWidget
void layerTrChanged();

private:
QgsMapLayer *mLayer = nullptr;
QPointer<QgsMapLayer> mLayer;
QSlider *mSlider = nullptr;
QTimer *mTimer = nullptr;
};
Expand Down

0 comments on commit 15d4196

Please sign in to comment.