23#include <Qt3DRender/QParameter>
24#include <Qt3DRender/QTexture>
26using namespace Qt::StringLiterals;
97 elem.setAttribute( u
"point-size"_s,
mPointSize );
109 mPointSize = elem.attribute( u
"point-size"_s, u
"3.0"_s ).toFloat();
137 return u
"single-color"_s;
143 result->mSingleColor = mSingleColor;
166 mSingleColor = color;
172 mat->addParameter( renderingStyle );
173 Qt3DRender::QParameter *pointSizeParameter =
new Qt3DRender::QParameter(
"u_pointSize", QVariant::fromValue(
mPointSize ) );
174 mat->addParameter( pointSizeParameter );
175 Qt3DRender::QParameter *singleColorParameter =
new Qt3DRender::QParameter(
"u_singleColor", QVector3D( mSingleColor.redF(), mSingleColor.greenF(), mSingleColor.blueF() ) );
176 mat->addParameter( singleColorParameter );
188 result->mRenderingParameter = mRenderingParameter;
189 result->mColorRampShader = mColorRampShader;
190 result->mColorRampShaderMin = mColorRampShaderMin;
191 result->mColorRampShaderMax = mColorRampShaderMax;
198 return u
"color-ramp"_s;
206 elem.setAttribute( u
"rendering-parameter"_s, mRenderingParameter );
207 elem.setAttribute( u
"color-ramp-shader-min"_s, mColorRampShaderMin );
208 elem.setAttribute( u
"color-ramp-shader-max"_s, mColorRampShaderMax );
209 QDomDocument doc = elem.ownerDocument();
210 const QDomElement elemColorRampShader = mColorRampShader.writeXml( doc );
211 elem.appendChild( elemColorRampShader );
219 mRenderingParameter = elem.attribute(
"rendering-parameter", QString() );
220 mColorRampShaderMin = elem.attribute( u
"color-ramp-shader-min"_s, u
"0.0"_s ).toDouble();
221 mColorRampShaderMax = elem.attribute( u
"color-ramp-shader-max"_s, u
"1.0"_s ).toDouble();
222 mColorRampShader.readXml( elem );
227 return mRenderingParameter;
232 mRenderingParameter = parameter;
237 return mColorRampShader;
247 mColorRampShaderMin = min;
248 mColorRampShaderMax = max;
254 mat->addParameter( renderingStyle );
255 Qt3DRender::QParameter *pointSizeParameter =
new Qt3DRender::QParameter(
"u_pointSize", QVariant::fromValue(
mPointSize ) );
256 mat->addParameter( pointSizeParameter );
258 Qt3DRender::QTexture1D *colorRampTexture =
nullptr;
259 if ( mColorRampShader.colorRampItemList().count() > 0 )
261 colorRampTexture =
new Qt3DRender::QTexture1D( mat );
262 colorRampTexture->addTextureImage(
new QgsColorRampTexture( mColorRampShader, 1 ) );
263 colorRampTexture->setMinificationFilter( Qt3DRender::QTexture1D::Linear );
264 colorRampTexture->setMagnificationFilter( Qt3DRender::QTexture1D::Linear );
268 Qt3DRender::QParameter *colorRampTextureParameter =
new Qt3DRender::QParameter(
"u_colorRampTexture", colorRampTexture );
269 mat->addParameter( colorRampTextureParameter );
270 Qt3DRender::QParameter *colorRampCountParameter =
new Qt3DRender::QParameter(
"u_colorRampCount", mColorRampShader.colorRampItemList().count() );
271 mat->addParameter( colorRampCountParameter );
273 Qt3DRender::QParameter *colorRampTypeParameter =
new Qt3DRender::QParameter(
"u_colorRampType",
static_cast<int>( colorRampType ) );
274 mat->addParameter( colorRampTypeParameter );
291 result->mRedAttribute = mRedAttribute;
292 result->mGreenAttribute = mGreenAttribute;
293 result->mBlueAttribute = mBlueAttribute;
295 if ( mRedContrastEnhancement )
299 if ( mGreenContrastEnhancement )
303 if ( mBlueContrastEnhancement )
317 elem.setAttribute( u
"red"_s, mRedAttribute );
318 elem.setAttribute( u
"green"_s, mGreenAttribute );
319 elem.setAttribute( u
"blue"_s, mBlueAttribute );
321 QDomDocument doc = elem.ownerDocument();
324 if ( mRedContrastEnhancement )
326 QDomElement redContrastElem = doc.createElement( u
"redContrastEnhancement"_s );
327 mRedContrastEnhancement->writeXml( doc, redContrastElem );
328 elem.appendChild( redContrastElem );
330 if ( mGreenContrastEnhancement )
332 QDomElement greenContrastElem = doc.createElement( u
"greenContrastEnhancement"_s );
333 mGreenContrastEnhancement->writeXml( doc, greenContrastElem );
334 elem.appendChild( greenContrastElem );
336 if ( mBlueContrastEnhancement )
338 QDomElement blueContrastElem = doc.createElement( u
"blueContrastEnhancement"_s );
339 mBlueContrastEnhancement->writeXml( doc, blueContrastElem );
340 elem.appendChild( blueContrastElem );
356 const QDomElement redContrastElem = elem.firstChildElement( u
"redContrastEnhancement"_s );
357 if ( !redContrastElem.isNull() )
365 const QDomElement greenContrastElem = elem.firstChildElement( u
"greenContrastEnhancement"_s );
366 if ( !greenContrastElem.isNull() )
374 const QDomElement blueContrastElem = elem.firstChildElement( u
"blueContrastEnhancement"_s );
375 if ( !blueContrastElem.isNull() )
386 mat->addParameter( renderingStyle );
387 Qt3DRender::QParameter *pointSizeParameter =
new Qt3DRender::QParameter(
"u_pointSize", QVariant::fromValue(
mPointSize ) );
388 mat->addParameter( pointSizeParameter );
394 return mRedAttribute;
404 return mGreenAttribute;
414 return mBlueAttribute;
424 return mRedContrastEnhancement.get();
429 mRedContrastEnhancement.reset( enhancement );
434 return mGreenContrastEnhancement.get();
439 mGreenContrastEnhancement.reset( enhancement );
444 return mBlueContrastEnhancement.get();
449 mBlueContrastEnhancement.reset( enhancement );
462 result->mRenderingParameter = mRenderingParameter;
463 result->mCategoriesList = mCategoriesList;
470 return u
"classification"_s;
476 QDomDocument doc = elem.ownerDocument();
480 elem.setAttribute( u
"rendering-parameter"_s, mRenderingParameter );
483 QDomElement catsElem = doc.createElement( u
"categories"_s );
486 QDomElement catElem = doc.createElement( u
"category"_s );
487 catElem.setAttribute( u
"value"_s, QString::number( category.value() ) );
488 catElem.setAttribute( u
"pointSize"_s, category.pointSize() );
489 catElem.setAttribute( u
"label"_s, category.label() );
491 catElem.setAttribute( u
"render"_s, category.renderState() ?
"true" :
"false" );
492 catsElem.appendChild( catElem );
494 elem.appendChild( catsElem );
502 mRenderingParameter = elem.attribute(
"rendering-parameter", QString() );
504 const QDomElement catsElem = elem.firstChildElement( u
"categories"_s );
505 if ( !catsElem.isNull() )
507 mCategoriesList.clear();
508 QDomElement catElem = catsElem.firstChildElement();
509 while ( !catElem.isNull() )
511 if ( catElem.tagName() ==
"category"_L1 )
513 const int value = catElem.attribute( u
"value"_s ).toInt();
514 const double size = catElem.attribute( u
"pointSize"_s, u
"0"_s ).toDouble();
515 const QString label = catElem.attribute( u
"label"_s );
516 const bool render = catElem.attribute( u
"render"_s ) !=
"false"_L1;
520 catElem = catElem.nextSiblingElement();
527 return mRenderingParameter;
537 mCategoriesList = categories;
545 if ( !category.renderState() )
546 filteredOut.push_back( category );
556 QList<QgsColorRampShader::ColorRampItem> colorRampItemList;
559 const QColor color = category.color();
561 colorRampItemList.push_back( item );
563 colorRampShader.setColorRampItemList( colorRampItemList );
564 return colorRampShader;
572 mat->addParameter( renderingStyle );
573 Qt3DRender::QParameter *pointSizeParameter =
new Qt3DRender::QParameter(
"u_pointSize", QVariant::fromValue(
mPointSize ) );
574 mat->addParameter( pointSizeParameter );
576 Qt3DRender::QTexture1D *colorRampTexture =
nullptr;
579 colorRampTexture =
new Qt3DRender::QTexture1D( mat );
580 colorRampTexture->addTextureImage(
new QgsColorRampTexture( mColorRampShader, 1 ) );
581 colorRampTexture->setMinificationFilter( Qt3DRender::QTexture1D::Linear );
582 colorRampTexture->setMagnificationFilter( Qt3DRender::QTexture1D::Linear );
586 Qt3DRender::QParameter *colorRampTextureParameter =
new Qt3DRender::QParameter(
"u_colorRampTexture", colorRampTexture );
587 mat->addParameter( colorRampTextureParameter );
588 Qt3DRender::QParameter *colorRampCountParameter =
new Qt3DRender::QParameter(
"u_colorRampCount", mColorRampShader.
colorRampItemList().count() );
589 mat->addParameter( colorRampCountParameter );
591 Qt3DRender::QParameter *colorRampTypeParameter =
new Qt3DRender::QParameter(
"u_colorRampType",
static_cast<int>( colorRampType ) );
592 mat->addParameter( colorRampTypeParameter );
ShaderInterpolationMethod
Color ramp shader interpolation methods.
@ Exact
Assigns the color of the exact matching value in the color ramp item list.
@ Continuous
Uses breaks from color palette.
@ UnknownDataType
Unknown or unspecified type.
Abstract base class for 3D symbols that are used by VectorLayer3DRenderer objects.
virtual void copyBaseSettings(QgsAbstract3DSymbol *destination) const
Copies base class settings from this object to a destination object.
void readXml(const QDomElement &elem, const QgsReadWriteContext &context) override
void writeXml(QDomElement &elem, const QgsReadWriteContext &context) const override
void fillMaterial(QgsMaterial *material) override SIP_SKIP
Used to fill material object with necessary QParameters (and consequently opengl uniforms).
QString attribute() const
Returns the attribute used to select the color of the point cloud.
void setCategoriesList(const QgsPointCloudCategoryList &categories)
Sets the list of categories of the classification.
QgsPointCloudCategoryList getFilteredOutCategories() const
Gets the list of categories of the classification that should not be rendered.
void setAttribute(const QString &attribute)
Sets the attribute used to select the color of the point cloud.
QString symbolType() const override
Returns a unique string identifier of the symbol type.
QgsClassificationPointCloud3DSymbol * clone() const override SIP_FACTORY
QgsClassificationPointCloud3DSymbol()
QgsColorRampPointCloud3DSymbol * clone() const override SIP_FACTORY
void readXml(const QDomElement &elem, const QgsReadWriteContext &context) override
void setAttribute(const QString &attribute)
Sets the attribute used to select the color of the point cloud.
void writeXml(QDomElement &elem, const QgsReadWriteContext &context) const override
void setColorRampShaderMinMax(double min, double max)
Sets the minimum and maximum values used when classifying colors in the color ramp shader.
QString attribute() const
Returns the attribute used to select the color of the point cloud.
QString symbolType() const override
Returns a unique string identifier of the symbol type.
QgsColorRampShader colorRampShader() const
Returns the color ramp shader used to render the color.
void setColorRampShader(const QgsColorRampShader &colorRampShader)
Sets the color ramp shader used to render the point cloud.
void fillMaterial(QgsMaterial *material) override SIP_SKIP
Used to fill material object with necessary QParameters (and consequently opengl uniforms).
QgsColorRampPointCloud3DSymbol()
A ramp shader will color a raster pixel based on a list of values ranges in a ramp.
Qgis::ShaderInterpolationMethod colorRampType() const
Returns the color ramp interpolation method.
void setClassificationMode(Qgis::ShaderClassificationMethod classificationMode)
Sets the classification mode.
QList< QgsColorRampShader::ColorRampItem > colorRampItemList() const
Returns the custom color map.
void setColorRampType(Qgis::ShaderInterpolationMethod colorRampType)
Sets the color ramp interpolation method.
static QColor colorFromString(const QString &string)
Decodes a string into a color value.
static QString colorToString(const QColor &color)
Encodes a color into a string value.
Handles contrast enhancement and clipping.
Base class for all materials used within QGIS 3D views.
bool verticalTriangleFilter() const
Returns whether triangles are filtered by vertical height for rendering.
float mVerticalFilterThreshold
float verticalFilterThreshold() const
Returns the threshold vertical height value for filtering triangles.
void setVerticalTriangleFilter(bool verticalTriangleFilter)
Sets whether triangles are filtered by vertical height for rendering.
void setHorizontalFilterThreshold(float horizontalFilterThreshold)
Sets the threshold horizontal size value for filtering triangles.
void setRenderAsTriangles(bool asTriangles)
Sets whether points are triangulated to render solid surface.
float horizontalFilterThreshold() const
Returns the threshold horizontal size value for filtering triangles.
void copyBaseSettings(QgsAbstract3DSymbol *destination) const override
float mHorizontalFilterThreshold
bool renderAsTriangles() const
Returns whether points are triangulated to render solid surface.
bool mHorizontalTriangleFilter
void setPointSize(float size)
Sets the point size.
~QgsPointCloud3DSymbol() override
void writeBaseXml(QDomElement &elem, const QgsReadWriteContext &context) const
Writes symbol configuration of this class to the given DOM element.
bool mVerticalTriangleFilter
@ Classification
Render the point cloud with classified colors.
@ SingleColor
Render the point cloud with a single color.
@ ColorRamp
Render the point cloud with a color ramp.
@ RgbRendering
Render the RGB colors of the point cloud.
void setHorizontalTriangleFilter(bool horizontalTriangleFilter)
Sets whether whether triangles are filtered by horizontal size for rendering.
bool horizontalTriangleFilter() const
Returns whether triangles are filtered by horizontal size for rendering.
void readBaseXml(const QDomElement &elem, const QgsReadWriteContext &context)
Reads symbol configuration of this class from the given DOM element.
void setVerticalFilterThreshold(float verticalFilterThreshold)
Sets the threshold vertical height value for filtering triangles.
Represents an individual category (class) from a QgsPointCloudClassifiedRenderer.
A container for the context for various read/write operations on objects.
QString blueAttribute() const
Returns the attribute to use for the blue channel.
void readXml(const QDomElement &elem, const QgsReadWriteContext &context) override
void setBlueAttribute(const QString &attribute)
Sets the attribute to use for the blue channel.
void setGreenContrastEnhancement(QgsContrastEnhancement *enhancement SIP_TRANSFER)
Sets the contrast enhancement to use for the green channel.
QgsRgbPointCloud3DSymbol()
QString greenAttribute() const
Returns the attribute to use for the green channel.
QgsContrastEnhancement * blueContrastEnhancement()
Returns the contrast enhancement to use for the blue channel.
void setGreenAttribute(const QString &attribute)
Sets the attribute to use for the green channel.
QString redAttribute() const
Returns the attribute to use for the red channel.
void setBlueContrastEnhancement(QgsContrastEnhancement *enhancement SIP_TRANSFER)
Sets the contrast enhancement to use for the blue channel.
QgsContrastEnhancement * greenContrastEnhancement()
Returns the contrast enhancement to use for the green channel.
QgsContrastEnhancement * redContrastEnhancement()
Returns the contrast enhancement to use for the red channel.
void setRedContrastEnhancement(QgsContrastEnhancement *enhancement SIP_TRANSFER)
Sets the contrast enhancement to use for the red channel.
QString symbolType() const override
Returns a unique string identifier of the symbol type.
QgsRgbPointCloud3DSymbol * clone() const override SIP_FACTORY
void writeXml(QDomElement &elem, const QgsReadWriteContext &context) const override
void fillMaterial(QgsMaterial *material) override SIP_SKIP
Used to fill material object with necessary QParameters (and consequently opengl uniforms).
void setRedAttribute(const QString &attribute)
Sets the attribute to use for the red channel.
QString symbolType() const override
Returns a unique string identifier of the symbol type.
void fillMaterial(QgsMaterial *material) override SIP_SKIP
Used to fill material object with necessary QParameters (and consequently opengl uniforms).
void readXml(const QDomElement &elem, const QgsReadWriteContext &context) override
void writeXml(QDomElement &elem, const QgsReadWriteContext &context) const override
QgsSingleColorPointCloud3DSymbol * clone() const override SIP_FACTORY
QgsSingleColorPointCloud3DSymbol()
void setSingleColor(QColor color)
Sets the color used by the renderer when using SingleColor rendering mode.
QList< QgsPointCloudCategory > QgsPointCloudCategoryList