KiCad PCB EDA Suite
Loading...
Searching...
No Matches
dxf_import_plugin.h
Go to the documentation of this file.
1/*
2 * This program source code file is part of KiCad, a free EDA CAD application.
3 *
4 * Copyright (C) 2019 Jean-Pierre Charras, jp.charras at wanadoo.fr
5 * Copyright The KiCad Developers, see AUTHORS.txt for contributors.
6 *
7 * This program is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU General Public License
9 * as published by the Free Software Foundation; either version 2
10 * of the License, or (at your option) any later version.
11 *
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with this program. If not, see <https://www.gnu.org/licenses/>.
19 */
20
21#ifndef DXF2BRD_ITEMS_H
22#define DXF2BRD_ITEMS_H
23
26#include "wx/translation.h"
27
28#include <dl_creationadapter.h>
29#include <dl_dxf.h>
30#include <math/vector3.h>
31#include <math/matrix3x3.h>
33
34#include <list>
35
36class BOARD;
37class BOARD_ITEM;
38
43{
44 double m_x;
45 double m_y;
46 double m_weight;
47
48 SPLINE_CTRL_POINT( double a_x, double a_y, double a_weight )
49 : m_x( a_x ), m_y( a_y ), m_weight( a_weight )
50 {}
51};
52
57{
58public:
60
61 // Reset the entity parameters
62 void Clear()
63 {
64 m_EntityType = DL_UNKNOWN;
66 m_EntityFlag = 0;
67 m_LayerName.clear();
76 m_BulgeVertex = 0.0;
77 m_SplineKnotsList.clear();
80 }
81
82 int m_EntityType; // the DXF type of entity
83 int m_EntityParseStatus; // Inside a entity: status of parsing:
84 // 0 = no entity
85 // 1 = first item of entity
86 // 2 = entity in progress
87 int m_EntityFlag; // a info flag to parse entities
88 //
89 wxString m_LayerName; // the source DXF layer for the current entity
90
91 VECTOR2D m_LastCoordinate; // the last vertex coordinate read (unit = mm)
92 VECTOR2D m_PolylineStart; // The first point of the polyline entity, when reading a
93 // polyline (unit = mm)
94 double m_BulgeVertex; // the last vertex bulge value read
95
96 // for spline parsing: parameters
97 unsigned int m_SplineDegree;
98 unsigned int m_SplineKnotsCount;
100 unsigned int m_SplineFitCount;
101 double m_SplineTangentStartX; // tangent dir X for the start point
102 double m_SplineTangentStartY; // tangent dir Y for the start point
103 double m_SplineTangentEndX; // tangent dir X for the end point
104 double m_SplineTangentEndY; // tangent dir Y for the end point
105
106 // for spline parsing: buffers to store control points, fit points and knot
107 std::vector<double> m_SplineKnotsList; // knots list, code 40
108 // control points list coordinates, code 10, 20 & 30 (only X and Y cood and Weight)
109 std::vector<SPLINE_CTRL_POINT> m_SplineControlPointList;
110 // fit points list, code 11, 21 & 31 (only X and Y cood)
111 std::vector<VECTOR2D> m_SplineFitPointList;
112};
113
114// Magic constants as defined by dxf specification for line weight
115#define DXF_IMPORT_LINEWEIGHT_BY_LAYER -1
116#define DXF_IMPORT_LINEWEIGHT_BY_BLOCK -2
117#define DXF_IMPORT_LINEWEIGHT_BY_LW_DEFAULT -3
118
123{
124public:
125 wxString m_layerName;
127
128 DXF_IMPORT_LAYER( const wxString& aName, int aLineWeight )
129 {
130 m_layerName = aName;
131 m_lineWeight = aLineWeight;
132 }
133};
134
139{
140public:
141 wxString m_name;
143
145
146 DXF_IMPORT_BLOCK( const wxString& aName, double aX, double aY )
147 {
148 m_name = aName;
149 m_baseX = aX;
150 m_baseY = aY;
151 }
152};
153
158{
159public:
160 wxString m_name;
163 bool m_bold;
165
166 DXF_IMPORT_STYLE( const wxString& aName, double aTextHeight, double aWidthFactor, bool aBold,
167 bool aItalic )
168 {
169 m_name = aName;
170 m_textHeight = aTextHeight;
171 m_widthFactor = aWidthFactor;
172 m_bold = aBold;
173 m_italic = aItalic;
174 }
175};
176
177
203
204
209#define ON_UNSUPPORTED( error_msg ) reportMessage( wxString::Format( _( "%s is not supported." ), \
210 error_msg ) )
211
212class DXF_IMPORT_PLUGIN : public GRAPHICS_IMPORT_PLUGIN, public DL_CreationAdapter
213{
214public:
217
218 const wxString GetName() const override
219 {
220 return "AutoCAD DXF";
221 }
222
223 const std::vector<std::string> GetFileExtensions() const override
224 {
225 static std::vector<std::string> exts = { "dxf" };
226 return exts;
227 }
228
229 bool Load( const wxString& aFileName ) override;
230 bool LoadFromMemory( const wxMemoryBuffer& aMemBuffer ) override;
231 bool Import() override;
232
233 double GetImageWidth() const override;
234 double GetImageHeight() const override;
235 BOX2D GetImageBBox() const override;
236
237 std::vector<wxString> GetSourceLayers() const { return m_internalImporter.GetSourceLayers(); }
238
239 void updateImageLimits( const VECTOR2D& aPoint );
240
241 virtual void SetImporter( GRAPHICS_IMPORTER* aImporter ) override;
242
249 void ImportAsFootprintGraphic( bool aImportAsFootprintGraphic )
250 {
251 m_importAsFPShapes = aImportAsFootprintGraphic;
252 }
253
262 {
263 m_currentUnit = aUnit;
264 }
265
274 void SetDefaultLineWidthMM( double aWidth )
275 {
276 m_defaultThickness = aWidth;
277 }
278
279 void SetLineWidthMM( double aWidth ) override { SetDefaultLineWidthMM( aWidth ); }
280
290 void SetOffset( double aOffsetX, double aOffsetY )
291 {
292 m_xOffset = aOffsetX;
293 m_yOffset = aOffsetY;
294 }
295
301 void SetBrdLayer( int aBrdLayer ) { m_brdLayer = aBrdLayer; }
302
308 bool ImportDxfFile( const wxString& aFile );
309
315 bool ImportDxfFile( const wxMemoryBuffer& aMemBuffer );
316
320 const wxString& GetMessages() const override
321 {
322 return m_messages;
323 }
324 // report message to keep trace of not supported dxf entities:
325 void ReportMsg( const wxString& aMessage ) override;
326
327private:
328
329 // coordinate conversions from dxf file to mm
330 double mapX( double aDxfCoordX );
331 double mapY( double aDxfCoordY );
332 double mapDim( double aDxfValue );
333 double lineWeightToWidth( int lw, DXF_IMPORT_LAYER* aLayer );
334 double getCurrentUnitScale();
335 wxString getDxfLayerName( const std::string& aLayerName ) const;
336
337 MATRIX3x3D getArbitraryAxis( DL_Extrusion* aData );
338
343 VECTOR3D wcsToOcs( const MATRIX3x3D& arbitraryAxis, VECTOR3D point );
344
349 VECTOR3D ocsToWcs( const MATRIX3x3D& arbitraryAxis, VECTOR3D point );
350
357 DXF_IMPORT_LAYER* getImportLayer( const std::string& aLayerName );
358
365 DXF_IMPORT_BLOCK* getImportBlock( const std::string& aBlockName );
366
373 DXF_IMPORT_STYLE* getImportStyle( const std::string& aStyleName );
374
375 // Functions to aid in the creation of a Polyline.
376 void insertLine( const VECTOR2D& aSegStart, const VECTOR2D& aSegEnd, double aWidth );
377 void insertArc( const VECTOR2D& aSegStart, const VECTOR2D& aSegEnd,
378 double aBulge, double aWidth );
379
380 // Add a dxf spline (stored in m_curr_entity) to the board, after conversion to segments.
381 void insertSpline( double aWidth );
382
383 // Methods from DL_CreationAdapter:
384 // They are something like"call back" functions,
385 // called when the corresponding object is read in dxf file
386
390 virtual void setVariableString( const std::string& key, const std::string& value,
391 int code ) override;
392
396 virtual void setVariableInt( const std::string& key, int value, int code ) override;
397
401 virtual void setVariableDouble( const std::string& key, double value, int code ) override {}
402
403 virtual void addLayer( const DL_LayerData& aData ) override;
404 virtual void addLine( const DL_LineData& aData ) override;
405 virtual void addLinetype( const DL_LinetypeData& data ) override;
406
414 virtual void addBlock( const DL_BlockData& ) override;
415 virtual void endBlock() override;
416 virtual void addTextStyle( const DL_StyleData& aData ) override;
417 virtual void addPoint( const DL_PointData& aData ) override;
418
419 virtual void addCircle( const DL_CircleData& aData ) override;
420 virtual void addArc( const DL_ArcData& aData ) override;
421 void addEllipse( const DL_EllipseData& aData ) override;
422 //virtual void addLWPolyline( const DRW_LWPolyline& aData ) override;
423 virtual void addText( const DL_TextData& aData ) override;
424 virtual void addPolyline( const DL_PolylineData& aData ) override;
425
426 /* Inserts blocks where specified by insert data */
427 virtual void addInsert( const DL_InsertData& aData ) override;
428
432 virtual void addVertex( const DL_VertexData& aData ) override;
433
434 virtual void addMTextChunk( const std::string& text ) override;
435 virtual void addMText( const DL_MTextData& aData ) override;
436
437 virtual void endEntity() override;
438
442 virtual void addSpline( const DL_SplineData& aData ) override;
443
447 virtual void addControlPoint( const DL_ControlPointData& aData ) override;
448
452 virtual void addFitPoint( const DL_FitPointData& aData ) override;
453
457 virtual void addKnot( const DL_KnotData& aData ) override;
458
459 // Not yet handled DXF entities:
460 virtual void addXLine( const DL_XLineData& ) override
461 {
462 ReportMsg( _( "DXF construction lines not currently supported." ) );
463 }
464
465 virtual void addRay( const DL_RayData& ) override
466 {
467 ReportMsg( _( "DXF construction lines not currently supported." ) );
468 }
469
470 virtual void addArcAlignedText( const DL_ArcAlignedTextData& ) override
471 {
472 ReportMsg( _( "DXF arc-aligned text not currently supported." ) );
473 }
474
475 virtual void addDimAlign( const DL_DimensionData&, const DL_DimAlignedData& ) override
476 {
477 ReportMsg( _( "DXF dimensions not currently supported." ) );
478 }
479
480 virtual void addDimLinear( const DL_DimensionData&, const DL_DimLinearData& ) override
481 {
482 ReportMsg( _( "DXF dimensions not currently supported." ) );
483 }
484
485 virtual void addDimRadial( const DL_DimensionData&, const DL_DimRadialData& ) override
486 {
487 ReportMsg( _( "DXF dimensions not currently supported." ) );
488 }
489
490 virtual void addDimDiametric( const DL_DimensionData&, const DL_DimDiametricData& ) override
491 {
492 ReportMsg( _( "DXF dimensions not currently supported." ) );
493 }
494
495 virtual void addDimAngular( const DL_DimensionData&, const DL_DimAngular2LData& ) override
496 {
497 ReportMsg( _( "DXF dimensions not currently supported." ) );
498 }
499
500 virtual void addDimAngular3P( const DL_DimensionData&, const DL_DimAngular3PData& ) override
501 {
502 ReportMsg( _( "DXF dimensions not currently supported." ) );
503 }
504
505 virtual void addDimOrdinate( const DL_DimensionData&, const DL_DimOrdinateData& ) override
506 {
507 ReportMsg( _( "DXF dimensions not currently supported." ) );
508 }
509
510 virtual void addLeader( const DL_LeaderData& ) override
511 {
512 ReportMsg( _( "DXF dimensions not currently supported." ) );
513 }
514 virtual void addLeaderVertex( const DL_LeaderVertexData& ) override { }
515
516 virtual void addHatch( const DL_HatchData& ) override
517 {
518 ReportMsg( _( "DXF hatches not currently supported." ) );
519 }
520
521 virtual void addHatchLoop( const DL_HatchLoopData& ) override { }
522 virtual void addHatchEdge( const DL_HatchEdgeData& ) override { }
523
524 virtual void addTrace( const DL_TraceData& ) override
525 {
526 ReportMsg( _( "DXF traces not currently supported." ) );
527 }
528
529 virtual void add3dFace( const DL_3dFaceData& ) override
530 {
531 ReportMsg( _( "DXF 3dfaces not currently supported." ) );
532 }
533
534 virtual void addSolid( const DL_SolidData& ) override
535 {
536 ReportMsg( _( "DXF solids not currently supported." ) );
537 }
538
539 virtual void addImage( const DL_ImageData& ) override
540 {
541 ReportMsg( _( "DXF images not currently supported." ) );
542 }
543 virtual void linkImage( const DL_ImageDefData& ) override {}
544
545 // Eat these silently
546 virtual void addAttribute( const DL_AttributeData& ) override { }
547 virtual void addXRecord( const std::string& ) override { }
548 virtual void addXRecordString( int, const std::string& ) override { }
549 virtual void addXRecordReal( int, double ) override { }
550 virtual void addXRecordInt( int, int ) override { }
551 virtual void addXRecordBool( int, bool ) override { }
552 virtual void addXDataApp( const std::string& ) override { }
553 virtual void addXDataString( int, const std::string& ) override { }
554 virtual void addXDataReal( int, double ) override { }
555 virtual void addXDataInt( int, int ) override { }
556
565 static wxString toDxfString( const wxString& aStr );
566
570 static wxString toNativeString( const wxString& aData );
571
572 void writeLine();
574
575private:
576 double m_xOffset; // X coord offset for conversion (in mm)
577 double m_yOffset; // Y coord offset for conversion (in mm)
578 double m_defaultThickness; // default line thickness for conversion (in mm)
579 int m_brdLayer; // The board layer to place imported DXF items
580 int m_version; // the dxf version, not used here
581 std::string m_codePage; // The code page, not used here
582 bool m_importAsFPShapes; // Use footprint items instead of board items when true.
583 // true when the items are imported in the footprint editor
584 wxString m_messages; // messages generated during dxf file parsing.
585 // Each message ends by '\n'
586 DXF2BRD_ENTITY_DATA m_curr_entity; // the current entity parameters when parsing a DXF entity
587
588 std::string m_mtextContent; // Contents of MText.
589
590 double m_minX, m_maxX; // handles image size in mm
591 double m_minY, m_maxY; // handles image size in mm
592
593 DXF_IMPORT_UNITS m_currentUnit; // current unit during import
594 int m_importCoordinatePrecision; // current precision for linear units (points)
595 int m_importAnglePrecision; // current precision for angles
596
598
599 // List of layers as we import, used just to grab props for objects.
600 std::vector<std::unique_ptr<DXF_IMPORT_LAYER>> m_layers;
601 std::vector<std::unique_ptr<DXF_IMPORT_BLOCK>> m_blocks; // List of blocks as we import
602 std::vector<std::unique_ptr<DXF_IMPORT_STYLE>> m_styles; // List of blocks as we import
604};
605
606#endif // DXF2BRD_ITEMS_H
BOX2< VECTOR2D > BOX2D
Definition box2.h:919
A base class for any item which can be embedded within the BOARD container class, and therefore insta...
Definition board_item.h:81
Information pertinent to a Pcbnew printed circuit board.
Definition board.h:372
A helper class to parse a DXF entity (polyline and spline)
unsigned int m_SplineDegree
std::vector< VECTOR2D > m_SplineFitPointList
unsigned int m_SplineFitCount
std::vector< SPLINE_CTRL_POINT > m_SplineControlPointList
unsigned int m_SplineKnotsCount
unsigned int m_SplineControlCount
std::vector< double > m_SplineKnotsList
A helper class to hold layer settings temporarily during import.
GRAPHICS_IMPORTER_BUFFER m_buffer
DXF_IMPORT_BLOCK(const wxString &aName, double aX, double aY)
A helper class to hold layer settings temporarily during import.
DXF_IMPORT_LAYER(const wxString &aName, int aLineWeight)
DXF_IMPORT_UNITS m_currentUnit
virtual void addXDataApp(const std::string &) override
virtual void addPolyline(const DL_PolylineData &aData) override
double mapY(double aDxfCoordY)
virtual void addImage(const DL_ImageData &) override
std::vector< std::unique_ptr< DXF_IMPORT_LAYER > > m_layers
void addEllipse(const DL_EllipseData &aData) override
static wxString toNativeString(const wxString &aData)
Convert a DXF encoded string into a native Unicode string.
virtual void addDimAngular(const DL_DimensionData &, const DL_DimAngular2LData &) override
virtual void addDimAngular3P(const DL_DimensionData &, const DL_DimAngular3PData &) override
virtual void addAttribute(const DL_AttributeData &) override
virtual void setVariableInt(const std::string &key, int value, int code) override
Called for every int variable in the DXF file (e.g.
bool LoadFromMemory(const wxMemoryBuffer &aMemBuffer) override
Set memory buffer with content for import.
void insertSpline(double aWidth)
virtual void linkImage(const DL_ImageDefData &) override
virtual void addLine(const DL_LineData &aData) override
virtual void addLeader(const DL_LeaderData &) override
VECTOR3D ocsToWcs(const MATRIX3x3D &arbitraryAxis, VECTOR3D point)
Convert a given object coordinate point to world coordinate using the given arbitrary axis vectors.
void insertLine(const VECTOR2D &aSegStart, const VECTOR2D &aSegEnd, double aWidth)
virtual void addXDataReal(int, double) override
DXF_IMPORT_BLOCK * getImportBlock(const std::string &aBlockName)
Return the import layer block.
virtual void addBlock(const DL_BlockData &) override
Called for each BLOCK in the DXF file.
virtual void addDimAlign(const DL_DimensionData &, const DL_DimAlignedData &) override
virtual void addRay(const DL_RayData &) override
virtual void addLayer(const DL_LayerData &aData) override
virtual void addCircle(const DL_CircleData &aData) override
virtual void addMText(const DL_MTextData &aData) override
DXF_IMPORT_LAYER * getImportLayer(const std::string &aLayerName)
Return the import layer data.
static wxString toDxfString(const wxString &aStr)
Convert a native Unicode string into a DXF encoded string.
virtual void addArcAlignedText(const DL_ArcAlignedTextData &) override
virtual void setVariableDouble(const std::string &key, double value, int code) override
Called for every double variable in the DXF file (e.g.
virtual void addTrace(const DL_TraceData &) override
virtual void addSolid(const DL_SolidData &) override
DXF_IMPORT_STYLE * getImportStyle(const std::string &aStyleName)
Return the import style.
virtual void addInsert(const DL_InsertData &aData) override
BOX2D GetImageBBox() const override
Return image bounding box from original imported file.
const wxString GetName() const override
Return the plugin name.
virtual void addLeaderVertex(const DL_LeaderVertexData &) override
virtual void addXRecordString(int, const std::string &) override
MATRIX3x3D getArbitraryAxis(DL_Extrusion *aData)
double GetImageWidth() const override
Return image width from original imported file.
virtual void addDimLinear(const DL_DimensionData &, const DL_DimLinearData &) override
double GetImageHeight() const override
Return image height from original imported file.
virtual void addXDataString(int, const std::string &) override
virtual void add3dFace(const DL_3dFaceData &) override
virtual void addHatch(const DL_HatchData &) override
void updateImageLimits(const VECTOR2D &aPoint)
virtual void addTextStyle(const DL_StyleData &aData) override
virtual void addXDataInt(int, int) override
virtual void addVertex(const DL_VertexData &aData) override
Called for every polyline vertex.
VECTOR3D wcsToOcs(const MATRIX3x3D &arbitraryAxis, VECTOR3D point)
Convert a given world coordinate point to object coordinate using the given arbitrary axis vectors.
virtual void addSpline(const DL_SplineData &aData) override
Called for every spline.
virtual void addText(const DL_TextData &aData) override
virtual void endBlock() override
virtual void setVariableString(const std::string &key, const std::string &value, int code) override
Called for every string variable in the DXF file (e.g.
virtual void addKnot(const DL_KnotData &aData) override
Called for every spline knot value.
virtual void addXRecordInt(int, int) override
bool ImportDxfFile(const wxString &aFile)
Implementation of the method used for communicate with this filter.
virtual void addArc(const DL_ArcData &aData) override
virtual void addXRecordReal(int, double) override
void SetLineWidthMM(double aWidth) override
void SetDefaultLineWidthMM(double aWidth)
Set the default line width when importing dxf items like lines to Pcbnew.
virtual void addFitPoint(const DL_FitPointData &aData) override
Called for every spline fit point.
virtual void addPoint(const DL_PointData &aData) override
void SetBrdLayer(int aBrdLayer)
Set the layer number to import dxf items.
double mapDim(double aDxfValue)
virtual void addDimOrdinate(const DL_DimensionData &, const DL_DimOrdinateData &) override
virtual void addDimDiametric(const DL_DimensionData &, const DL_DimDiametricData &) override
void ReportMsg(const wxString &aMessage) override
virtual void addXRecord(const std::string &) override
virtual void addHatchEdge(const DL_HatchEdgeData &) override
double mapX(double aDxfCoordX)
double lineWeightToWidth(int lw, DXF_IMPORT_LAYER *aLayer)
void insertArc(const VECTOR2D &aSegStart, const VECTOR2D &aSegEnd, double aBulge, double aWidth)
std::vector< std::unique_ptr< DXF_IMPORT_BLOCK > > m_blocks
virtual void addHatchLoop(const DL_HatchLoopData &) override
bool Import() override
Actually imports the file.
virtual void addMTextChunk(const std::string &text) override
virtual void endEntity() override
virtual void addControlPoint(const DL_ControlPointData &aData) override
Called for every spline control point.
std::vector< wxString > GetSourceLayers() const
GRAPHICS_IMPORTER_BUFFER m_internalImporter
virtual void addXRecordBool(int, bool) override
std::vector< std::unique_ptr< DXF_IMPORT_STYLE > > m_styles
bool Load(const wxString &aFileName) override
Load file for import.
const wxString & GetMessages() const override
virtual void addDimRadial(const DL_DimensionData &, const DL_DimRadialData &) override
void SetUnit(DXF_IMPORT_UNITS aUnit)
Set the default units when importing DXFs.
virtual void addXLine(const DL_XLineData &) override
DXF_IMPORT_BLOCK * m_currentBlock
DXF2BRD_ENTITY_DATA m_curr_entity
void ImportAsFootprintGraphic(bool aImportAsFootprintGraphic)
Allow the import DXF items converted to board graphic items or footprint graphic items.
wxString getDxfLayerName(const std::string &aLayerName) const
const std::vector< std::string > GetFileExtensions() const override
Return a vector of the file extensions handled by this plugin.
virtual void SetImporter(GRAPHICS_IMPORTER *aImporter) override
Set the receiver of the imported shapes.
void SetOffset(double aOffsetX, double aOffsetY)
Set the coordinate offset between the imported dxf items and Pcbnew.
virtual void addLinetype(const DL_LinetypeData &data) override
A helper class to hold style settings temporarily during import.
DXF_IMPORT_STYLE(const wxString &aName, double aTextHeight, double aWidthFactor, bool aBold, bool aItalic)
Interface that creates objects representing shapes for a given data model.
Interface for vector graphics import plugins.
DXF_IMPORT_UNITS
DXF Units enum with values as specified in DXF 2012 Specification.
#define _(s)
MATRIX3x3< double > MATRIX3x3D
Definition matrix3x3.h:469
@ INCH
Definition rs274x.cpp:58
SPLINE_CTRL_POINT(double a_x, double a_y, double a_weight)
static const long long MM
VECTOR2< double > VECTOR2D
Definition vector2d.h:682
VECTOR3< double > VECTOR3D
Definition vector3.h:230
Definition of file extensions used in Kicad.