Add "Select All" option to disambiguation menu in page layout editor

This commit is contained in:
Mikołaj Wielgus 2020-08-10 13:24:40 +00:00 committed by Seth Hillbrand
parent 692aeff334
commit bd8de15f2f
2 changed files with 79 additions and 25 deletions

View File

@ -203,7 +203,7 @@ PL_SELECTION& PL_SELECTION_TOOL::GetSelection()
} }
EDA_ITEM* PL_SELECTION_TOOL::SelectPoint( const VECTOR2I& aWhere, bool* aSelectionCancelledFlag ) void PL_SELECTION_TOOL::SelectPoint( const VECTOR2I& aWhere, bool* aSelectionCancelledFlag )
{ {
int threshold = KiROUND( getView()->ToWorld( HITTEST_THRESHOLD_PIXELS ) ); int threshold = KiROUND( getView()->ToWorld( HITTEST_THRESHOLD_PIXELS ) );
@ -240,32 +240,38 @@ EDA_ITEM* PL_SELECTION_TOOL::SelectPoint( const VECTOR2I& aWhere, bool* aSelecti
if( aSelectionCancelledFlag ) if( aSelectionCancelledFlag )
*aSelectionCancelledFlag = true; *aSelectionCancelledFlag = true;
return nullptr; return;
} }
} }
if( !m_additive && !m_subtractive && !m_exclusive_or ) if( !m_additive && !m_subtractive && !m_exclusive_or )
ClearSelection(); ClearSelection();
if( collector.GetCount() == 1 ) bool anyAdded = false;
{ bool anySubtracted = false;
EDA_ITEM* item = collector[ 0 ];
if( m_subtractive || ( m_exclusive_or && item->IsSelected() ) ) if( collector.GetCount() > 0 )
{ {
unselect( item ); for( int i = 0; i < collector.GetCount(); ++i )
m_toolMgr->ProcessEvent( EVENTS::UnselectedEvent ); {
return nullptr; if( m_subtractive || ( m_exclusive_or && collector[i]->IsSelected() ) )
{
unselect( collector[i] );
anySubtracted = true;
} }
else else
{ {
select( item ); select( collector[i] );
m_toolMgr->ProcessEvent( EVENTS::SelectedEvent ); anyAdded = true;
return item; }
} }
} }
return nullptr; if( anyAdded )
m_toolMgr->ProcessEvent( EVENTS::SelectedEvent );
if( anySubtracted )
m_toolMgr->ProcessEvent( EVENTS::UnselectedEvent );
} }
@ -534,7 +540,9 @@ bool PL_SELECTION_TOOL::doSelectionMenu( COLLECTOR* aCollector )
EDA_ITEM* current = nullptr; EDA_ITEM* current = nullptr;
ACTION_MENU menu( true ); ACTION_MENU menu( true );
int limit = std::min( MAX_SELECT_ITEM_IDS, aCollector->GetCount() ); // ID limit is `MAX_SELECT_ITEM_IDS+1` because the last item is "select all"
// and the first item has ID of 1.
int limit = std::min( MAX_SELECT_ITEM_IDS + 1, aCollector->GetCount() );
for( int i = 0; i < limit; ++i ) for( int i = 0; i < limit; ++i )
{ {
@ -542,10 +550,13 @@ bool PL_SELECTION_TOOL::doSelectionMenu( COLLECTOR* aCollector )
EDA_ITEM* item = ( *aCollector )[i]; EDA_ITEM* item = ( *aCollector )[i];
text = item->GetSelectMenuText( m_frame->GetUserUnits() ); text = item->GetSelectMenuText( m_frame->GetUserUnits() );
wxString menuText = wxString::Format("&%d. %s", i + 1, text ); wxString menuText = wxString::Format( "&%d. %s\t%d", i + 1, text, i + 1 );
menu.Add( menuText, i + 1, item->GetMenuImage() ); menu.Add( menuText, i + 1, item->GetMenuImage() );
} }
menu.AppendSeparator();
menu.Add( _( "Select &All\tA" ), limit + 1, net_highlight_xpm );
if( aCollector->m_MenuTitle.Length() ) if( aCollector->m_MenuTitle.Length() )
menu.SetTitle( aCollector->m_MenuTitle ); menu.SetTitle( aCollector->m_MenuTitle );
@ -553,12 +564,21 @@ bool PL_SELECTION_TOOL::doSelectionMenu( COLLECTOR* aCollector )
menu.DisplayTitle( true ); menu.DisplayTitle( true );
SetContextMenu( &menu, CMENU_NOW ); SetContextMenu( &menu, CMENU_NOW );
bool selectAll = false;
while( TOOL_EVENT* evt = Wait() ) while( TOOL_EVENT* evt = Wait() )
{ {
if( evt->Action() == TA_CHOICE_MENU_UPDATE ) if( evt->Action() == TA_CHOICE_MENU_UPDATE )
{ {
if( current ) if( selectAll )
{
for( int i = 0; i < aCollector->GetCount(); ++i )
unhighlight( ( *aCollector )[i], BRIGHTENED );
}
else if( current )
{
unhighlight( current, BRIGHTENED ); unhighlight( current, BRIGHTENED );
}
int id = *evt->GetCommandId(); int id = *evt->GetCommandId();
@ -570,21 +590,51 @@ bool PL_SELECTION_TOOL::doSelectionMenu( COLLECTOR* aCollector )
} }
else else
{ {
current = NULL; current = nullptr;
}
if( id == limit + 1 )
{
for( int i = 0; i < aCollector->GetCount(); ++i )
highlight( ( *aCollector )[i], BRIGHTENED );
selectAll = true;
}
else
{
selectAll = false;
} }
} }
else if( evt->Action() == TA_CHOICE_MENU_CHOICE ) else if( evt->Action() == TA_CHOICE_MENU_CHOICE )
{ {
if( current ) if( selectAll )
{
for( int i = 0; i < aCollector->GetCount(); ++i )
unhighlight( ( *aCollector )[i], BRIGHTENED );
}
else if( current )
{
unhighlight( current, BRIGHTENED ); unhighlight( current, BRIGHTENED );
}
OPT<int> id = evt->GetCommandId(); OPT<int> id = evt->GetCommandId();
// User has selected an item, so this one will be returned // User has selected an item, so this one will be returned
if( id && ( *id > 0 ) ) if( id == limit + 1 )
{
selectAll = true;
current = nullptr;
}
else if( id && ( *id > 0 ) && ( *id <= limit ) )
{
selectAll = false;
current = ( *aCollector )[*id - 1]; current = ( *aCollector )[*id - 1];
}
else else
current = NULL; {
selectAll = false;
current = nullptr;
}
} }
else if( evt->Action() == TA_CHOICE_MENU_CLOSED ) else if( evt->Action() == TA_CHOICE_MENU_CLOSED )
{ {
@ -595,7 +645,11 @@ bool PL_SELECTION_TOOL::doSelectionMenu( COLLECTOR* aCollector )
m_frame->GetCanvas()->Refresh(); m_frame->GetCanvas()->Refresh();
} }
if( current ) if( selectAll )
{
return true;
}
else if( current )
{ {
unhighlight( current, BRIGHTENED ); unhighlight( current, BRIGHTENED );

View File

@ -91,7 +91,7 @@ public:
* @param aSelectionCancelledFlag allows the function to inform its caller that a selection * @param aSelectionCancelledFlag allows the function to inform its caller that a selection
* was cancelled (for instance, by clicking outside of the disambiguation menu). * was cancelled (for instance, by clicking outside of the disambiguation menu).
*/ */
EDA_ITEM* SelectPoint( const VECTOR2I& aWhere, bool* aSelectionCancelledFlag = nullptr ); void SelectPoint( const VECTOR2I& aWhere, bool* aSelectionCancelledFlag = nullptr );
int AddItemToSel( const TOOL_EVENT& aEvent ); int AddItemToSel( const TOOL_EVENT& aEvent );
void AddItemToSel( EDA_ITEM* aItem, bool aQuietMode = false ); void AddItemToSel( EDA_ITEM* aItem, bool aQuietMode = false );