26 #include <QDataStream> 
   41   d = 
new QgsFeaturePrivate( 
id );
 
   46   d = 
new QgsFeaturePrivate( 
id );
 
   67   if ( d->fid == other.d->fid
 
   68        && d->valid == other.d->valid
 
   69        && d->fields == other.d->fields
 
   70        && d->attributes == other.d->attributes
 
   71        && d->geometry.equals( other.d->geometry )
 
   72        && d->symbol == other.d->symbol )
 
   80   return !( *
this == other );
 
  101   d->attributes.remove( 
field );
 
  127   return d->attributes;
 
  132   return d->attributes.size();
 
  137   if ( attrs == d->attributes )
 
  141   d->attributes = attrs;
 
  198   if ( d->valid == validity )
 
  207   return !d->geometry.isNull();
 
  213   d->attributes.resize( 0 ); 
 
  216   d->attributes.resize( fieldCount );
 
  221   if ( fieldCount == d->attributes.size() )
 
  225   d->attributes.resize( fieldCount );
 
  234   d->attributes.resize( d->attributes.size() + count );
 
  239   if ( idx < 0 || idx >= d->attributes.size() )
 
  241     QgsMessageLog::logMessage( QObject::tr( 
"Attribute index %1 out of bounds [0;%2]" ).arg( idx ).arg( d->attributes.size() ), QString(), Qgis::MessageLevel::Warning );
 
  246   d->attributes[idx] = value;
 
  260   if ( fieldIdx == -1 )
 
  264   d->attributes[fieldIdx] = value;
 
  272   if ( fieldIdx == -1 )
 
  276   d->attributes[fieldIdx].clear();
 
  282   if ( fieldIdx < 0 || fieldIdx >= d->attributes.count() )
 
  285   return d->attributes.at( fieldIdx );
 
  290   return d->symbol.get();
 
  295   if ( symbol == d->symbol.get() )
 
  299   d->symbol.reset( symbol );
 
  305   if ( fieldIdx == -1 )
 
  308   return d->attributes.at( fieldIdx );
 
  319   return d->fields.lookupField( fieldName );
 
  322 static size_t qgsQStringApproximateMemoryUsage( 
const QString &
str )
 
  324   return sizeof( QString ) + 
str.size() * 
sizeof( QChar );
 
  327 static size_t qgsQVariantApproximateMemoryUsage( 
const QVariant &v )
 
  331   size_t s = 
sizeof( QVariant ) + 
sizeof( 
long long ) + 
sizeof( int );
 
  332   if ( v.type() == QVariant::String )
 
  334     s += qgsQStringApproximateMemoryUsage( v.toString() );
 
  336   else if ( v.type() == QVariant::StringList )
 
  338     for ( 
const QString &
str : v.toStringList() )
 
  339       s += qgsQStringApproximateMemoryUsage( 
str );
 
  341   else if ( v.type() == QVariant::List )
 
  343     for ( 
const QVariant &subV : v.toList() )
 
  344       s += qgsQVariantApproximateMemoryUsage( subV );
 
  351   size_t s = 
sizeof( *this ) + 
sizeof( *d );
 
  354   for ( 
const QVariant &attr : std::as_const( d->attributes ) )
 
  356     s += qgsQVariantApproximateMemoryUsage( attr );
 
  360   s += 
sizeof( QAtomicInt ) + 
sizeof( 
void * ); 
 
  363   s += d->geometry.wkbSize();
 
  366   s += 
sizeof( QgsFieldsPrivate );
 
  368   s += d->fields.size() * ( 
sizeof( 
QgsField )  + 
sizeof( QgsFieldPrivate ) );
 
  370   return static_cast<int>( s );
 
  403   in >> 
id >> attr >> geometry >> valid;
 
  414   const auto constAttributes = key.
attributes();
 
  415   for ( 
const QVariant &attr : constAttributes )
 
  417     hash ^= 
qHash( attr.toString() );
 
The feature class encapsulates a single feature including its unique ID, geometry and a list of field...
bool setAttribute(int field, const QVariant &attr)
Sets an attribute's value by field index.
void resizeAttributes(int fieldCount)
Resizes the attributes attached to this feature to the given number of fields.
bool operator!=(const QgsFeature &other) const
Compares two features.
int fieldNameIndex(const QString &fieldName) const
Utility method to get attribute index from name.
void initAttributes(int fieldCount)
Initialize this feature with the given number of fields.
void deleteAttribute(int field)
Deletes an attribute and its value.
QgsFeature & operator=(const QgsFeature &rhs)
Assignment operator.
int approximateMemoryUsage() const
Returns the approximate RAM usage of the feature, in bytes.
void setAttributes(const QgsAttributes &attrs)
Sets the feature's attributes.
bool operator==(const QgsFeature &other) const
Compares two features.
void setFields(const QgsFields &fields, bool initAttributes=false)
Assigns a field map with the feature to allow attribute access by attribute name.
QgsFeature(QgsFeatureId id=FID_NULL)
Constructor for QgsFeature.
int attributeCount() const
Returns the number of attributes attached to the feature.
void padAttributes(int count)
Resizes the attributes attached to this feature by appending the specified count of NULL values to th...
const QgsSymbol * embeddedSymbol() const
Returns the feature's embedded symbology, or nullptr if the feature has no embedded symbol.
void setId(QgsFeatureId id)
Sets the feature id for this feature.
void setEmbeddedSymbol(QgsSymbol *symbol)
Sets the feature's embedded symbol.
void clearGeometry()
Removes any geometry associated with the feature.
void setValid(bool validity)
Sets the validity of the feature.
bool hasGeometry() const
Returns true if the feature has an associated geometry.
bool isValid() const
Returns the validity of this feature.
QVariant attribute(const QString &name) const
Lookup attribute value by attribute name.
void setGeometry(const QgsGeometry &geometry)
Set the feature's geometry.
Encapsulate a field in an attribute table or data source.
Container of fields for a vector layer.
A geometry is the spatial representation of a feature.
QString asWkt(int precision=17) const
Exports the geometry to WKT.
static void logMessage(const QString &message, const QString &tag=QString(), Qgis::MessageLevel level=Qgis::MessageLevel::Warning, bool notifyUser=true)
Adds a message to the log instance (and creates it if necessary).
Abstract base class for all rendered symbols.
uint qHash(const QgsFeature &key, uint seed)
QDataStream & operator<<(QDataStream &out, const QgsFeature &feature)
Writes the feature to stream out. QGIS version compatibility is not guaranteed.
QDataStream & operator>>(QDataStream &in, QgsFeature &feature)
Reads a feature from stream in into feature. QGIS version compatibility is not guaranteed.
qint64 QgsFeatureId
64 bit feature ids negative numbers are used for uncommitted/newly added features