23 QString QgsUnionAlgorithm::name()
 const    25   return QStringLiteral( 
"union" );
    28 QString QgsUnionAlgorithm::displayName()
 const    30   return QObject::tr( 
"Union" );
    33 QString QgsUnionAlgorithm::group()
 const    35   return QObject::tr( 
"Vector overlay" );
    38 QString QgsUnionAlgorithm::groupId()
 const    40   return QStringLiteral( 
"vectoroverlay" );
    43 QString QgsUnionAlgorithm::shortHelpString()
 const    45   return QObject::tr( 
"This algorithm checks overlaps between features within the Input layer and creates separate features for overlapping "    46                       "and non-overlapping parts. The area of overlap will create as many identical overlapping features as there are "    47                       "features that participate in that overlap." )
    48          + QStringLiteral( 
"\n\n" )
    49          + QObject::tr( 
"An Overlay layer can also be used, in which case features from each layer are split at their overlap with features from "    50                         "the other one, creating a layer containing all the portions from both Input and Overlay layers. "    51                         "The attribute table of the Union layer is filled with attribute values from the respective original layer "    52                         "for non-overlapping features, and attribute values from both layers for overlapping features." );
    57   return new QgsUnionAlgorithm();
    60 void QgsUnionAlgorithm::initAlgorithm( 
const QVariantMap & )
    70   std::unique_ptr< QgsFeatureSource > sourceA( parameterAsSource( parameters, QStringLiteral( 
"INPUT" ), context ) );
    74   std::unique_ptr< QgsFeatureSource > sourceB( parameterAsSource( parameters, QStringLiteral( 
"OVERLAY" ), context ) );
    75   if ( parameters.value( QStringLiteral( 
"OVERLAY" ) ).isValid() && !sourceB )
    83   std::unique_ptr< QgsFeatureSink > sink( parameterAsSink( parameters, QStringLiteral( 
"OUTPUT" ), context, dest, fields, geomType, sourceA->sourceCrs() ) );
    88   outputs.insert( QStringLiteral( 
"OUTPUT" ), dest );
    93     QgsOverlayUtils::resolveOverlaps( *sourceA, *sink, feedback );
   101   int total = sourceA->featureCount() * 2 + sourceB->featureCount();
   103   QgsOverlayUtils::intersection( *sourceA, *sourceB, *sink, context, feedback, count, total, fieldIndicesA, fieldIndicesB );
   105   QgsOverlayUtils::difference( *sourceA, *sourceB, *sink, context, feedback, count, total, QgsOverlayUtils::OutputAB );
   107   QgsOverlayUtils::difference( *sourceB, *sourceA, *sink, context, feedback, count, total, QgsOverlayUtils::OutputBA );
 static Type multiType(Type type)
Returns the multi type for a WKB type. 
Base class for providing feedback from a processing algorithm. 
Container of fields for a vector layer. 
Abstract base class for processing algorithms. 
A feature sink output for processing algorithms. 
static QList< int > fieldNamesToIndices(const QStringList &fieldNames, const QgsFields &fields)
Returns a list of field indices parsed from the given list of field names. 
Type
The WKB type describes the number of dimensions a geometry has. 
static QgsFields combineFields(const QgsFields &fieldsA, const QgsFields &fieldsB)
Combines two field lists, avoiding duplicate field names (in a case-insensitive manner). 
Custom exception class for processing related exceptions. 
An input feature source (such as vector layers) parameter for processing algorithms. 
Contains information about the context in which a processing algorithm is executed.