Improvements to Eagle dimension importing.
1) Import leaders 2) Drop radius and angle dimensions 3) Import dimension text sizes 4) Correctly interpret which side dimension offset is on 5) Correclty handle offsets for non-cardinal dimensions Fixes https://gitlab.com/kicad/code/kicad/issues/10763
This commit is contained in:
parent
392ed5fecd
commit
739f4d0a1e
|
@ -538,19 +538,21 @@ EDIMENSION::EDIMENSION( wxXmlNode* aDimension )
|
||||||
y2 %Coord; #REQUIRED
|
y2 %Coord; #REQUIRED
|
||||||
x3 %Coord; #REQUIRED
|
x3 %Coord; #REQUIRED
|
||||||
y3 %Coord; #REQUIRED
|
y3 %Coord; #REQUIRED
|
||||||
|
textsize %Coord;
|
||||||
layer %Layer; #REQUIRED
|
layer %Layer; #REQUIRED
|
||||||
dtype %DimensionType; "parallel"
|
dtype %DimensionType; "parallel"
|
||||||
>
|
>
|
||||||
*/
|
*/
|
||||||
|
|
||||||
x1 = parseRequiredAttribute<ECOORD>( aDimension, "x1" );
|
x1 = parseRequiredAttribute<ECOORD>( aDimension, wxT( "x1" ) );
|
||||||
y1 = parseRequiredAttribute<ECOORD>( aDimension, "y1" );
|
y1 = parseRequiredAttribute<ECOORD>( aDimension, wxT( "y1" ) );
|
||||||
x2 = parseRequiredAttribute<ECOORD>( aDimension, "x2" );
|
x2 = parseRequiredAttribute<ECOORD>( aDimension, wxT( "x2" ) );
|
||||||
y2 = parseRequiredAttribute<ECOORD>( aDimension, "y2" );
|
y2 = parseRequiredAttribute<ECOORD>( aDimension, wxT( "y2" ) );
|
||||||
x3 = parseRequiredAttribute<ECOORD>( aDimension, "x3" );
|
x3 = parseRequiredAttribute<ECOORD>( aDimension, wxT( "x3" ) );
|
||||||
y3 = parseRequiredAttribute<ECOORD>( aDimension, "y3" );
|
y3 = parseRequiredAttribute<ECOORD>( aDimension, wxT( "y3" ) );
|
||||||
layer = parseRequiredAttribute<int>( aDimension, "layer" );
|
textsize = parseOptionalAttribute<ECOORD>( aDimension, wxT( "textsize" ) );
|
||||||
dimensionType = parseOptionalAttribute<wxString>( aDimension, "dtype" );
|
layer = parseRequiredAttribute<int>( aDimension, wxT( "layer" ) );
|
||||||
|
dimensionType = parseOptionalAttribute<wxString>( aDimension, wxT( "dtype" ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -623,8 +623,8 @@ struct EDIMENSION
|
||||||
ECOORD y2;
|
ECOORD y2;
|
||||||
ECOORD x3;
|
ECOORD x3;
|
||||||
ECOORD y3;
|
ECOORD y3;
|
||||||
|
opt_ecoord textsize;
|
||||||
int layer;
|
int layer;
|
||||||
|
|
||||||
opt_wxString dimensionType;
|
opt_wxString dimensionType;
|
||||||
|
|
||||||
EDIMENSION( wxXmlNode* aDimension );
|
EDIMENSION( wxXmlNode* aDimension );
|
||||||
|
|
|
@ -1006,12 +1006,50 @@ void EAGLE_PLUGIN::loadPlain( wxXmlNode* aGraphics )
|
||||||
}
|
}
|
||||||
else if( grName == wxT( "dimension" ) )
|
else if( grName == wxT( "dimension" ) )
|
||||||
{
|
{
|
||||||
|
const BOARD_DESIGN_SETTINGS& designSettings = m_board->GetDesignSettings();
|
||||||
|
|
||||||
EDIMENSION d( gr );
|
EDIMENSION d( gr );
|
||||||
PCB_LAYER_ID layer = kicad_layer( d.layer );
|
PCB_LAYER_ID layer = kicad_layer( d.layer );
|
||||||
|
VECTOR2I pt1( kicad_x( d.x1 ), kicad_y( d.y1 ) );
|
||||||
|
VECTOR2I pt2( kicad_x( d.x2 ), kicad_y( d.y2 ) );
|
||||||
|
VECTOR2I pt3( kicad_x( d.x3 ), kicad_y( d.y3 ) );
|
||||||
|
wxSize textSize = designSettings.GetTextSize( layer );
|
||||||
|
int textThickness = designSettings.GetLineThickness( layer );
|
||||||
|
|
||||||
|
if( d.textsize )
|
||||||
|
{
|
||||||
|
double ratio = 8; // DTD says 8 is default
|
||||||
|
textThickness = KiROUND( d.textsize->ToPcbUnits() * ratio / 100 );
|
||||||
|
textSize = kicad_fontz( *d.textsize, textThickness );
|
||||||
|
}
|
||||||
|
|
||||||
if( layer != UNDEFINED_LAYER )
|
if( layer != UNDEFINED_LAYER )
|
||||||
{
|
{
|
||||||
const BOARD_DESIGN_SETTINGS& designSettings = m_board->GetDesignSettings();
|
if( d.dimensionType == wxT( "angle" ) )
|
||||||
|
{
|
||||||
|
// Kicad doesn't (at present) support angle dimensions
|
||||||
|
}
|
||||||
|
else if( d.dimensionType == wxT( "radius" ) )
|
||||||
|
{
|
||||||
|
// Radial dimensions added in 7.0....
|
||||||
|
}
|
||||||
|
else if( d.dimensionType == wxT( "leader" ) )
|
||||||
|
{
|
||||||
|
PCB_DIM_LEADER* leader = new PCB_DIM_LEADER( m_board );
|
||||||
|
m_board->Add( leader, ADD_MODE::APPEND );
|
||||||
|
|
||||||
|
leader->SetLayer( layer );
|
||||||
|
leader->SetPrecision( DIMENSION_PRECISION );
|
||||||
|
|
||||||
|
leader->SetStart( (wxPoint) pt1 );
|
||||||
|
leader->SetEnd( (wxPoint) pt2 );
|
||||||
|
leader->Text().SetPosition( (wxPoint) pt3 );
|
||||||
|
leader->Text().SetTextSize( textSize );
|
||||||
|
leader->Text().SetTextThickness( textThickness );
|
||||||
|
leader->SetLineThickness( designSettings.GetLineThickness( layer ) );
|
||||||
|
}
|
||||||
|
else // horizontal, vertical, <default>, diameter
|
||||||
|
{
|
||||||
PCB_DIM_ALIGNED* dimension = new PCB_DIM_ALIGNED( m_board, PCB_DIM_ALIGNED_T );
|
PCB_DIM_ALIGNED* dimension = new PCB_DIM_ALIGNED( m_board, PCB_DIM_ALIGNED_T );
|
||||||
m_board->Add( dimension, ADD_MODE::APPEND );
|
m_board->Add( dimension, ADD_MODE::APPEND );
|
||||||
|
|
||||||
|
@ -1022,15 +1060,15 @@ void EAGLE_PLUGIN::loadPlain( wxXmlNode* aGraphics )
|
||||||
// such case.
|
// such case.
|
||||||
if( *d.dimensionType == wxT( "horizontal" ) )
|
if( *d.dimensionType == wxT( "horizontal" ) )
|
||||||
{
|
{
|
||||||
int newY = ( d.y1.ToPcbUnits() + d.y2.ToPcbUnits() ) / 2;
|
int newY = ( pt1.y + pt2.y ) / 2;
|
||||||
d.y1 = ECOORD( newY, ECOORD::EAGLE_UNIT::EU_NM );
|
pt1.y = newY;
|
||||||
d.y2 = ECOORD( newY, ECOORD::EAGLE_UNIT::EU_NM );
|
pt2.y = newY;
|
||||||
}
|
}
|
||||||
else if( *d.dimensionType == wxT( "vertical" ) )
|
else if( *d.dimensionType == wxT( "vertical" ) )
|
||||||
{
|
{
|
||||||
int newX = ( d.x1.ToPcbUnits() + d.x2.ToPcbUnits() ) / 2;
|
int newX = ( pt1.x + pt2.x ) / 2;
|
||||||
d.x1 = ECOORD( newX, ECOORD::EAGLE_UNIT::EU_NM );
|
pt1.x = newX;
|
||||||
d.x2 = ECOORD( newX, ECOORD::EAGLE_UNIT::EU_NM );
|
pt2.x = newX;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1038,10 +1076,10 @@ void EAGLE_PLUGIN::loadPlain( wxXmlNode* aGraphics )
|
||||||
dimension->SetPrecision( DIMENSION_PRECISION );
|
dimension->SetPrecision( DIMENSION_PRECISION );
|
||||||
|
|
||||||
// The origin and end are assumed to always be in this order from eagle
|
// The origin and end are assumed to always be in this order from eagle
|
||||||
dimension->SetStart( VECTOR2I( kicad_x( d.x1 ), kicad_y( d.y1 ) ) );
|
dimension->SetStart( pt1 );
|
||||||
dimension->SetEnd( VECTOR2I( kicad_x( d.x2 ), kicad_y( d.y2 ) ) );
|
dimension->SetEnd( pt2 );
|
||||||
dimension->Text().SetTextSize( designSettings.GetTextSize( layer ) );
|
dimension->Text().SetTextSize( textSize );
|
||||||
dimension->Text().SetTextThickness( designSettings.GetTextThickness( layer ) );
|
dimension->Text().SetTextThickness( textThickness );
|
||||||
dimension->SetLineThickness( designSettings.GetLineThickness( layer ) );
|
dimension->SetLineThickness( designSettings.GetLineThickness( layer ) );
|
||||||
dimension->SetUnits( EDA_UNITS::MILLIMETRES );
|
dimension->SetUnits( EDA_UNITS::MILLIMETRES );
|
||||||
|
|
||||||
|
@ -1049,10 +1087,34 @@ void EAGLE_PLUGIN::loadPlain( wxXmlNode* aGraphics )
|
||||||
// because the "height" of the dimension is perpendicular to that axis
|
// because the "height" of the dimension is perpendicular to that axis
|
||||||
// Note the check is just if two axes are close enough to each other
|
// Note the check is just if two axes are close enough to each other
|
||||||
// Eagle appears to have some rounding errors
|
// Eagle appears to have some rounding errors
|
||||||
if( abs( ( d.x1 - d.x2 ).ToPcbUnits() ) < 50000 ) // 50000 nm = 0.05 mm
|
if( abs( pt1.x - pt2.x ) < 50000 ) // 50000 nm = 0.05 mm
|
||||||
dimension->SetHeight( kicad_x( d.x3 - d.x1 ) );
|
{
|
||||||
|
int offset = pt3.x - pt1.x;
|
||||||
|
|
||||||
|
if( pt1.y > pt2.y )
|
||||||
|
dimension->SetHeight( offset );
|
||||||
else
|
else
|
||||||
dimension->SetHeight( kicad_y( d.y3 - d.y1 ) );
|
dimension->SetHeight( -offset );
|
||||||
|
}
|
||||||
|
else if( abs( pt1.y - pt2.y ) < 50000 )
|
||||||
|
{
|
||||||
|
int offset = pt3.y - pt1.y;
|
||||||
|
|
||||||
|
if( pt1.x > pt2.x )
|
||||||
|
dimension->SetHeight( -offset );
|
||||||
|
else
|
||||||
|
dimension->SetHeight( offset );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
int offset = GetLineLength( (wxPoint) pt3, (wxPoint) pt1 );
|
||||||
|
|
||||||
|
if( pt1.y > pt2.y )
|
||||||
|
dimension->SetHeight( offset );
|
||||||
|
else
|
||||||
|
dimension->SetHeight( -offset );
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue