KiCad PCB EDA Suite
Loading...
Searching...
No Matches
pcb_selection_tool.h
Go to the documentation of this file.
1/*
2 * This program source code file is part of KiCad, a free EDA CAD application.
3 *
4 * Copyright (C) 2013-2017 CERN
5 * Copyright The KiCad Developers, see AUTHORS.TXT for contributors.
6 *
7 * @author Tomasz Wlostowski <[email protected]>
8 * @author Maciej Suminski <[email protected]>
9 *
10 * This program is free software; you can redistribute it and/or
11 * modify it under the terms of the GNU General Public License
12 * as published by the Free Software Foundation; either version 2
13 * of the License, or (at your option) any later version.
14 *
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU General Public License for more details.
19 *
20 * You should have received a copy of the GNU General Public License
21 * along with this program; if not, you may find one here:
22 * http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
23 * or you may search the http://www.gnu.org website for the version 2 license,
24 * or you may write to the Free Software Foundation, Inc.,
25 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
26 */
27
28#ifndef PCB_SELECTION_TOOL_H
29#define PCB_SELECTION_TOOL_H
30
31#include <functional>
32#include <memory>
33
34#include <tool/actions.h>
35#include <math/vector2d.h>
38#include <tool/action_menu.h>
39#include <tool/selection_tool.h>
40#include <tool/tool_menu.h>
42#include <tools/pcb_tool_base.h>
43#include <tools/pcb_selection.h>
44
45class PCB_BASE_FRAME;
46class BOARD_ITEM;
48class PCB_TABLE;
49class PCB_TABLECELL;
50
51namespace KIGFX
52{
53 class GAL;
54}
55
56
67{
68public:
71
73 bool Init() override;
74
76 void Reset( RESET_REASON aReason ) override;
77
78 void OnIdle( wxIdleEvent& aEvent );
79
81 {
83 }
84
88 int Main( const TOOL_EVENT& aEvent );
89
94
103
105 int CursorSelection( const TOOL_EVENT& aEvent );
106
107 int SelectColumns( const TOOL_EVENT& aEvent );
108 int SelectRows( const TOOL_EVENT& aEvent );
109 int SelectTable( const TOOL_EVENT& aEvent );
110
112 int ClearSelection( const TOOL_EVENT& aEvent );
113 void ClearSelection( bool aQuietMode = false );
114
116 int SelectAll( const TOOL_EVENT& aEvent );
117
119 int UnselectAll( const TOOL_EVENT& aEvent );
120
122 int SetSelectRect( const TOOL_EVENT& aEvent );
123 int SetSelectPoly( const TOOL_EVENT& aEvent );
124
130 int SelectRectArea( const TOOL_EVENT& aEvent );
131
138 int SelectPolyArea( const TOOL_EVENT& aEvent );
139
143 void SelectMultiple( KIGFX::PREVIEW::SELECTION_AREA& aArea, bool aSubtractive = false,
144 bool aExclusiveOr = false );
145
151 void FindItem( BOARD_ITEM* aItem );
152
158 void select( EDA_ITEM* aItem ) override;
159
163 bool Selectable( const BOARD_ITEM* aItem, bool checkVisibilityOnly = false ) const;
164
171 void SelectAllItemsOnNet( int aNetCode, bool aSelect = true );
172
180 void GuessSelectionCandidates( GENERAL_COLLECTOR& aCollector, const VECTOR2I& aWhere ) const;
181
188 void RebuildSelection();
189
191 {
192 return m_filter;
193 }
194
196 void setTransitions() override;
197
199 void zoomFitSelection();
200
202 void ZoomFitCrossProbeBBox( const BOX2I& bbox );
203
207 void EnterGroup() override;
208
214 void ExitGroup( bool aSelectGroup = false ) override;
215
220
221 PCB_LAYER_ID GetActiveLayer() { return m_frame->GetActiveLayer(); }
222
227
234
239 void FilterCollectorForHierarchy( GENERAL_COLLECTOR& aCollector, bool aMultiselect ) const;
240
246 bool aForcePromotion = false ) const;
247
251 void FilterCollectorForTableCells( GENERAL_COLLECTOR& aCollector ) const;
252
256 void FilterCollectorForMarkers( GENERAL_COLLECTOR& aCollector ) const;
257
261 void FilterCollectedItems( GENERAL_COLLECTOR& aCollector, bool aMultiSelect,
262 PCB_SELECTION_FILTER_OPTIONS* aRejected = nullptr );
263
268 const VECTOR2I& aWhere ) const;
269
270protected:
272 {
273 return static_cast<KIGFX::PCB_VIEW*>( getView() );
274 }
275
277 {
278 return getViewControls();
279 }
280
282 {
284 }
285
290
291 BOARD* board() const
292 {
293 return getModel<BOARD>();
294 }
295
297 {
298 return static_cast<PCB_DRAW_PANEL_GAL*>( frame()->GetCanvas() );
299 }
300
301 virtual bool ctrlClickHighlights() override;
302
303 SELECTION& selection() override { return m_selection; }
304
305private:
320 bool selectPoint( const VECTOR2I& aWhere, bool aOnDrag = false,
321 bool* aSelectionCancelledFlag = nullptr,
322 CLIENT_SELECTION_FILTER aClientFilter = nullptr );
323
332 bool selectCursor( bool aForceSelect = false,
333 CLIENT_SELECTION_FILTER aClientFilter = nullptr );
334
335 bool selectTableCells( PCB_TABLE* aTable );
336
342
348 void selectCellsBetween( const VECTOR2D& aStart, const VECTOR2D& aEnd, PCB_TABLE* aTable );
349
358 bool extendTableCellSelectionTo( const VECTOR2I& aPosition );
359
369 bool toggleTableCellSelection( const VECTOR2I& aPosition );
370
375 void collectTableCellsAt( const VECTOR2I& aPosition, GENERAL_COLLECTOR& aCollector );
376
382
386 int disambiguateCursor( const TOOL_EVENT& aEvent );
387
391 int expandConnection( const TOOL_EVENT& aEvent );
392
396 int unrouteSelected( const TOOL_EVENT& aEvent );
397
401 int unrouteSegment( const TOOL_EVENT& aEvent );
402
406 int selectNet( const TOOL_EVENT& aEvent );
407
411 int selectNetChain( const TOOL_EVENT& aEvent );
412
416 int selectUnconnected( const TOOL_EVENT& aEvent );
417
421 int grabUnconnected( const TOOL_EVENT& aEvent );
422
439
445 void selectAllConnectedTracks( const std::vector<BOARD_CONNECTED_ITEM*>& aStartItems,
446 STOP_CONDITION aStopCondition );
447
453 void selectAllConnectedShapes( const std::vector<PCB_SHAPE*>& aStartItems );
454
458 bool isExpandableGraphicShape( const EDA_ITEM* aItem ) const;
459
460 /*
461 * Select tracks and vias connected to specified board items.
462 */
463 void selectConnections( const std::vector<BOARD_ITEM*>& aItems );
464
470 void selectAllItemsOnSheet( wxString& aSheetPath );
471
473 int selectSheetContents( const TOOL_EVENT& aEvent );
474
477 int selectSameSheet( const TOOL_EVENT& aEvent );
478
481 int syncSelection( const TOOL_EVENT& aEvent );
482 int syncSelectionWithNets( const TOOL_EVENT& aEvent );
483 void doSyncSelection( const std::vector<BOARD_ITEM*>& aItems, bool aWithNets );
484
486 int filterSelection( const TOOL_EVENT& aEvent );
487
489 bool itemPassesFilter( BOARD_ITEM* aItem, bool aMultiSelect,
490 PCB_SELECTION_FILTER_OPTIONS* aRejected = nullptr );
491
497 void unselect( EDA_ITEM* aItem ) override;
498
506 void highlight( EDA_ITEM* aItem, int aHighlightMode, SELECTION* aGroup = nullptr ) override;
507
515 void unhighlight( EDA_ITEM* aItem, int aHighlightMode, SELECTION* aGroup = nullptr ) override;
516
520 bool selectionContains( const VECTOR2I& aPoint ) const;
521
525 int hitTestDistance( const VECTOR2I& aWhere, BOARD_ITEM* aItem, int aMaxDistance ) const;
526
530 int updateSelection( const TOOL_EVENT& aEvent );
531
532 void pruneObscuredSelectionCandidates( GENERAL_COLLECTOR& aCollector ) const;
533
535
536private:
537 void highlightInternal( EDA_ITEM* aItem, int aHighlightMode, bool aUsingOverlay );
538
539 void unhighlightInternal( EDA_ITEM* aItem, int aHighlightMode, bool aUsingOverlay );
540
541private:
542 PCB_BASE_FRAME* m_frame; // Pointer to the parent frame
544
545 PCB_SELECTION m_selection; // Current state of selection
546
548
549 KICURSOR m_nonModifiedCursor; // Cursor in the absence of shift/ctrl/alt
550
551 PCB_GROUP* m_enteredGroup; // If non-null, selections are limited to
552 // members of this group
553 KIGFX::VIEW_GROUP m_enteredGroupOverlay; // Overlay for the entered group's frame.
554
555 SELECTION_MODE m_selectionMode; // Current selection mode
556
558
559 // Anchor cell for shift+click range selection in a PCB_TABLE
561
563 class PRIV;
564 std::unique_ptr<PRIV> m_priv;
565};
566
567#endif /* PCB_SELECTION_TOOL_H */
std::function< void(const VECTOR2I &, GENERAL_COLLECTOR &, PCB_SELECTION_TOOL *)> CLIENT_SELECTION_FILTER
Definition actions.h:37
BOX2< VECTOR2I > BOX2I
Definition box2.h:922
A base class for any item which can be embedded within the BOARD container class, and therefore insta...
Definition board_item.h:84
Information pertinent to a Pcbnew printed circuit board.
Definition board.h:323
A base class for most all the KiCad significant classes used in schematics and boards.
Definition eda_item.h:100
A general implementation of a COLLECTORS_GUIDE.
Definition collectors.h:324
Used when the right click button is pressed, or when the select tool is in effect.
Definition collectors.h:207
Abstract interface for drawing on a 2D-surface.
Represent a selection area (currently a rectangle) in a VIEW, drawn corner-to-corner between two poin...
An interface for classes handling user events controlling the view behavior such as zooming,...
Extend VIEW_ITEM by possibility of grouping items into a single object.
Definition view_group.h:43
Common, abstract interface for edit frames.
Base PCB main window class for Pcbnew, Gerbview, and CvPcb footprint viewer.
PCB_DRAW_PANEL_GAL * GetCanvas() const override
Return a pointer to GAL-based canvas of given EDA draw frame.
A set of BOARD_ITEMs (i.e., without duplicates).
Definition pcb_group.h:53
Private implementation of firewalled private data.
void highlight(EDA_ITEM *aItem, int aHighlightMode, SELECTION *aGroup=nullptr) override
Highlight the item visually.
int syncSelectionWithNets(const TOOL_EVENT &aEvent)
int SelectTable(const TOOL_EVENT &aEvent)
Clear current selection event handler.
PCB_BASE_FRAME * frame() const
int syncSelection(const TOOL_EVENT &aEvent)
int selectNet(const TOOL_EVENT &aEvent)
Select all copper connections belonging to the same net(s) as the items in the selection.
int filterSelection(const TOOL_EVENT &aEvent)
Return true if the given item passes the current SELECTION_FILTER_OPTIONS.
void ZoomFitCrossProbeBBox(const BOX2I &bbox)
void EnterGroup() override
Enter the group at the head of the current selection.
void doSyncSelection(const std::vector< BOARD_ITEM * > &aItems, bool aWithNets)
Invoke filter dialog and modify current selection.
SELECTION_MODE m_selectionMode
void GuessSelectionCandidates(GENERAL_COLLECTOR &aCollector, const VECTOR2I &aWhere) const
Try to guess best selection candidates in case multiple items are clicked, by doing some brain-dead h...
int selectNetChain(const TOOL_EVENT &aEvent)
Select all copper connections belonging to every net in the selected item's net chain.
void ExitGroup(bool aSelectGroup=false) override
Leave the currently-entered group.
bool isExpandableGraphicShape(const EDA_ITEM *aItem) const
bool toggleTableCellSelection(const VECTOR2I &aPosition)
When the user Ctrl-clicks inside a PCB_TABLE whose cells are already in the selection,...
int disambiguateCursor(const TOOL_EVENT &aEvent)
Handle disambiguation actions including displaying the menu.
int SelectPolyArea(const TOOL_EVENT &aEvent)
Handles drawing a lasso selection area that allows multiple items to be selected simultaneously.
void FilterCollectorForMarkers(GENERAL_COLLECTOR &aCollector) const
Drop any PCB_MARKERs from the collector.
int UnselectAll(const TOOL_EVENT &aEvent)
Change the selection mode.
void unhighlightInternal(EDA_ITEM *aItem, int aHighlightMode, bool aUsingOverlay)
bool selectionContains(const VECTOR2I &aPoint) const
void select(EDA_ITEM *aItem) override
Take necessary action mark an item as selected.
bool selectCursor(bool aForceSelect=false, CLIENT_SELECTION_FILTER aClientFilter=nullptr)
Select an item under the cursor unless there is something already selected.
int SetSelectPoly(const TOOL_EVENT &aEvent)
int SetSelectRect(const TOOL_EVENT &aEvent)
int SelectColumns(const TOOL_EVENT &aEvent)
std::unique_ptr< PRIV > m_priv
PCB_TABLECELL * singleSelectedCell() const
int unrouteSelected(const TOOL_EVENT &aEvent)
Unroute the selected board connected items.
void ReportFilteredLockedItems()
If the most recent FilterCollectorForLockedItems call removed at least one item, show an InfoBar warn...
int unrouteSegment(const TOOL_EVENT &aEvent)
Unroute the selected track connected item.
SELECTION & selection() override
Return a reference to the selection.
int grabUnconnected(const TOOL_EVENT &aEvent)
Select and move other nearest footprint unconnected on same net as selected items.
PCB_SELECTION & RequestSelection(CLIENT_SELECTION_FILTER aClientFilter)
Return the current selection, filtered according to aClientFilter.
void FilterCollectorForFreePads(GENERAL_COLLECTOR &aCollector, bool aForcePromotion=false) const
Check the "allow free pads" setting and if disabled, replace any pads in the collector with their par...
bool itemPassesFilter(BOARD_ITEM *aItem, bool aMultiSelect, PCB_SELECTION_FILTER_OPTIONS *aRejected=nullptr)
const GENERAL_COLLECTORS_GUIDE getCollectorsGuide() const
bool Selectable(const BOARD_ITEM *aItem, bool checkVisibilityOnly=false) const
bool selectPoint(const VECTOR2I &aWhere, bool aOnDrag=false, bool *aSelectionCancelledFlag=nullptr, CLIENT_SELECTION_FILTER aClientFilter=nullptr)
Select an item pointed by the parameter aWhere.
KIGFX::PCB_VIEW * view() const
void selectAllItemsOnSheet(wxString &aSheetPath)
Select all items with the given sheet timestamp/UUID name (the sheet path).
PCB_GROUP * GetEnteredGroup()
void FilterCollectorForHierarchy(GENERAL_COLLECTOR &aCollector, bool aMultiselect) const
In general we don't want to select both a parent and any of it's children.
void SelectMultiple(KIGFX::PREVIEW::SELECTION_AREA &aArea, bool aSubtractive=false, bool aExclusiveOr=false)
Selects multiple PCB items within a specified area.
void setTransitions() override
Zoom the screen to center and fit the current selection.
PCB_BASE_EDIT_FRAME * editFrame() const
int expandConnection(const TOOL_EVENT &aEvent)
Expand the current connected-item selection to the next boundary (junctions, pads,...
PCB_SELECTION_FILTER_OPTIONS & GetFilter()
Set up handlers for various events.
PCB_LAYER_ID GetActiveLayer()
int selectUnconnected(const TOOL_EVENT &aEvent)
Select nearest unconnected footprints on same net as selected items.
virtual bool ctrlClickHighlights() override
Determine if ctrl-click is highlight net or XOR selection.
int selectSheetContents(const TOOL_EVENT &aEvent)
Select all footprints belonging to same hierarchical sheet as the selected footprint (same sheet path...
int SelectRows(const TOOL_EVENT &aEvent)
int selectSameSheet(const TOOL_EVENT &aEvent)
Set selection to items passed by parameter and connected nets (optionally).
void zoomFitSelection()
Zoom the screen to fit the bounding box for cross probing/selection sync.
void selectAllConnectedTracks(const std::vector< BOARD_CONNECTED_ITEM * > &aStartItems, STOP_CONDITION aStopCondition)
Select connected tracks and vias.
KIGFX::VIEW_CONTROLS * controls() const
int CursorSelection(const TOOL_EVENT &aEvent)
int ClearSelection(const TOOL_EVENT &aEvent)
void collectTableCellsAt(const VECTOR2I &aPosition, GENERAL_COLLECTOR &aCollector)
Collect PCB_TABLECELL items at aPosition into aCollector, scoped to either the active footprint (in t...
void highlightInternal(EDA_ITEM *aItem, int aHighlightMode, bool aUsingOverlay)
PCB_BASE_FRAME * m_frame
PCB_SELECTION_FILTER_OPTIONS m_filter
void initializeTableCellSelectionState(PCB_TABLE *aTable)
Mark the existing selection state of table cells so that drag- and shift-click range selection can pr...
PCB_SELECTION & GetSelection()
@ STOP_AT_SEGMENT
Stop when reaching a segment (next track/arc/via).
@ STOP_AT_PAD
Stop when reaching a pad.
@ STOP_NEVER
Select the entire net.
@ STOP_AT_JUNCTION
Stop at any place where more than two traces meet.
int Main(const TOOL_EVENT &aEvent)
The main loop.
void RebuildSelection()
Rebuild the selection from the EDA_ITEMs' selection flags.
void pruneObscuredSelectionCandidates(GENERAL_COLLECTOR &aCollector) const
void OnIdle(wxIdleEvent &aEvent)
PCB_DRAW_PANEL_GAL * canvas() const
void FilterCollectorForFootprints(GENERAL_COLLECTOR &aCollector, const VECTOR2I &aWhere) const
Drop footprints that are not directly selected.
PCB_TABLECELL * m_previousFirstCell
void FindItem(BOARD_ITEM *aItem)
Take necessary actions to mark an item as found.
void FilterCollectorForLockedItems(GENERAL_COLLECTOR &aCollector)
In the PCB editor strip out any locked items unless the OverrideLocks checkbox is set.
int SelectRectArea(const TOOL_EVENT &aEvent)
Handles drawing a selection box that allows multiple items to be selected simultaneously.
int updateSelection(const TOOL_EVENT &aEvent)
Event handler to update the selection VIEW_ITEM.
bool Init() override
Init() is called once upon a registration of the tool.
KIGFX::VIEW_GROUP m_enteredGroupOverlay
void selectConnections(const std::vector< BOARD_ITEM * > &aItems)
int hitTestDistance(const VECTOR2I &aWhere, BOARD_ITEM *aItem, int aMaxDistance) const
bool extendTableCellSelectionTo(const VECTOR2I &aPosition)
If the current selection holds one or more cells from a single PCB_TABLE and the cursor is over anoth...
void selectAllConnectedShapes(const std::vector< PCB_SHAPE * > &aStartItems)
Select all non-closed shapes that are graphically connected to the given start items.
void SelectAllItemsOnNet(int aNetCode, bool aSelect=true)
Select all items with the given net code.
void FilterCollectorForTableCells(GENERAL_COLLECTOR &aCollector) const
Promote any table cell selections to the whole table.
void unselect(EDA_ITEM *aItem) override
Take necessary action mark an item as unselected.
int SelectAll(const TOOL_EVENT &aEvent)
Unselect all items on the board.
void FilterCollectedItems(GENERAL_COLLECTOR &aCollector, bool aMultiSelect, PCB_SELECTION_FILTER_OPTIONS *aRejected=nullptr)
Apply the SELECTION_FITLER_OPTIONS to the collector.
void selectCellsBetween(const VECTOR2D &aStart, const VECTOR2D &aEnd, PCB_TABLE *aTable)
Select table cells contained within the rectangle defined by two corner points, combining the result ...
bool selectTableCells(PCB_TABLE *aTable)
void unhighlight(EDA_ITEM *aItem, int aHighlightMode, SELECTION *aGroup=nullptr) override
Unhighlight the item visually.
SELECTION_TOOL(const std::string &aName)
T * getEditFrame() const
Return the application window object, casted to requested user type.
Definition tool_base.h:186
T * getModel() const
Return the model object if it matches the requested type.
Definition tool_base.h:199
KIGFX::VIEW_CONTROLS * getViewControls() const
Return the instance of VIEW_CONTROLS object used in the application.
Definition tool_base.cpp:44
KIGFX::VIEW * getView() const
Returns the instance of #VIEW object used in the application.
Definition tool_base.cpp:38
RESET_REASON
Determine the reason of reset for a tool.
Definition tool_base.h:78
Generic, UI-independent tool event.
Definition tool_event.h:171
KICURSOR
Definition cursors.h:44
void Reset() override
PCB_LAYER_ID
A quick note on layer IDs:
Definition layer_ids.h:60
The Cairo implementation of the graphics abstraction layer.
Definition eda_group.h:33
SELECTION_MODE
This file contains data structures that are saved in the project file or project local settings file ...
VECTOR2< int32_t > VECTOR2I
Definition vector2d.h:687
VECTOR2< double > VECTOR2D
Definition vector2d.h:686