33#include <QInputDialog>
37#include "moc_qgsrendererwidget.cpp"
43 contextMenu =
new QMenu( tr(
"Renderer Options" ),
this );
47 mCopyAction->setShortcut( QKeySequence( QKeySequence::Copy ) );
49 mPasteAction->setShortcut( QKeySequence( QKeySequence::Paste ) );
54 connect(
mCopySymbolAction, &QAction::triggered,
this, &QgsRendererWidget::copySymbol );
74 connect(
contextMenu, &QMenu::aboutToShow,
this, [
this] {
88 if ( symbolList.isEmpty() )
105 const QColor currentColor = firstSymbol->
color();
117 symbol->setColor( color );
127 if ( color.isValid() )
132 symbol->setColor( color );
142 if ( symbolList.isEmpty() )
148 const auto constSymbolList = symbolList;
149 for (
QgsSymbol *symbol : constSymbolList )
153 firstSymbol = symbol;
161 const double oldOpacity = firstSymbol->
opacity() * 100;
162 const double opacity = QInputDialog::getDouble(
this, tr(
"Opacity" ), tr(
"Change symbol opacity [%]" ), oldOpacity, 0.0, 100.0, 1, &ok );
165 const auto constSymbolList = symbolList;
166 for (
QgsSymbol *symbol : constSymbolList )
169 symbol->setOpacity( opacity / 100.0 );
178 if ( symbolList.isEmpty() )
184 const auto constSymbolList = symbolList;
185 for (
QgsSymbol *symbol : constSymbolList )
189 firstSymbol = symbol;
198 const QString item = QInputDialog::getItem(
this, tr(
"Symbol unit" ), tr(
"Select symbol unit" ), QStringList() << tr(
"Millimeter" ) << tr(
"Map unit" ), currentUnit,
false, &ok );
203 const auto constSymbolList = symbolList;
204 for (
QgsSymbol *symbol : constSymbolList )
207 symbol->setOutputUnit( unit );
216 if ( symbolList.isEmpty() )
225 if ( QDialog::Accepted == dlg.exec() )
227 if ( !dlg.mDDBtn->isActive() )
229 const auto constSymbolList = symbolList;
230 for (
QgsSymbol *symbol : constSymbolList )
246 if ( symbolList.isEmpty() )
254 if ( QDialog::Accepted == dlg.exec() )
256 if ( !dlg.mDDBtn->isActive() )
258 const auto constSymbolList = symbolList;
259 for (
QgsSymbol *symbol : constSymbolList )
275 if ( symbolList.isEmpty() )
283 if ( QDialog::Accepted == dlg.exec() )
285 if ( !dlg.mDDBtn->isActive() )
287 const auto constSymbolList = symbolList;
288 for (
QgsSymbol *symbol : constSymbolList )
305void QgsRendererWidget::copySymbol()
308 if ( symbolList.isEmpty() )
316void QgsRendererWidget::updateDataDefinedProperty()
318 QgsPropertyOverrideButton *button = qobject_cast<QgsPropertyOverrideButton *>( sender() );
381 if ( !ddSize || !ddSize.
isActive() )
383 QMessageBox::warning(
this, tr(
"Data-defined Size Legend" ), tr(
"Data-defined size is not enabled!" ) );
408 if (
auto *lExpressionContext =
mContext.expressionContext() )
409 return *lExpressionContext;
414 const auto constAdditionalExpressionContextScopes =
mContext.additionalExpressionContextScopes();
423 QStringList highlights;
426 if ( expContext.
hasVariable( QStringLiteral(
"zoom_level" ) ) )
428 highlights << QStringLiteral(
"zoom_level" );
430 if ( expContext.
hasVariable( QStringLiteral(
"vector_tile_zoom" ) ) )
432 highlights << QStringLiteral(
"vector_tile_zoom" );
445 : mSymbolList( symbolList )
449 setWindowFlags( Qt::WindowStaysOnTopHint );
450 mLabel->setText( label );
467 if (
auto *lMapCanvas = mContext.
mapCanvas() )
469 expContext = lMapCanvas->createExpressionContext();
483 const auto constAdditionalExpressionContextScopes = mContext.additionalExpressionContextScopes();
484 for (
const QgsExpressionContextScope &scope : constAdditionalExpressionContextScopes )
486 expContext.
appendScope(
new QgsExpressionContextScope( scope ) );
497 mDDBtn->registerExpressionContextGenerator(
this );
500 const auto constMSymbolList = mSymbolList;
501 for (
QgsSymbol *symbol : constMSymbolList )
505 initialSymbol = symbol;
508 mSpinBox->setValue( initialSymbol ? value( initialSymbol ) : 0 );
509 mSpinBox->setEnabled( !mDDBtn->isActive() );
512QgsProperty QgsDataDefinedValueDialog::symbolDataDefined()
const
514 if ( mSymbolList.isEmpty() || !mSymbolList.back() )
518 const QgsProperty dd = symbolDataDefined( mSymbolList.back() );
519 const auto constMSymbolList = mSymbolList;
522 const QgsProperty symbolDD( symbolDataDefined( it ) );
523 if ( !it || !dd || !symbolDD || symbolDD != dd )
532 mSpinBox->setEnabled( !dd.
isActive() );
542 const auto constMSymbolList = mSymbolList;
544 setDataDefined( it, dd );
552 if ( !symbolList.isEmpty() && symbolList.at( 0 ) &&
vectorLayer() )
555 mDDBtn->setSymbol( mAssistantSymbol );
614 return static_cast<const QgsLineSymbol *
>( symbol )->width();
619 static_cast<QgsLineSymbol *
>( symbol )->setDataDefinedWidth( dd );
622void QgsRendererWidget::apply()
@ ScaleDiameter
Calculate scale by the diameter.
RenderUnit
Rendering size units.
@ Millimeters
Millimeters.
static QColor getColor(const QColor &initialColor, QWidget *parent, const QString &title=QString(), bool allowOpacity=false)
Returns a color selection from a color dialog.
A dialog for configuring symbol-level data defined rotation.
void setDataDefined(QgsSymbol *symbol, const QgsProperty &dd) override
QgsDataDefinedRotationDialog(const QList< QgsSymbol * > &symbolList, QgsVectorLayer *layer)
double value(const QgsSymbol *symbol) const override
QgsProperty symbolDataDefined(const QgsSymbol *symbol) const override
A dialog for configuring symbol-level data defined size.
QgsProperty symbolDataDefined(const QgsSymbol *symbol) const override
void setDataDefined(QgsSymbol *symbol, const QgsProperty &dd) override
double value(const QgsSymbol *symbol) const override
QgsDataDefinedSizeDialog(const QList< QgsSymbol * > &symbolList, QgsVectorLayer *layer)
Object that keeps configuration of appearance of marker symbol's data-defined size in legend.
void setContext(const QgsSymbolWidgetContext &context)
Sets the context in which the symbol widget is shown, e.g., the associated map canvas and expression ...
void dataDefinedChanged()
QgsDataDefinedValueDialog(const QList< QgsSymbol * > &symbolList, QgsVectorLayer *layer, const QString &label)
Constructor.
const QgsVectorLayer * vectorLayer() const
Returns the vector layer associated with the widget.
QgsSymbolWidgetContext context() const
Returns the context in which the symbol widget is shown, e.g., the associated map canvas and expressi...
void init(int propertyKey)
Should be called in the constructor of child classes.
A dialog for configuring symbol-level data defined width.
QgsProperty symbolDataDefined(const QgsSymbol *symbol) const override
double value(const QgsSymbol *symbol) const override
void setDataDefined(QgsSymbol *symbol, const QgsProperty &dd) override
QgsDataDefinedWidthDialog(const QList< QgsSymbol * > &symbolList, QgsVectorLayer *layer)
virtual QgsExpressionContext createExpressionContext() const =0
This method needs to be reimplemented in all classes which implement this interface and return an exp...
Single scope for storing variables and functions for use within a QgsExpressionContext.
static QgsExpressionContextScope * projectScope(const QgsProject *project)
Creates a new scope which contains variables and functions relating to a QGIS project.
static QgsExpressionContextScope * atlasScope(const QgsLayoutAtlas *atlas)
Creates a new scope which contains variables and functions relating to a QgsLayoutAtlas.
static QgsExpressionContextScope * mapSettingsScope(const QgsMapSettings &mapSettings)
Creates a new scope which contains variables and functions relating to a QgsMapSettings object.
static QgsExpressionContextScope * layerScope(const QgsMapLayer *layer)
Creates a new scope which contains variables and functions relating to a QgsMapLayer.
static QgsExpressionContextScope * globalScope()
Creates a new scope which contains variables and functions relating to the global QGIS context.
Expression contexts are used to encapsulate the parameters around which a QgsExpression should be eva...
void setOriginalValueVariable(const QVariant &value)
Sets the original value variable value for the context.
void appendScope(QgsExpressionContextScope *scope)
Appends a scope to the end of the context.
bool hasVariable(const QString &name) const
Check whether a variable is specified by any scope within the context.
void setHighlightedVariables(const QStringList &variableNames)
Sets the list of variable names within the context intended to be highlighted to the user.
static const QString EXPR_ORIGINAL_VALUE
Inbuilt variable name for value original value variable.
Abstract base class for all 2D vector feature renderers.
virtual QgsLegendSymbolList legendSymbolItems() const
Returns a list of symbology items for the legend.
Property
Data definable properties for renderers.
bool usingSymbolLevels() const
static const QgsPropertiesDefinition & propertyDefinitions()
Returns the symbol property definitions.
void setDataDefinedProperty(Property key, const QgsProperty &property)
Sets a data defined property for the renderer.
A line symbol type, for rendering LineString and MultiLineString geometries.
QgsProperty dataDefinedWidth() const
Returns data defined width for whole symbol (including all symbol layers).
A marker symbol type, for rendering Point and MultiPoint geometries.
QgsProperty dataDefinedAngle() const
Returns data defined angle for whole symbol (including all symbol layers).
QgsProperty dataDefinedSize() const
Returns data defined size for whole symbol (including all symbol layers).
QgsMarkerSymbol * clone() const override
Returns a deep copy of this symbol.
static QgsProject * instance()
Returns the QgsProject singleton instance.
A store for object properties.
bool isActive() const
Returns whether the property is currently active.
A database of saved style entities, including symbols, color ramps, text formats and others.
static std::unique_ptr< QgsSymbol > symbolFromMimeData(const QMimeData *data)
Attempts to parse mime data as a symbol.
static QMimeData * symbolToMimeData(const QgsSymbol *symbol)
Creates new mime data from a symbol.
@ StrokeWidth
Stroke width.
static const QgsPropertiesDefinition & propertyDefinitions()
Returns the symbol layer property definitions.
A dialog which allows the user to modify the rendering order of symbol layers.
QgsLegendSymbolList symbolLevels() const
Returns the current legend symbols with rendering passes set, as defined in the widget.
bool usingLevels() const
Returns whether the level ordering is enabled.
Contains settings which reflect the context in which a symbol (or renderer) widget is shown,...
QgsMapCanvas * mapCanvas() const
Returns the map canvas associated with the widget.
Abstract base class for all rendered symbols.
qreal opacity() const
Returns the opacity for the symbol.
QColor color() const
Returns the symbol's color.
Qgis::RenderUnit outputUnit() const
Returns the units to use for sizes and widths within the symbol.
Represents a vector layer which manages a vector based dataset.