Use selection tool for locateItem.

This commit is contained in:
Jeff Young 2019-05-06 09:52:51 +01:00
parent f87d371b8b
commit 8e75824d29
2 changed files with 16 additions and 68 deletions

View File

@ -1297,81 +1297,31 @@ void LIB_EDIT_FRAME::OnOrient( wxCommandEvent& aEvent )
} }
LIB_ITEM* LIB_EDIT_FRAME::LocateItemUsingCursor( const wxPoint& aPosition, LIB_ITEM* LIB_EDIT_FRAME::LocateItemUsingCursor( const wxPoint& aPos, const KICAD_T aFilter[] )
const KICAD_T aFilterList[] )
{ {
wxPoint pos; SCH_SELECTION_TOOL* selTool = m_toolManager->GetTool<SCH_SELECTION_TOOL>();
LIB_PART* part = GetCurPart(); LIB_PART* part = GetCurPart();
bool cancelled = false;
wxPoint gridPos;
if( !part ) if( !part )
return NULL; return NULL;
LIB_ITEM* item = locateItem( aPosition, aFilterList ); m_toolManager->RunAction( SCH_ACTIONS::clearSelection, true );
EDA_ITEM* item = selTool->SelectPoint( aPos, aFilter, &cancelled );
// If the user aborted the clarification context menu, don't show it again at the // If the user aborted the clarification context menu, don't show it again at the
// grid position. // grid position.
if( !item && m_canvas->GetAbortRequest() ) if( !item && !cancelled )
return NULL; {
gridPos = GetNearestGridPosition( aPos );
pos = GetNearestGridPosition( aPosition ); if( aPos != gridPos )
item = selTool->SelectPoint( gridPos, aFilter );
if( item == NULL && aPosition != pos )
item = locateItem( pos, aFilterList );
return item;
} }
// JEY TODO: move to a selection event...
LIB_ITEM* LIB_EDIT_FRAME::locateItem( const wxPoint& aPosition, const KICAD_T aFilterList[] )
{
LIB_PART* part = GetCurPart();
if( !part )
return NULL;
#if 0
SCH_SELECTION_TOOL* selTool = m_toolManager->GetTool<SCH_SELECTION_TOOL>();
EDA_ITEM* item = selTool->SelectPoint( aPosition, aFilterList );
#else
LIB_ITEM* item = NULL;
m_collectedItems.Collect( part, aFilterList, aPosition, m_unit, m_convert );
if( m_collectedItems.GetCount() == 0 )
{
ClearMsgPanel();
}
else if( m_collectedItems.GetCount() == 1 )
{
item = (LIB_ITEM*) m_collectedItems[0];
}
else
{
wxASSERT_MSG( m_collectedItems.GetCount() <= MAX_SELECT_ITEM_IDS,
"Select item clarification context menu size limit exceeded." );
wxMenu selectMenu;
AddMenuItem( &selectMenu, wxID_NONE, _( "Clarify Selection" ), KiBitmap( info_xpm ) );
selectMenu.AppendSeparator();
for( int i = 0; i < m_collectedItems.GetCount() && i < MAX_SELECT_ITEM_IDS; i++ )
{
wxString text = m_collectedItems[i]->GetSelectMenuText( m_UserUnits );
BITMAP_DEF xpm = m_collectedItems[i]->GetMenuImage();
AddMenuItem( &selectMenu, ID_SELECT_ITEM_START + i, text, KiBitmap( xpm ) );
}
// Set to NULL in case user aborts the clarification context menu.
SetDrawItem( NULL );
m_canvas->SetAbortRequest( true ); // Changed to false if an item is selected
PopupMenu( &selectMenu );
m_canvas->MoveCursorToCrossHair();
item = GetDrawItem();
}
#endif
if( item ) if( item )
{ {
MSG_PANEL_ITEMS items; MSG_PANEL_ITEMS items;

View File

@ -138,8 +138,6 @@ class LIB_EDIT_FRAME : public SCH_BASE_FRAME
friend class DIALOG_LIB_EDIT_TEXT; friend class DIALOG_LIB_EDIT_TEXT;
LIB_ITEM* locateItem( const wxPoint& aPosition, const KICAD_T aFilterList[] );
public: public:
LIB_EDIT_FRAME( KIWAY* aKiway, wxWindow* aParent ); LIB_EDIT_FRAME( KIWAY* aKiway, wxWindow* aParent );
@ -595,8 +593,8 @@ private:
void EditGraphicSymbol( wxDC* DC, LIB_ITEM* DrawItem ); void EditGraphicSymbol( wxDC* DC, LIB_ITEM* DrawItem );
void EditSymbolText( wxDC* DC, LIB_ITEM* DrawItem ); void EditSymbolText( wxDC* DC, LIB_ITEM* DrawItem );
LIB_ITEM* LocateItemUsingCursor( const wxPoint& aPosition, LIB_ITEM* LocateItemUsingCursor( const wxPoint& aPos,
const KICAD_T aFilterList[] = SCH_COLLECTOR::LibItems ); const KICAD_T aFilter[] = SCH_COLLECTOR::LibItems );
void EditField( LIB_FIELD* Field ); void EditField( LIB_FIELD* Field );
void refreshSchematic(); void refreshSchematic();