Fix handling of selection overlay in schematic editor
We weren't actually using the overlay group at all
Fixes https://gitlab.com/kicad/code/kicad/-/issues/11142
(cherry picked from commit 0f18a36f8f
)
This commit is contained in:
parent
89d22e5f94
commit
e2711a6121
|
@ -1646,6 +1646,9 @@ void SCH_EDIT_FRAME::SetScreen( BASE_SCREEN* aScreen )
|
||||||
|
|
||||||
SCH_BASE_FRAME::SetScreen( aScreen );
|
SCH_BASE_FRAME::SetScreen( aScreen );
|
||||||
GetCanvas()->DisplaySheet( static_cast<SCH_SCREEN*>( aScreen ) );
|
GetCanvas()->DisplaySheet( static_cast<SCH_SCREEN*>( aScreen ) );
|
||||||
|
|
||||||
|
if( m_toolManager )
|
||||||
|
m_toolManager->ResetTools( TOOL_BASE::MODEL_RELOAD );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -115,3 +115,18 @@ BOX2I EE_SELECTION::GetBoundingBox() const
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
const std::vector<KIGFX::VIEW_ITEM*> EE_SELECTION::updateDrawList() const
|
||||||
|
{
|
||||||
|
std::vector<VIEW_ITEM*> items;
|
||||||
|
|
||||||
|
auto addItem =
|
||||||
|
[&]( EDA_ITEM* item )
|
||||||
|
{
|
||||||
|
items.push_back( item );
|
||||||
|
};
|
||||||
|
|
||||||
|
for( EDA_ITEM* item : m_items )
|
||||||
|
addItem( item );
|
||||||
|
|
||||||
|
return items;
|
||||||
|
}
|
||||||
|
|
|
@ -50,6 +50,8 @@ public:
|
||||||
|
|
||||||
void SetScreen( SCH_SCREEN* aScreen ) { m_screen = aScreen; }
|
void SetScreen( SCH_SCREEN* aScreen ) { m_screen = aScreen; }
|
||||||
SCH_SCREEN* GetScreen() { return m_screen; }
|
SCH_SCREEN* GetScreen() { return m_screen; }
|
||||||
|
|
||||||
|
const std::vector<KIGFX::VIEW_ITEM*> updateDrawList() const override;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // EE_SELECTION_H
|
#endif // EE_SELECTION_H
|
||||||
|
|
|
@ -1906,10 +1906,13 @@ void EE_SELECTION_TOOL::highlight( EDA_ITEM* aItem, int aMode, SELECTION* aGroup
|
||||||
} );
|
} );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if( aGroup && aMode != BRIGHTENED )
|
||||||
|
getView()->Hide( aItem, true );
|
||||||
|
|
||||||
if( itemType == SCH_PIN_T || itemType == SCH_FIELD_T || itemType == SCH_SHEET_PIN_T )
|
if( itemType == SCH_PIN_T || itemType == SCH_FIELD_T || itemType == SCH_SHEET_PIN_T )
|
||||||
getView()->Update( aItem->GetParent() );
|
getView()->Update( aItem->GetParent(), KIGFX::REPAINT );
|
||||||
else
|
else
|
||||||
getView()->Update( aItem );
|
getView()->Update( aItem, KIGFX::REPAINT );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -1923,6 +1926,9 @@ void EE_SELECTION_TOOL::unhighlight( EDA_ITEM* aItem, int aMode, SELECTION* aGro
|
||||||
// Lines need endpoints cleared here
|
// Lines need endpoints cleared here
|
||||||
if( aItem->Type() == SCH_LINE_T )
|
if( aItem->Type() == SCH_LINE_T )
|
||||||
aItem->ClearFlags( STARTPOINT | ENDPOINT );
|
aItem->ClearFlags( STARTPOINT | ENDPOINT );
|
||||||
|
|
||||||
|
if( aMode != BRIGHTENED )
|
||||||
|
getView()->Hide( aItem, false );
|
||||||
}
|
}
|
||||||
else if( aMode == BRIGHTENED )
|
else if( aMode == BRIGHTENED )
|
||||||
aItem->ClearBrightened();
|
aItem->ClearBrightened();
|
||||||
|
@ -1945,9 +1951,9 @@ void EE_SELECTION_TOOL::unhighlight( EDA_ITEM* aItem, int aMode, SELECTION* aGro
|
||||||
}
|
}
|
||||||
|
|
||||||
if( itemType == SCH_PIN_T || itemType == SCH_FIELD_T || itemType == SCH_SHEET_PIN_T )
|
if( itemType == SCH_PIN_T || itemType == SCH_FIELD_T || itemType == SCH_SHEET_PIN_T )
|
||||||
getView()->Update( aItem->GetParent() );
|
getView()->Update( aItem->GetParent(), KIGFX::REPAINT );
|
||||||
else
|
else
|
||||||
getView()->Update( aItem );
|
getView()->Update( aItem, KIGFX::REPAINT );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue