30#include "moc_qgsfeature.cpp"
32using namespace Qt::StringLiterals;
47 d =
new QgsFeaturePrivate(
id );
52 d =
new QgsFeaturePrivate(
id );
75 if ( !( d->fid == other.d->fid && d->valid == other.d->valid && d->fields == other.d->fields && d->attributes == other.d->attributes && d->symbol == other.d->symbol ) )
79 if ( d->geometry.isNull() && other.d->geometry.isNull() )
81 else if ( d->geometry.isNull() || other.d->geometry.isNull() )
83 else if ( !d->geometry.equals( other.d->geometry ) )
91 return !( *
this == other );
111 d->attributes.remove( field );
137 return d->attributes;
143 const int fieldSize = d->fields.size();
144 const int attributeSize = d->attributes.size();
145 if ( fieldSize != attributeSize )
147 QgsDebugError( u
"Attribute size (%1) does not match number of fields (%2)"_s.arg( attributeSize ).arg( fieldSize ) );
148 return QVariantMap();
151 for (
int i = 0; i < attributeSize; ++i )
153 res[d->fields.at( i ).name()] = d->attributes.at( i );
160 return d->attributes.size();
166 d->attributes = attrs;
186 if ( d->geometry.isNull() && d->valid )
226 if ( d->valid == validity )
235 return !d->geometry.isNull();
241 d->attributes.resize( 0 );
244 d->attributes.resize( fieldCount );
249 if ( fieldCount == d->attributes.size() )
253 d->attributes.resize( fieldCount );
262 d->attributes.resize( d->attributes.size() + count );
267 if ( idx < 0 || idx >= d->attributes.size() )
274 d->attributes[idx] = value;
288 if ( fieldIdx == -1 )
292 d->attributes[fieldIdx] = value;
300 if ( fieldIdx == -1 )
304 d->attributes[fieldIdx].clear();
310 if ( fieldIdx < 0 || fieldIdx >= d->attributes.count() )
313 return d->attributes.at( fieldIdx );
318 if ( fieldIdx < 0 || fieldIdx >= d->attributes.count() )
321 return d->attributes.at( fieldIdx ).userType() == qMetaTypeId<QgsUnsetAttributeValue>();
326 return d->symbol.get();
331 if ( symbol == d->symbol.get() )
335 d->symbol.reset( symbol );
341 if ( fieldIdx == -1 )
344 return d->attributes.at( fieldIdx );
355 return d->fields.lookupField( fieldName );
358static size_t qgsQStringApproximateMemoryUsage(
const QString &str )
360 return sizeof( QString ) + str.size() *
sizeof( QChar );
363static size_t qgsQVariantApproximateMemoryUsage(
const QVariant &v )
367 size_t s =
sizeof( QVariant ) +
sizeof(
long long ) +
sizeof( int );
368 if ( v.userType() == QMetaType::Type::QString )
370 s += qgsQStringApproximateMemoryUsage( v.toString() );
372 else if ( v.userType() == QMetaType::Type::QStringList )
374 for (
const QString &str : v.toStringList() )
375 s += qgsQStringApproximateMemoryUsage( str );
377 else if ( v.userType() == QMetaType::Type::QVariantList )
379 for (
const QVariant &subV : v.toList() )
380 s += qgsQVariantApproximateMemoryUsage( subV );
387 size_t s =
sizeof( *this ) +
sizeof( *d );
390 for (
const QVariant &attr : std::as_const( d->attributes ) )
392 s += qgsQVariantApproximateMemoryUsage( attr );
396 s +=
sizeof( QAtomicInt ) +
sizeof(
void * );
399 s += d->geometry.wkbSize();
402 s +=
sizeof( QgsFieldsPrivate );
404 s += d->fields.size() * (
sizeof(
QgsField ) +
sizeof( QgsFieldPrivate ) );
406 return static_cast<int>( s );
439 in >>
id >> attr >> geometry >> valid;
450 const auto constAttributes = key.
attributes();
451 for (
const QVariant &attr : constAttributes )
453 hash ^=
qHash( attr.toString() );
@ Warning
Warning message.
The feature class encapsulates a single feature including its unique ID, geometry and a list of field...
Q_INVOKABLE 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
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)
Clear's an attribute's value by its index.
QgsFeature & operator=(const QgsFeature &rhs)
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
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 isUnsetValue(int fieldIdx) const
Returns true if the attribute at the specified index is an unset value.
bool isValid() const
Returns the validity of this feature.
Q_INVOKABLE QVariant attribute(const QString &name) const
Lookup attribute value by attribute name.
void setGeometry(const QgsGeometry &geometry)
Set the feature's geometry.
QVariantMap attributeMap() const
Returns the feature's attributes as a map of field name to value.
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.
Q_INVOKABLE 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, const char *file=__builtin_FILE(), const char *function=__builtin_FUNCTION(), int line=__builtin_LINE(), Qgis::StringFormat format=Qgis::StringFormat::PlainText)
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
#define QgsDebugError(str)