KiCad PCB EDA Suite
Loading...
Searching...
No Matches
edit_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-2020 CERN
5 * Copyright (C) 2013-2023 KiCad Developers, see AUTHORS.txt for contributors.
6 *
7 * @author Maciej Suminski <[email protected]>
8 * @author Tomasz Wlostowski <[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 __EDIT_TOOL_H
29#define __EDIT_TOOL_H
30
31#include <math/vector2d.h>
32#include <tools/pcb_tool_base.h>
34#include <status_popup.h>
35#include <unordered_set>
36
37
38class BOARD_COMMIT;
39class BOARD_ITEM;
42
43namespace KIGFX::PREVIEW
44{
45 class RULER_ITEM;
46}
47
48
56{
57public:
58 EDIT_TOOL();
59
61 void Reset( RESET_REASON aReason ) override;
62
64 bool Init() override;
65
67 int GetAndPlace( const TOOL_EVENT& aEvent );
68
72 int Move( const TOOL_EVENT& aEvent );
73
78 int Drag( const TOOL_EVENT& aEvent );
79
83 int DragArcTrack( const TOOL_EVENT& aTrack );
84
88 int Properties( const TOOL_EVENT& aEvent );
89
93 int Rotate( const TOOL_EVENT& aEvent );
94
98 int Flip( const TOOL_EVENT& aEvent );
99
103 int Mirror( const TOOL_EVENT& aEvent );
104
105 static const std::vector<KICAD_T> MirrorableItems;
106
110 int JustifyText( const TOOL_EVENT& aEvent );
111
115 int Swap( const TOOL_EVENT& aEvent );
116
120 int PackAndMoveFootprints( const TOOL_EVENT& aEvent );
121
122 int ChangeTrackWidth( const TOOL_EVENT& aEvent );
123
127 int FilletTracks( const TOOL_EVENT& aEvent );
128
133 int ModifyLines( const TOOL_EVENT& aEvent );
134
138 int HealShapes( const TOOL_EVENT& aEvent );
139
144 int BooleanPolygons( const TOOL_EVENT& aEvent );
145
149 int Remove( const TOOL_EVENT& aEvent );
150
151 void DeleteItems( const PCB_SELECTION& aItem, bool aIsCut );
152
156 int Duplicate( const TOOL_EVENT& aItem );
157
161 int MoveExact( const TOOL_EVENT& aEvent );
162
166 int CreateArray( const TOOL_EVENT& aEvent );
167
171 static void FootprintFilter( const VECTOR2I&, GENERAL_COLLECTOR& aCollector,
172 PCB_SELECTION_TOOL* sTool );
173
177 static void PadFilter( const VECTOR2I&, GENERAL_COLLECTOR& aCollector,
178 PCB_SELECTION_TOOL* sTool );
179
180private:
182 void setTransitions() override;
183
188 int copyToClipboard( const TOOL_EVENT& aEvent );
189
194 int cutToClipboard( const TOOL_EVENT& aEvent );
195
198 bool updateModificationPoint( PCB_SELECTION& aSelection );
199
200 bool invokeInlineRouter( int aDragMode );
201 bool isRouterActive() const;
202
203 VECTOR2I getSafeMovement( const VECTOR2I& aMovement, const BOX2I& aSourceBBox,
204 const VECTOR2D& aBBoxOffset );
205
206 bool pickReferencePoint( const wxString& aTooltip, const wxString& aSuccessMessage,
207 const wxString& aCanceledMessage, VECTOR2I& aReferencePoint );
208
209 bool doMoveSelection( const TOOL_EVENT& aEvent, BOARD_COMMIT* aCommit, bool aAutoStart );
210
212 void rebuildConnectivity();
213
216 void removeNonRootItems( std::unordered_set<EDA_ITEM*>& items );
217
220 std::unordered_set<BOARD_ITEM*>& children );
221
222
223private:
225 bool m_dragging; // Indicates objects are currently being dragged
226 VECTOR2I m_cursor; // Last cursor position (so getModificationPoint()
227 // can avoid changes of edit reference point).
228 std::unique_ptr<STATUS_TEXT_POPUP> m_statusPopup;
229
230 static const unsigned int COORDS_PADDING; // Padding from coordinates limits for this tool
231};
232
233#endif
A base class for any item which can be embedded within the BOARD container class, and therefore insta...
Definition: board_item.h:77
A base class for most all the KiCad significant classes used in schematics and boards.
Definition: eda_item.h:88
The interactive edit tool.
Definition: edit_tool.h:56
bool isRouterActive() const
Definition: edit_tool.cpp:435
int Duplicate(const TOOL_EVENT &aItem)
Duplicate the current selection and starts a move action.
Definition: edit_tool.cpp:2623
int Drag(const TOOL_EVENT &aEvent)
Invoke the PNS router to drag tracks or do an offline resizing of an arc track if a single arc track ...
Definition: edit_tool.cpp:443
bool doMoveSelection(const TOOL_EVENT &aEvent, BOARD_COMMIT *aCommit, bool aAutoStart)
Rebuilds the ratsnest for operations that require it outside the commit rebuild.
int Swap(const TOOL_EVENT &aEvent)
Swap currently selected items' positions.
int PackAndMoveFootprints(const TOOL_EVENT &aEvent)
Try to fit selected footprints inside a minimal area and start movement.
int Mirror(const TOOL_EVENT &aEvent)
Mirror the current selection.
Definition: edit_tool.cpp:1957
int CreateArray(const TOOL_EVENT &aEvent)
Create an array of the selected items, invoking the array editor dialog to set the options.
Definition: edit_tool.cpp:2788
bool pickReferencePoint(const wxString &aTooltip, const wxString &aSuccessMessage, const wxString &aCanceledMessage, VECTOR2I &aReferencePoint)
Definition: edit_tool.cpp:2864
bool Init() override
Init() is called once upon a registration of the tool.
Definition: edit_tool.cpp:178
int ModifyLines(const TOOL_EVENT &aEvent)
"Modify" graphical lines.
Definition: edit_tool.cpp:1236
bool m_dragging
Definition: edit_tool.h:225
int MoveExact(const TOOL_EVENT &aEvent)
Invoke a dialog box to allow moving of the item by an exact amount.
Definition: edit_tool.cpp:2532
int Move(const TOOL_EVENT &aEvent)
Main loop in which events are handled.
static const unsigned int COORDS_PADDING
Definition: edit_tool.h:230
int JustifyText(const TOOL_EVENT &aEvent)
Set the justification on any text items (or fields) in the current selection.
Definition: edit_tool.cpp:2067
void getChildItemsOfGroupsAndGenerators(EDA_ITEM *item, std::unordered_set< BOARD_ITEM * > &children)
Definition: edit_tool.cpp:2220
bool updateModificationPoint(PCB_SELECTION &aSelection)
Definition: edit_tool.cpp:2838
VECTOR2I getSafeMovement(const VECTOR2I &aMovement, const BOX2I &aSourceBBox, const VECTOR2D &aBBoxOffset)
std::unique_ptr< STATUS_TEXT_POPUP > m_statusPopup
Definition: edit_tool.h:228
int DragArcTrack(const TOOL_EVENT &aTrack)
Drag-resize an arc (and change end points of connected straight segments).
Definition: edit_tool.cpp:539
int copyToClipboard(const TOOL_EVENT &aEvent)
Send the current selection to the clipboard by formatting it as a fake pcb see #AppendBoardFromClipbo...
Definition: edit_tool.cpp:2946
int Remove(const TOOL_EVENT &aEvent)
Delete currently selected items.
Definition: edit_tool.cpp:2459
int cutToClipboard(const TOOL_EVENT &aEvent)
Cut the current selection to the clipboard by formatting it as a fake pcb see #AppendBoardFromClipboa...
Definition: edit_tool.cpp:3027
static const std::vector< KICAD_T > MirrorableItems
Definition: edit_tool.h:105
void DeleteItems(const PCB_SELECTION &aItem, bool aIsCut)
Definition: edit_tool.cpp:2265
static void PadFilter(const VECTOR2I &, GENERAL_COLLECTOR &aCollector, PCB_SELECTION_TOOL *sTool)
A selection filter which prunes the selection to contain only items of type PCB_PAD_T.
Definition: edit_tool.cpp:2816
VECTOR2I m_cursor
Definition: edit_tool.h:226
bool invokeInlineRouter(int aDragMode)
Definition: edit_tool.cpp:406
void removeNonRootItems(std::unordered_set< EDA_ITEM * > &items)
Recursively adds any child items of the given item to the set.
Definition: edit_tool.cpp:2237
void rebuildConnectivity()
Removes all items from the set which are children of other PCB_GROUP or PCB_GENERATOR items in the se...
Definition: edit_tool.cpp:3043
void setTransitions() override
< Set up handlers for various events.
Definition: edit_tool.cpp:3051
int HealShapes(const TOOL_EVENT &aEvent)
Make ends of selected shapes meet by extending or cutting them, or adding extra geometry.
Definition: edit_tool.cpp:1466
int ChangeTrackWidth(const TOOL_EVENT &aEvent)
Definition: edit_tool.cpp:891
int BooleanPolygons(const TOOL_EVENT &aEvent)
Modify selected polygons into a single polygon using boolean operations such as merge (union) or subt...
Definition: edit_tool.cpp:1545
int GetAndPlace(const TOOL_EVENT &aEvent)
Definition: edit_tool.cpp:383
int FilletTracks(const TOOL_EVENT &aEvent)
Fillet (i.e.
Definition: edit_tool.cpp:963
PCB_SELECTION_TOOL * m_selectionTool
Definition: edit_tool.h:224
int Properties(const TOOL_EVENT &aEvent)
Display properties window for the selected object.
Definition: edit_tool.cpp:1656
static void FootprintFilter(const VECTOR2I &, GENERAL_COLLECTOR &aCollector, PCB_SELECTION_TOOL *sTool)
A selection filter which prunes the selection to contain only items of type #PCB_MODULE_T.
Definition: edit_tool.cpp:2827
int Rotate(const TOOL_EVENT &aEvent)
Rotate currently selected items.
Definition: edit_tool.cpp:1737
Used when the right click button is pressed, or when the select tool is in effect.
Definition: collectors.h:206
The selection tool: currently supports:
Extension of STATUS_POPUP for displaying a single line text.
Definition: status_popup.h:84
RESET_REASON
Determine the reason of reset for a tool.
Definition: tool_base.h:78
Generic, UI-independent tool event.
Definition: tool_event.h:167
void Reset() override
void Flip(T &aValue)
#define EDIT_TOOL(tool)