52 qDeleteAll( mMetadata );
57 return mMetadata.value( metadataId );
65 int id = mMetadata.count();
66 mMetadata[id] = metadata;
73 if ( mItemGroups.contains( group.
id ) )
76 mItemGroups.insert( group.
id, group );
82 return mItemGroups[ id ];
87 if ( !mMetadata.contains( metadataId ) )
90 std::unique_ptr< QgsLayoutItem > item( mMetadata.value( metadataId )->createItem( layout ) );
92 return item.release();
94 int type = mMetadata.value( metadataId )->type();
100 if ( !mMetadata.contains( metadataId ) )
103 mMetadata.value( metadataId )->newItemAddedToLayout( item );
111 int type = item->
type();
116 type = multiFrame->
type();
118 for (
auto it = mMetadata.constBegin(); it != mMetadata.constEnd(); ++it )
120 if ( it.value()->type() == type )
121 return it.value()->createItemWidget( item );
129 if ( !mMetadata.contains( metadataId ) )
132 return mMetadata[metadataId]->createRubberBand( view );
137 if ( !mMetadata.contains( metadataId ) )
140 return mMetadata[metadataId]->createNodeRubberBand( view );
145 return mMetadata.keys();
155 if ( mAddedToLayoutFunc )
156 mAddedToLayoutFunc( item );
QgsLayoutItemGuiRegistry(QObject *parent=nullptr)
Creates a new empty item GUI registry.
Stores GUI metadata about a group of layout item classes.
QgsLayoutViewRubberBand * createItemRubberBand(int metadataId, QgsLayoutView *view) const
Creates a new rubber band item for the specified item metadataId and destination view.
Base class for graphical items within a QgsLayout.
int type() const override
Returns a unique graphics item type identifier.
A graphical widget to display and interact with QgsLayouts.
QList< int > itemMetadataIds() const
Returns a list of available item metadata ids handled by the registry.
QgsLayoutItem * createItem(int type, QgsLayout *layout) const
Creates a new instance of a layout item given the item type, and target layout.
Abstract base class for layout items with the ability to distribute the content to several frames (Qg...
static QgsLayoutItemRegistry * layoutItemRegistry()
Returns the application's layout item registry, used for layout item types.
QString id
Unique (untranslated) group ID string.
Base class for layouts, which can contain items such as maps, labels, scalebars, etc.
QgsLayoutItemBaseWidget * createItemWidget(QgsLayoutItem *item) const
Creates a new instance of a layout item configuration widget for the specified item.
bool addItemGroup(const QgsLayoutItemGuiGroup &group)
Registers a new item group with the registry.
Frame item, part of a QgsLayoutMultiFrame object.
~QgsLayoutItemGuiRegistry() override
QgsLayoutViewRectangularRubberBand is rectangular rubber band for use within QgsLayoutView widgets...
QgsLayoutItemAbstractGuiMetadata * itemMetadata(int metadataId) const
Returns the metadata for the specified item metadataId.
QgsLayoutViewRubberBand is an abstract base class for temporary rubber band items in various shapes...
virtual int type() const =0
Returns unique multiframe type id.
void newItemAddedToLayout(int metadataId, QgsLayoutItem *item)
Called when a newly created item of the associated metadata metadataId has been added to a layout...
bool addLayoutItemGuiMetadata(QgsLayoutItemAbstractGuiMetadata *metadata)
Registers the gui metadata for a new layout item type.
const QgsLayoutItemGuiGroup & itemGroup(const QString &id)
Returns a reference to the item group with matching id.
QAbstractGraphicsShapeItem * createNodeItemRubberBand(int metadataId, QgsLayoutView *view)
Creates a rubber band for the specified item metadataId and destination view.
Base class for frame items, which form a layout multiframe item.
QgsLayoutItem * createItem(int metadataId, QgsLayout *layout) const
Creates a new instance of a layout item given the item metadata metadataId, target layout...
void typeAdded(int metadataId)
Emitted whenever a new item type is added to the registry, with the specified metadataId.