Skip to content

Commit

Permalink
[FEATURE] zoom to group of layers. Contributed by Alex Bruy - thanks! (
Browse files Browse the repository at this point in the history
…#2783)

git-svn-id: http://svn.osgeo.org/qgis/trunk/qgis@15220 c8812cc2-4d05-0410-92ff-de0c093fc19c
  • Loading branch information
wonder committed Feb 20, 2011
1 parent 47cb1b8 commit 94fd8c3
Showing 1 changed file with 52 additions and 11 deletions.
63 changes: 52 additions & 11 deletions src/app/legend/qgslegend.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -549,6 +549,9 @@ void QgsLegend::handleRightClickEvent( QTreeWidgetItem* item, const QPoint& posi
}
else if ( li->type() == QgsLegendItem::LEGEND_GROUP )
{
theMenu.addAction( QgisApp::getThemeIcon( "/mActionZoomToLayer.png" ),
tr( "Zoom to group" ), this, SLOT( legendLayerZoom() ) );

theMenu.addAction( QgisApp::getThemeIcon( "/mActionRemoveLayer.png" ),
tr( "&Remove" ), this, SLOT( legendGroupRemove() ) );
}
Expand Down Expand Up @@ -1656,21 +1659,59 @@ void QgsLegend::legendLayerZoom()
return;
}

//find current Layer
QgsLegendLayer* currentLayer = dynamic_cast<QgsLegendLayer *>( currentItem() );
if ( !currentLayer )
return;
QgsRectangle extent;

QgsMapLayer* theLayer = currentLayer->layer();
QgsRectangle extent = theLayer->extent();
QgsLegendItem* li = dynamic_cast<QgsLegendItem *>( currentItem() );

//transform extent if otf-projection is on
if ( mMapCanvas->hasCrsTransformEnabled() )
if ( li->type() == QgsLegendItem::LEGEND_LAYER )
{
QgsMapRenderer* renderer = mMapCanvas->mapRenderer();
if ( renderer )
QgsLegendLayer* currentLayer = dynamic_cast<QgsLegendLayer *>( currentItem() );
if ( !currentLayer )
return;

QgsMapLayer* theLayer = currentLayer->layer();
extent = theLayer->extent();

//transform extent if otf-projection is on
if ( mMapCanvas->hasCrsTransformEnabled() )
{
extent = renderer->layerExtentToOutputExtent( theLayer, extent );
QgsMapRenderer* renderer = mMapCanvas->mapRenderer();
if ( renderer )
{
extent = renderer->layerExtentToOutputExtent( theLayer, extent );
}
}
}
else if ( li->type() == QgsLegendItem::LEGEND_GROUP )
{
QgsLegendGroup* currentGroup = dynamic_cast<QgsLegendGroup *>( currentItem() );

QgsRectangle layerExtent;

QList<QgsLegendLayer*> layers = currentGroup->legendLayers();
for ( int i = 0; i < layers.size(); ++i )
{
QgsMapLayer* theLayer = layers.at( i )->layer();
layerExtent = theLayer->extent();

//transform extent if otf-projection is on
if ( mMapCanvas->hasCrsTransformEnabled() )
{
QgsMapRenderer* renderer = mMapCanvas->mapRenderer();
if ( renderer )
{
layerExtent = renderer->layerExtentToOutputExtent( theLayer, layerExtent );
}
}

if ( i == 0 )
{
extent = layerExtent;
}
else
{
extent.combineExtentWith( &layerExtent );
}
}
}

Expand Down

0 comments on commit 94fd8c3

Please sign in to comment.