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:
parent
abf33cce68
commit
f14dc8f2be
|
@ -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() );
|
||||||
|
|
|
@ -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();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -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 ) );
|
||||||
|
|
|
@ -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.
|
||||||
|
|
Loading…
Reference in New Issue