Pcbnew: Make 'GetBoundingBox' return correct answer when passed false
CHANGED: 'GetBoundingBox' has a variant that accepts a boolean that determines if invisible text is included in the Bbox calculations. The 'IsVisible' function for the value and reference strings doesn't factor in if the layer it's on is visible or even in the PCB stackup, so 'GetBoundingBox' returns a bbox that factors in invisible text regardless of what it's passed. This MR fixes that problem. CHANGED: Refactored the original 'GetBoundingBox' function that doesn't take a parameter. It now just calls the variant that does take a parameter and passes it 'true'. The two versions had a lot of duplicate code and this eliminates it. Note: Issue 5629 might be better solved at the PCB module level, but this does fix the known problems caused by it which were discovered in 'GetBoundingBox'. Fixes https://gitlab.com/kicad/code/kicad/issues/5629
This commit is contained in:
parent
e9b627bfd8
commit
f3586ccd45
|
@ -562,19 +562,7 @@ EDA_RECT MODULE::GetFpPadsLocalBbox() const
|
|||
|
||||
const EDA_RECT MODULE::GetBoundingBox() const
|
||||
{
|
||||
EDA_RECT area = GetFootprintRect();
|
||||
|
||||
// Add in items not collected by GetFootprintRect():
|
||||
for( BOARD_ITEM* item : m_drawings )
|
||||
{
|
||||
if( item->Type() != PCB_MODULE_EDGE_T )
|
||||
area.Merge( item->GetBoundingBox() );
|
||||
}
|
||||
|
||||
area.Merge( m_Value->GetBoundingBox() );
|
||||
area.Merge( m_Reference->GetBoundingBox() );
|
||||
|
||||
return area;
|
||||
return GetBoundingBox( true );
|
||||
}
|
||||
|
||||
|
||||
|
@ -589,10 +577,32 @@ const EDA_RECT MODULE::GetBoundingBox( bool aIncludeInvisibleText ) const
|
|||
area.Merge( item->GetBoundingBox() );
|
||||
}
|
||||
|
||||
if( m_Value->IsVisible() || aIncludeInvisibleText )
|
||||
// This can be further optimized when aIncludeInvisibleText is true, but currently
|
||||
// leaving this as is until it's determined there is a noticeable speed hit.
|
||||
bool valueLayerIsVisible = true;
|
||||
bool refLayerIsVisible = true;
|
||||
BOARD* board = GetBoard();
|
||||
|
||||
if( board )
|
||||
{
|
||||
// The first "&&" conditional handles the user turning layers off as well as layers
|
||||
// not being present in the current PCB stackup. Values, references, and all
|
||||
// footprint text can also be turned off via the GAL meta-layers, so the 2nd and
|
||||
// 3rd "&&" conditionals handle that.
|
||||
valueLayerIsVisible = board->IsLayerVisible( m_Value->GetLayer() )
|
||||
&& board->IsElementVisible( LAYER_MOD_VALUES )
|
||||
&& board->IsElementVisible( LAYER_MOD_TEXT_FR );
|
||||
|
||||
refLayerIsVisible = board->IsLayerVisible( m_Reference->GetLayer() )
|
||||
&& board->IsElementVisible( LAYER_MOD_REFERENCES )
|
||||
&& board->IsElementVisible( LAYER_MOD_TEXT_FR );
|
||||
}
|
||||
|
||||
|
||||
if( ( m_Value->IsVisible() && valueLayerIsVisible ) || aIncludeInvisibleText )
|
||||
area.Merge( m_Value->GetBoundingBox() );
|
||||
|
||||
if( m_Reference->IsVisible() || aIncludeInvisibleText )
|
||||
if( ( m_Reference->IsVisible() && refLayerIsVisible ) || aIncludeInvisibleText )
|
||||
area.Merge( m_Reference->GetBoundingBox() );
|
||||
|
||||
return area;
|
||||
|
|
Loading…
Reference in New Issue