Home

QtVariantPropertyManager Class Reference

The QtVariantPropertyManager class provides and manages QVariant based properties. More...

 #include <QtVariantPropertyManager>

Inherits QtAbstractPropertyManager.

Public Functions

Public Slots

Signals

Static Public Members

Additional Inherited Members


Detailed Description

The QtVariantPropertyManager class provides and manages QVariant based properties.

QtVariantPropertyManager provides the addProperty() function which creates QtVariantProperty objects. The QtVariantProperty class is a convenience class handling QVariant based properties inheriting QtProperty. A QtProperty object created by a QtVariantPropertyManager instance can be converted into a QtVariantProperty object using the variantProperty() function.

The property's value can be retrieved using the value(), and set using the setValue() slot. In addition the property's type, and the type of its value, can be retrieved using the propertyType() and valueType() functions respectively.

A property's type is a QVariant::Type enumerator value, and usually a property's type is the same as its value type. But for some properties the types differ, for example for enums, flags and group types in which case QtVariantPropertyManager provides the enumTypeId(), flagTypeId() and groupTypeId() functions, respectively, to identify their property type (the value types are QVariant::Int for the enum and flag types, and QVariant::Invalid for the group type).

Use the isPropertyTypeSupported() function to check if a particular property type is supported. The currently supported property types are:

Property TypeProperty Type Id
intQVariant::Int
doubleQVariant::Double
boolQVariant::Bool
QStringQVariant::String
QDateQVariant::Date
QTimeQVariant::Time
QDateTimeQVariant::DateTime
QKeySequenceQVariant::KeySequence
QCharQVariant::Char
QLocaleQVariant::Locale
QPointQVariant::Point
QPointFQVariant::PointF
QSizeQVariant::Size
QSizeFQVariant::SizeF
QRectQVariant::Rect
QRectFQVariant::RectF
QColorQVariant::Color
QSizePolicyQVariant::SizePolicy
QFontQVariant::Font
QCursorQVariant::Cursor
enumenumTypeId()
flagflagTypeId()
groupgroupTypeId()

Each property type can provide additional attributes, e.g. QVariant::Int and QVariant::Double provides minimum and maximum values. The currently supported attributes are:

Property TypeAttribute NameAttribute Type
intminimumQVariant::Int
maximumQVariant::Int
singleStepQVariant::Int
doubleminimumQVariant::Double
maximumQVariant::Double
singleStepQVariant::Double
decimalsQVariant::Int
QStringregExpQVariant::RegExp
QDateminimumQVariant::Date
maximumQVariant::Date
QPointFdecimalsQVariant::Int
QSizeminimumQVariant::Size
maximumQVariant::Size
QSizeFminimumQVariant::SizeF
maximumQVariant::SizeF
decimalsQVariant::Int
QRectconstraintQVariant::Rect
QRectFconstraintQVariant::RectF
decimalsQVariant::Int
enumenumNamesQVariant::StringList
enumIconsiconMapTypeId()
flagflagNamesQVariant::StringList

The attributes for a given property type can be retrieved using the attributes() function. Each attribute has a value type which can be retrieved using the attributeType() function, and a value accessible through the attributeValue() function. In addition, the value can be set using the setAttribute() slot.

QtVariantManager also provides the valueChanged() signal which is emitted whenever a property created by this manager change, and the attributeChanged() signal which is emitted whenever an attribute of such a property changes.

See also QtVariantProperty and QtVariantEditorFactory.


Member Function Documentation

QtVariantPropertyManager::QtVariantPropertyManager ( QObject * parent = 0 )

Creates a manager with the given parent.

QtVariantPropertyManager::~QtVariantPropertyManager ()

Destroys this manager, and all the properties it has created.

QtVariantProperty * QtVariantPropertyManager::addProperty ( int propertyType, const QString & name = QString() )   [virtual]

Creates and returns a variant property of the given propertyType with the given name.

If the specified propertyType is not supported by this variant manager, this function returns 0.

Do not use the inherited QtAbstractPropertyManager::addProperty() function to create a variant property (that function will always return 0 since it will not be clear what type the property should have).

See also isPropertyTypeSupported().

void QtVariantPropertyManager::attributeChanged ( QtProperty * property, const QString & attribute, const QVariant & value )   [signal]

This signal is emitted whenever an attribute of a property created by this manager changes its value, passing a pointer to the property, the attribute and the new value as parameters.

See also setAttribute().

int QtVariantPropertyManager::attributeType ( int propertyType, const QString & attribute ) const   [virtual]

Returns the type of the specified attribute of the given propertyType.

If the given propertyType is not supported by this manager, or if the given propertyType does not possess the specified attribute, this function returns QVariant::Invalid.

See also attributes() and valueType().

QVariant QtVariantPropertyManager::attributeValue ( const QtProperty * property, const QString & attribute ) const   [virtual]

Returns the given property's value for the specified attribute

If the given property was not created by this manager, or if the specified attribute does not exist, this function returns an invalid variant.

See also attributes(), attributeType(), and setAttribute().

QStringList QtVariantPropertyManager::attributes ( int propertyType ) const   [virtual]

Returns a list of the given propertyType 's attributes.

See also attributeValue() and attributeType().

int QtVariantPropertyManager::enumTypeId ()   [static]

Returns the type id for an enum property.

Note that the property's value type can be retrieved using the valueType() function (which is QVariant::Int for the enum property type).

See also propertyType() and valueType().

int QtVariantPropertyManager::flagTypeId ()   [static]

Returns the type id for a flag property.

Note that the property's value type can be retrieved using the valueType() function (which is QVariant::Int for the flag property type).

See also propertyType() and valueType().

int QtVariantPropertyManager::groupTypeId ()   [static]

Returns the type id for a group property.

Note that the property's value type can be retrieved using the valueType() function (which is QVariant::Invalid for the group property type, since it doesn't provide any value).

See also propertyType() and valueType().

int QtVariantPropertyManager::iconMapTypeId ()   [static]

Returns the type id for a icon map attribute.

Note that the property's attribute type can be retrieved using the attributeType() function.

See also attributeType() and QtEnumPropertyManager::enumIcons().

bool QtVariantPropertyManager::isPropertyTypeSupported ( int propertyType ) const   [virtual]

Returns true if the given propertyType is supported by this variant manager; otherwise false.

See also propertyType().

int QtVariantPropertyManager::propertyType ( const QtProperty * property ) const

Returns the given property's type.

See also valueType().

void QtVariantPropertyManager::setAttribute ( QtProperty * property, const QString & attribute, const QVariant & value )   [virtual slot]

Sets the value of the specified attribute of the given property, to value.

The new value's type must be of the type returned by attributeType(), or of a type that can be converted to attributeType() using the QVariant::canConvert() function, otherwise this function does nothing.

See also attributeValue(), QtVariantProperty::setAttribute(), and attributeChanged().

void QtVariantPropertyManager::setValue ( QtProperty * property, const QVariant & value )   [virtual slot]

Sets the value of the given property to value.

The specified value must be of a type returned by valueType(), or of type that can be converted to valueType() using the QVariant::canConvert() function, otherwise this function does nothing.

See also value(), QtVariantProperty::setValue(), and valueChanged().

QVariant QtVariantPropertyManager::value ( const QtProperty * property ) const   [virtual]

Returns the given property's value.

If the given property is not managed by this manager, this function returns an invalid variant.

See also setValue().

void QtVariantPropertyManager::valueChanged ( QtProperty * property, const QVariant & value )   [signal]

This signal is emitted whenever a property created by this manager changes its value, passing a pointer to the property and the new value as parameters.

See also setValue().

int QtVariantPropertyManager::valueType ( const QtProperty * property ) const

Returns the given property's value type.

See also propertyType().

int QtVariantPropertyManager::valueType ( int propertyType ) const   [virtual]

This is an overloaded function.

Returns the value type associated with the given propertyType.

QtVariantProperty * QtVariantPropertyManager::variantProperty ( const QtProperty * property ) const

Returns the given property converted into a QtVariantProperty.

If the property was not created by this variant manager, the function returns 0.

See also createProperty().


Copyright © 2009 Nokia Corporation and/or its subsidiary(-ies) Trademarks
Qt Solutions