Skip to content

Commit

Permalink
QgsVectorLayer:
Browse files Browse the repository at this point in the history
- boundingBoxOfSelected() iterate only selected feature with featureAtId where available
- identify unknown extents in metadata
  • Loading branch information
jef-n committed Jan 9, 2012
1 parent ed01a8b commit c099afc
Showing 1 changed file with 59 additions and 40 deletions.
99 changes: 59 additions & 40 deletions src/core/qgsvectorlayer.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1390,24 +1390,36 @@ QgsRectangle QgsVectorLayer::boundingBoxOfSelected()
}

QgsRectangle r, retval;


select( QgsAttributeList(), QgsRectangle(), true );

retval.setMinimal();

QgsFeature fet;
while ( nextFeature( fet ) )
if ( mDataProvider->capabilities() & QgsVectorDataProvider::SelectAtId )
{
if ( mSelectedFeatureIds.contains( fet.id() ) )
foreach( QgsFeatureId fid, mSelectedFeatureIds )
{
if ( fet.geometry() )
if ( featureAtId( fid, fet, true, false ) && fet.geometry() )
{
r = fet.geometry()->boundingBox();
retval.combineExtentWith( &r );
}
}
}
else
{
select( QgsAttributeList(), QgsRectangle(), true );

while ( nextFeature( fet ) )
{
if ( mSelectedFeatureIds.contains( fet.id() ) )
{
if ( fet.geometry() )
{
r = fet.geometry()->boundingBox();
retval.combineExtentWith( &r );
}
}
}
}

if ( retval.width() == 0.0 || retval.height() == 0.0 )
{
Expand Down Expand Up @@ -5428,7 +5440,7 @@ QString QgsVectorLayer::metadata()
myMetadata += tr( "Extents:" );
myMetadata += "</td></tr>";
//extents in layer cs TODO...maybe make a little nested table to improve layout...
myMetadata += "<tr><td>";
myMetadata += "<tr><td>" + tr( "In layer spatial reference system units : " );

// Try to be a bit clever over what number format we use for the
// extents. Some people don't like it using scientific notation when the
Expand All @@ -5440,44 +5452,51 @@ QString QgsVectorLayer::metadata()
// - for all smaller numbers let the OS decide which format to use (it will
// generally use non-scientific unless the number gets much less than 1).

QString xMin, yMin, xMax, yMax;
double changeoverValue = 99999; // The 'largest' 5 digit number
if ( qAbs( myExtent.xMinimum() ) > changeoverValue )
{
xMin = QString( "%1" ).arg( myExtent.xMinimum(), 0, 'f', 2 );
}
else
{
xMin = QString( "%1" ).arg( myExtent.xMinimum() );
}
if ( qAbs( myExtent.yMinimum() ) > changeoverValue )
if ( !myExtent.isEmpty() )
{
yMin = QString( "%1" ).arg( myExtent.yMinimum(), 0, 'f', 2 );
}
else
{
yMin = QString( "%1" ).arg( myExtent.yMinimum() );
}
if ( qAbs( myExtent.xMaximum() ) > changeoverValue )
{
xMax = QString( "%1" ).arg( myExtent.xMaximum(), 0, 'f', 2 );
}
else
{
xMax = QString( "%1" ).arg( myExtent.xMaximum() );
}
if ( qAbs( myExtent.yMaximum() ) > changeoverValue )
{
yMax = QString( "%1" ).arg( myExtent.yMaximum(), 0, 'f', 2 );
QString xMin, yMin, xMax, yMax;
double changeoverValue = 99999; // The 'largest' 5 digit number
if ( qAbs( myExtent.xMinimum() ) > changeoverValue )
{
xMin = QString( "%1" ).arg( myExtent.xMinimum(), 0, 'f', 2 );
}
else
{
xMin = QString( "%1" ).arg( myExtent.xMinimum() );
}
if ( qAbs( myExtent.yMinimum() ) > changeoverValue )
{
yMin = QString( "%1" ).arg( myExtent.yMinimum(), 0, 'f', 2 );
}
else
{
yMin = QString( "%1" ).arg( myExtent.yMinimum() );
}
if ( qAbs( myExtent.xMaximum() ) > changeoverValue )
{
xMax = QString( "%1" ).arg( myExtent.xMaximum(), 0, 'f', 2 );
}
else
{
xMax = QString( "%1" ).arg( myExtent.xMaximum() );
}
if ( qAbs( myExtent.yMaximum() ) > changeoverValue )
{
yMax = QString( "%1" ).arg( myExtent.yMaximum(), 0, 'f', 2 );
}
else
{
yMax = QString( "%1" ).arg( myExtent.yMaximum() );
}

myMetadata += tr( "xMin,yMin %1,%2 : xMax,yMax %3,%4" )
.arg( xMin ).arg( yMin ).arg( xMax ).arg( yMax );
}
else
{
yMax = QString( "%1" ).arg( myExtent.yMaximum() );
myMetadata += tr( "unknown extent" );
}

myMetadata += tr( "In layer spatial reference system units : " )
+ tr( "xMin,yMin %1,%2 : xMax,yMax %3,%4" )
.arg( xMin ).arg( yMin ).arg( xMax ).arg( yMax );
myMetadata += "</td></tr>";

//extents in project cs
Expand Down

0 comments on commit c099afc

Please sign in to comment.