From b2bcde1bfc4c7658c044be45b8160ec4c8d1894a Mon Sep 17 00:00:00 2001 From: Seth Hillbrand Date: Mon, 20 May 2019 20:03:43 -0700 Subject: [PATCH] EAGLE: Correct pcb text orientation Fixes: lp:1829711 * https://bugs.launchpad.net/kicad/+bug/1829711 (cherry picked from commit 1181b9f9b42709558dd66c5b4b9ece672c5e548f) --- pcbnew/eagle_plugin.cpp | 27 +++++++++++++++++++++++++-- 1 file changed, 25 insertions(+), 2 deletions(-) diff --git a/pcbnew/eagle_plugin.cpp b/pcbnew/eagle_plugin.cpp index 3399b3bb22..8e1329f86c 100644 --- a/pcbnew/eagle_plugin.cpp +++ b/pcbnew/eagle_plugin.cpp @@ -1298,6 +1298,9 @@ void EAGLE_PLUGIN::orientModuleText( MODULE* m, const EELEMENT& e, int align = ETEXT::BOTTOM_LEFT; // bottom-left is eagle default + if( a.align ) + align = a.align; + // The "rot" in a EATTR seems to be assumed to be zero if it is not // present, and this zero rotation becomes an override to the // package's text field. If they did not want zero, they specify @@ -1324,12 +1327,12 @@ void EAGLE_PLUGIN::orientModuleText( MODULE* m, const EELEMENT& e, { orient = 0 - m->GetOrientation() / 10; txt->SetTextAngle( sign * orient * 10 ); - align = ETEXT::TOP_RIGHT; + align = -align; } else if( degrees == 270 ) { orient = 90 - m->GetOrientation() / 10; - align = ETEXT::TOP_RIGHT; + align = -align; txt->SetTextAngle( sign * orient * 10 ); } else @@ -1350,6 +1353,26 @@ void EAGLE_PLUGIN::orientModuleText( MODULE* m, const EELEMENT& e, txt->SetVertJustify( GR_TEXT_VJUSTIFY_BOTTOM ); break; + case ETEXT::TOP_LEFT: + txt->SetHorizJustify( GR_TEXT_HJUSTIFY_LEFT ); + txt->SetVertJustify( GR_TEXT_VJUSTIFY_TOP ); + break; + + case ETEXT::BOTTOM_RIGHT: + txt->SetHorizJustify( GR_TEXT_HJUSTIFY_RIGHT ); + txt->SetVertJustify( GR_TEXT_VJUSTIFY_BOTTOM ); + break; + + case ETEXT::TOP_CENTER: + txt->SetHorizJustify( GR_TEXT_HJUSTIFY_CENTER ); + txt->SetVertJustify( GR_TEXT_VJUSTIFY_TOP ); + break; + + case ETEXT::BOTTOM_CENTER: + txt->SetHorizJustify( GR_TEXT_HJUSTIFY_CENTER ); + txt->SetVertJustify( GR_TEXT_VJUSTIFY_BOTTOM ); + break; + default: ; }