Eeschema Eagle Import: refactored common code for setting text attributes
This commit is contained in:
parent
7d7303215b
commit
62156b9b69
|
@ -1679,33 +1679,15 @@ LIB_PIN* SCH_EAGLE_PLUGIN::loadPin( std::unique_ptr<LIB_PART>& aPart,
|
||||||
|
|
||||||
|
|
||||||
LIB_TEXT* SCH_EAGLE_PLUGIN::loadSymbolText( std::unique_ptr<LIB_PART>& aPart,
|
LIB_TEXT* SCH_EAGLE_PLUGIN::loadSymbolText( std::unique_ptr<LIB_PART>& aPart,
|
||||||
wxXmlNode* aLibText,
|
wxXmlNode* aLibText, int aGateNumber )
|
||||||
int aGateNumber )
|
|
||||||
{
|
{
|
||||||
std::unique_ptr<LIB_TEXT> libtext( new LIB_TEXT( aPart.get() ) );
|
std::unique_ptr<LIB_TEXT> libtext( new LIB_TEXT( aPart.get() ) );
|
||||||
|
|
||||||
ETEXT etext( aLibText );
|
ETEXT etext( aLibText );
|
||||||
|
|
||||||
libtext->SetUnit( aGateNumber );
|
libtext->SetUnit( aGateNumber );
|
||||||
libtext->SetPosition( wxPoint( etext.x.ToSchUnits(), etext.y.ToSchUnits() ) );
|
libtext->SetPosition( wxPoint( etext.x.ToSchUnits(), etext.y.ToSchUnits() ) );
|
||||||
libtext->SetText( aLibText->GetNodeContent().IsEmpty() ? "~~" : aLibText->GetNodeContent() );
|
libtext->SetText( aLibText->GetNodeContent().IsEmpty() ? "~~" : aLibText->GetNodeContent() );
|
||||||
libtext->SetTextSize( etext.ConvertSize() );
|
loadTextAttributes( libtext.get(), etext );
|
||||||
|
|
||||||
if( etext.ratio )
|
|
||||||
{
|
|
||||||
if( etext.ratio.Get()>12 )
|
|
||||||
{
|
|
||||||
libtext->SetBold( true );
|
|
||||||
libtext->SetThickness( GetPenSizeForBold( libtext->GetTextWidth() ) );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
int align = etext.align ? *etext.align : ETEXT::BOTTOM_LEFT;
|
|
||||||
int degrees = etext.rot ? etext.rot->degrees : 0;
|
|
||||||
bool mirror = etext.rot ? etext.rot->mirror : false;
|
|
||||||
bool spin = etext.rot ? etext.rot->spin : false;
|
|
||||||
|
|
||||||
eagleToKicadAlignment( (EDA_TEXT*) libtext.get(), align, degrees, mirror, spin, 0 );
|
|
||||||
|
|
||||||
return libtext.release();
|
return libtext.release();
|
||||||
}
|
}
|
||||||
|
@ -1714,33 +1696,37 @@ LIB_TEXT* SCH_EAGLE_PLUGIN::loadSymbolText( std::unique_ptr<LIB_PART>& aPart,
|
||||||
SCH_TEXT* SCH_EAGLE_PLUGIN::loadPlainText( wxXmlNode* aSchText )
|
SCH_TEXT* SCH_EAGLE_PLUGIN::loadPlainText( wxXmlNode* aSchText )
|
||||||
{
|
{
|
||||||
std::unique_ptr<SCH_TEXT> schtext( new SCH_TEXT() );
|
std::unique_ptr<SCH_TEXT> schtext( new SCH_TEXT() );
|
||||||
auto etext = ETEXT( aSchText );
|
ETEXT etext = ETEXT( aSchText );
|
||||||
|
|
||||||
schtext->SetItalic( false );
|
const wxString& thetext = aSchText->GetNodeContent();
|
||||||
|
schtext->SetText( thetext.IsEmpty() ? "\" \"" : escapeName( thetext ) );
|
||||||
schtext->SetPosition( wxPoint( etext.x.ToSchUnits(), -etext.y.ToSchUnits() ) );
|
schtext->SetPosition( wxPoint( etext.x.ToSchUnits(), -etext.y.ToSchUnits() ) );
|
||||||
|
loadTextAttributes( schtext.get(), etext );
|
||||||
|
schtext->SetItalic( false );
|
||||||
|
|
||||||
wxString thetext = aSchText->GetNodeContent();
|
return schtext.release();
|
||||||
schtext->SetText( aSchText->GetNodeContent().IsEmpty() ? "\" \"" : escapeName( thetext ) );
|
}
|
||||||
|
|
||||||
if( etext.ratio )
|
|
||||||
|
void SCH_EAGLE_PLUGIN::loadTextAttributes( EDA_TEXT* aText, const ETEXT& aAttribs ) const
|
||||||
|
{
|
||||||
|
aText->SetTextSize( aAttribs.ConvertSize() );
|
||||||
|
|
||||||
|
if( aAttribs.ratio )
|
||||||
{
|
{
|
||||||
if( etext.ratio.Get()>12 )
|
if( aAttribs.ratio.CGet() > 12 )
|
||||||
{
|
{
|
||||||
schtext->SetBold( true );
|
aText->SetBold( true );
|
||||||
schtext->SetThickness( GetPenSizeForBold( schtext->GetTextWidth() ) );
|
aText->SetThickness( GetPenSizeForBold( aText->GetTextWidth() ) );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
schtext->SetTextSize( etext.ConvertSize() );
|
int align = aAttribs.align ? *aAttribs.align : ETEXT::BOTTOM_LEFT;
|
||||||
|
int degrees = aAttribs.rot ? aAttribs.rot->degrees : 0;
|
||||||
|
bool mirror = aAttribs.rot ? aAttribs.rot->mirror : false;
|
||||||
|
bool spin = aAttribs.rot ? aAttribs.rot->spin : false;
|
||||||
|
|
||||||
int align = etext.align ? *etext.align : ETEXT::BOTTOM_LEFT;
|
eagleToKicadAlignment( aText, align, degrees, mirror, spin, 0 );
|
||||||
int degrees = etext.rot ? etext.rot->degrees : 0;
|
|
||||||
bool mirror = etext.rot ? etext.rot->mirror : false;
|
|
||||||
bool spin = etext.rot ? etext.rot->spin : false;
|
|
||||||
|
|
||||||
eagleToKicadAlignment( (EDA_TEXT*) schtext.get(), align, degrees, mirror, spin, 0 );
|
|
||||||
|
|
||||||
return schtext.release();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -33,6 +33,7 @@
|
||||||
|
|
||||||
#include <boost/ptr_container/ptr_map.hpp>
|
#include <boost/ptr_container/ptr_map.hpp>
|
||||||
|
|
||||||
|
class EDA_TEXT;
|
||||||
class KIWAY;
|
class KIWAY;
|
||||||
class LINE_READER;
|
class LINE_READER;
|
||||||
class SCH_SCREEN;
|
class SCH_SCREEN;
|
||||||
|
@ -167,6 +168,8 @@ private:
|
||||||
LIB_PIN* loadPin( std::unique_ptr<LIB_PART>& aPart, wxXmlNode*, EPIN* epin, int aGateNumber );
|
LIB_PIN* loadPin( std::unique_ptr<LIB_PART>& aPart, wxXmlNode*, EPIN* epin, int aGateNumber );
|
||||||
LIB_TEXT* loadSymbolText( std::unique_ptr<LIB_PART>& aPart, wxXmlNode* aLibText, int aGateNumber );
|
LIB_TEXT* loadSymbolText( std::unique_ptr<LIB_PART>& aPart, wxXmlNode* aLibText, int aGateNumber );
|
||||||
|
|
||||||
|
void loadTextAttributes( EDA_TEXT* aText, const ETEXT& aAttribs ) const;
|
||||||
|
|
||||||
KIWAY* m_kiway; ///< For creating sub sheets.
|
KIWAY* m_kiway; ///< For creating sub sheets.
|
||||||
SCH_SHEET* m_rootSheet; ///< The root sheet of the schematic being loaded..
|
SCH_SHEET* m_rootSheet; ///< The root sheet of the schematic being loaded..
|
||||||
SCH_SHEET* m_currentSheet; ///< The current sheet of the schematic being loaded..
|
SCH_SHEET* m_currentSheet; ///< The current sheet of the schematic being loaded..
|
||||||
|
|
Loading…
Reference in New Issue