18 #ifndef QGSDXFEXPORT_H
19 #define QGSDXFEXPORT_H
21 #include "qgis_core.h"
31 #include <QTextStream>
44 #define DXF_HANDSEED 100
45 #define DXF_HANDMAX 9999999
46 #define DXF_HANDPLOTSTYLE 0xf
76 , mLayerOutputAttributeIndex( layerOutputAttributeIndex )
95 QString splitLayerAttribute()
const;
99 int mLayerOutputAttributeIndex = -1;
112 FlagNoMText = 1 << 1,
114 Q_DECLARE_FLAGS( Flags, Flag )
125 DeviceNotWritableError,
164 Is3DPolygonMesh = 16,
167 ContinuousPattern = 128,
170 Q_DECLARE_FLAGS( DxfPolylineFlags, DxfPolylineFlag )
212 ExportResult writeToFile( QIODevice *d, const QString &codec );
220 void setSymbologyScale(
double scale ) { mSymbologyScale = scale; }
309 static int closestColorMatch( QRgb color );
317 QString layerName(
const QString &
id,
const QgsFeature &f )
const;
333 void writeGroup(
int code,
int i )
SIP_PYNAME( writeGroupInt );
341 void writeGroup(
int code,
double d )
SIP_PYNAME( writeGroupDouble );
348 void writeGroup(
int code,
const QString &s );
367 void writeGroup(
const QColor &color,
int exactMatch = 62,
int rgbCode = 420,
int transparencyCode = 440 );
373 void writeGroupCode(
int code );
379 void writeInt(
int i );
385 void writeDouble(
double d );
391 void writeString(
const QString &s );
399 int writeHandle(
int code = 5,
int handle = 0 );
411 void writePolyline(
const QgsPointSequence &line,
const QString &layer,
const QString &lineStyleName,
const QColor &color,
double width = -1 )
SIP_SKIP;
423 void writePolyline( const
QgsCurve &curve, const QString &layer, const QString &lineStyleName, const QColor &color,
double width = -1 )
SIP_SKIP;
434 void writePolygon( const
QgsRingSequence &polygon, const QString &layer, const QString &hatchPattern, const QColor &color )
SIP_SKIP;
445 void writePolygon( const
QgsCurvePolygon &polygon, const QString &layer, const QString &hatchPattern, const QColor &color )
SIP_SKIP;
451 void writeLine( const
QgsPoint &pt1, const
QgsPoint &pt2, const QString &layer, const QString &lineStyleName, const QColor &color,
double width = -1 );
458 void writePoint( const QString &layer, const QColor &color, const
QgsPoint &pt )
SIP_PYNAME( writePointV2 );
465 void writeFilledCircle( const QString &layer, const QColor &color, const
QgsPoint &pt,
double radius )
SIP_PYNAME( writeFillCircleV2 );
472 void writeCircle( const QString &layer, const QColor &color, const
QgsPoint &pt,
double radius, const QString &lineStyleName,
double width )
SIP_PYNAME( writeCircleV2 );
486 void writeMText( const QString &layer, const QString &text, const
QgsPoint &pt,
double width,
double angle, const QColor &color );
495 static
double mapUnitScaleFactor(
double scale,
QgsUnitTypes::RenderUnit symbolUnits,
QgsUnitTypes::DistanceUnit mapUnits,
double mapUnitsPerPixel = 1.0 );
503 void clipValueToMapUnitScale(
double &value, const
QgsMapUnitScale &scale,
double pixelToMMFactor ) const;
506 static QString dxfLayerName( const QString &name );
509 static QString dxfEncoding( const QString &name );
512 static QStringList encodings();
529 Q_DECL_DEPRECATED
void registerDxfLayer( const QString &layerId,
QgsFeatureId fid, const QString &layer );
540 double mSymbologyScale = 1.0;
541 SymbologyExport mSymbologyExport = NoSymbology;
543 bool mLayerTitleAsName =
false;
545 QTextStream mTextStream;
547 int mSymbolLayerCounter = 0;
549 int mBlockCounter = 0;
551 QHash< const QgsSymbolLayer *, QString > mLineStyles;
552 QHash< const QgsSymbolLayer *, QString > mPointSymbolBlocks;
555 void writeHeader(
const QString &codepage );
556 void prepareRenderers();
559 void writeEntities();
560 void writeEntitiesSymbolLevels(
DxfLayerJob *job );
561 void stopRenderers();
568 void writeDefaultLinetypes();
569 void writeSymbolLayerLinetype(
const QgsSymbolLayer *symbolLayer );
591 QString lineStyleFromSymbolLayer(
const QgsSymbolLayer *symbolLayer );
594 static int color_distance( QRgb p1,
int index );
595 static QRgb createRgbEntry( qreal r, qreal g, qreal b );
600 QList< QPair< QgsSymbolLayer *, QgsSymbol * > > symbolLayers(
QgsRenderContext &context );
601 static int nLineTypes(
const QList< QPair< QgsSymbolLayer *, QgsSymbol *> > &symbolLayers );
603 double dashSize()
const;
604 double dotSize()
const;
605 double dashSeparatorSize()
const;
606 double sizeToMapUnits(
double s )
const;
607 static QString lineNameFromPenStyle( Qt::PenStyle style );
608 bool layerIsScaleBasedVisible(
const QgsMapLayer *layer )
const;
610 QHash<QString, int> mBlockHandles;
611 QString mBlockHandle;
614 QMap< QString, QMap<QgsFeatureId, QString> > mDxfLayerNames;
617 QHash<QString, int> mLayerNameAttribute;
618 double mFactor = 1.0;
619 bool mForce2d =
false;
621 QgsDxfExport::Flags mFlags = QgsDxfExport::Flags();
623 void appendCurve(
const QgsCurve &
c, QVector<QgsPoint> &points, QVector<double> &bulges );
624 void appendLineString(
const QgsLineString &ls, QVector<QgsPoint> &points, QVector<double> &bulges );
625 void appendCircularString(
const QgsCircularString &cs, QVector<QgsPoint> &points, QVector<double> &bulges );
626 void appendCompoundCurve(
const QgsCompoundCurve &cc, QVector<QgsPoint> &points, QVector<double> &bulges );
630 QList<DxfLayerJob *> mJobs;
631 std::unique_ptr<QgsLabelingEngine> mLabelingEngine;
Circular string geometry type.
Compound curve geometry type.
This class represents a coordinate reference system (CRS).
Curve polygon geometry type.
Abstract base class for curved geometry type.
Exports QGIS layers to the DXF format.
void setForce2d(bool force2d)
Force 2d output (eg.
ExportResult
The result of an export as dxf operation.
@ FeatureSymbology
Keeps the number of features and export symbology per feature (using the first symbol level)
void setSymbologyExport(QgsDxfExport::SymbologyExport e)
Set symbology export mode.
bool layerTitleAsName()
Retrieve whether layer title (where set) instead of name shall be use.
QgsRectangle extent() const
Gets extent of area to export.
HAlign
Horizontal alignments.
bool force2d()
Retrieve whether the output should be forced to 2d.
void setExtent(const QgsRectangle &r)
Set extent of area to export.
double symbologyScale() const
Returns the reference scale for output.
VAlign
Vertical alignments.
QgsDxfExport::SymbologyExport symbologyExport() const
Gets symbology export mode.
DxfPolylineFlag
Flags for polylines.
void setLayerTitleAsName(bool layerTitleAsName)
Enable use of title (where set) instead of layer name, when attribute index of corresponding layer in...
Expression contexts are used to encapsulate the parameters around which a QgsExpression should be eva...
The feature class encapsulates a single feature including its id, geometry and a list of field/values...
Abstract base class that can be used to intercept rendered labels from a labeling / rendering job.
Line string geometry type, with support for z-dimension and m-values.
Base class for all map layer types.
The QgsMapSettings class contains configuration for rendering of the map.
Struct for storing maximum and minimum scales for measurements in map units.
Contains settings for how a map layer will be labeled.
A class to represent a 2D point.
Point geometry type, with support for z-dimension and m-values.
A rectangle specified with double values.
Contains information about the context of a rendering operation.
Abstract base class for all rendered symbols.
Helper functions for various unit types.
DistanceUnit
Units of distance.
RenderUnit
Rendering size units.
Represents a vector layer which manages a vector based data sets.
LabelPosition is a candidate feature label position.
double ANALYSIS_EXPORT angle(QgsPoint *p1, QgsPoint *p2, QgsPoint *p3, QgsPoint *p4)
Calculates the angle between two segments (in 2 dimension, z-values are ignored)
As part of the API refactoring and improvements which landed in the Processing API was substantially reworked from the x version This was done in order to allow much of the underlying Processing framework to be ported into c
QVector< QgsPointSequence > QgsRingSequence
QVector< QgsPoint > QgsPointSequence
qint64 QgsFeatureId
64 bit feature ids negative numbers are used for uncommitted/newly added features
Q_DECLARE_OPERATORS_FOR_FLAGS(QgsField::ConfigurationFlags) CORE_EXPORT QDataStream &operator<<(QDataStream &out
Writes the field to stream out. QGIS version compatibility is not guaranteed.
const QgsCoordinateReferenceSystem & crs
Holds information about each layer in a DXF job.
Layers and optional attribute index to split into multiple layers using attribute value as layer name...
DxfLayer(QgsVectorLayer *vl, int layerOutputAttributeIndex=-1)
QgsVectorLayer * layer() const
Returns the layer.
int layerOutputAttributeIndex() const
Returns the attribute index used to split into multiple layers.