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, you may find one here:
19 * http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
20 * or you may search the http://www.gnu.org website for the version 2 license,
21 * or you may write to the Free Software Foundation, Inc.,
22 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
23 */
24
25#ifndef DXF2BRD_ITEMS_H
26#define DXF2BRD_ITEMS_H
27
30#include "wx/translation.h"
31
32#include <dl_creationadapter.h>
33#include <dl_dxf.h>
34#include <math/vector3.h>
35#include <math/matrix3x3.h>
37
38#include <list>
39
40class BOARD;
41class BOARD_ITEM;
42
47{
48 double m_x;
49 double m_y;
50 double m_weight;
51
52 SPLINE_CTRL_POINT( double a_x, double a_y, double a_weight )
53 : m_x( a_x ), m_y( a_y ), m_weight( a_weight )
54 {}
55};
56
61{
62public:
64
65 // Reset the entity parameters
66 void Clear()
67 {
68 m_EntityType = DL_UNKNOWN;
70 m_EntityFlag = 0;
71 m_LayerName.clear();
80 m_BulgeVertex = 0.0;
81 m_SplineKnotsList.clear();
84 }
85
86 int m_EntityType; // the DXF type of entity
87 int m_EntityParseStatus; // Inside a entity: status of parsing:
88 // 0 = no entity
89 // 1 = first item of entity
90 // 2 = entity in progress
91 int m_EntityFlag; // a info flag to parse entities
92 //
93 wxString m_LayerName; // the source DXF layer for the current entity
94
95 VECTOR2D m_LastCoordinate; // the last vertex coordinate read (unit = mm)
96 VECTOR2D m_PolylineStart; // The first point of the polyline entity, when reading a
97 // polyline (unit = mm)
98 double m_BulgeVertex; // the last vertex bulge value read
99
100 // for spline parsing: parameters
101 unsigned int m_SplineDegree;
102 unsigned int m_SplineKnotsCount;
104 unsigned int m_SplineFitCount;
105 double m_SplineTangentStartX; // tangent dir X for the start point
106 double m_SplineTangentStartY; // tangent dir Y for the start point
107 double m_SplineTangentEndX; // tangent dir X for the end point
108 double m_SplineTangentEndY; // tangent dir Y for the end point
109
110 // for spline parsing: buffers to store control points, fit points and knot
111 std::vector<double> m_SplineKnotsList; // knots list, code 40
112 // control points list coordinates, code 10, 20 & 30 (only X and Y cood and Weight)
113 std::vector<SPLINE_CTRL_POINT> m_SplineControlPointList;
114 // fit points list, code 11, 21 & 31 (only X and Y cood)
115 std::vector<VECTOR2D> m_SplineFitPointList;
116};
117
118// Magic constants as defined by dxf specification for line weight
119#define DXF_IMPORT_LINEWEIGHT_BY_LAYER -1
120#define DXF_IMPORT_LINEWEIGHT_BY_BLOCK -2
121#define DXF_IMPORT_LINEWEIGHT_BY_LW_DEFAULT -3
122
127{
128public:
129 wxString m_layerName;
131
132 DXF_IMPORT_LAYER( const wxString& aName, int aLineWeight )
133 {
134 m_layerName = aName;
135 m_lineWeight = aLineWeight;
136 }
137};
138
143{
144public:
145 wxString m_name;
147
149
150 DXF_IMPORT_BLOCK( const wxString& aName, double aX, double aY )
151 {
152 m_name = aName;
153 m_baseX = aX;
154 m_baseY = aY;
155 }
156};
157
162{
163public:
164 wxString m_name;
167 bool m_bold;
169
170 DXF_IMPORT_STYLE( const wxString& aName, double aTextHeight, double aWidthFactor, bool aBold,
171 bool aItalic )
172 {
173 m_name = aName;
174 m_textHeight = aTextHeight;
175 m_widthFactor = aWidthFactor;
176 m_bold = aBold;
177 m_italic = aItalic;
178 }
179};
180
181
207
208
213#define ON_UNSUPPORTED( error_msg ) reportMessage( wxString::Format( _( "%s is not supported." ), \
214 error_msg ) )
215
216class DXF_IMPORT_PLUGIN : public GRAPHICS_IMPORT_PLUGIN, public DL_CreationAdapter
217{
218public:
221
222 const wxString GetName() const override
223 {
224 return "AutoCAD DXF";
225 }
226
227 const std::vector<std::string> GetFileExtensions() const override
228 {
229 static std::vector<std::string> exts = { "dxf" };
230 return exts;
231 }
232
233 bool Load( const wxString& aFileName ) override;
234 bool LoadFromMemory( const wxMemoryBuffer& aMemBuffer ) override;
235 bool Import() override;
236
237 double GetImageWidth() const override;
238 double GetImageHeight() const override;
239 BOX2D GetImageBBox() const override;
240
241 std::vector<wxString> GetSourceLayers() const { return m_internalImporter.GetSourceLayers(); }
242
243 void updateImageLimits( const VECTOR2D& aPoint );
244
245 virtual void SetImporter( GRAPHICS_IMPORTER* aImporter ) override;
246
253 void ImportAsFootprintGraphic( bool aImportAsFootprintGraphic )
254 {
255 m_importAsFPShapes = aImportAsFootprintGraphic;
256 }
257
266 {
267 m_currentUnit = aUnit;
268 }
269
278 void SetDefaultLineWidthMM( double aWidth )
279 {
280 m_defaultThickness = aWidth;
281 }
282
283 void SetLineWidthMM( double aWidth ) override { SetDefaultLineWidthMM( aWidth ); }
284
294 void SetOffset( double aOffsetX, double aOffsetY )
295 {
296 m_xOffset = aOffsetX;
297 m_yOffset = aOffsetY;
298 }
299
305 void SetBrdLayer( int aBrdLayer ) { m_brdLayer = aBrdLayer; }
306
312 bool ImportDxfFile( const wxString& aFile );
313
319 bool ImportDxfFile( const wxMemoryBuffer& aMemBuffer );
320
324 const wxString& GetMessages() const override
325 {
326 return m_messages;
327 }
328 // report message to keep trace of not supported dxf entities:
329 void ReportMsg( const wxString& aMessage ) override;
330
331private:
332
333 // coordinate conversions from dxf file to mm
334 double mapX( double aDxfCoordX );
335 double mapY( double aDxfCoordY );
336 double mapDim( double aDxfValue );
337 double lineWeightToWidth( int lw, DXF_IMPORT_LAYER* aLayer );
338 double getCurrentUnitScale();
339 wxString getDxfLayerName( const std::string& aLayerName ) const;
340
341 MATRIX3x3D getArbitraryAxis( DL_Extrusion* aData );
342
347 VECTOR3D wcsToOcs( const MATRIX3x3D& arbitraryAxis, VECTOR3D point );
348
353 VECTOR3D ocsToWcs( const MATRIX3x3D& arbitraryAxis, VECTOR3D point );
354
361 DXF_IMPORT_LAYER* getImportLayer( const std::string& aLayerName );
362
369 DXF_IMPORT_BLOCK* getImportBlock( const std::string& aBlockName );
370
377 DXF_IMPORT_STYLE* getImportStyle( const std::string& aStyleName );
378
379 // Functions to aid in the creation of a Polyline.
380 void insertLine( const VECTOR2D& aSegStart, const VECTOR2D& aSegEnd, double aWidth );
381 void insertArc( const VECTOR2D& aSegStart, const VECTOR2D& aSegEnd,
382 double aBulge, double aWidth );
383
384 // Add a dxf spline (stored in m_curr_entity) to the board, after conversion to segments.
385 void insertSpline( double aWidth );
386
387 // Methods from DL_CreationAdapter:
388 // They are something like"call back" functions,
389 // called when the corresponding object is read in dxf file
390
394 virtual void setVariableString( const std::string& key, const std::string& value,
395 int code ) override;
396
400 virtual void setVariableInt( const std::string& key, int value, int code ) override;
401
405 virtual void setVariableDouble( const std::string& key, double value, int code ) override {}
406
407 virtual void addLayer( const DL_LayerData& aData ) override;
408 virtual void addLine( const DL_LineData& aData ) override;
409 virtual void addLinetype( const DL_LinetypeData& data ) override;
410
418 virtual void addBlock( const DL_BlockData& ) override;
419 virtual void endBlock() override;
420 virtual void addTextStyle( const DL_StyleData& aData ) override;
421 virtual void addPoint( const DL_PointData& aData ) override;
422
423 virtual void addCircle( const DL_CircleData& aData ) override;
424 virtual void addArc( const DL_ArcData& aData ) override;
425 void addEllipse( const DL_EllipseData& aData ) override;
426 //virtual void addLWPolyline( const DRW_LWPolyline& aData ) override;
427 virtual void addText( const DL_TextData& aData ) override;
428 virtual void addPolyline( const DL_PolylineData& aData ) override;
429
430 /* Inserts blocks where specified by insert data */
431 virtual void addInsert( const DL_InsertData& aData ) override;
432
436 virtual void addVertex( const DL_VertexData& aData ) override;
437
438 virtual void addMTextChunk( const std::string& text ) override;
439 virtual void addMText( const DL_MTextData& aData ) override;
440
441 virtual void endEntity() override;
442
446 virtual void addSpline( const DL_SplineData& aData ) override;
447
451 virtual void addControlPoint( const DL_ControlPointData& aData ) override;
452
456 virtual void addFitPoint( const DL_FitPointData& aData ) override;
457
461 virtual void addKnot( const DL_KnotData& aData ) override;
462
463 // Not yet handled DXF entities:
464 virtual void addXLine( const DL_XLineData& ) override
465 {
466 ReportMsg( _( "DXF construction lines not currently supported." ) );
467 }
468
469 virtual void addRay( const DL_RayData& ) override
470 {
471 ReportMsg( _( "DXF construction lines not currently supported." ) );
472 }
473
474 virtual void addArcAlignedText( const DL_ArcAlignedTextData& ) override
475 {
476 ReportMsg( _( "DXF arc-aligned text not currently supported." ) );
477 }
478
479 virtual void addDimAlign( const DL_DimensionData&, const DL_DimAlignedData& ) override
480 {
481 ReportMsg( _( "DXF dimensions not currently supported." ) );
482 }
483
484 virtual void addDimLinear( const DL_DimensionData&, const DL_DimLinearData& ) override
485 {
486 ReportMsg( _( "DXF dimensions not currently supported." ) );
487 }
488
489 virtual void addDimRadial( const DL_DimensionData&, const DL_DimRadialData& ) override
490 {
491 ReportMsg( _( "DXF dimensions not currently supported." ) );
492 }
493
494 virtual void addDimDiametric( const DL_DimensionData&, const DL_DimDiametricData& ) override
495 {
496 ReportMsg( _( "DXF dimensions not currently supported." ) );
497 }
498
499 virtual void addDimAngular( const DL_DimensionData&, const DL_DimAngular2LData& ) override
500 {
501 ReportMsg( _( "DXF dimensions not currently supported." ) );
502 }
503
504 virtual void addDimAngular3P( const DL_DimensionData&, const DL_DimAngular3PData& ) override
505 {
506 ReportMsg( _( "DXF dimensions not currently supported." ) );
507 }
508
509 virtual void addDimOrdinate( const DL_DimensionData&, const DL_DimOrdinateData& ) override
510 {
511 ReportMsg( _( "DXF dimensions not currently supported." ) );
512 }
513
514 virtual void addLeader( const DL_LeaderData& ) override
515 {
516 ReportMsg( _( "DXF dimensions not currently supported." ) );
517 }
518 virtual void addLeaderVertex( const DL_LeaderVertexData& ) override { }
519
520 virtual void addHatch( const DL_HatchData& ) override
521 {
522 ReportMsg( _( "DXF hatches not currently supported." ) );
523 }
524
525 virtual void addHatchLoop( const DL_HatchLoopData& ) override { }
526 virtual void addHatchEdge( const DL_HatchEdgeData& ) override { }
527
528 virtual void addTrace( const DL_TraceData& ) override
529 {
530 ReportMsg( _( "DXF traces not currently supported." ) );
531 }
532
533 virtual void add3dFace( const DL_3dFaceData& ) override
534 {
535 ReportMsg( _( "DXF 3dfaces not currently supported." ) );
536 }
537
538 virtual void addSolid( const DL_SolidData& ) override
539 {
540 ReportMsg( _( "DXF solids not currently supported." ) );
541 }
542
543 virtual void addImage( const DL_ImageData& ) override
544 {
545 ReportMsg( _( "DXF images not currently supported." ) );
546 }
547 virtual void linkImage( const DL_ImageDefData& ) override {}
548
549 // Eat these silently
550 virtual void addAttribute( const DL_AttributeData& ) override { }
551 virtual void addXRecord( const std::string& ) override { }
552 virtual void addXRecordString( int, const std::string& ) override { }
553 virtual void addXRecordReal( int, double ) override { }
554 virtual void addXRecordInt( int, int ) override { }
555 virtual void addXRecordBool( int, bool ) override { }
556 virtual void addXDataApp( const std::string& ) override { }
557 virtual void addXDataString( int, const std::string& ) override { }
558 virtual void addXDataReal( int, double ) override { }
559 virtual void addXDataInt( int, int ) override { }
560
569 static wxString toDxfString( const wxString& aStr );
570
574 static wxString toNativeString( const wxString& aData );
575
576 void writeLine();
578
579private:
580 double m_xOffset; // X coord offset for conversion (in mm)
581 double m_yOffset; // Y coord offset for conversion (in mm)
582 double m_defaultThickness; // default line thickness for conversion (in mm)
583 int m_brdLayer; // The board layer to place imported DXF items
584 int m_version; // the dxf version, not used here
585 std::string m_codePage; // The code page, not used here
586 bool m_importAsFPShapes; // Use footprint items instead of board items when true.
587 // true when the items are imported in the footprint editor
588 wxString m_messages; // messages generated during dxf file parsing.
589 // Each message ends by '\n'
590 DXF2BRD_ENTITY_DATA m_curr_entity; // the current entity parameters when parsing a DXF entity
591
592 std::string m_mtextContent; // Contents of MText.
593
594 double m_minX, m_maxX; // handles image size in mm
595 double m_minY, m_maxY; // handles image size in mm
596
597 DXF_IMPORT_UNITS m_currentUnit; // current unit during import
598 int m_importCoordinatePrecision; // current precision for linear units (points)
599 int m_importAnglePrecision; // current precision for angles
600
602
603 // List of layers as we import, used just to grab props for objects.
604 std::vector<std::unique_ptr<DXF_IMPORT_LAYER>> m_layers;
605 std::vector<std::unique_ptr<DXF_IMPORT_BLOCK>> m_blocks; // List of blocks as we import
606 std::vector<std::unique_ptr<DXF_IMPORT_STYLE>> m_styles; // List of blocks as we import
608};
609
610#endif // DXF2BRD_ITEMS_H
BOX2< VECTOR2D > BOX2D
Definition box2.h:923
A base class for any item which can be embedded within the BOARD container class, and therefore insta...
Definition board_item.h:84
Information pertinent to a Pcbnew printed circuit board.
Definition board.h:323
A helper class to parse a DXF entity (polyline and spline)
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:473
@ INCH
Definition rs274x.cpp:62
SPLINE_CTRL_POINT(double a_x, double a_y, double a_weight)
static const long long MM
VECTOR2< double > VECTOR2D
Definition vector2d.h:686
VECTOR3< double > VECTOR3D
Definition vector3.h:230
Definition of file extensions used in Kicad.