Add pins to net highlighting.

Fixes: lp:1763873
* https://bugs.launchpad.net/kicad/+bug/1763873
This commit is contained in:
Jeff Young 2019-03-08 00:16:59 +00:00
parent 8a9b82c2a2
commit 52246121b9
8 changed files with 97 additions and 52 deletions

View File

@ -32,6 +32,7 @@
#include <sch_view.h> #include <sch_view.h>
#include <sch_draw_panel.h> #include <sch_draw_panel.h>
#include <sch_edit_frame.h> #include <sch_edit_frame.h>
#include <sch_component.h>
#include <erc.h> #include <erc.h>
#include <netlist_object.h> #include <netlist_object.h>
@ -93,38 +94,54 @@ bool SCH_EDIT_FRAME::SetCurrentSheetHighlightFlags( std::vector<EDA_ITEM*>* aIte
if( !screen ) if( !screen )
return true; return true;
// Disable highlight flag on all items in the current screen
for( SCH_ITEM* ptr = screen->GetDrawItems(); ptr; ptr = ptr->Next() ) for( SCH_ITEM* ptr = screen->GetDrawItems(); ptr; ptr = ptr->Next() )
{ {
auto conn = ptr->Connection( *g_CurrentSheet ); auto conn = ptr->Connection( *g_CurrentSheet );
bool bright = ptr->GetState( BRIGHTENED ); bool redraw = ptr->GetState( BRIGHTENED );
if( bright && aItemsToRedrawList )
aItemsToRedrawList->push_back( ptr );
ptr->SetState( BRIGHTENED, ( conn && conn->Name() == m_SelectedNetName ) ); ptr->SetState( BRIGHTENED, ( conn && conn->Name() == m_SelectedNetName ) );
if( !bright && ptr->GetState( BRIGHTENED ) && aItemsToRedrawList ) redraw |= ptr->GetState( BRIGHTENED );
aItemsToRedrawList->push_back( ptr );
if( ptr->Type() == SCH_SHEET_T ) if( ptr->Type() == SCH_COMPONENT_T )
{
SCH_COMPONENT* comp = static_cast<SCH_COMPONENT*>( ptr );
redraw |= comp->HasBrightenedPins();
comp->ClearBrightenedPins();
std::vector<LIB_PIN*> pins;
comp->GetPins( pins );
for( LIB_PIN* pin : pins )
{
auto pin_conn = comp->GetConnectionForPin( pin, *g_CurrentSheet );
if( pin_conn && pin_conn->Name( false, true ) == m_SelectedNetName )
{
comp->BrightenPin( pin );
redraw = true;
}
}
}
else if( ptr->Type() == SCH_SHEET_T )
{ {
for( SCH_SHEET_PIN& pin : static_cast<SCH_SHEET*>( ptr )->GetPins() ) for( SCH_SHEET_PIN& pin : static_cast<SCH_SHEET*>( ptr )->GetPins() )
{ {
auto pin_conn = pin.Connection( *g_CurrentSheet ); auto pin_conn = pin.Connection( *g_CurrentSheet );
bool redrawPin = pin.GetState( BRIGHTENED );
bright = pin.GetState( BRIGHTENED ); pin.SetState( BRIGHTENED, ( pin_conn && pin_conn->Name() == m_SelectedNetName ) );
if( bright && aItemsToRedrawList ) redrawPin |= pin.GetState( BRIGHTENED );
aItemsToRedrawList->push_back( &pin );
pin.SetState( BRIGHTENED, ( pin_conn && if( redrawPin && aItemsToRedrawList )
pin_conn->Name() == m_SelectedNetName ) );
if( !bright && pin.GetState( BRIGHTENED ) && aItemsToRedrawList )
aItemsToRedrawList->push_back( &pin ); aItemsToRedrawList->push_back( &pin );
} }
} }
if( redraw && aItemsToRedrawList )
aItemsToRedrawList->push_back( ptr );
} }
if( m_SelectedNetName == "" ) if( m_SelectedNetName == "" )

View File

@ -1774,14 +1774,10 @@ void LIB_PIN::GetMsgPanelInfo( EDA_UNITS_T aUnits, std::vector< MSG_PANEL_ITEM >
#if defined(DEBUG) #if defined(DEBUG)
if( auto pin_connection = aComponent->GetConnectionForPin( this ) ) auto conn = aComponent->GetConnectionForPin( this, *g_CurrentSheet );
{
auto conn = pin_connection->Connection( *g_CurrentSheet );
wxASSERT( conn );
if( conn )
conn->AppendDebugInfoToMsgPanel( aList ); conn->AppendDebugInfoToMsgPanel( aList );
}
#endif #endif
} }

View File

@ -566,17 +566,17 @@ void SCH_COMPONENT::UpdatePinConnections( SCH_SHEET_PATH aSheet )
} }
SCH_PIN_CONNECTION* SCH_COMPONENT::GetConnectionForPin( LIB_PIN* aPin ) SCH_CONNECTION* SCH_COMPONENT::GetConnectionForPin( LIB_PIN* aPin, const SCH_SHEET_PATH& aSheet )
{ {
try if( m_pin_connections.count( aPin ) )
{ {
return m_pin_connections.at( aPin ); SCH_PIN_CONNECTION* pin_conn = m_pin_connections.at( aPin );
}
catch( const std::out_of_range& oor ) if( pin_conn )
{ return pin_conn->Connection( aSheet );
return nullptr;
} }
return nullptr;
} }
@ -2028,6 +2028,30 @@ void SCH_COMPONENT::Plot( PLOTTER* aPlotter )
} }
bool SCH_COMPONENT::HasBrightenedPins()
{
return m_brightenedPins.size() > 0;
}
void SCH_COMPONENT::ClearBrightenedPins()
{
m_brightenedPins.clear();
}
void SCH_COMPONENT::BrightenPin( LIB_PIN* aPin )
{
m_brightenedPins.insert( aPin->GetNumber() );
}
bool SCH_COMPONENT::IsPinBrightened( const LIB_PIN* aPin )
{
return m_brightenedPins.find( aPin->GetNumber() ) != m_brightenedPins.end();
}
void SCH_COMPONENT::ClearHighlightedPins() void SCH_COMPONENT::ClearHighlightedPins()
{ {
m_highlightedPins.clear(); m_highlightedPins.clear();

View File

@ -96,6 +96,7 @@ private:
std::vector<bool> m_isDangling; ///< One isDangling per pin std::vector<bool> m_isDangling; ///< One isDangling per pin
std::vector<wxPoint> m_Pins; std::vector<wxPoint> m_Pins;
std::set<wxString> m_highlightedPins; ///< God forgive me - Tom std::set<wxString> m_highlightedPins; ///< God forgive me - Tom
std::set<wxString> m_brightenedPins; ///< ... and me too - Jeff
AUTOPLACED m_fieldsAutoplaced; ///< indicates status of field autoplacement AUTOPLACED m_fieldsAutoplaced; ///< indicates status of field autoplacement
@ -221,9 +222,9 @@ public:
void UpdatePinConnections( SCH_SHEET_PATH aSheet ); void UpdatePinConnections( SCH_SHEET_PATH aSheet );
/** /**
* Retrieves the pin connection for a given pin of the component * Retrieves the connection for a given pin of the component
*/ */
SCH_PIN_CONNECTION* GetConnectionForPin( LIB_PIN* aPin ); SCH_CONNECTION* GetConnectionForPin( LIB_PIN* aPin, const SCH_SHEET_PATH& aSheet );
const std::unordered_map<LIB_PIN*, SCH_PIN_CONNECTION*>& PinConnections() const std::unordered_map<LIB_PIN*, SCH_PIN_CONNECTION*>& PinConnections()
{ {
@ -662,6 +663,14 @@ public:
void Show( int nestLevel, std::ostream& os ) const override; void Show( int nestLevel, std::ostream& os ) const override;
#endif #endif
void ClearBrightenedPins();
bool HasBrightenedPins();
void BrightenPin( LIB_PIN* aPin );
bool IsPinBrightened( const LIB_PIN* aPin );
void ClearHighlightedPins(); void ClearHighlightedPins();
void HighlightPin( LIB_PIN* aPin ); void HighlightPin( LIB_PIN* aPin );

View File

@ -243,7 +243,7 @@ bool SCH_CONNECTION::IsDriver() const
} }
wxString SCH_CONNECTION::Name( bool aIgnoreSheet ) const wxString SCH_CONNECTION::Name( bool aIgnoreSheet, bool aForceSheet ) const
{ {
wxString ret = m_name + m_suffix; wxString ret = m_name + m_suffix;
@ -271,7 +271,7 @@ wxString SCH_CONNECTION::Name( bool aIgnoreSheet ) const
} }
} }
if( prepend_path && !aIgnoreSheet ) if( aForceSheet || ( prepend_path && !aIgnoreSheet ) )
ret = m_sheet.PathHumanReadable() + ret; ret = m_sheet.PathHumanReadable() + ret;
return ret; return ret;

View File

@ -145,7 +145,7 @@ public:
m_dirty = false; m_dirty = false;
} }
wxString Name( bool aIgnoreSheet = false ) const; wxString Name( bool aIgnoreSheet = false, bool aForceSheet = false ) const;
wxString Prefix() const wxString Prefix() const
{ {

View File

@ -540,8 +540,12 @@ void SCH_PAINTER::draw( LIB_PIN *aPin, int aLayer, bool aIsDangling, bool isMovi
isMoving = true; isMoving = true;
VECTOR2I pos = mapCoords( aPin->GetPosition() ); VECTOR2I pos = mapCoords( aPin->GetPosition() );
COLOR4D color;
COLOR4D color = getOverlayColor( aPin, m_schSettings.GetLayerColor( LAYER_PIN ), false ); if( aPin->IsBrightened() )
color = m_schSettings.GetLayerColor( LAYER_BRIGHTENED );
else
color = getOverlayColor( aPin, m_schSettings.GetLayerColor( LAYER_PIN ), false );
if( !aPin->IsVisible() ) if( !aPin->IsVisible() )
{ {
@ -1144,10 +1148,11 @@ void SCH_PAINTER::draw( SCH_COMPONENT *aComp, int aLayer )
if( item.Type() == LIB_PIN_T ) if( item.Type() == LIB_PIN_T )
{ {
auto pin = static_cast<LIB_PIN*>( &item ); auto pin = static_cast<LIB_PIN*>( &item );
if( aComp->IsPinHighlighted( pin ) )
{ if( aComp->IsPinBrightened( pin ) )
pin->SetFlags( BRIGHTENED );
else if( aComp->IsPinHighlighted( pin ) )
pin->SetFlags( HIGHLIGHTED ); pin->SetFlags( HIGHLIGHTED );
}
} }
} }

View File

@ -53,26 +53,20 @@ wxString SCH_PIN_CONNECTION::GetDefaultNetName( const SCH_SHEET_PATH aPath )
if( m_pin->IsPowerConnection() ) if( m_pin->IsPowerConnection() )
return m_pin->GetName(); return m_pin->GetName();
wxString name; if( m_net_name_map.count( aPath ) > 0 )
return m_net_name_map.at( aPath );
try wxString name = wxT( "Net-(" );
{
name = m_net_name_map.at( aPath );
}
catch( const std::out_of_range& oor )
{
name = wxT( "Net-(" );
name << m_comp->GetRef( &aPath ); name << m_comp->GetRef( &aPath );
// TODO(JE) do we need adoptTimestamp? // TODO(JE) do we need adoptTimestamp?
if( /* adoptTimestamp && */ name.Last() == '?' ) if( /* adoptTimestamp && */ name.Last() == '?' )
name << m_comp->GetTimeStamp(); name << m_comp->GetTimeStamp();
name << _( "-Pad" ) << m_pin->GetNumber() << _( ")" ); name << _( "-Pad" ) << m_pin->GetNumber() << _( ")" );
m_net_name_map[ aPath ] = name; m_net_name_map[ aPath ] = name;
}
return name; return name;
} }