/*************************************************************************** qgsstyle.h --------------------- begin : November 2009 copyright : (C) 2009 by Martin Dobias email : wonder dot sk at gmail dot com *************************************************************************** * * * This program is free software; you can redistribute it and/or modify * * it under the terms of the GNU General Public License as published by * * the Free Software Foundation; either version 2 of the License, or * * (at your option) any later version. * * * ***************************************************************************/ #ifndef QGSSTYLE_H #define QGSSTYLE_H #include "qgis_core.h" #include "qgis.h" #include #include #include #include #include "qgssqliteutils.h" #include "qgssymbollayerutils.h" // QgsStringMap #include "qgstextformat.h" #include "qgspallabeling.h" #include "qgslegendpatchshape.h" class QgsSymbol; class QgsSymbolLayer; class QgsColorRamp; class QgsStyleEntityInterface; class QgsAbstract3DSymbol; class QDomDocument; class QDomElement; typedef QMap QgsVectorColorRampMap; typedef QMap QgsSymbolGroupMap; /** * Map of name to text format. * \since QGIS 3.10 */ typedef QMap QgsTextFormatMap; /** * Map of name to label settings. * \since QGIS 3.10 */ typedef QMap QgsLabelSettingsMap; /* * Constants used to describe copy-paste MIME types */ #define QGSCLIPBOARD_STYLE_MIME "application/qgis.style" /** * \ingroup core * A multimap to hold the smart group conditions as constraint and parameter pairs. * Both the key and the value of the map are QString. The key is the constraint of the condition and the value is the parameter which is applied for the constraint. * * The supported constraints are: * tag -> symbol has the tag matching the parameter * !tag -> symbol doesn't have the tag matching the parameter * name -> symbol has a part of its name matching the parameter * !name -> symbol doesn't have any part of the name matching the parameter * * Example Usage: * QgsSmartConditionMap conditions; * conditions.insert( "tag", "red" ); // adds the condition: Symbol has the tag red * conditions.insert( "!name", "way" ); // add the condition: Symbol doesn't have any part of its name matching `way` * * \note This is a Multimap, which means it will contain multiple values for the same key. */ typedef QMultiMap QgsSmartConditionMap; // enumerators representing sqlite DB columns /** * Columns available in the Symbols table. */ enum SymbolTable { SymbolId, //!< Symbol ID SymbolName, //!< Symbol Name SymbolXML, //!< Symbol definition (as XML) SymbolFavoriteId, //!< Symbol is favorite flag }; /** * Columns available in the Tags table. */ enum TagTable { TagId, //!< Tag ID TagName, //!< Tag name }; /** * Columns available in the tag to symbol table. */ enum TagmapTable { TagmapTagId, //!< Tag ID TagmapSymbolId, //!< Symbol ID }; /** * Columns available in the color ramp table. */ enum ColorrampTable { ColorrampId, //!< Color ramp ID ColorrampName, //!< Color ramp name ColorrampXML, //!< Color ramp definition (as XML) ColorrampFavoriteId, //!< Color ramp is favorite flag }; /** * Columns available in the text format table. */ enum TextFormatTable { TextFormatId, //!< Text format ID TextFormatName, //!< Text format name TextFormatXML, //!< Text format definition (as XML) TextFormatFavoriteId, //!< Text format is favorite flag }; /** * Columns available in the label settings table. */ enum LabelSettingsTable { LabelSettingsId, //!< Label settings ID LabelSettingsName, //!< Label settings name LabelSettingsXML, //!< Label settings definition (as XML) LabelSettingsFavoriteId, //!< Label settings is favorite flag }; /** * Columns available in the smart group table. */ enum SmartgroupTable { SmartgroupId, //!< Smart group ID SmartgroupName, //!< Smart group name SmartgroupXML, //!< Smart group definition (as XML) }; /** * \ingroup core * \class QgsStyle */ class CORE_EXPORT QgsStyle : public QObject { Q_OBJECT public: /** * Constructor for QgsStyle. */ QgsStyle(); ~QgsStyle() override; /** * Enum for Entities involved in a style * * The enumerator is used for identifying the entity being operated on when generic * database functions are being run. * \sa rename(), remove(), symbolsOfFavorite(), symbolsWithTag(), symbolsOfSmartgroup() */ enum StyleEntity { SymbolEntity, //!< Symbols TagEntity, //!< Tags ColorrampEntity, //!< Color ramps SmartgroupEntity, //!< Smart groups TextFormatEntity, //!< Text formats LabelSettingsEntity, //!< Label settings LegendPatchShapeEntity, //!< Legend patch shape (since QGIS 3.14) Symbol3DEntity, //!< 3D symbol entity (since QGIS 3.14) }; /** * Adds an \a entity to the style, with the specified \a name. Ownership is not transferred. * * If \a update is TRUE then the style database is updated automatically as a result. * * Returns TRUE if the add operation was successful. * * \note Adding an entity with the name of existing one replaces the existing one automatically. * * \since QGIS 3.10 */ bool addEntity( const QString &name, const QgsStyleEntityInterface *entity, bool update = false ); /** * Adds a symbol to style and takes symbol's ownership * * \note Adding a symbol with the name of existing one replaces it. * \param name is the name of the symbol being added or updated * \param symbol is the Vector symbol * \param update set to TRUE when the style database has to be updated, by default it is FALSE * \returns success status of the operation */ bool addSymbol( const QString &name, QgsSymbol *symbol SIP_TRANSFER, bool update = false ); /** * Adds a color ramp to the style. Calling this method takes the ramp's ownership. * \note Adding a color ramp with the name of existing one replaces it. * \param name is the name of the color ramp being added or updated * \param colorRamp is the color ramp. Ownership is transferred. * \param update set to TRUE when the style database has to be updated, by default it is FALSE * \returns success status of the operation */ bool addColorRamp( const QString &name, QgsColorRamp *colorRamp SIP_TRANSFER, bool update = false ); /** * Adds a text \a format with the specified \a name to the style. * * If \a update is set to TRUE, the style database will be automatically updated with the new text format. * * Returns TRUE if the operation was successful. * * \note Adding a text format with the name of existing one replaces it. * \since QGIS 3.10 */ bool addTextFormat( const QString &name, const QgsTextFormat &format, bool update = false ); /** * Adds label \a settings with the specified \a name to the style. * * If \a update is set to TRUE, the style database will be automatically updated with the new text format. * * Returns TRUE if the operation was successful. * * \note Adding label settings with the name of existing ones replaces them. * \since QGIS 3.10 */ bool addLabelSettings( const QString &name, const QgsPalLayerSettings &settings, bool update = false ); /** * Adds a legend patch \a shape with the specified \a name to the style. * * If \a update is set to TRUE, the style database will be automatically updated with the new legend patch shape. * * Returns TRUE if the operation was successful. * * \note Adding legend patch shapes with the name of existing ones replaces them. * \since QGIS 3.14 */ bool addLegendPatchShape( const QString &name, const QgsLegendPatchShape &shape, bool update = false ); /** * Adds a 3d \a symbol with the specified \a name to the style. Ownership of \a symbol is transferred. * * If \a update is set to TRUE, the style database will be automatically updated with the new legend patch shape. * * Returns TRUE if the operation was successful. * * \note Adding 3d symbols with the name of existing ones replaces them. * \since QGIS 3.16 */ bool addSymbol3D( const QString &name, QgsAbstract3DSymbol *symbol SIP_TRANSFER, bool update = false ); /** * Adds a new tag and returns the tag's id * * \param tagName the name of the new tag to be created * \returns returns an int, which is the database id of the new tag created, 0 if the tag couldn't be created */ int addTag( const QString &tagName ); /** * Adds a new smartgroup to the database and returns the id * * \param name is the name of the new Smart Group to be added * \param op is the operator between the conditions; AND/OR as QString * \param conditions are the smart group conditions * * \note Not available from Python bindings */ int addSmartgroup( const QString &name, const QString &op, const QgsSmartConditionMap &conditions ) SIP_SKIP; /** * Adds a new smartgroup to the database and returns the id. * * \param name is the name of the new Smart Group to be added * \param op is the operator between the conditions; AND/OR as QString * \param matchTag list of strings to match within tags * \param noMatchTag list of strings to exclude matches from tags * \param matchName list of string to match within names * \param noMatchName list of strings to exclude matches from names * * \since QGIS 3.4 */ int addSmartgroup( const QString &name, const QString &op, const QStringList &matchTag, const QStringList &noMatchTag, const QStringList &matchName, const QStringList &noMatchName ); /** * Returns a list of all tags in the style database * * \see addTag() * \since QGIS 2.16 */ QStringList tags() const; //! Removes all contents of the style void clear(); /** * Returns a new copy of the specified color ramp. The caller * takes responsibility for deleting the returned object. */ QgsColorRamp *colorRamp( const QString &name ) const SIP_FACTORY; //! Returns count of color ramps int colorRampCount(); //! Returns a list of names of color ramps QStringList colorRampNames() const; //! Returns a const pointer to a symbol (doesn't create new instance) const QgsColorRamp *colorRampRef( const QString &name ) const; /** * Returns the id in the style database for the given colorramp name * returns 0 if not found */ int colorrampId( const QString &name ); /** * Returns the text format with the specified \a name. * * \since QGIS 3.10 */ QgsTextFormat textFormat( const QString &name ) const; /** * Returns count of text formats in the style. * \since QGIS 3.10 */ int textFormatCount() const; /** * Returns a list of names of text formats in the style. * \since QGIS 3.10 */ QStringList textFormatNames() const; /** * Returns the ID in the style database for the given text format by \a name. * Returns 0 if the text format was not found. * * \since QGIS 3.10 */ int textFormatId( const QString &name ); /** * Returns the label settings with the specified \a name. * * \since QGIS 3.10 */ QgsPalLayerSettings labelSettings( const QString &name ) const; /** * Returns the legend patch shape with the specified \a name. * * \since QGIS 3.14 */ QgsLegendPatchShape legendPatchShape( const QString &name ) const; /** * Returns count of legend patch shapes in the style. * \since QGIS 3.14 */ int legendPatchShapesCount() const; /** * Returns the symbol type corresponding to the legend patch shape * with the specified \a name, or QgsSymbol::Hybrid * if a matching legend patch shape is not present. * * \since QGIS 3.14 */ Qgis::SymbolType legendPatchShapeSymbolType( const QString &name ) const; /** * Returns a new copy of the 3D symbol with the specified \a name. * * \since QGIS 3.16 */ QgsAbstract3DSymbol *symbol3D( const QString &name ) const SIP_FACTORY; /** * Returns count of 3D symbols in the style. * \since QGIS 3.16 */ int symbol3DCount() const; /** * Returns the list of the vector layer geometry types which are compatible with the 3D symbol * with the specified \a name, or an empty list if a matching 3d symbol is not present. * * \since QGIS 3.16 */ QList< QgsWkbTypes::GeometryType > symbol3DCompatibleGeometryTypes( const QString &name ) const; /** * Returns the layer geometry type corresponding to the label settings * with the specified \a name, or QgsWkbTypes::UnknownGeometry * if matching label settings are not present. * * \since QGIS 3.10 */ QgsWkbTypes::GeometryType labelSettingsLayerType( const QString &name ) const; /** * Returns count of label settings in the style. * \since QGIS 3.10 */ int labelSettingsCount() const; /** * Returns a list of names of label settings in the style. * \since QGIS 3.10 */ QStringList labelSettingsNames() const; /** * Returns the ID in the style database for the given label settings by \a name. * Returns 0 if the label settings were not found. * * \since QGIS 3.10 */ int labelSettingsId( const QString &name ); //! Returns default application-wide style static QgsStyle *defaultStyle(); //! Deletes the default style. Only to be used by QgsApplication::exitQgis() static void cleanDefaultStyle() SIP_SKIP; /** * Tags the symbol with the tags in the list * * Applies the given tags to the given symbol or colorramp * \param type is either SymbolEntity or ColorrampEntity * \param symbol is the name of the symbol or colorramp as QString * \param tags is the list of the tags that are to be applied as QStringList * \returns returns the success state of the operation */ bool tagSymbol( StyleEntity type, const QString &symbol, const QStringList &tags ); /** * Detags the symbol with the given list * * Removes the given tags for the specified symbol or colorramp * \param type is either SymbolEntity or ColorrampEntity * \param symbol is the name of the symbol or colorramp * \param tags is the list of tags that are to be removed as QStringList * \returns returns the success state of the operation */ bool detagSymbol( StyleEntity type, const QString &symbol, const QStringList &tags ); /** * Clears the symbol from all attached tags * * Removes all tags for the specified symbol or colorramp * \param type is either SymbolEntity or ColorrampEntity * \param symbol is the name of the symbol or colorramp * \returns returns the success state of the operation */ bool detagSymbol( StyleEntity type, const QString &symbol ); //! Removes symbol from style (and delete it) bool removeSymbol( const QString &name ); /** * Renames an entity of the specified \a type from \a oldName to \a newName. * * Returns TRUE if the entity was successfully renamed. * * \since QGIS 3.14 */ bool renameEntity( StyleEntity type, const QString &oldName, const QString &newName ); /** * Renames a symbol from \a oldName to \a newName. * * Returns TRUE if symbol was successfully renamed. */ bool renameSymbol( const QString &oldName, const QString &newName ); //! Returns a NEW copy of symbol QgsSymbol *symbol( const QString &name ) SIP_FACTORY; //! Returns a const pointer to a symbol (doesn't create new instance) const QgsSymbol *symbolRef( const QString &name ) const; //! Returns count of symbols in style int symbolCount(); //! Returns a list of names of symbols QStringList symbolNames() const; /** * Returns the id in the style database for the given symbol name * returns 0 if not found */ int symbolId( const QString &name ); /** * Returns the id in the style database for the given \a name of the specified entity \a type. * Returns 0 if not found. */ int entityId( StyleEntity type, const QString &name ); //! Returns the database id for the given tag name int tagId( const QString &tag ); //! Returns the database id for the given smartgroup name int smartgroupId( const QString &smartgroup ); /** * Returns a list of the names of all existing entities of the specified \a type. * \since QGIS 3.10 */ QStringList allNames( StyleEntity type ) const; /** * Returns the symbol names which are flagged as favorite * * \param type is either SymbolEntity or ColorampEntity * \returns A QStringList of the symbol or colorramp names flagged as favorite */ QStringList symbolsOfFavorite( StyleEntity type ) const; /** * Returns the symbol names with which have the given tag * * \param type is either SymbolEntity or ColorampEntity * \param tagid is id of the tag which has been applied over the symbol as int * \returns A QStringList of the symbol or colorramp names for the given tag id */ QStringList symbolsWithTag( StyleEntity type, int tagid ) const; /** * Adds the specified symbol to favorites * * \param type is either SymbolEntity of ColorrampEntity * \param name is the name of the symbol or coloramp whose is to be added to favorites * \returns returns the success state as bool */ bool addFavorite( StyleEntity type, const QString &name ); /** * Removes the specified symbol from favorites * * \param type is either SymbolEntity of ColorrampEntity * \param name is the name of the symbol or coloramp whose is to be removed from favorites * \returns returns the success state as bool */ bool removeFavorite( StyleEntity type, const QString &name ); /** * Renames the given entity with the specified id * * \param type is any of the style entities. Refer enum StyleEntity. * \param id is the database id of the entity which is to be renamed * \param newName is the new name of the entity */ bool rename( StyleEntity type, int id, const QString &newName ); /** * Removes the specified entity from the database. * * \param type is any of the style entities. Refer enum StyleEntity. * \param id is the database id of the entity to be removed * * \see removeEntityByName() */ bool remove( StyleEntity type, int id ); /** * Removes the entry of the specified \a type with matching \a name from the database. * * \see remove() * \since QGIS 3.14 */ bool removeEntityByName( StyleEntity type, const QString &name ); /** * Adds the symbol to the database with tags. * * \param name is the name of the symbol as QString * \param symbol is the pointer to the new QgsSymbol being saved * \param favorite is a boolean value to specify whether the symbol should be added to favorites * \param tags is a list of tags that are associated with the symbol as a QStringList. * \returns returns the success state of the save operation */ bool saveSymbol( const QString &name, QgsSymbol *symbol, bool favorite, const QStringList &tags ); /** * Adds the colorramp to the database. * * \param name is the name of the colorramp as QString * \param ramp is the pointer to the new QgsColorRamp being saved * \param favorite is a boolean value to specify whether the colorramp should be added to favorites * \param tags is a list of tags that are associated with the color ramp as a QStringList. * \returns returns the success state of the save operation */ bool saveColorRamp( const QString &name, QgsColorRamp *ramp, bool favorite, const QStringList &tags ); //! Removes color ramp from style (and delete it) bool removeColorRamp( const QString &name ); //! Changes ramp's name bool renameColorRamp( const QString &oldName, const QString &newName ); /** * Adds a text \a format to the database. * * \param name is the name of the text format * \param format text format to save * \param favorite is a boolean value to specify whether the text format should be added to favorites * \param tags is a list of tags that are associated with the text format * \returns returns the success state of the save operation */ bool saveTextFormat( const QString &name, const QgsTextFormat &format, bool favorite, const QStringList &tags ); /** * Removes a text format from the style. * \since QGIS 3.10 */ bool removeTextFormat( const QString &name ); /** * Changes a text format's name. * * \since QGIS 3.10 */ bool renameTextFormat( const QString &oldName, const QString &newName ); /** * Adds label \a settings to the database. * * \param name is the name of the label settings * \param settings label settings to save * \param favorite is a boolean value to specify whether the label settings should be added to favorites * \param tags is a list of tags that are associated with the label settings * \returns returns the success state of the save operation */ bool saveLabelSettings( const QString &name, const QgsPalLayerSettings &settings, bool favorite, const QStringList &tags ); /** * Removes label settings from the style. * \since QGIS 3.10 */ bool removeLabelSettings( const QString &name ); /** * Changes a label setting's name. * * \since QGIS 3.10 */ bool renameLabelSettings( const QString &oldName, const QString &newName ); /** * Adds a legend patch \a shape to the database. * * \param name is the name of the legend patch shape * \param shape legend patch shape to save * \param favorite is a boolean value to specify whether the legend patch shape should be added to favorites * \param tags is a list of tags that are associated with the legend patch shape * \returns returns the success state of the save operation * * \since QGIS 3.14 */ bool saveLegendPatchShape( const QString &name, const QgsLegendPatchShape &shape, bool favorite, const QStringList &tags ); /** * Changes a legend patch shape's name. * * \since QGIS 3.14 */ bool renameLegendPatchShape( const QString &oldName, const QString &newName ); /** * Returns a list of names of legend patch shapes in the style. * \since QGIS 3.14 */ QStringList legendPatchShapeNames() const; /** * Returns a symbol to use for rendering preview icons for a patch \a shape. * * Ownership of the symbol is not transferred. * * \since QGIS 3.14 */ const QgsSymbol *previewSymbolForPatchShape( const QgsLegendPatchShape &shape ) const; /** * Returns the default legend patch shape for the given symbol \a type. * * \see defaultPatchAsQPolygonF() * \since QGIS 3.14 */ QgsLegendPatchShape defaultPatch( Qgis::SymbolType type, QSizeF size ) const; /** * Returns the default patch geometry for the given symbol \a type and \a size as a set of QPolygonF objects (parts and rings). * * \see defaultPatch() * \since QGIS 3.14 */ QList< QList< QPolygonF > > defaultPatchAsQPolygonF( Qgis::SymbolType type, QSizeF size ) const; /** * Text format context. * * \since QGIS 3.20 */ enum class TextFormatContext : int { Labeling, //!< Text format used in labeling }; /** * Returns the default text format to use for new text based objects in the specified \a context. * * \since QGIS 3.20 */ QgsTextFormat defaultTextFormat( QgsStyle::TextFormatContext context = QgsStyle::TextFormatContext::Labeling ) const; /** * Adds a 3d \a symbol to the database. * * \param name is the name of the 3d symbol * \param symbol 3d symbol to save. Ownership is transferred. * \param favorite is a boolean value to specify whether the 3d symbol should be added to favorites * \param tags is a list of tags that are associated with the 3d symbol * \returns returns the success state of the save operation * * \since QGIS 3.16 */ bool saveSymbol3D( const QString &name, QgsAbstract3DSymbol *symbol SIP_TRANSFER, bool favorite, const QStringList &tags ); /** * Changes a 3d symbol's name. * * \since QGIS 3.16 */ bool renameSymbol3D( const QString &oldName, const QString &newName ); /** * Returns a list of names of 3d symbols in the style. * \since QGIS 3.16 */ QStringList symbol3DNames() const; /** * Creates an on-disk database * * This function creates a new on-disk permanent style database. * \returns returns the success state of the database creation * \see createMemoryDatabase() * \since QGIS 3.0 */ bool createDatabase( const QString &filename ); /** * Creates a temporary memory database * * This function is used to create a temporary style database in case a permanent on-disk database is not needed. * \returns returns the success state of the temporary memory database creation * \see createDatabase() * \since QGIS 3.0 */ bool createMemoryDatabase(); /** * Creates tables structure for new database * * This function is used to create the tables structure in a newly-created database. * \returns returns the success state of the temporary memory database creation * \see createDatabase() * \see createMemoryDatabase() * \since QGIS 3.0 */ void createTables(); /** * Loads a file into the style * * This function will load an on-disk database and populate styles. * \param filename location of the database to load styles from * \returns returns the success state of the database being loaded */ bool load( const QString &filename ); //! Saves style into a file (will use current filename if empty string is passed) bool save( QString filename = QString() ); //! Returns last error from load/save operation QString errorString() { return mErrorString; } //! Returns current file name of the style QString fileName() { return mFileName; } /** * Returns the names of the symbols which have a matching 'substring' in its definition * * \param type is either SymbolEntity or ColorrampEntity * \param qword is the query string to search the symbols or colorramps. * \returns A QStringList of the matched symbols or colorramps */ QStringList findSymbols( StyleEntity type, const QString &qword ); /** * Returns the tags associated with the symbol * * \param type is either SymbolEntity or ColorrampEntity * \param symbol is the name of the symbol or color ramp * \returns A QStringList of the tags that have been applied to that symbol/colorramp */ QStringList tagsOfSymbol( StyleEntity type, const QString &symbol ); /** * Returns TRUE if the symbol with matching \a type and \a name is * marked as a favorite. * * \since QGIS 3.10 */ bool isFavorite( StyleEntity type, const QString &name ); /** * Returns whether a given tag is associated with the symbol * * \param type is either SymbolEntity or ColorrampEntity * \param symbol is the name of the symbol or color ramp * \param tag the name of the tag to look for * \returns A boolean value identicating whether a tag was found attached to the symbol */ bool symbolHasTag( StyleEntity type, const QString &symbol, const QString &tag ); //! Returns the tag name for the given id QString tag( int id ) const; //! Returns the smart groups map with id as key and name as value QgsSymbolGroupMap smartgroupsListMap(); //! Returns the smart groups list QStringList smartgroupNames() const; //! Returns the QgsSmartConditionMap for the given id QgsSmartConditionMap smartgroup( int id ); /** * Returns the operator for the smartgroup. */ QString smartgroupOperator( int id ); //! Returns the symbols for the smartgroup QStringList symbolsOfSmartgroup( StyleEntity type, int id ); //! Exports the style as a XML file bool exportXml( const QString &filename ); //! Imports the symbols and colorramps into the default style database from the given XML file bool importXml( const QString &filename ); /** * Tests if the file at \a path is a QGIS style XML file. * * This method samples only the first line in the file, so is safe to call on * large xml files. * * \since QGIS 3.6 */ static bool isXmlStyleFile( const QString &path ); signals: /** * Emitted every time a new symbol has been added to the database. * Emitted whenever a symbol has been added to the style and the database * has been updated as a result. * \see symbolRemoved() * \see rampAdded() * \see symbolChanged() */ void symbolSaved( const QString &name, QgsSymbol *symbol ); /** * Emitted whenever a symbol's definition is changed. This does not include * name or tag changes. * * \see symbolSaved() * * \since QGIS 3.4 */ void symbolChanged( const QString &name ); //! Emitted every time a tag or smartgroup has been added, removed, or renamed void groupsModified(); /** * Emitted whenever an \a entity's tags are changed. * * \since QGIS 3.4 */ void entityTagsChanged( QgsStyle::StyleEntity entity, const QString &name, const QStringList &newTags ); /** * Emitted whenever an \a entity is either favorited or un-favorited. * * \since QGIS 3.4 */ void favoritedChanged( QgsStyle::StyleEntity entity, const QString &name, bool isFavorite ); /** * Emitted every time a new entity has been added to the database. * * \since QGIS 3.14 */ void entityAdded( QgsStyle::StyleEntity entity, const QString &name ); /** * Emitted whenever an entity of the specified type is removed from the style and the database * has been updated as a result. * * \since QGIS 3.14 */ void entityRemoved( QgsStyle::StyleEntity entity, const QString &name ); /** * Emitted whenever a entity of the specified type has been renamed from \a oldName to \a newName * \since QGIS 3.14 */ void entityRenamed( QgsStyle::StyleEntity entity, const QString &oldName, const QString &newName ); /** * Emitted whenever an entity's definition is changed. This does not include * name or tag changes. * * \since QGIS 3.14 */ void entityChanged( QgsStyle::StyleEntity entity, const QString &name ); /** * Emitted whenever a symbol has been removed from the style and the database * has been updated as a result. * \see symbolSaved() * \see rampRemoved() * \since QGIS 3.4 */ void symbolRemoved( const QString &name ); /** * Emitted whenever a symbol has been renamed from \a oldName to \a newName * \see rampRenamed() * \since QGIS 3.4 */ void symbolRenamed( const QString &oldName, const QString &newName ); /** * Emitted whenever a color ramp has been renamed from \a oldName to \a newName * \see symbolRenamed() * \since QGIS 3.4 */ void rampRenamed( const QString &oldName, const QString &newName ); /** * Emitted whenever a color ramp has been added to the style and the database * has been updated as a result. * \see rampRemoved() * \see symbolSaved() * \since QGIS 3.4 */ void rampAdded( const QString &name ); /** * Emitted whenever a color ramp has been removed from the style and the database * has been updated as a result. * \see rampAdded() * \see symbolRemoved() * \since QGIS 3.4 */ void rampRemoved( const QString &name ); /** * Emitted whenever a color ramp's definition is changed. This does not include * name or tag changes. * * \see rampAdded() * * \since QGIS 3.4 */ void rampChanged( const QString &name ); /** * Emitted whenever a text format has been renamed from \a oldName to \a newName * \see symbolRenamed() * \since QGIS 3.10 */ void textFormatRenamed( const QString &oldName, const QString &newName ); /** * Emitted whenever a text format has been added to the style and the database * has been updated as a result. * \see textFormatRemoved() * \see symbolSaved() * \since QGIS 3.10 */ void textFormatAdded( const QString &name ); /** * Emitted whenever a text format has been removed from the style and the database * has been updated as a result. * \see textFormatAdded() * \see symbolRemoved() * \since QGIS 3.10 */ void textFormatRemoved( const QString &name ); /** * Emitted whenever a text format's definition is changed. This does not include * name or tag changes. * * \see textFormatAdded() * * \since QGIS 3.10 */ void textFormatChanged( const QString &name ); /** * Emitted whenever label settings have been renamed from \a oldName to \a newName * \see symbolRenamed() * \since QGIS 3.10 */ void labelSettingsRenamed( const QString &oldName, const QString &newName ); /** * Emitted whenever label settings have been added to the style and the database * has been updated as a result. * \see labelSettingsRemoved() * \see symbolSaved() * \since QGIS 3.10 */ void labelSettingsAdded( const QString &name ); /** * Emitted whenever label settings have been removed from the style and the database * has been updated as a result. * \see labelSettingsAdded() * \see symbolRemoved() * \since QGIS 3.10 */ void labelSettingsRemoved( const QString &name ); /** * Emitted whenever a label setting's definition is changed. This does not include * name or tag changes. * * \see labelSettingsAdded() * * \since QGIS 3.10 */ void labelSettingsChanged( const QString &name ); private: QgsSymbolMap mSymbols; QgsVectorColorRampMap mColorRamps; QgsTextFormatMap mTextFormats; QgsLabelSettingsMap mLabelSettings; QMap mLegendPatchShapes; QMap m3dSymbols; QHash< QgsStyle::StyleEntity, QHash< QString, QStringList > > mCachedTags; QHash< QgsStyle::StyleEntity, QHash< QString, bool > > mCachedFavorites; QString mErrorString; QString mFileName; sqlite3_database_unique_ptr mCurrentDB; std::unique_ptr< QgsSymbol > mPatchMarkerSymbol; std::unique_ptr< QgsSymbol > mPatchLineSymbol; std::unique_ptr< QgsSymbol > mPatchFillSymbol; mutable QHash< int, QHash< QSizeF, QgsLegendPatchShape > > mDefaultPatchCache; mutable QHash< int, QHash< QSizeF, QList< QList< QPolygonF > > > > mDefaultPatchQPolygonFCache; QMap< QString, QDomElement > mDeferred3DsymbolElements; void handleDeferred3DSymbolCreation(); static QgsStyle *sDefaultStyle; //! Convenience function to open the DB and return a sqlite3 object bool openDatabase( const QString &filename ); //! Imports the symbols and colorramps into the default style database from the given XML file bool importXml( const QString &filename, int sinceVersion ); /** * Convenience function that would run queries which don't generate return values * * \param query query to run * \returns success TRUE on success */ bool runEmptyQuery( const QString &query ); //! Gets the id from the table for the given name from the database, 0 if not found int getId( const QString &table, const QString &name ); //! Gets the name from the table for the given id from the database, empty if not found QString getName( const QString &table, int id ) const; /** * Updates the properties of an existing symbol/colorramp * * \note This should not be called separately, only called through addSymbol or addColorRamp * \param type is either SymbolEntity or ColorrampEntity * \param name is the name of an existing symbol or a color ramp * \returns Success state of the update operation */ bool updateSymbol( StyleEntity type, const QString &name ); void clearCachedTags( StyleEntity type, const QString &name ); void upgradeIfRequired(); /** * Returns the table name for the specified entity \a type. */ static QString entityTableName( StyleEntity type ); /** * Returns the tag map table name for the specified entity \a type. */ static QString tagmapTableName( StyleEntity type ); /** * Returns the entity ID field name for for the tag map table for the specified entity \a type. */ static QString tagmapEntityIdFieldName( StyleEntity type ); friend class Qgs3D; friend class TestStyle; Q_DISABLE_COPY( QgsStyle ) }; /** * \class QgsStyleEntityInterface * \ingroup core * \brief An interface for entities which can be placed in a QgsStyle database. * \since QGIS 3.10 */ class CORE_EXPORT QgsStyleEntityInterface { #ifdef SIP_RUN SIP_CONVERT_TO_SUBCLASS_CODE switch ( sipCpp->type() ) { case QgsStyle::SymbolEntity: sipType = sipType_QgsStyleSymbolEntity; break; case QgsStyle::ColorrampEntity: sipType = sipType_QgsStyleColorRampEntity; break; case QgsStyle::TextFormatEntity: sipType = sipType_QgsStyleTextFormatEntity; break; case QgsStyle::LabelSettingsEntity: sipType = sipType_QgsStyleLabelSettingsEntity; break; case QgsStyle::SmartgroupEntity: case QgsStyle::TagEntity: sipType = 0; break; } SIP_END #endif public: virtual ~QgsStyleEntityInterface() = default; /** * Returns the type of style entity. */ virtual QgsStyle::StyleEntity type() const = 0; }; /** * \class QgsStyleSymbolEntity * \ingroup core * \brief A symbol entity for QgsStyle databases. * \since QGIS 3.10 */ class CORE_EXPORT QgsStyleSymbolEntity : public QgsStyleEntityInterface { public: /** * Constructor for QgsStyleSymbolEntity, with the specified \a symbol. * * Ownership of \a symbol is NOT transferred. */ QgsStyleSymbolEntity( QgsSymbol *symbol ) : mSymbol( symbol ) {} QgsStyle::StyleEntity type() const override; /** * Returns the entity's symbol. */ QgsSymbol *symbol() const { return mSymbol; } private: QgsSymbol *mSymbol = nullptr; }; /** * \class QgsStyleColorRampEntity * \ingroup core * \brief A color ramp entity for QgsStyle databases. * \since QGIS 3.10 */ class CORE_EXPORT QgsStyleColorRampEntity : public QgsStyleEntityInterface { public: /** * Constructor for QgsStyleColorRampEntity, with the specified color \a ramp. * * Ownership of \a ramp is NOT transferred. */ QgsStyleColorRampEntity( QgsColorRamp *ramp ) : mRamp( ramp ) {} QgsStyle::StyleEntity type() const override; /** * Returns the entity's color ramp. */ QgsColorRamp *ramp() const { return mRamp; } private: QgsColorRamp *mRamp = nullptr; }; /** * \class QgsStyleTextFormatEntity * \ingroup core * \brief A text format entity for QgsStyle databases. * \since QGIS 3.10 */ class CORE_EXPORT QgsStyleTextFormatEntity : public QgsStyleEntityInterface { public: /** * Constructor for QgsStyleTextFormatEntity, with the specified text \a format. */ QgsStyleTextFormatEntity( const QgsTextFormat &format ) : mFormat( format ) {} QgsStyle::StyleEntity type() const override; /** * Returns the entity's text format. */ QgsTextFormat format() const { return mFormat; } private: QgsTextFormat mFormat; }; /** * \class QgsStyleLabelSettingsEntity * \ingroup core * \brief A label settings entity for QgsStyle databases. * \since QGIS 3.10 */ class CORE_EXPORT QgsStyleLabelSettingsEntity : public QgsStyleEntityInterface { public: /** * Constructor for QgsStyleLabelSettingsEntity, with the specified label \a settings. */ QgsStyleLabelSettingsEntity( const QgsPalLayerSettings &settings ) : mSettings( settings ) {} QgsStyle::StyleEntity type() const override; /** * Returns the entity's label settings. */ const QgsPalLayerSettings &settings() const { return mSettings; } private: QgsPalLayerSettings mSettings; }; /** * \class QgsStyleLegendPatchShapeEntity * \ingroup core * \brief A legend patch shape entity for QgsStyle databases. * \since QGIS 3.14 */ class CORE_EXPORT QgsStyleLegendPatchShapeEntity : public QgsStyleEntityInterface { public: /** * Constructor for QgsStyleLegendPatchShapeEntity, with the specified legend patch \a shape. */ QgsStyleLegendPatchShapeEntity( const QgsLegendPatchShape &shape ) : mShape( shape ) {} QgsStyle::StyleEntity type() const override; /** * Returns the entity's legend patch shape. */ const QgsLegendPatchShape &shape() const { return mShape; } private: QgsLegendPatchShape mShape; }; /** * \class QgsStyleSymbol3DEntity * \ingroup core * \brief A 3d symbol entity for QgsStyle databases. * \since QGIS 3.16 */ class CORE_EXPORT QgsStyleSymbol3DEntity : public QgsStyleEntityInterface { public: /** * Constructor for QgsStyleSymbol3DEntity, with the specified \a symbol. * * Ownership of \a symbol is NOT transferred. */ QgsStyleSymbol3DEntity( const QgsAbstract3DSymbol *symbol ) : mSymbol( symbol ) {} QgsStyle::StyleEntity type() const override; /** * Returns the entity's symbol. */ const QgsAbstract3DSymbol *symbol() const { return mSymbol; } private: const QgsAbstract3DSymbol *mSymbol = nullptr; }; #endif