Skip to content

Commit 085b939

Browse files
authored
Merge pull request #7250 from rldhont/composer-filter-legend-nodes-fix-218
Remove invisible layers from legend
2 parents 4d07516 + cf3054d commit 085b939

File tree

1 file changed

+13
-10
lines changed

1 file changed

+13
-10
lines changed

src/core/layertree/qgslayertreemodel.cpp

+13-10
Original file line numberDiff line numberDiff line change
@@ -1150,21 +1150,24 @@ QList<QgsLayerTreeModelLegendNode*> QgsLayerTreeModel::filterLegendNodes( const
11501150
}
11511151
else if ( mLegendFilterMapSettings )
11521152
{
1153-
Q_FOREACH ( QgsLayerTreeModelLegendNode* node, nodes )
1153+
if ( !nodes.isEmpty() && mLegendFilterMapSettings->layers().contains( nodes.at( 0 )->layerNode()->layerId() ) )
11541154
{
1155-
QgsSymbolV2* ruleKey = reinterpret_cast< QgsSymbolV2* >( node->data( QgsSymbolV2LegendNode::SymbolV2LegacyRuleKeyRole ).value<void*>() );
1156-
bool checked = mLegendFilterUsesExtent || node->data( Qt::CheckStateRole ).toInt() == Qt::Checked;
1157-
if ( ruleKey && checked )
1155+
Q_FOREACH ( QgsLayerTreeModelLegendNode* node, nodes )
11581156
{
1159-
QString ruleKey = node->data( QgsSymbolV2LegendNode::RuleKeyRole ).toString();
1160-
if ( QgsVectorLayer* vl = qobject_cast<QgsVectorLayer*>( node->layerNode()->layer() ) )
1157+
QgsSymbolV2* ruleKey = reinterpret_cast< QgsSymbolV2* >( node->data( QgsSymbolV2LegendNode::SymbolV2LegacyRuleKeyRole ).value<void*>() );
1158+
bool checked = mLegendFilterUsesExtent || node->data( Qt::CheckStateRole ).toInt() == Qt::Checked;
1159+
if ( ruleKey && checked )
11611160
{
1162-
if ( mLegendFilterHitTest->legendKeyVisible( ruleKey, vl ) )
1163-
filtered << node;
1161+
QString ruleKey = node->data( QgsSymbolV2LegendNode::RuleKeyRole ).toString();
1162+
if ( QgsVectorLayer* vl = qobject_cast<QgsVectorLayer*>( node->layerNode()->layer() ) )
1163+
{
1164+
if ( mLegendFilterHitTest->legendKeyVisible( ruleKey, vl ) )
1165+
filtered << node;
1166+
}
11641167
}
1168+
else // unknown node type or unchecked
1169+
filtered << node;
11651170
}
1166-
else // unknown node type or unchecked
1167-
filtered << node;
11681171
}
11691172
}
11701173
else

0 commit comments

Comments
 (0)