Net navigator bug fixes and improvements.
Note: This changes the net highlight tool behavior. When clicking on an already highlighted net, the net highlighting is no longer toggled off. This prevents the net navigator panel from being cleared.
This commit is contained in:
parent
46564055f4
commit
4ccbbde54a
|
@ -24,6 +24,7 @@
|
||||||
#include <tool/tool_manager.h>
|
#include <tool/tool_manager.h>
|
||||||
#include <kiface_base.h>
|
#include <kiface_base.h>
|
||||||
#include <sch_edit_frame.h>
|
#include <sch_edit_frame.h>
|
||||||
|
#include <sch_bus_entry.h>
|
||||||
#include <sch_line.h>
|
#include <sch_line.h>
|
||||||
#include <sch_junction.h>
|
#include <sch_junction.h>
|
||||||
#include <sch_sheet_pin.h>
|
#include <sch_sheet_pin.h>
|
||||||
|
@ -80,7 +81,7 @@ static wxString GetNetNavigatorItemText( const SCH_ITEM* aItem,
|
||||||
SCH_SYMBOL* symbol = pin->GetParentSymbol();
|
SCH_SYMBOL* symbol = pin->GetParentSymbol();
|
||||||
wxCHECK( symbol, retv );
|
wxCHECK( symbol, retv );
|
||||||
|
|
||||||
retv.Printf( _( "Symbol %s pin %s" ), symbol->GetRef( &aSheetPath, true ),
|
retv.Printf( _( "Symbol '%s' pin '%s'" ), symbol->GetRef( &aSheetPath, true ),
|
||||||
pin->GetNumber() );
|
pin->GetNumber() );
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -92,7 +93,7 @@ static wxString GetNetNavigatorItemText( const SCH_ITEM* aItem,
|
||||||
SCH_SHEET* sheet = pin->GetParent();
|
SCH_SHEET* sheet = pin->GetParent();
|
||||||
wxCHECK( sheet, retv );
|
wxCHECK( sheet, retv );
|
||||||
|
|
||||||
retv.Printf( _( "Sheet %s pin %s" ), sheet->GetName(), pin->GetText() );
|
retv.Printf( _( "Sheet '%s' pin '%s'" ), sheet->GetName(), pin->GetText() );
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case SCH_LABEL_T:
|
case SCH_LABEL_T:
|
||||||
|
@ -100,7 +101,7 @@ static wxString GetNetNavigatorItemText( const SCH_ITEM* aItem,
|
||||||
const SCH_LABEL* label = static_cast<const SCH_LABEL*>( aItem );
|
const SCH_LABEL* label = static_cast<const SCH_LABEL*>( aItem );
|
||||||
wxCHECK( label, retv );
|
wxCHECK( label, retv );
|
||||||
|
|
||||||
retv.Printf( _( "Label %s at %s, %s" ), label->GetText(),
|
retv.Printf( _( "Label '%s' at %s, %s" ), label->GetText(),
|
||||||
aUnitsProvider->MessageTextFromValue( label->GetPosition().x ),
|
aUnitsProvider->MessageTextFromValue( label->GetPosition().x ),
|
||||||
aUnitsProvider->MessageTextFromValue( label->GetPosition().y ) );
|
aUnitsProvider->MessageTextFromValue( label->GetPosition().y ) );
|
||||||
break;
|
break;
|
||||||
|
@ -110,7 +111,7 @@ static wxString GetNetNavigatorItemText( const SCH_ITEM* aItem,
|
||||||
const SCH_GLOBALLABEL* label = static_cast<const SCH_GLOBALLABEL*>( aItem );
|
const SCH_GLOBALLABEL* label = static_cast<const SCH_GLOBALLABEL*>( aItem );
|
||||||
wxCHECK( label, retv );
|
wxCHECK( label, retv );
|
||||||
|
|
||||||
retv.Printf( _( "Global label %s at %s, %s" ), label->GetText(),
|
retv.Printf( _( "Global label '%s' at %s, %s" ), label->GetText(),
|
||||||
aUnitsProvider->MessageTextFromValue( label->GetPosition().x ),
|
aUnitsProvider->MessageTextFromValue( label->GetPosition().x ),
|
||||||
aUnitsProvider->MessageTextFromValue( label->GetPosition().y ) );
|
aUnitsProvider->MessageTextFromValue( label->GetPosition().y ) );
|
||||||
break;
|
break;
|
||||||
|
@ -120,7 +121,7 @@ static wxString GetNetNavigatorItemText( const SCH_ITEM* aItem,
|
||||||
const SCH_HIERLABEL* label = static_cast<const SCH_HIERLABEL*>( aItem );
|
const SCH_HIERLABEL* label = static_cast<const SCH_HIERLABEL*>( aItem );
|
||||||
wxCHECK( label, retv );
|
wxCHECK( label, retv );
|
||||||
|
|
||||||
retv.Printf( _( "Hierarchical label %s at %s, %s" ), label->GetText(),
|
retv.Printf( _( "Hierarchical label '%s' at %s, %s" ), label->GetText(),
|
||||||
aUnitsProvider->MessageTextFromValue( label->GetPosition().x ),
|
aUnitsProvider->MessageTextFromValue( label->GetPosition().x ),
|
||||||
aUnitsProvider->MessageTextFromValue( label->GetPosition().y ) );
|
aUnitsProvider->MessageTextFromValue( label->GetPosition().y ) );
|
||||||
break;
|
break;
|
||||||
|
@ -135,6 +136,30 @@ static wxString GetNetNavigatorItemText( const SCH_ITEM* aItem,
|
||||||
aUnitsProvider->MessageTextFromValue( junction->GetPosition().y ) );
|
aUnitsProvider->MessageTextFromValue( junction->GetPosition().y ) );
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
case SCH_BUS_WIRE_ENTRY_T:
|
||||||
|
{
|
||||||
|
const SCH_BUS_WIRE_ENTRY* entry = static_cast<const SCH_BUS_WIRE_ENTRY*>( aItem );
|
||||||
|
wxCHECK( entry, retv );
|
||||||
|
|
||||||
|
retv.Printf( _( "Bus to wire entry from %s, %s to %s, %s" ),
|
||||||
|
aUnitsProvider->MessageTextFromValue( entry->GetPosition().x ),
|
||||||
|
aUnitsProvider->MessageTextFromValue( entry->GetPosition().y ),
|
||||||
|
aUnitsProvider->MessageTextFromValue( entry->GetEnd().x ),
|
||||||
|
aUnitsProvider->MessageTextFromValue( entry->GetEnd().y ) );
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case SCH_BUS_BUS_ENTRY_T:
|
||||||
|
{
|
||||||
|
const SCH_BUS_BUS_ENTRY* entry = static_cast<const SCH_BUS_BUS_ENTRY*>( aItem );
|
||||||
|
wxCHECK( entry, retv );
|
||||||
|
|
||||||
|
retv.Printf( _( "Bus to bus entry from %s, %s to %s, %s" ),
|
||||||
|
aUnitsProvider->MessageTextFromValue( entry->GetPosition().x ),
|
||||||
|
aUnitsProvider->MessageTextFromValue( entry->GetPosition().y ),
|
||||||
|
aUnitsProvider->MessageTextFromValue( entry->GetEnd().x ),
|
||||||
|
aUnitsProvider->MessageTextFromValue( entry->GetEnd().y ) );
|
||||||
|
break;
|
||||||
|
}
|
||||||
default:
|
default:
|
||||||
retv.Printf( _( "Unhandled item type %d" ), aItem->Type() );
|
retv.Printf( _( "Unhandled item type %d" ), aItem->Type() );
|
||||||
}
|
}
|
||||||
|
@ -164,7 +189,10 @@ void SCH_EDIT_FRAME::MakeNetNavigatorNode( const wxString& aNetName, wxTreeItemI
|
||||||
NET_NAVIGATOR_ITEM_DATA* itemData = nullptr;
|
NET_NAVIGATOR_ITEM_DATA* itemData = nullptr;
|
||||||
SCH_SHEET_PATH sheetPath = subGraph->GetSheet();
|
SCH_SHEET_PATH sheetPath = subGraph->GetSheet();
|
||||||
|
|
||||||
wxCHECK2( sheetPath.Last(), continue );
|
wxCHECK2( subGraph && sheetPath.Last(), continue );
|
||||||
|
|
||||||
|
if( subGraph->GetItems().empty() )
|
||||||
|
continue;
|
||||||
|
|
||||||
itemData = new NET_NAVIGATOR_ITEM_DATA( sheetPath, nullptr );
|
itemData = new NET_NAVIGATOR_ITEM_DATA( sheetPath, nullptr );
|
||||||
|
|
||||||
|
@ -224,7 +252,7 @@ void SCH_EDIT_FRAME::RefreshNetNavigator( const NET_NAVIGATOR_ITEM_DATA* aSelect
|
||||||
|
|
||||||
wxTreeItemId rootId = m_netNavigator->AddRoot( m_highlightedConn, 0 );
|
wxTreeItemId rootId = m_netNavigator->AddRoot( m_highlightedConn, 0 );
|
||||||
|
|
||||||
MakeNetNavigatorNode( m_highlightedConn, rootId );
|
MakeNetNavigatorNode( m_highlightedConn, rootId, aSelection );
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -298,6 +326,25 @@ void SCH_EDIT_FRAME::SelectNetNavigatorItem( const NET_NAVIGATOR_ITEM_DATA* aSel
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
const SCH_ITEM* SCH_EDIT_FRAME::GetSelectedNetNavigatorItem() const
|
||||||
|
{
|
||||||
|
if( m_netNavigator )
|
||||||
|
return nullptr;
|
||||||
|
|
||||||
|
wxTreeItemId id = m_netNavigator->GetSelection();
|
||||||
|
|
||||||
|
if( !id.IsOk() )
|
||||||
|
return nullptr;
|
||||||
|
|
||||||
|
NET_NAVIGATOR_ITEM_DATA* itemData =
|
||||||
|
dynamic_cast<NET_NAVIGATOR_ITEM_DATA*>( m_netNavigator->GetItemData( id ) );
|
||||||
|
|
||||||
|
wxCHECK( itemData, nullptr );
|
||||||
|
|
||||||
|
return itemData->GetItem();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void SCH_EDIT_FRAME::onNetNavigatorSelection( wxTreeEvent& aEvent )
|
void SCH_EDIT_FRAME::onNetNavigatorSelection( wxTreeEvent& aEvent )
|
||||||
{
|
{
|
||||||
wxCHECK( m_netNavigator, /* void */ );
|
wxCHECK( m_netNavigator, /* void */ );
|
||||||
|
|
|
@ -834,6 +834,8 @@ public:
|
||||||
|
|
||||||
wxTreeCtrl* GetNetNavigator() { return m_netNavigator; }
|
wxTreeCtrl* GetNetNavigator() { return m_netNavigator; }
|
||||||
|
|
||||||
|
const SCH_ITEM* GetSelectedNetNavigatorItem() const;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return the name of the wxAuiPaneInfo managing the Hierarchy Navigator panel
|
* @return the name of the wxAuiPaneInfo managing the Hierarchy Navigator panel
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -802,7 +802,7 @@ static bool highlightNet( TOOL_MANAGER* aToolMgr, const VECTOR2D& aPosition )
|
||||||
|
|
||||||
wxString connectionName = ( conn ) ? conn->Name() : wxString( wxS( "" ) );
|
wxString connectionName = ( conn ) ? conn->Name() : wxString( wxS( "" ) );
|
||||||
|
|
||||||
if( !conn || connectionName == editFrame->GetHighlightedConnection() )
|
if( !conn )
|
||||||
{
|
{
|
||||||
editFrame->SetStatusText( wxT( "" ) );
|
editFrame->SetStatusText( wxT( "" ) );
|
||||||
editFrame->SendCrossProbeClearHighlight();
|
editFrame->SendCrossProbeClearHighlight();
|
||||||
|
@ -811,8 +811,16 @@ static bool highlightNet( TOOL_MANAGER* aToolMgr, const VECTOR2D& aPosition )
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
NET_NAVIGATOR_ITEM_DATA itemData( editFrame->GetCurrentSheet(), item );
|
NET_NAVIGATOR_ITEM_DATA itemData( editFrame->GetCurrentSheet(), item );
|
||||||
editFrame->SetCrossProbeConnection( conn );
|
|
||||||
editFrame->SetHighlightedConnection( connectionName, &itemData );
|
if( connectionName != editFrame->GetHighlightedConnection() )
|
||||||
|
{
|
||||||
|
editFrame->SetCrossProbeConnection( conn );
|
||||||
|
editFrame->SetHighlightedConnection( connectionName, &itemData );
|
||||||
|
}
|
||||||
|
else if( item != editFrame->GetSelectedNetNavigatorItem() )
|
||||||
|
{
|
||||||
|
editFrame->SelectNetNavigatorItem( &itemData );
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
editFrame->UpdateNetHighlightStatus();
|
editFrame->UpdateNetHighlightStatus();
|
||||||
|
|
Loading…
Reference in New Issue