Fix some placement bugs with selection haloes on text.

Fixes: lp:1838841
* https://bugs.launchpad.net/kicad/+bug/1838841
This commit is contained in:
Jeff Young 2019-08-03 17:03:35 -06:00
parent 7349fe2e72
commit 5503727d3d
8 changed files with 60 additions and 38 deletions

View File

@ -169,11 +169,9 @@ wxString EDA_TEXT::ShortenedShownText() const
} }
int EDA_TEXT::GetInterline( int aTextThickness ) const int EDA_TEXT::GetInterline() const
{ {
int thickness = aTextThickness <= 0 ? GetThickness() : aTextThickness; return KiROUND( KIGFX::STROKE_FONT::GetInterline( GetTextHeight() ) );
return KiROUND( KIGFX::STROKE_FONT::GetInterline( GetTextHeight(), thickness ) );
} }
@ -215,7 +213,7 @@ EDA_RECT EDA_TEXT::GetTextBox( int aLine, int aThickness, bool aInvertY ) const
// calculate the H and V size // calculate the H and V size
int dx = KiROUND( basic_gal.GetStrokeFont().ComputeStringBoundaryLimits( int dx = KiROUND( basic_gal.GetStrokeFont().ComputeStringBoundaryLimits(
text, VECTOR2D( GetTextSize() ), double( thickness ) ).x ); text, VECTOR2D( GetTextSize() ), double( thickness ) ).x );
int dy = GetInterline( thickness ); int dy = GetInterline();
// Creates bounding box (rectangle) for an horizontal // Creates bounding box (rectangle) for an horizontal
// and left and top justified text. the bounding box will be moved later // and left and top justified text. the bounding box will be moved later
@ -317,7 +315,7 @@ EDA_RECT EDA_TEXT::GetTextBox( int aLine, int aThickness, bool aInvertY ) const
break; break;
case GR_TEXT_VJUSTIFY_BOTTOM: case GR_TEXT_VJUSTIFY_BOTTOM:
yoffset = linecount * GetInterline( aThickness ); yoffset = linecount * GetInterline();
rect.SetY( rect.GetY() - yoffset ); rect.SetY( rect.GetY() - yoffset );
break; break;
} }

View File

@ -34,7 +34,7 @@
using namespace KIGFX; using namespace KIGFX;
const double STROKE_FONT::INTERLINE_PITCH_RATIO = 1.5; const double STROKE_FONT::INTERLINE_PITCH_RATIO = 1.61;
const double STROKE_FONT::OVERBAR_POSITION_FACTOR = 1.22; const double STROKE_FONT::OVERBAR_POSITION_FACTOR = 1.22;
const double STROKE_FONT::BOLD_FACTOR = 1.3; const double STROKE_FONT::BOLD_FACTOR = 1.3;
const double STROKE_FONT::STROKE_FONT_SCALE = 1.0 / 21.0; const double STROKE_FONT::STROKE_FONT_SCALE = 1.0 / 21.0;
@ -124,15 +124,11 @@ bool STROKE_FONT::LoadNewStrokeFont( const char* const aNewStrokeFont[], int aNe
// Static function: // Static function:
double STROKE_FONT::GetInterline( double aGlyphHeight, double aGlyphThickness ) double STROKE_FONT::GetInterline( double aGlyphHeight )
{ {
return ( aGlyphHeight * INTERLINE_PITCH_RATIO ) + aGlyphThickness; // Do not add the glyph thickness to the interline. This makes bold text line-spacing
} // different from normal text, which is poor typography.
return ( aGlyphHeight * INTERLINE_PITCH_RATIO );
int STROKE_FONT::getInterline() const
{
return KiROUND( GetInterline( m_gal->GetGlyphSize().y, m_gal->GetLineWidth() ) );
} }
@ -172,7 +168,7 @@ void STROKE_FONT::Draw( const UTF8& aText, const VECTOR2D& aPosition, double aRo
m_gal->Rotate( -aRotationAngle ); m_gal->Rotate( -aRotationAngle );
// Single line height // Single line height
int lineHeight = getInterline( ); int lineHeight = KiROUND( GetInterline( m_gal->GetGlyphSize().y ) );
int lineCount = linesCount( aText ); int lineCount = linesCount( aText );
const VECTOR2D& glyphSize = m_gal->GetGlyphSize(); const VECTOR2D& glyphSize = m_gal->GetGlyphSize();
@ -450,7 +446,7 @@ VECTOR2D STROKE_FONT::ComputeStringBoundaryLimits( const UTF8& aText, const VECT
string_bbox.x = std::max( maxX, curX ); string_bbox.x = std::max( maxX, curX );
string_bbox.x *= aGlyphSize.x; string_bbox.x *= aGlyphSize.x;
string_bbox.x += aGlyphThickness; string_bbox.x += aGlyphThickness;
string_bbox.y = line_count * GetInterline( aGlyphSize.y, aGlyphThickness ); string_bbox.y = line_count * GetInterline( aGlyphSize.y );
// For italic correction, take in account italic tilt // For italic correction, take in account italic tilt
if( m_gal->IsFontItalic() ) if( m_gal->IsFontItalic() )

View File

@ -156,8 +156,8 @@ void SCH_DRAW_PANEL::setDefaultLayerDeps()
m_view->SetLayerTarget( LAYER_WORKSHEET, KIGFX::TARGET_NONCACHED ); m_view->SetLayerTarget( LAYER_WORKSHEET, KIGFX::TARGET_NONCACHED );
m_view->SetLayerDisplayOnly( LAYER_WORKSHEET ) ; m_view->SetLayerDisplayOnly( LAYER_WORKSHEET ) ;
m_view->SetLayerTarget( LAYER_SELECTION_SHADOWS, KIGFX::TARGET_NONCACHED ); // m_view->SetLayerTarget( LAYER_SELECTION_SHADOWS, KIGFX::TARGET_NONCACHED );
m_view->SetLayerDisplayOnly( LAYER_SELECTION_SHADOWS ) ; // m_view->SetLayerDisplayOnly( LAYER_SELECTION_SHADOWS ) ;
} }

View File

@ -821,6 +821,9 @@ void SCH_PAINTER::draw( LIB_PIN *aPin, int aLayer )
{ {
for( float& t : thickness ) for( float& t : thickness )
t += getShadowWidth(); t += getShadowWidth();
insideOffset -= KiROUND( getShadowWidth() / 2 );
outsideOffset -= KiROUND( getShadowWidth() / 2 );
} }
#define SET_DC( i ) \ #define SET_DC( i ) \
@ -1127,9 +1130,34 @@ void SCH_PAINTER::draw( SCH_TEXT *aText, int aLayer )
m_gal->SetStrokeColor( color ); m_gal->SetStrokeColor( color );
m_gal->SetTextAttributes( aText ); m_gal->SetTextAttributes( aText );
wxPoint text_offset = aText->GetTextPos() + aText->GetSchematicTextOffset(); VECTOR2D text_offset = aText->GetTextPos() + aText->GetSchematicTextOffset();
wxString shownText( aText->GetShownText() ); wxString shownText( aText->GetShownText() );
if( drawingShadows )
{
switch( aText->GetLabelSpinStyle() )
{
case 0:
if( aText->Type() == SCH_LABEL_T || aText->Type() == SCH_TEXT_T )
text_offset.x -= getShadowWidth() / 2;
else
text_offset.x += getShadowWidth() / 2;
break;
case 1:
text_offset.y += getShadowWidth() / 2;
break;
case 2:
if( aText->Type() == SCH_LABEL_T || aText->Type() == SCH_TEXT_T )
text_offset.x += getShadowWidth() / 2;
else
text_offset.x -= getShadowWidth() / 2;
break;
case 3:
text_offset.y -= getShadowWidth() / 2;
break;
}
}
if( !shownText.IsEmpty() ) if( !shownText.IsEmpty() )
m_gal->StrokeText( shownText, text_offset, aText->GetTextAngleRadians() ); m_gal->StrokeText( shownText, text_offset, aText->GetTextAngleRadians() );
@ -1446,6 +1474,20 @@ void SCH_PAINTER::draw( SCH_SHEET *aSheet, int aLayer )
if( aSheet->IsVerticalOrientation() ) if( aSheet->IsVerticalOrientation() )
nameAngle = M_PI/2; nameAngle = M_PI/2;
if( drawingShadows )
{
if( aSheet->IsVerticalOrientation() )
{
pos_sheetname.y += getShadowWidth() / 2;
pos_filename.y += getShadowWidth() / 2;
}
else
{
pos_sheetname.x -= getShadowWidth() / 2;
pos_filename.x -= getShadowWidth() / 2;
}
}
m_gal->SetStrokeColor( getRenderColor( aSheet, LAYER_SHEETNAME, drawingShadows ) ); m_gal->SetStrokeColor( getRenderColor( aSheet, LAYER_SHEETNAME, drawingShadows ) );
auto text = wxT( "Sheet: " ) + aSheet->GetName(); auto text = wxT( "Sheet: " ) + aSheet->GetName();

View File

@ -861,7 +861,7 @@ void SCH_GLOBALLABEL::CreateGraphicShape( std::vector <wxPoint>& aPoints, const
#define OVERBAR_V_MARGIN 1.2 #define OVERBAR_V_MARGIN 1.2
// Note: this factor is due to the fact we need a margin for the graphic symbol. // Note: this factor is due to the fact we need a margin for the graphic symbol.
if( hasOverBar ) if( hasOverBar )
y = KiROUND( KIGFX::STROKE_FONT::GetInterline( halfSize, linewidth ) * OVERBAR_V_MARGIN ); y = KiROUND( KIGFX::STROKE_FONT::GetInterline( halfSize ) * OVERBAR_V_MARGIN );
// Gives room for line thickess and margin // Gives room for line thickess and margin
y += linewidth; // for line thickess y += linewidth; // for line thickess

View File

@ -324,17 +324,11 @@ public:
/** /**
* Return the distance between two lines of text. * Return the distance between two lines of text.
* *
* <p>
* Calculates the distance (pitch) between two lines of text. This distance includes the * Calculates the distance (pitch) between two lines of text. This distance includes the
* interline distance plus room for characters like j, {, and [. It also used for single * interline distance plus room for characters like j, {, and [. It also used for single
* line text, to calculate the text bounding box. * line text, to calculate the text bounding box.
* </p>
*
* @param aTextThickness Overrides the current thickness when greater than 0.
* this is needed when the current m_Thickness is 0 and a default line thickness
* is used
*/ */
int GetInterline( int aTextThickness = -1 ) const; int GetInterline() const;
/** /**
* Function GetTextStyleName * Function GetTextStyleName

View File

@ -108,10 +108,9 @@ public:
* @brief Compute the distance (interline) between 2 lines of text (for multiline texts). * @brief Compute the distance (interline) between 2 lines of text (for multiline texts).
* *
* @param aGlyphHeight is the height (vertical size) of the text. * @param aGlyphHeight is the height (vertical size) of the text.
* @param aGlyphThickness is the thickness of the lines used to draw the text.
* @return the interline. * @return the interline.
*/ */
static double GetInterline( double aGlyphHeight, double aGlyphThickness ); static double GetInterline( double aGlyphHeight );
@ -136,13 +135,6 @@ private:
*/ */
double computeOverbarVerticalPosition() const; double computeOverbarVerticalPosition() const;
/**
* @brief Returns a single line height using current settings.
*
* @return The line height.
*/
int getInterline() const;
/** /**
* @brief Compute the bounding box of a given glyph. * @brief Compute the bounding box of a given glyph.
* *