From 36508807e71f700fcb5c04b2a777562a0fa3e4b3 Mon Sep 17 00:00:00 2001 From: Jeff Young Date: Fri, 15 Jan 2021 00:50:52 +0000 Subject: [PATCH] Give the pad placement tool a context menu. ADDED: allow pad properties to be edited while placing pads. Fixes https://gitlab.com/kicad/code/kicad/issues/6953 --- pcbnew/tools/pad_tool.cpp | 28 +++++++++++++++++++++++----- pcbnew/tools/pcb_tool_base.cpp | 8 +++++++- 2 files changed, 30 insertions(+), 6 deletions(-) diff --git a/pcbnew/tools/pad_tool.cpp b/pcbnew/tools/pad_tool.cpp index f1719c69bc..9dfec71c2a 100644 --- a/pcbnew/tools/pad_tool.cpp +++ b/pcbnew/tools/pad_tool.cpp @@ -101,7 +101,23 @@ bool PAD_TOOL::Init() menu.AddItem( PCB_ACTIONS::pushPadSettings, singlePadSel, 400 ); } + auto& ctxMenu = m_menu.GetMenu(); + + // cancel current tool goes in main context menu at the top if present + ctxMenu.AddItem( ACTIONS::cancelInteractive, SELECTION_CONDITIONS::ShowAlways, 1 ); + ctxMenu.AddSeparator( 1 ); + + ctxMenu.AddItem( PCB_ACTIONS::rotateCcw, SELECTION_CONDITIONS::ShowAlways ); + ctxMenu.AddItem( PCB_ACTIONS::rotateCw, SELECTION_CONDITIONS::ShowAlways ); + ctxMenu.AddItem( PCB_ACTIONS::flip, SELECTION_CONDITIONS::ShowAlways ); + ctxMenu.AddItem( PCB_ACTIONS::mirror, SELECTION_CONDITIONS::ShowAlways ); + ctxMenu.AddItem( PCB_ACTIONS::properties, SELECTION_CONDITIONS::ShowAlways ); + + // Finally, add the standard zoom/grid items + getEditFrame()->AddStandardSubMenus( m_menu ); + return true; + } @@ -526,19 +542,22 @@ int PAD_TOOL::EditPad( const TOOL_EVENT& aEvent ) PAD* pad = static_cast( selection[0] ); PCB_LAYER_ID layer = explodePad( pad ); - m_wasHighContrast = ( opts.m_ContrastModeDisplay != - HIGH_CONTRAST_MODE::NORMAL ); + m_wasHighContrast = ( opts.m_ContrastModeDisplay != HIGH_CONTRAST_MODE::NORMAL ); frame()->SetActiveLayer( layer ); if( !m_wasHighContrast ) m_toolMgr->RunAction( ACTIONS::highContrastMode, false ); if( PCB_ACTIONS::explodePad.GetHotKey() == PCB_ACTIONS::recombinePad.GetHotKey() ) + { msg.Printf( _( "Pad Edit Mode. Press %s again to exit." ), - KeyNameFromKeyCode( PCB_ACTIONS::recombinePad.GetHotKey() ) ); + KeyNameFromKeyCode( PCB_ACTIONS::recombinePad.GetHotKey() ) );} + else + { msg.Printf( _( "Pad Edit Mode. Press %s to exit." ), KeyNameFromKeyCode( PCB_ACTIONS::recombinePad.GetHotKey() ) ); + } infoBar->RemoveAllButtons(); infoBar->ShowMessage( msg, wxICON_INFORMATION ); @@ -548,8 +567,7 @@ int PAD_TOOL::EditPad( const TOOL_EVENT& aEvent ) if( m_editPad == niluuid ) { - bool highContrast = ( opts.m_ContrastModeDisplay != - HIGH_CONTRAST_MODE::NORMAL ); + bool highContrast = ( opts.m_ContrastModeDisplay != HIGH_CONTRAST_MODE::NORMAL ); if( m_wasHighContrast != highContrast ) m_toolMgr->RunAction( ACTIONS::highContrastMode, false ); diff --git a/pcbnew/tools/pcb_tool_base.cpp b/pcbnew/tools/pcb_tool_base.cpp index a3beaaf7f4..cfa697417f 100644 --- a/pcbnew/tools/pcb_tool_base.cpp +++ b/pcbnew/tools/pcb_tool_base.cpp @@ -23,7 +23,6 @@ #include "pcb_tool_base.h" -#include #include #include #include @@ -221,6 +220,13 @@ void PCB_TOOL_BASE::doInteractiveItemPlacement( const std::string& aTool, // Refresh preview after event runs m_toolMgr->RunAction( ACTIONS::refreshPreview ); } + else if( evt->IsAction( &PCB_ACTIONS::properties ) ) + { + frame()->OnEditItemRequest( newItem.get() ); + + // Notify other tools of the changes + m_toolMgr->ProcessEvent( EVENTS::SelectedItemsModified ); + } else if( evt->IsAction( &ACTIONS::refreshPreview ) ) { preview.Clear();