Skip to content

Commit

Permalink
Merge pull request #2643 from alexbruy/sublayers
Browse files Browse the repository at this point in the history
More informative layer names when loading GDAL/OGR sublayers
  • Loading branch information
alexbruy committed Jan 20, 2016
2 parents 9fda6aa + 77a0b88 commit 1c3f066
Showing 1 changed file with 19 additions and 10 deletions.
29 changes: 19 additions & 10 deletions src/app/qgisapp.cpp
Expand Up @@ -3257,16 +3257,10 @@ bool QgisApp::addVectorLayers( const QStringList &theLayerQStringList, const QSt
//set friendly name for datasources with only one layer
QStringList sublayers = layer->dataProvider()->subLayers();
QStringList elements = sublayers.at( 0 ).split( ':' );
if ( layer->storageType() != "GeoJSON" )
{
while ( elements.size() > 4 )
{
elements[1] += ':' + elements[2];
elements.removeAt( 2 );
}

layer->setLayerName( elements.at( 1 ) );
}
Q_ASSERT( elements.size() >= 4 );
layer->setLayerName( QString( "%1 %2 %3" ).arg( layer->name(), elements.at( 1 ), elements.at( 3 ) ) );

myList << layer;
}
else
Expand Down Expand Up @@ -3486,9 +3480,24 @@ void QgisApp::askUserForGDALSublayers( QgsRasterLayer *layer )

if ( chooseSublayersDialog.exec() )
{
// create more informative layer names, containing filename as well as sublayer name
QRegExp rx( "\"(.*)\"" );
QString uri, name;

Q_FOREACH ( int i, chooseSublayersDialog.selectionIndexes() )
{
QgsRasterLayer *rlayer = new QgsRasterLayer( sublayers[i], names[i] );
if ( rx.indexIn( sublayers[i] ) != -1 )
{
uri = rx.cap( 1 );
name = sublayers[i];
name.replace( uri, QFileInfo( uri ).completeBaseName() );
}
else
{
name = names[i];
}

QgsRasterLayer *rlayer = new QgsRasterLayer( sublayers[i], name );
if ( rlayer && rlayer->isValid() )
{
addRasterLayer( rlayer );
Expand Down

0 comments on commit 1c3f066

Please sign in to comment.