Pcbnew: Drag selections containing only tracks or vias
CHANGED: If the user made a selection and then tried dragging it, the drag would only succeed if the selection contained at least one footprint. Selections with only tracks and vias would instead make KiCad drag a new selection box. This MR allows routing of selections of a single track or via, while moving selections containing more than one item, whether or not they also contain a footprint. Fixes https://gitlab.com/kicad/code/kicad/issues/7539
This commit is contained in:
parent
b2cd97fd84
commit
c001c26575
|
@ -398,9 +398,12 @@ int PCB_SELECTION_TOOL::Main( const TOOL_EVENT& aEvent )
|
||||||
// Yes -> run the move tool and wait till it finishes
|
// Yes -> run the move tool and wait till it finishes
|
||||||
TRACK* track = dynamic_cast<TRACK*>( m_selection.GetItem( 0 ) );
|
TRACK* track = dynamic_cast<TRACK*>( m_selection.GetItem( 0 ) );
|
||||||
|
|
||||||
if( track && trackDragAction == TRACK_DRAG_ACTION::DRAG )
|
// If there is only item in the selection and it's a track, then we need to route it
|
||||||
|
bool doRouting = ( track && ( 1 == m_selection.GetSize() ) );
|
||||||
|
|
||||||
|
if( doRouting && trackDragAction == TRACK_DRAG_ACTION::DRAG )
|
||||||
m_toolMgr->RunAction( PCB_ACTIONS::drag45Degree, true );
|
m_toolMgr->RunAction( PCB_ACTIONS::drag45Degree, true );
|
||||||
else if( track && trackDragAction == TRACK_DRAG_ACTION::DRAG_FREE_ANGLE )
|
else if( doRouting && trackDragAction == TRACK_DRAG_ACTION::DRAG_FREE_ANGLE )
|
||||||
m_toolMgr->RunAction( PCB_ACTIONS::dragFreeAngle, true );
|
m_toolMgr->RunAction( PCB_ACTIONS::dragFreeAngle, true );
|
||||||
else
|
else
|
||||||
m_toolMgr->RunAction( PCB_ACTIONS::move, true );
|
m_toolMgr->RunAction( PCB_ACTIONS::move, true );
|
||||||
|
|
Loading…
Reference in New Issue