Pcbnew: fix epic footprint editor DXF import fail.

The unfortunate combination of using static_cast to promote board items
to module items then using the assignment operator without any thought as
to what would happen in MODULE::Add() caused the board objects to not be
added to the module.  This is expected because board items cannot be in
modules.  Did this ever work or did someone have a colossal brain cramp?
If it did work, who ever changed it did not test it because in debug
builds, you would have gotten and assertion on every object imported.  On
release builds nothing is imported silently.

Add module object types to the DXF importer and code to choose which type
of object to import.

Remove offending static casts and assignment operator and pass the correct
object directly to the MODULE::Add() function when importing DXF in the
footprint editor.

The usual coding policy fixes.
This commit is contained in:
Wayne Stambaugh 2016-10-07 21:10:51 -04:00
parent abf33cce68
commit f14dc8f2be
4 changed files with 198 additions and 190 deletions

View File

@ -7,7 +7,7 @@
* This program source code file is part of KiCad, a free EDA CAD application. * This program source code file is part of KiCad, a free EDA CAD application.
* *
* Copyright (C) 2013 Jean-Pierre Charras, jp.charras at wanadoo.fr * Copyright (C) 2013 Jean-Pierre Charras, jp.charras at wanadoo.fr
* Copyright (C) 1992-2015 KiCad Developers, see AUTHORS.txt for contributors. * Copyright (C) 1992-2016 KiCad Developers, see AUTHORS.txt for contributors.
* *
* This program is free software; you can redistribute it and/or * This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License * modify it under the terms of the GNU General Public License
@ -39,12 +39,12 @@
#include <class_pcb_text.h> #include <class_pcb_text.h>
// Keys to store setup in config // Keys to store setup in config
#define DXF_IMPORT_LAYER_OPTION_KEY wxT("DxfImportBrdLayer") #define DXF_IMPORT_LAYER_OPTION_KEY "DxfImportBrdLayer"
#define DXF_IMPORT_COORD_ORIGIN_KEY wxT("DxfImportCoordOrigin") #define DXF_IMPORT_COORD_ORIGIN_KEY "DxfImportCoordOrigin"
#define DXF_IMPORT_LAST_FILE_KEY wxT("DxfImportLastFile") #define DXF_IMPORT_LAST_FILE_KEY "DxfImportLastFile"
#define DXF_IMPORT_GRID_UNITS_KEY wxT("DxfImportGridUnits") #define DXF_IMPORT_GRID_UNITS_KEY "DxfImportGridUnits"
#define DXF_IMPORT_GRID_OFFSET_X_KEY wxT("DxfImportGridOffsetX") #define DXF_IMPORT_GRID_OFFSET_X_KEY "DxfImportGridOffsetX"
#define DXF_IMPORT_GRID_OFFSET_Y_KEY wxT("DxfImportGridOffsetY") #define DXF_IMPORT_GRID_OFFSET_Y_KEY "DxfImportGridOffsetY"
// Static members of DIALOG_DXF_IMPORT, to remember // Static members of DIALOG_DXF_IMPORT, to remember
@ -54,10 +54,11 @@ int DIALOG_DXF_IMPORT::m_offsetSelection = 0;
LAYER_NUM DIALOG_DXF_IMPORT::m_layer = Dwgs_User; LAYER_NUM DIALOG_DXF_IMPORT::m_layer = Dwgs_User;
DIALOG_DXF_IMPORT::DIALOG_DXF_IMPORT( PCB_BASE_FRAME* aParent ) DIALOG_DXF_IMPORT::DIALOG_DXF_IMPORT( PCB_BASE_FRAME* aParent, bool aUseModuleItems )
: DIALOG_DXF_IMPORT_BASE( aParent ) : DIALOG_DXF_IMPORT_BASE( aParent )
{ {
m_parent = aParent; m_parent = aParent;
m_dxfImporter.UseModuleItems( aUseModuleItems );
m_config = Kiface().KifaceSettings(); m_config = Kiface().KifaceSettings();
m_PCBGridUnits = 0; m_PCBGridUnits = 0;
m_PCBGridOffsetX = 0.0; m_PCBGridOffsetX = 0.0;
@ -77,7 +78,7 @@ DIALOG_DXF_IMPORT::DIALOG_DXF_IMPORT( PCB_BASE_FRAME* aParent )
wxString tmpStr; wxString tmpStr;
tmpStr << m_PCBGridOffsetX; tmpStr << m_PCBGridOffsetX;
m_DXFPCBXCoord->SetValue( tmpStr ); m_DXFPCBXCoord->SetValue( tmpStr );
tmpStr = wxT( "" ); tmpStr = "";
tmpStr << m_PCBGridOffsetY; tmpStr << m_PCBGridOffsetY;
m_DXFPCBYCoord->SetValue( tmpStr ); m_DXFPCBYCoord->SetValue( tmpStr );
@ -136,7 +137,7 @@ void DIALOG_DXF_IMPORT::OnBrowseDxfFiles( wxCommandEvent& event )
wxFileDialog dlg( m_parent, wxFileDialog dlg( m_parent,
_( "Open File" ), _( "Open File" ),
path, filename, path, filename,
wxT( "DXF Files (*.dxf)|*.dxf" ), "DXF Files (*.dxf)|*.dxf",
wxFD_OPEN|wxFD_FILE_MUST_EXIST ); wxFD_OPEN|wxFD_FILE_MUST_EXIST );
if( dlg.ShowModal() != wxID_OK ) if( dlg.ShowModal() != wxID_OK )
@ -238,7 +239,7 @@ bool InvokeDXFDialogModuleImport( PCB_BASE_FRAME* aCaller, MODULE* aModule )
{ {
wxASSERT( aModule ); wxASSERT( aModule );
DIALOG_DXF_IMPORT dlg( aCaller ); DIALOG_DXF_IMPORT dlg( aCaller, true );
bool success = ( dlg.ShowModal() == wxID_OK ); bool success = ( dlg.ShowModal() == wxID_OK );
if( success ) if( success )
@ -252,35 +253,7 @@ bool InvokeDXFDialogModuleImport( PCB_BASE_FRAME* aCaller, MODULE* aModule )
for( it = list.begin(), itEnd = list.end(); it != itEnd; ++it ) for( it = list.begin(), itEnd = list.end(); it != itEnd; ++it )
{ {
BOARD_ITEM* item = *it; aModule->Add( *it );
BOARD_ITEM* converted = NULL;
// Modules use different types for the same things,
// so we need to convert imported items to appropriate classes.
switch( item->Type() )
{
case PCB_LINE_T:
{
converted = new EDGE_MODULE( aModule );
*static_cast<DRAWSEGMENT*>( converted ) = *static_cast<DRAWSEGMENT*>( item );
aModule->Add( converted );
delete item;
break;
}
case PCB_TEXT_T:
{
converted = new TEXTE_MODULE( aModule );
*static_cast<TEXTE_PCB*>( converted ) = *static_cast<TEXTE_PCB*>( item );
aModule->Add( converted );
delete item;
break;
}
default:
wxLogDebug( wxT( "type %d currently not handled" ), item->Type() );
break;
}
} }
} }
@ -303,6 +276,7 @@ int DIALOG_DXF_IMPORT::GetPCBGridUnits( void )
return m_DXFPCBGridUnits->GetSelection(); return m_DXFPCBGridUnits->GetSelection();
} }
void DIALOG_DXF_IMPORT::GetPCBGridOffsets( double &aXOffset, double &aYOffset ) void DIALOG_DXF_IMPORT::GetPCBGridOffsets( double &aXOffset, double &aYOffset )
{ {
aXOffset = DoubleValueFromString( UNSCALED_UNITS, m_DXFPCBXCoord->GetValue() ); aXOffset = DoubleValueFromString( UNSCALED_UNITS, m_DXFPCBXCoord->GetValue() );

View File

@ -2,7 +2,7 @@
* This program source code file is part of KiCad, a free EDA CAD application. * This program source code file is part of KiCad, a free EDA CAD application.
* *
* Copyright (C) 2013 Jean-Pierre Charras, jp.charras at wanadoo.fr * Copyright (C) 2013 Jean-Pierre Charras, jp.charras at wanadoo.fr
* Copyright (C) 1992-2013 KiCad Developers, see AUTHORS.txt for contributors. * Copyright (C) 1992-2016 KiCad Developers, see AUTHORS.txt for contributors.
* *
* This program is free software; you can redistribute it and/or * This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License * modify it under the terms of the GNU General Public License
@ -29,7 +29,7 @@
class DIALOG_DXF_IMPORT : public DIALOG_DXF_IMPORT_BASE class DIALOG_DXF_IMPORT : public DIALOG_DXF_IMPORT_BASE
{ {
public: public:
DIALOG_DXF_IMPORT( PCB_BASE_FRAME* aParent ); DIALOG_DXF_IMPORT( PCB_BASE_FRAME* aParent, bool aUseModuleItems = false );
~DIALOG_DXF_IMPORT(); ~DIALOG_DXF_IMPORT();
/** /**

View File

@ -2,7 +2,7 @@
* This program source code file is part of KiCad, a free EDA CAD application. * This program source code file is part of KiCad, a free EDA CAD application.
* *
* Copyright (C) 2013 Jean-Pierre Charras, jp.charras at wanadoo.fr * Copyright (C) 2013 Jean-Pierre Charras, jp.charras at wanadoo.fr
* Copyright (C) 1992-2013 KiCad Developers, see AUTHORS.txt for contributors. * Copyright (C) 1992-2016 KiCad Developers, see AUTHORS.txt for contributors.
* *
* This program is free software; you can redistribute it and/or * This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License * modify it under the terms of the GNU General Public License
@ -44,7 +44,9 @@
#include <macros.h> #include <macros.h>
#include <class_board.h> #include <class_board.h>
#include <class_drawsegment.h> #include <class_drawsegment.h>
#include <class_edge_mod.h>
#include <class_pcb_text.h> #include <class_pcb_text.h>
#include <class_text_mod.h>
#include <drw_base.h> #include <drw_base.h>
// minimum bulge value before resorting to a line segment; // minimum bulge value before resorting to a line segment;
@ -97,9 +99,6 @@ bool DXF2BRD_CONVERTER::ImportDxfFile( const wxString& aFile )
} }
/*
* Implementation of the method which handles layers.
*/
void DXF2BRD_CONVERTER::addLayer( const DRW_Layer& aData ) void DXF2BRD_CONVERTER::addLayer( const DRW_Layer& aData )
{ {
// Not yet useful in Pcbnew. // Not yet useful in Pcbnew.
@ -110,12 +109,10 @@ void DXF2BRD_CONVERTER::addLayer( const DRW_Layer& aData )
} }
/*
* Import line entities.
*/
void DXF2BRD_CONVERTER::addLine( const DRW_Line& aData ) void DXF2BRD_CONVERTER::addLine( const DRW_Line& aData )
{ {
DRAWSEGMENT* segm = new DRAWSEGMENT; DRAWSEGMENT* segm = ( m_useModuleItems ) ?
static_cast< DRAWSEGMENT* >( new EDGE_MODULE( NULL ) ) : new DRAWSEGMENT;
segm->SetLayer( ToLAYER_ID( m_brdLayer ) ); segm->SetLayer( ToLAYER_ID( m_brdLayer ) );
wxPoint start( mapX( aData.basePoint.x ), mapY( aData.basePoint.y ) ); wxPoint start( mapX( aData.basePoint.x ), mapY( aData.basePoint.y ) );
@ -147,7 +144,9 @@ void DXF2BRD_CONVERTER::addPolyline(const DRW_Polyline& aData )
continue; continue;
} }
DRAWSEGMENT* segm = new DRAWSEGMENT( NULL ); DRAWSEGMENT* segm = ( m_useModuleItems ) ?
static_cast< DRAWSEGMENT* >( new EDGE_MODULE( NULL ) ) :
new DRAWSEGMENT;
segm->SetLayer( ToLAYER_ID( m_brdLayer ) ); segm->SetLayer( ToLAYER_ID( m_brdLayer ) );
segm->SetStart( segment_startpoint ); segm->SetStart( segment_startpoint );
@ -162,7 +161,9 @@ void DXF2BRD_CONVERTER::addPolyline(const DRW_Polyline& aData )
// Polyline flags bit 0 indicates closed (1) or open (0) polyline // Polyline flags bit 0 indicates closed (1) or open (0) polyline
if( aData.flags & 1 ) if( aData.flags & 1 )
{ {
DRAWSEGMENT* closing_segm = new DRAWSEGMENT( NULL ); DRAWSEGMENT* closing_segm = ( m_useModuleItems ) ?
static_cast< DRAWSEGMENT* >( new EDGE_MODULE( NULL ) ) :
new DRAWSEGMENT;
closing_segm->SetLayer( ToLAYER_ID( m_brdLayer ) ); closing_segm->SetLayer( ToLAYER_ID( m_brdLayer ) );
closing_segm->SetStart( segment_startpoint ); closing_segm->SetStart( segment_startpoint );
@ -173,6 +174,7 @@ void DXF2BRD_CONVERTER::addPolyline(const DRW_Polyline& aData )
} }
} }
void DXF2BRD_CONVERTER::addLWPolyline(const DRW_LWPolyline& aData ) void DXF2BRD_CONVERTER::addLWPolyline(const DRW_LWPolyline& aData )
{ {
// Currently, Pcbnew does not know polylines, for boards. // Currently, Pcbnew does not know polylines, for boards.
@ -220,12 +222,11 @@ void DXF2BRD_CONVERTER::addLWPolyline(const DRW_LWPolyline& aData )
} }
} }
/*
* Import Circle entities.
*/
void DXF2BRD_CONVERTER::addCircle( const DRW_Circle& aData ) void DXF2BRD_CONVERTER::addCircle( const DRW_Circle& aData )
{ {
DRAWSEGMENT* segm = new DRAWSEGMENT; DRAWSEGMENT* segm = ( m_useModuleItems ) ?
static_cast< DRAWSEGMENT* >( new EDGE_MODULE( NULL ) ) : new DRAWSEGMENT;
segm->SetLayer( ToLAYER_ID( m_brdLayer ) ); segm->SetLayer( ToLAYER_ID( m_brdLayer ) );
segm->SetShape( S_CIRCLE ); segm->SetShape( S_CIRCLE );
@ -243,7 +244,8 @@ void DXF2BRD_CONVERTER::addCircle( const DRW_Circle& aData )
*/ */
void DXF2BRD_CONVERTER::addArc( const DRW_Arc& data ) void DXF2BRD_CONVERTER::addArc( const DRW_Arc& data )
{ {
DRAWSEGMENT* segm = new DRAWSEGMENT; DRAWSEGMENT* segm = ( m_useModuleItems ) ?
static_cast< DRAWSEGMENT* >( new EDGE_MODULE( NULL ) ) : new DRAWSEGMENT;
segm->SetLayer( ToLAYER_ID( m_brdLayer ) ); segm->SetLayer( ToLAYER_ID( m_brdLayer ) );
segm->SetShape( S_ARC ); segm->SetShape( S_ARC );
@ -275,13 +277,26 @@ void DXF2BRD_CONVERTER::addArc( const DRW_Arc& data )
m_newItemsList.push_back( segm ); m_newItemsList.push_back( segm );
} }
/**
* Import texts (TEXT).
*/
void DXF2BRD_CONVERTER::addText( const DRW_Text& aData ) void DXF2BRD_CONVERTER::addText( const DRW_Text& aData )
{ {
TEXTE_PCB* pcb_text = new TEXTE_PCB( NULL ); BOARD_ITEM* brdItem;
pcb_text->SetLayer( ToLAYER_ID( m_brdLayer ) ); EDA_TEXT* textItem;
if( m_useModuleItems )
{
TEXTE_MODULE* modText = new TEXTE_MODULE( NULL );
brdItem = static_cast< BOARD_ITEM* >( modText );
textItem = static_cast< EDA_TEXT* >( modText );
}
else
{
TEXTE_PCB* pcbText = new TEXTE_PCB( NULL );
brdItem = static_cast< BOARD_ITEM* >( pcbText );
textItem = static_cast< EDA_TEXT* >( pcbText );
}
brdItem->SetLayer( ToLAYER_ID( m_brdLayer ) );
wxPoint refPoint( mapX( aData.basePoint.x ), mapY( aData.basePoint.y ) ); wxPoint refPoint( mapX( aData.basePoint.x ), mapY( aData.basePoint.y ) );
wxPoint secPoint( mapX( aData.secPoint.x ), mapY( aData.secPoint.y ) ); wxPoint secPoint( mapX( aData.secPoint.x ), mapY( aData.secPoint.y ) );
@ -298,63 +313,63 @@ void DXF2BRD_CONVERTER::addText( const DRW_Text& aData )
switch( aData.alignV ) switch( aData.alignV )
{ {
case DRW_Text::VBaseLine: case DRW_Text::VBaseLine:
pcb_text->SetVertJustify( GR_TEXT_VJUSTIFY_BOTTOM ); textItem->SetVertJustify( GR_TEXT_VJUSTIFY_BOTTOM );
break; break;
case DRW_Text::VBottom: case DRW_Text::VBottom:
pcb_text->SetVertJustify( GR_TEXT_VJUSTIFY_BOTTOM ); textItem->SetVertJustify( GR_TEXT_VJUSTIFY_BOTTOM );
break; break;
case DRW_Text::VMiddle: case DRW_Text::VMiddle:
pcb_text->SetVertJustify( GR_TEXT_VJUSTIFY_CENTER ); textItem->SetVertJustify( GR_TEXT_VJUSTIFY_CENTER );
break; break;
case DRW_Text::VTop: case DRW_Text::VTop:
pcb_text->SetVertJustify( GR_TEXT_VJUSTIFY_TOP ); textItem->SetVertJustify( GR_TEXT_VJUSTIFY_TOP );
break; break;
} }
switch( aData.alignH ) switch( aData.alignH )
{ {
case DRW_Text::HLeft: case DRW_Text::HLeft:
pcb_text->SetHorizJustify( GR_TEXT_HJUSTIFY_LEFT ); textItem->SetHorizJustify( GR_TEXT_HJUSTIFY_LEFT );
break; break;
case DRW_Text::HCenter: case DRW_Text::HCenter:
pcb_text->SetHorizJustify( GR_TEXT_HJUSTIFY_CENTER ); textItem->SetHorizJustify( GR_TEXT_HJUSTIFY_CENTER );
break; break;
case DRW_Text::HRight: case DRW_Text::HRight:
pcb_text->SetHorizJustify( GR_TEXT_HJUSTIFY_RIGHT ); textItem->SetHorizJustify( GR_TEXT_HJUSTIFY_RIGHT );
break; break;
case DRW_Text::HAligned: case DRW_Text::HAligned:
// no equivalent options in text pcb. // no equivalent options in text pcb.
pcb_text->SetHorizJustify( GR_TEXT_HJUSTIFY_LEFT ); textItem->SetHorizJustify( GR_TEXT_HJUSTIFY_LEFT );
break; break;
case DRW_Text::HMiddle: case DRW_Text::HMiddle:
// no equivalent options in text pcb. // no equivalent options in text pcb.
pcb_text->SetHorizJustify( GR_TEXT_HJUSTIFY_CENTER ); textItem->SetHorizJustify( GR_TEXT_HJUSTIFY_CENTER );
break; break;
case DRW_Text::HFit: case DRW_Text::HFit:
// no equivalent options in text pcb. // no equivalent options in text pcb.
pcb_text->SetHorizJustify( GR_TEXT_HJUSTIFY_LEFT ); textItem->SetHorizJustify( GR_TEXT_HJUSTIFY_LEFT );
break; break;
} }
#if 0 #if 0
wxString sty = wxString::FromUTF8(aData.style.c_str()); wxString sty = wxString::FromUTF8( aData.style.c_str() );
sty=sty.ToLower(); sty = sty.ToLower();
if (aData.textgen==2) if( aData.textgen == 2 )
{ {
// Text dir = left to right; // Text dir = left to right;
} else if (aData.textgen==4) } else if( aData.textgen == 4 )
{ {
/ Text dir = top to bottom; // Text dir = top to bottom;
} else } else
{ {
} }
@ -362,21 +377,19 @@ void DXF2BRD_CONVERTER::addText( const DRW_Text& aData )
wxString text = toNativeString( wxString::FromUTF8( aData.text.c_str() ) ); wxString text = toNativeString( wxString::FromUTF8( aData.text.c_str() ) );
pcb_text->SetTextPosition( refPoint ); textItem->SetTextPosition( refPoint );
pcb_text->SetOrientation( aData.angle * 10 ); textItem->SetOrientation( aData.angle * 10 );
// The 0.8 factor gives a better height/width ratio with our font
pcb_text->SetWidth( mapDim( aData.height * 0.8 ) );
pcb_text->SetHeight( mapDim( aData.height ) );
pcb_text->SetThickness( mapDim( aData.thickness == 0 ? m_defaultThickness : aData.thickness ) );
pcb_text->SetText( text );
m_newItemsList.push_back( pcb_text ); // The 0.8 factor gives a better height/width ratio with our font
textItem->SetWidth( mapDim( aData.height * 0.8 ) );
textItem->SetHeight( mapDim( aData.height ) );
textItem->SetThickness( mapDim( aData.thickness == 0 ? m_defaultThickness : aData.thickness ) );
textItem->SetText( text );
m_newItemsList.push_back( static_cast< BOARD_ITEM* >( brdItem ) );
} }
/**
* Import multi line texts (MTEXT).
*/
void DXF2BRD_CONVERTER::addMText( const DRW_MText& aData ) void DXF2BRD_CONVERTER::addMText( const DRW_MText& aData )
{ {
wxString text = toNativeString( wxString::FromUTF8( aData.text.c_str() ) ); wxString text = toNativeString( wxString::FromUTF8( aData.text.c_str() ) );
@ -407,46 +420,63 @@ void DXF2BRD_CONVERTER::addMText( const DRW_MText& aData )
text = tmp; text = tmp;
} }
TEXTE_PCB* pcb_text = new TEXTE_PCB( NULL ); BOARD_ITEM* brdItem;
pcb_text->SetLayer( ToLAYER_ID( m_brdLayer ) ); EDA_TEXT* textItem;
if( m_useModuleItems )
{
TEXTE_MODULE* modText = new TEXTE_MODULE( NULL );
brdItem = static_cast< BOARD_ITEM* >( modText );
textItem = static_cast< EDA_TEXT* >( modText );
}
else
{
TEXTE_PCB* pcbText = new TEXTE_PCB( NULL );
brdItem = static_cast< BOARD_ITEM* >( pcbText );
textItem = static_cast< EDA_TEXT* >( pcbText );
}
brdItem->SetLayer( ToLAYER_ID( m_brdLayer ) );
wxPoint textpos( mapX( aData.basePoint.x ), mapY( aData.basePoint.y ) ); wxPoint textpos( mapX( aData.basePoint.x ), mapY( aData.basePoint.y ) );
pcb_text->SetTextPosition( textpos );
pcb_text->SetOrientation( aData.angle * 10 ); textItem->SetTextPosition( textpos );
textItem->SetOrientation( aData.angle * 10 );
// The 0.8 factor gives a better height/width ratio with our font // The 0.8 factor gives a better height/width ratio with our font
pcb_text->SetWidth( mapDim( aData.height * 0.8 ) ); textItem->SetWidth( mapDim( aData.height * 0.8 ) );
pcb_text->SetHeight( mapDim( aData.height ) ); textItem->SetHeight( mapDim( aData.height ) );
pcb_text->SetThickness( mapDim( aData.thickness == 0 ? m_defaultThickness : aData.thickness ) ); textItem->SetThickness( mapDim( aData.thickness == 0 ? m_defaultThickness : aData.thickness ) );
pcb_text->SetText( text ); textItem->SetText( text );
// Initialize text justifications: // Initialize text justifications:
if( aData.textgen <= 3 ) if( aData.textgen <= 3 )
{ {
pcb_text->SetVertJustify( GR_TEXT_VJUSTIFY_TOP ); textItem->SetVertJustify( GR_TEXT_VJUSTIFY_TOP );
} }
else if( aData.textgen <= 6 ) else if( aData.textgen <= 6 )
{ {
pcb_text->SetVertJustify( GR_TEXT_VJUSTIFY_CENTER ); textItem->SetVertJustify( GR_TEXT_VJUSTIFY_CENTER );
} }
else else
{ {
pcb_text->SetVertJustify( GR_TEXT_VJUSTIFY_BOTTOM ); textItem->SetVertJustify( GR_TEXT_VJUSTIFY_BOTTOM );
} }
if( aData.textgen % 3 == 1 ) if( aData.textgen % 3 == 1 )
{ {
pcb_text->SetHorizJustify( GR_TEXT_HJUSTIFY_LEFT ); textItem->SetHorizJustify( GR_TEXT_HJUSTIFY_LEFT );
} }
else if( aData.textgen % 3 == 2 ) else if( aData.textgen % 3 == 2 )
{ {
pcb_text->SetHorizJustify( GR_TEXT_HJUSTIFY_CENTER ); textItem->SetHorizJustify( GR_TEXT_HJUSTIFY_CENTER );
} }
else else
{ {
pcb_text->SetHorizJustify( GR_TEXT_HJUSTIFY_RIGHT ); textItem->SetHorizJustify( GR_TEXT_HJUSTIFY_RIGHT );
} }
#if 0 // These setting have no mening in Pcbnew #if 0 // These setting have no mening in Pcbnew
if( data.alignH==1 ) if( data.alignH == 1 )
{ {
// Text is left to right; // Text is left to right;
} }
@ -459,7 +489,7 @@ void DXF2BRD_CONVERTER::addMText( const DRW_MText& aData )
// use ByStyle; // use ByStyle;
} }
if( aData.alignV==1 ) if( aData.alignV == 1 )
{ {
// use AtLeast; // use AtLeast;
} }
@ -469,13 +499,10 @@ void DXF2BRD_CONVERTER::addMText( const DRW_MText& aData )
} }
#endif #endif
m_newItemsList.push_back( pcb_text ); m_newItemsList.push_back( static_cast< BOARD_ITEM* >( brdItem ) );
} }
/**
* Sets the header variables from the DXF file.
*/
void DXF2BRD_CONVERTER::addHeader( const DRW_Header* data ) void DXF2BRD_CONVERTER::addHeader( const DRW_Header* data )
{ {
std::map<std::string, DRW_Variant*>::const_iterator it; std::map<std::string, DRW_Variant*>::const_iterator it;
@ -496,77 +523,69 @@ void DXF2BRD_CONVERTER::addHeader( const DRW_Header* data )
switch( var->content.i ) switch( var->content.i )
{ {
case 1: // inches case 1: // inches
m_DXF2mm = 25.4; m_DXF2mm = 25.4;
break; break;
case 2: // feet case 2: // feet
m_DXF2mm = 304.8; m_DXF2mm = 304.8;
break; break;
case 5: // centimeters case 5: // centimeters
m_DXF2mm = 10.0; m_DXF2mm = 10.0;
break; break;
case 6: // meters case 6: // meters
m_DXF2mm = 1000.0; m_DXF2mm = 1000.0;
break; break;
case 8: // microinches case 8: // microinches
m_DXF2mm = 2.54e-5; m_DXF2mm = 2.54e-5;
break; break;
case 9: // mils case 9: // mils
m_DXF2mm = 0.0254; m_DXF2mm = 0.0254;
break; break;
case 10: // yards case 10: // yards
m_DXF2mm = 914.4; m_DXF2mm = 914.4;
break; break;
case 11: // Angstroms case 11: // Angstroms
m_DXF2mm = 1.0e-7; m_DXF2mm = 1.0e-7;
break; break;
case 12: // nanometers case 12: // nanometers
m_DXF2mm = 1.0e-6; m_DXF2mm = 1.0e-6;
break; break;
case 13: // micrometers case 13: // micrometers
m_DXF2mm = 1.0e-3; m_DXF2mm = 1.0e-3;
break; break;
case 14: // decimeters case 14: // decimeters
m_DXF2mm = 100.0; m_DXF2mm = 100.0;
break; break;
default: default:
// use the default of 1.0 for: // use the default of 1.0 for:
// 0: Unspecified Units // 0: Unspecified Units
// 4: mm // 4: mm
// 3: miles // 3: miles
// 7: kilometers // 7: kilometers
// 15: decameters // 15: decameters
// 16: hectometers // 16: hectometers
// 17: gigameters // 17: gigameters
// 18: AU // 18: AU
// 19: lightyears // 19: lightyears
// 20: parsecs // 20: parsecs
break; break;
} }
} }
} }
} }
/**
* Converts a native unicode string into a DXF encoded string.
*
* DXF endoding includes the following special sequences:
* - %%%c for a diameter sign
* - %%%d for a degree sign
* - %%%p for a plus/minus sign
*/
wxString DXF2BRD_CONVERTER::toDxfString( const wxString& aStr ) wxString DXF2BRD_CONVERTER::toDxfString( const wxString& aStr )
{ {
wxString res; wxString res;
@ -621,9 +640,6 @@ wxString DXF2BRD_CONVERTER::toDxfString( const wxString& aStr )
} }
/**
* Converts a DXF encoded string into a native Unicode string.
*/
wxString DXF2BRD_CONVERTER::toNativeString( const wxString& aData ) wxString DXF2BRD_CONVERTER::toNativeString( const wxString& aData )
{ {
wxString res; wxString res;
@ -707,7 +723,8 @@ void DXF2BRD_CONVERTER::addTextStyle( const DRW_Textstyle& aData )
void DXF2BRD_CONVERTER::insertLine( const wxRealPoint& aSegStart, void DXF2BRD_CONVERTER::insertLine( const wxRealPoint& aSegStart,
const wxRealPoint& aSegEnd, int aWidth ) const wxRealPoint& aSegEnd, int aWidth )
{ {
DRAWSEGMENT* segm = new DRAWSEGMENT( NULL ); DRAWSEGMENT* segm = ( m_useModuleItems ) ?
static_cast< DRAWSEGMENT* >( new EDGE_MODULE( NULL ) ) : new DRAWSEGMENT;
wxPoint segment_startpoint( Millimeter2iu( aSegStart.x ), Millimeter2iu( aSegStart.y ) ); wxPoint segment_startpoint( Millimeter2iu( aSegStart.x ), Millimeter2iu( aSegStart.y ) );
wxPoint segment_endpoint( Millimeter2iu( aSegEnd.x ), Millimeter2iu( aSegEnd.y ) ); wxPoint segment_endpoint( Millimeter2iu( aSegEnd.x ), Millimeter2iu( aSegEnd.y ) );
@ -724,7 +741,8 @@ void DXF2BRD_CONVERTER::insertLine( const wxRealPoint& aSegStart,
void DXF2BRD_CONVERTER::insertArc( const wxRealPoint& aSegStart, const wxRealPoint& aSegEnd, void DXF2BRD_CONVERTER::insertArc( const wxRealPoint& aSegStart, const wxRealPoint& aSegEnd,
double aBulge, int aWidth ) double aBulge, int aWidth )
{ {
DRAWSEGMENT* segm = new DRAWSEGMENT( NULL ); DRAWSEGMENT* segm = ( m_useModuleItems ) ?
static_cast< DRAWSEGMENT* >( new EDGE_MODULE( NULL ) ) : new DRAWSEGMENT;
wxPoint segment_startpoint( Millimeter2iu( aSegStart.x ), Millimeter2iu( aSegStart.y ) ); wxPoint segment_startpoint( Millimeter2iu( aSegStart.x ), Millimeter2iu( aSegStart.y ) );
wxPoint segment_endpoint( Millimeter2iu( aSegEnd.x ), Millimeter2iu( aSegEnd.y ) ); wxPoint segment_endpoint( Millimeter2iu( aSegEnd.x ), Millimeter2iu( aSegEnd.y ) );

View File

@ -50,11 +50,15 @@ private:
int m_brdLayer; // The board layer to place imported DXF items int m_brdLayer; // The board layer to place imported DXF items
int m_version; // the dxf version, not used here int m_version; // the dxf version, not used here
std::string m_codePage; // The code page, not used here std::string m_codePage; // The code page, not used here
bool m_useModuleItems; // Use module items instead of board items when true.
public: public:
DXF2BRD_CONVERTER(); DXF2BRD_CONVERTER();
~DXF2BRD_CONVERTER(); ~DXF2BRD_CONVERTER();
bool IsUsingModuleItems() const { return m_useModuleItems; }
void UseModuleItems( bool aUseModuleItems = true ) { m_useModuleItems = aUseModuleItems; }
/** /**
* Set the coordinate offset between the importede dxf items * Set the coordinate offset between the importede dxf items
* and Pcbnew. * and Pcbnew.
@ -151,7 +155,19 @@ private:
virtual void setBlock( const int aHandle ) override {} virtual void setBlock( const int aHandle ) override {}
/**
* Converts a native unicode string into a DXF encoded string.
*
* DXF endoding includes the following special sequences:
* - %%%c for a diameter sign
* - %%%d for a degree sign
* - %%%p for a plus/minus sign
*/
static wxString toDxfString( const wxString& aStr ); static wxString toDxfString( const wxString& aStr );
/**
* Converts a DXF encoded string into a native Unicode string.
*/
static wxString toNativeString( const wxString& aData ); static wxString toNativeString( const wxString& aData );
// These functions are not used in Kicad. // These functions are not used in Kicad.