27using namespace std::placeholders;
158 if( oldA && oldA->
m_Uuid == newId )
159 itemA->Enable(
false );
161 if( oldB && oldB->
m_Uuid == newId )
162 itemB->Enable(
false );
267 std::shared_ptr<SELECT_MENU> selectMenu = std::make_shared<SELECT_MENU>();
268 selectMenu->SetTool(
this );
269 m_menu->RegisterSubMenu( selectMenu );
271 std::shared_ptr<NET_CHAINS_MENU> netChainsMenu = std::make_shared<NET_CHAINS_MENU>();
272 netChainsMenu->SetTool(
this );
273 m_menu->RegisterSubMenu( netChainsMenu );
277 auto& menu =
m_menu->GetMenu();
279 auto activeToolCondition =
294 auto groupEnterCondition =
297 auto applyDesignBlockLayoutCondition = [](
const SELECTION& aSel )
310 auto inGroupCondition =
321 if( aSel.GetSize() != 1 )
331 menu.AddMenu( netChainsMenu.get(), netItemSelection );
332 menu.AddSeparator( 1000 );
343 menu.AddSeparator( haveHighlight, 1 );
349 menu.AddSeparator( 1 );
393 wxMouseState keyboardState = wxGetMouseState();
395 setModifiersState( keyboardState.ShiftDown(), keyboardState.ControlDown(), keyboardState.AltDown() );
418 trackDragAction = cfg->m_TrackDragAction;
432 else if( evt->IsMouseDown(
BUT_LEFT ) )
481 bool selectionCancelled =
false;
485 selectPoint( evt->Position(),
false, &selectionCancelled );
490 m_frame->GetCanvas()->ForceRefresh();
492 if( !selectionCancelled )
498 else if( evt->IsDblClick(
BUT_LEFT ) )
540 const int delta = evt->Parameter<
int>();
591 wxASSERT_MSG(
false, wxT(
"Unknown selection mode" ) );
598 auto zoneFilledAreaFilter =
601 int accuracy = aCollector.GetGuide()->Accuracy();
602 std::set<EDA_ITEM*> remove;
608 ZONE* zone =
static_cast<ZONE*
>( item );
613 remove.insert( zone );
619 aCollector.Remove( item );
625 if( evt->HasPosition() )
628 &&
selectPoint( evt->DragOrigin(),
false,
nullptr, zoneFilledAreaFilter ) )
646 bool routable = ( segs >= 1 || arcs >= 1 || vias == 1 )
647 && ( segs + arcs + vias ==
m_selection.GetSize() );
671 else if( evt->IsCancel() )
680 else if( evt->FirstResponder() ==
this && evt->GetCommandId() == (
int) WXK_ESCAPE )
692 if( controller &&
m_frame->GetPcbNewSettings()->m_ESCClearsNetHighlight )
695 catch(
const std::runtime_error& e )
697 wxCHECK_MSG(
false, 0, e.what() );
708 if(
m_frame->ToolStackIsEmpty() )
714 && evt->HasPosition()
738 wxT(
"EnterGroup called when selection is not a single group" ) );
807 enum DISPOSITION { BEFORE = 1, AFTER,
BOTH };
809 std::map<EDA_ITEM*, DISPOSITION> itemDispositions;
818 itemDispositions[ item ] = BEFORE;
821 aClientFilter(
VECTOR2I(), collector,
this );
825 if( itemDispositions.count( item ) )
826 itemDispositions[ item ] =
BOTH;
828 itemDispositions[ item ] = AFTER;
836 for( std::pair<EDA_ITEM* const, DISPOSITION> itemDisposition : itemDispositions )
838 EDA_ITEM* item = itemDisposition.first;
839 DISPOSITION disposition = itemDisposition.second;
841 if( disposition == BEFORE )
845 for( std::pair<EDA_ITEM* const, DISPOSITION> itemDisposition : itemDispositions )
847 EDA_ITEM* item = itemDisposition.first;
848 DISPOSITION disposition = itemDisposition.second;
852 if( disposition == AFTER || disposition ==
BOTH )
856 m_frame->GetCanvas()->ForceRefresh();
912 for(
int i = collector.
GetCount() - 1; i >= 0; --i )
914 if( !
Selectable( collector[ i ] ) || ( aOnDrag && collector[i]->IsLocked() ) )
920 size_t preFilterCount = collector.
GetCount();
927 if( collector.
GetCount() == 0 && preFilterCount > 0 )
930 editFrame->HighlightSelectionFilter( rejected );
945 aClientFilter( aWhere, collector,
this );
954 for(
int i = collector.
GetCount() - 1; i >= 0; --i )
956 if( !collector[i]->IsSelected() )
968 catch(
const std::exception& exc )
970 wxLogWarning( wxS(
"Exception '%s' occurred attempting to guess selection candidates." ),
984 if( aSelectionCancelledFlag )
985 *aSelectionCancelledFlag =
true;
992 bool anySubtracted =
false;
999 anySubtracted =
true;
1005 for(
int i = 0; i < collector.
GetCount(); ++i )
1010 anySubtracted =
true;
1020 if( addedCount == 1 )
1025 else if( addedCount > 1 )
1030 else if( anySubtracted )
1067 for(
int i = 0; aAllowedActions[i]; ++i )
1069 if( aEvent->
IsAction( aAllowedActions[i] ) )
1082 if( cell->IsSelected() )
1093 BOX2I selectionRect( aStart, aEnd );
1099 return ( aItem->GetFlags() &
CANDIDATE ) > 0;
1104 bool doSelect =
false;
1106 if( cell->HitTest( selectionRect,
false ) )
1111 doSelect = !wasSelected( cell );
1115 else if( wasSelected( cell ) )
1120 if( doSelect && !cell->IsSelected() )
1122 else if( !doSelect && cell->IsSelected() )
1170 std::set<EDA_ITEM*> previousSelection;
1173 previousSelection.insert( item );
1185 VECTOR2D topLeft( std::min( start.
x,
end.x ), std::min( start.
y,
end.y ) );
1186 VECTOR2D bottomRight( std::max( start.
x,
end.x ), std::max( start.
y,
end.y ) );
1190 bool anyAdded =
false;
1191 bool anySubtracted =
false;
1195 bool wasInPrevious = previousSelection.count( cell ) > 0;
1197 if( cell->IsSelected() && !wasInPrevious )
1199 else if( wasInPrevious && !cell->IsSelected() )
1200 anySubtracted =
true;
1251 if( !cell || cell->
GetParent() != selectedTable )
1263 if( clickedCell->
GetParent() != selectedTable )
1286 bool cancelled =
false;
1292 bool haveAnchorStart =
false;
1299 haveAnchorStart =
true;
1311 return ( aItem->GetFlags() &
CANDIDATE ) > 0;
1316 if( evt->IsCancelInteractive() || evt->IsActivate() )
1325 VECTOR2D start = haveAnchorStart ? anchorStart :
VECTOR2D( evt->DragOrigin() );
1330 else if( evt->IsMouseUp(
BUT_LEFT ) )
1334 bool anyAdded =
false;
1335 bool anySubtracted =
false;
1339 if( cell->IsSelected() && !wasSelected( cell ) )
1341 else if( wasSelected( cell ) && !cell->IsSelected() )
1342 anySubtracted =
true;
1374 bool cancelled =
false;
1389 if(
view->IsMirroredX() )
1390 greedySelection = !greedySelection;
1395 if( evt->IsCancelInteractive() || evt->IsActivate() )
1414 area.
SetEnd( evt->Position() );
1420 view->SetVisible( &area,
true );
1421 view->Update( &area );
1430 view->SetVisible( &area,
false );
1444 view->Remove( &area );
1476 bool cancelled =
false;
1494 bool isClockwise = shapeArea > 0 ? true :
false;
1496 if(
getView()->IsMirroredX() && shapeArea != 0 )
1497 isClockwise = !isClockwise;
1501 if( evt->IsCancelInteractive() || evt->IsActivate() )
1504 evt->SetPassEvent(
false );
1511 points.
Append( evt->Position() );
1513 else if( evt->IsDblClick(
BUT_LEFT )
1519 evt->SetPassEvent(
false );
1555 area.
SetMode( selectionMode );
1578 bool anyAdded =
false;
1579 bool anySubtracted =
false;
1587 std::vector<KIGFX::VIEW::LAYER_ITEM_PAIR> candidates;
1589 view->Query( selectionBox, candidates );
1593 std::set<EDA_ITEM*> group_items;
1601 std::unordered_set<EDA_ITEM*>& newset =
group->GetItems();
1604 [&](
const BOX2I& aBox )
1606 return boxMode ? selectionBox.
Contains( aBox )
1612 if( containedMode && boxContained(
group->GetBoundingBox() ) && newset.size() )
1614 for(
EDA_ITEM* group_item : newset )
1616 if( !group_item->IsBOARD_ITEM() )
1620 collector.
Append( *newset.begin() );
1624 for(
EDA_ITEM* group_item : newset )
1625 group_items.emplace( group_item );
1631 return boxMode ? aItem->HitTest( selectionBox, containedMode )
1632 : aItem->HitTest( aArea.
GetPoly(), containedMode );
1635 for(
const auto& [item, layer] : candidates )
1637 if( !item->IsBOARD_ITEM() )
1642 if(
Selectable( boardItem ) && hitTest( boardItem )
1643 && ( !containedMode || !group_items.count( boardItem ) ) )
1646 padsCollector.
Append( boardItem );
1648 collector.
Append( boardItem );
1660 collector = padsCollector;
1667 std::sort( collector.
begin(), collector.
end(),
1670 VECTOR2I aPos = a->GetPosition();
1671 VECTOR2I bPos = b->GetPosition();
1673 if( aPos.y == bPos.y )
1674 return aPos.x < bPos.x;
1676 return aPos.y < bPos.y;
1681 if( !i->IsBOARD_ITEM() )
1686 if( aSubtractive || ( aExclusiveOr && item->
IsSelected() ) )
1689 anySubtracted =
true;
1703 else if( anySubtracted )
1710 wxMouseState keyboardState = wxGetMouseState();
1712 setModifiersState( keyboardState.ShiftDown(), keyboardState.ControlDown(), keyboardState.AltDown() );
1756 collection.
Append( item );
1769 m_frame->GetCanvas()->ForceRefresh();
1797 m_frame->GetCanvas()->ForceRefresh();
1807 std::set<int> representedNets;
1809 for(
int i = aCollector.
GetCount() - 1; i >= 0; i-- )
1815 else if ( representedNets.count( item->
GetNetCode() ) )
1818 representedNets.insert( item->
GetNetCode() );
1825 std::deque<EDA_ITEM*> selectedItems =
m_selection.GetItems();
1828 std::vector<BOARD_CONNECTED_ITEM*> toUnroute;
1829 std::set<EDA_ITEM*> toDelete;
1831 for(
EDA_ITEM* item : selectedItems )
1836 toUnroute.push_back(
pad );
1840 toDelete.insert( item );
1856 std::set<int> selectedNets;
1859 if( item->GetNetCode() > 0 )
1860 selectedNets.insert( item->GetNetCode() );
1862 std::set<VECTOR2I> endpointSet;
1868 endpointSet.insert( track->GetStart() );
1869 endpointSet.insert( track->GetEnd() );
1873 endpointSet.insert( item->GetPosition() );
1877 endpointSet.insert( item->GetPosition() );
1881 bool expanded =
true;
1889 if( toDelete.count( gen ) )
1893 std::map<VECTOR2I, int> epCount;
1895 for(
BOARD_ITEM* child : gen->GetBoardItems() )
1899 if( track && selectedNets.count( track->
GetNetCode() ) )
1902 epCount[track->
GetEnd()]++;
1907 bool connected =
false;
1909 for(
auto& [pt, count] : epCount )
1911 if( count == 1 && endpointSet.count( pt ) )
1920 toDelete.insert( gen );
1934 endpointSet.insert( track->GetStart() );
1935 endpointSet.insert( track->GetEnd() );
1958 std::set<BOARD_ITEM*> removed;
1962 if( !item->IsBOARD_ITEM() )
1968 toDelete.insert( bi );
1971 removed.insert( bi );
1977 for(
BOARD_ITEM* child : gen->GetBoardItems() )
1979 if( removed.count( child ) )
1981 toDelete.insert( gen );
1989 if( !item->IsBOARD_ITEM() )
1997 if( removed.find( aItem ) == removed.end() )
2000 removed.insert( aItem );
2005 if( removed.find( boardItem ) == removed.end() )
2006 commit.
Remove( boardItem );
2010 commit.
Push(
_(
"Unroute Selected" ) );
2015 for(
EDA_ITEM* item : selectedItems )
2027 std::deque<EDA_ITEM*> selectedItems =
m_selection.GetItems();
2030 std::vector<BOARD_CONNECTED_ITEM*> toUnroute;
2032 std::set<EDA_ITEM*> toDelete;
2034 for(
EDA_ITEM* item : selectedItems )
2045 if( !toDelete.count( gen ) )
2047 toDelete.insert( gen );
2051 toDelete.insert( generatedItem );
2061 toDelete.insert( item );
2066 toDelete.insert( item );
2070 toDelete.insert( generatedItem );
2081 std::deque<EDA_ITEM*> toSelectAfter;
2085 if( !item->IsBOARD_ITEM() )
2088 if( toDelete.find( item ) == toDelete.end() )
2089 toSelectAfter.push_back( item );
2093 std::set<BOARD_ITEM*> removed;
2097 if( !item->IsBOARD_ITEM() )
2107 if( removed.insert( aItem ).second )
2112 if( removed.insert( boardItem ).second )
2113 commit.
Remove( boardItem );
2117 if( removed.insert( boardItem ).second )
2118 commit.
Remove( boardItem );
2122 commit.
Push(
_(
"Unroute Segment" ) );
2127 for(
EDA_ITEM* item : toSelectAfter )
2129 if( !toDelete.count( item ) )
2142 unsigned initialCount = 0;
2154 if( initialCount == 0 )
2157 std::vector<PCB_SHAPE*> startShapes;
2162 startShapes.push_back(
static_cast<PCB_SHAPE*
>( item ) );
2166 if( !startShapes.empty() )
2172 m_frame->SetStatusText(
_(
"Select/Expand Connection..." ) );
2176 std::deque<EDA_ITEM*> selectedItems =
m_selection.GetItems();
2178 for(
EDA_ITEM* item : selectedItems )
2179 item->ClearTempFlags();
2181 std::vector<BOARD_CONNECTED_ITEM*> startItems;
2183 for(
EDA_ITEM* item : selectedItems )
2190 startItems.push_back(
pad );
2208 if(
m_selection.GetItems().size() > initialCount )
2212 m_frame->SetStatusText( wxEmptyString );
2225 double refreshIntervalMs = 500;
2226 int lastSelectionSize = (int)
m_selection.GetSize();
2230 std::set<PAD*> startPadSet;
2231 std::vector<BOARD_CONNECTED_ITEM*> cleanupItems;
2237 startPadSet.insert(
static_cast<PAD*
>( startItem ) );
2240 if( startItem->IsType( { PCB_TRACE_T, PCB_ARC_T, PCB_VIA_T } ) )
2249 std::map<VECTOR2I, std::vector<PCB_TRACK*>> trackMap;
2250 std::map<VECTOR2I, PCB_VIA*> viaMap;
2251 std::map<VECTOR2I, PAD*> padMap;
2252 std::map<VECTOR2I, std::vector<PCB_SHAPE*>> shapeMap;
2253 std::vector<std::pair<VECTOR2I, LSET>> activePts;
2263 switch( item->Type() )
2269 trackMap[track->
GetStart()].push_back( track );
2270 trackMap[track->
GetEnd()].push_back( track );
2277 viaMap[
via->GetStart()] =
via;
2284 padMap[
pad->GetPosition()] =
pad;
2293 shapeMap[point].push_back( shape );
2304 switch( startItem->Type() )
2317 activePts.push_back( { startItem->GetPosition(), startItem->GetLayerSet() } );
2321 activePts.push_back( { startItem->GetPosition(), startItem->GetLayerSet() } );
2329 activePts.push_back( { point, startItem->GetLayerSet() } );
2342 while( expand && failSafe++ < 100000 )
2346 for(
int i = (
int) activePts.size() - 1; i >= 0; --i )
2354 auto exactIt = viaMap.find( pt );
2356 if( exactIt != viaMap.end() && ( exactIt->second->GetLayerSet() & layerSetCu ).any() )
2358 hitVia = exactIt->second;
2363 for(
auto& [pos,
via] : viaMap )
2365 if( !(
via->GetLayerSet() & layerSetCu ).any() )
2372 int radius =
via->GetWidth( layer ) / 2;
2373 int64_t radiusSq =
static_cast<int64_t
>(
radius ) *
radius;
2375 if( ( pt - pos ).SquaredEuclideanNorm() <= radiusSq )
2390 auto padIt = padMap.find( pt );
2392 bool gotVia = hitVia !=
nullptr;
2393 bool gotPad = padIt != padMap.end() && ( padIt->second->GetLayerSet() & layerSetCu ).any();
2394 bool gotNonStartPad = gotPad && ( startPadSet.find( padIt->second ) == startPadSet.end() );
2398 activePts.erase( activePts.begin() + i );
2404 activePts.erase( activePts.begin() + i );
2410 size_t pt_count = 0;
2414 if( track->GetStart() != track->GetEnd() && layerSetCu.
Contains( track->GetLayer() ) )
2418 if( pt_count > 2 || gotVia || gotNonStartPad )
2420 activePts.erase( activePts.begin() + i );
2426 if( gotNonStartPad )
2428 activePts.erase( activePts.begin() + i );
2435 PAD*
pad = padIt->second;
2440 cleanupItems.push_back(
pad );
2442 activePts.push_back( {
pad->GetPosition(),
pad->GetLayerSet() } );
2449 if( !layerSetCu.
Contains( track->GetLayer() ) )
2455 if( !track->IsSelected() )
2461 cleanupItems.push_back( track );
2463 if( track->GetStart() == pt )
2464 activePts.push_back( { track->GetEnd(), track->GetLayerSet() } );
2466 activePts.push_back( { track->GetStart(), track->GetLayerSet() } );
2475 if( !layerSetCu.
Contains( shape->GetLayer() ) )
2481 if( !shape->IsSelected() )
2487 cleanupItems.push_back( shape );
2489 for(
const VECTOR2I& newPoint : shape->GetConnectionPoints() )
2491 if( newPoint == pt )
2494 activePts.push_back( { newPoint, shape->GetLayerSet() } );
2510 cleanupItems.push_back( hitVia );
2517 maxRadius = std::max( maxRadius, hitVia->
GetWidth( layer ) / 2 );
2519 int64_t maxRadiusSq =
static_cast<int64_t
>( maxRadius ) * maxRadius;
2521 for(
auto& [trkPt, tracks] : trackMap )
2523 if( ( trkPt - viaPos ).SquaredEuclideanNorm() > maxRadiusSq )
2527 bool inside =
false;
2536 int r = hitVia->
GetWidth( trkLayer ) / 2;
2537 int64_t rSq =
static_cast<int64_t
>( r ) * r;
2539 if( ( trkPt - viaPos ).SquaredEuclideanNorm() <= rSq )
2547 activePts.push_back( { trkPt, hitVia->
GetLayerSet() } );
2555 activePts.erase( activePts.begin() + i );
2559 if( refreshTimer.
msecs() >= refreshIntervalMs )
2563 m_frame->GetCanvas()->ForceRefresh();
2567 refreshTimer.
Start();
2572 std::set<EDA_ITEM*> toDeselect;
2573 std::set<EDA_ITEM*> toSelect;
2578 if( !item->IsBOARD_ITEM() )
2586 toDeselect.insert( item );
2631 std::stack<PCB_SHAPE*> toSearch;
2632 std::set<PCB_SHAPE*> toCleanup;
2634 for(
PCB_SHAPE* startItem : aStartItems )
2635 toSearch.push( startItem );
2648 toSearch.push(
static_cast<PCB_SHAPE*
>( item ) );
2652 while( !toSearch.empty() )
2661 toCleanup.insert( shape );
2670 searchPoint( shape->
GetEnd() );
2681 std::vector<PAD*> pads;
2688 pads.push_back(
pad );
2692 pads.push_back(
static_cast<PAD*
>( item ) );
2701 for(
const CN_EDGE& edge : conn->GetRatsnestForPad(
pad ) )
2703 wxCHECK2( edge.GetSourceNode() && !edge.GetSourceNode()->Dirty(),
continue );
2704 wxCHECK2( edge.GetTargetNode() && !edge.GetTargetNode()->Dirty(),
continue );
2709 if( sourceParent ==
pad )
2712 select(
static_cast<PAD*
>( targetParent )->GetParent() );
2714 else if( targetParent ==
pad )
2717 select(
static_cast<PAD*
>( sourceParent )->GetParent() );
2731 std::vector<BOARD_CONNECTED_ITEM*> sourceItems;
2738 sourceItems.push_back(
pad );
2742 sourceItems.push_back( connItem );
2749 std::shared_ptr<CN_CONNECTIVITY_ALGO> connAlgo = conn->GetConnectivityAlgo();
2753 RN_NET* net = conn->GetRatsnestForNet( sourceItem->GetNetCode() );
2756 if( !net || net->
GetEdges().empty() || !connAlgo->ItemExists( sourceItem ) )
2759 std::vector<std::shared_ptr<CN_CLUSTER>> sourceClusters;
2761 for(
CN_ITEM* cnItem : connAlgo->ItemEntry( sourceItem ).GetItems() )
2763 for(
const std::shared_ptr<CN_ANCHOR>&
anchor : cnItem->Anchors() )
2765 if(
anchor->GetCluster() )
2766 sourceClusters.push_back(
anchor->GetCluster() );
2770 if( sourceClusters.empty() )
2773 auto isSourceAnchor =
2774 [&](
const std::shared_ptr<const CN_ANCHOR>& aAnchor )
2776 if( aAnchor->Parent() == sourceItem )
2779 return std::find( sourceClusters.begin(), sourceClusters.end(),
2780 aAnchor->GetCluster() ) != sourceClusters.end();
2783 double currentDistance = DBL_MAX;
2789 const std::shared_ptr<const CN_ANCHOR>& source = edge.GetSourceNode();
2790 const std::shared_ptr<const CN_ANCHOR>& target = edge.GetTargetNode();
2792 wxCHECK2( source && !source->Dirty() && target && !target->Dirty(),
continue );
2794 if( source->Parent()->GetParentFootprint() == target->Parent()->GetParentFootprint() )
2799 bool sourceMatches = isSourceAnchor( source );
2800 bool targetMatches = isSourceAnchor( target );
2802 if( sourceMatches == targetMatches )
2805 const CN_ANCHOR* other = sourceMatches ? target.get() : source.get();
2811 if( edge.GetLength() < currentDistance )
2813 currentDistance = edge.GetLength();
2818 if( nearest !=
nullptr )
2832 for(
BOARD_ITEM* item : conn->GetNetItems( aNetCode, { PCB_TRACE_T,
2906 const wxString& chainName = netInfo->
GetNetChain();
2908 if( chainName.IsEmpty() )
2917 if( candidate && candidate->GetNetChain() == chainName )
2933 std::vector<BOARD_ITEM*> footprints;
2938 if( footprint ==
nullptr )
2941 wxString footprint_path = footprint->GetPath().AsString().BeforeLast(
'/' );
2943 if( footprint_path.IsEmpty() )
2944 footprint_path +=
'/';
2946 if( footprint_path == aSheetPath )
2947 footprints.push_back( footprint );
2963 std::list<int> netcodeList;
2964 std::vector<BOARD_CONNECTED_ITEM*> padList;
2968 switch( item->Type() )
2974 if(
pad->IsConnected() )
2976 netcodeList.push_back(
pad->GetNetCode() );
2977 padList.push_back(
pad );
2988 if(
pad->IsConnected() )
2990 netcodeList.push_back(
pad->GetNetCode() );
2991 padList.push_back(
pad );
3003 std::sort( padList.begin(), padList.end() );
3007 netcodeList.unique();
3013 std::vector<int> removeCodeList;
3016 for(
int netCode : netcodeList )
3020 if( !std::binary_search( padList.begin(), padList.end(),
pad ) )
3024 removeCodeList.push_back( netCode );
3030 for(
int removeCode : removeCodeList )
3031 netcodeList.remove( removeCode );
3033 std::unordered_set<BOARD_ITEM*> localConnectionList;
3035 for(
int netCode : netcodeList )
3037 for(
BOARD_ITEM* item : conn->GetNetItems( netCode, { PCB_TRACE_T,
3042 localConnectionList.insert( item );
3046 for(
BOARD_ITEM* item : localConnectionList )
3053 std::vector<BOARD_ITEM*>* items = aEvent.
Parameter<std::vector<BOARD_ITEM*>*>();
3064 std::vector<BOARD_ITEM*>* items = aEvent.
Parameter<std::vector<BOARD_ITEM*>*>();
3082 if( item->IsMoving() )
3099 if(
m_frame->GetPcbNewSettings()->m_CrossProbing.center_on_items )
3101 if(
m_frame->GetPcbNewSettings()->m_CrossProbing.zoom_to_fit )
3110 m_frame->GetCanvas()->ForceRefresh();
3120 wxString sheetPath = *aEvent.
Parameter<wxString*>();
3146 if( !footprint || footprint->
GetPath().empty() )
3152 wxString sheetPath = footprint->
GetPath().
AsString().BeforeLast(
'/' );
3154 if( sheetPath.IsEmpty() )
3175 screenSize.
x = std::max( 10.0, screenSize.
x );
3176 screenSize.
y = std::max( 10.0, screenSize.
y );
3181 double scale =
view->GetScale() / std::max( fabs( vsize.
x / screenSize.
x ),
3182 fabs( vsize.
y / screenSize.
y ) );
3188 m_frame->GetCanvas()->ForceRefresh();
3204#ifdef DEFAULT_PCBNEW_CODE
3206 auto screenSize =
view->ToWorld( GetCanvas()->GetClientSize(),
false );
3209 screenSize.x = std::max( 10.0, fabs( screenSize.x ) );
3210 screenSize.y = std::max( 10.0, screenSize.y );
3211 double ratio = std::max( fabs( bbSize.x / screenSize.x ), fabs( bbSize.y / screenSize.y ) );
3214 if( crossProbingSettings.zoom_to_fit && ( ratio < 0.5 || ratio > 1.0 ) )
3215 view->SetScale(
view->GetScale() / ratio );
3218#ifndef DEFAULT_PCBNEW_CODE
3235 double compRatio = bbSize.y / currTextHeight;
3238 double compRatioBent = 1.0;
3249 screenSize.
x = std::max( 10.0, fabs( screenSize.
x ) );
3250 screenSize.
y = std::max( 10.0, screenSize.
y );
3251 double ratio = std::max( -1.0, fabs( bbSize.y / screenSize.
y ) );
3254 double kicadRatio = std::max( fabs( bbSize.x / screenSize.
x ),
3255 fabs( bbSize.y / screenSize.
y ) );
3263 std::vector<std::pair<double, double>> lut {
3276 std::vector<std::pair<double, double>>::iterator it;
3278 compRatioBent = lut.back().second;
3280 if( compRatio >= lut.front().first )
3286 for( it = lut.begin(); it < lut.end() - 1; it++ )
3288 if( it->first <= compRatio &&
next( it )->first >= compRatio )
3290 double diffx = compRatio - it->first;
3291 double diffn =
next( it )->first - it->first;
3293 compRatioBent = it->second + (
next( it )->second - it->second ) * diffx / diffn;
3300 compRatioBent = lut.front().second;
3308 if( bbSize.x > screenSize.
x * ratio * compRatioBent )
3312 compRatioBent = 1.0;
3313 wxLogTrace(
"CROSS_PROBE_SCALE",
"Part TOO WIDE for screen. Using normal KiCad zoom ratio: %1.5f", ratio );
3318 ratio *= compRatioBent;
3320 bool alwaysZoom =
false;
3323 if( ( ratio < 0.5 || ratio > 1.0 ) || alwaysZoom )
3324 view->SetScale(
view->GetScale() / ratio );
3331 bool cleared =
false;
3343 switch( aItem->
Type() )
3347 int netCode =
static_cast<NETINFO_ITEM*
>( aItem )->GetNetCode();
3366 double marginFactor = 2;
3375 double scaleX = screenSize.
x /
static_cast<double>( aItem->
GetBoundingBox().GetWidth() );
3376 double scaleY = screenSize.
y /
static_cast<double>( aItem->
GetBoundingBox().GetHeight() );
3378 scaleX /= marginFactor;
3379 scaleY /= marginFactor;
3381 double scale = scaleX > scaleY ? scaleY : scaleX;
3400 m_frame->GetCanvas()->ForceRefresh();
3412 switch( aItem.
Type() )
3467 if( cmd != wxID_OK )
3478 if( !i->IsBOARD_ITEM() )
3500 std::set<BOARD_ITEM*> rejected;
3504 if( !i->IsBOARD_ITEM() )
3510 rejected.insert( item );
3514 aCollector.
Remove( item );
3579 aRejected->
pads =
true;
3591 aRejected->
tracks =
true;
3602 aRejected->
vias =
true;
3611 ZONE* zone =
static_cast<ZONE*
>( aItem );
3621 aRejected->
zones =
true;
3630 if( zone ==
m_frame->GetBoard()->m_SolderMaskBridges )
3661 aRejected->
text =
true;
3697 aRejected->
points =
true;
3753 bool enteredGroupFound =
false;
3756 [&](
EDA_ITEM* item,
void* testData )
3774 enteredGroupFound =
true;
3788 if( !enteredGroupFound )
3801 auto visibleLayers =
3809 set.
set( layer,
view()->IsLayerVisible( layer ) );
3831 bool onActiveLayer =
false;
3833 for(
int layer : activeLayers )
3836 if( layer < PCB_LAYER_ID_COUNT && aItem->IsOnLayer(
ToLAYER_ID( layer ) ) )
3838 onActiveLayer =
true;
3861 && footprint->
Pads().empty()
3862 && footprint->
Zones().empty() )
3879 for(
const ZONE* zone : footprint->
Zones() )
3911 const ZONE* zone =
nullptr;
3913 const PAD*
pad =
nullptr;
3926 switch( aItem->
Type() )
3932 zone =
static_cast<const ZONE*
>( aItem );
3950 if( !layerVisible( aItem->
GetLayer() ) )
3962 if( !( visibleLayers() &
via->GetLayerSet() ).any() )
3968 field =
static_cast<const PCB_FIELD*
>( aItem );
3984 if( !layerVisible(
text->GetLayer() ) )
3995 if(
text->GetText() == wxT(
"${REFERENCE}" ) )
3997 else if(
text->GetText() == wxT(
"${VALUE}" ) )
4000 if( !
view()->IsLayerVisible( controlLayer ) )
4014 if( !layerVisible( aItem->
GetLayer() ) )
4023 if( !layerVisible( aItem->
GetLayer() ) )
4029 if( !layerVisible( aItem->
GetLayer() ) )
4036 if( !layerVisible( aItem->
GetLayer() ) )
4044 if( !layerVisible( aItem->
GetLayer() ) )
4057 if( !layerVisible( aItem->
GetLayer() ) )
4066 pad =
static_cast<const PAD*
>( aItem );
4077 if( !(
pad->GetLayerSet() & visibleLayers() ).
any() )
4084 marker =
static_cast<const PCB_MARKER*
>( aItem );
4092 if( !layerVisible( aItem->
GetLayer() ) )
4146 aGroup->
Add( aItem );
4215 const unsigned GRIP_MARGIN = 20;
4221 if( !item->IsBOARD_ITEM() )
4224 BOX2I itemBox = item->ViewBBox();
4229 if( item->HitTest( aPoint, margin ) )
4236 group->RunOnChildren(
4239 if( aItem->
HitTest( aPoint, margin ) )
4259 SEG loc( aWhere, aWhere );
4261 switch( aItem->
Type() )
4269 if(
text->GetEffectiveTextShape()->Collide( loc, aMaxDistance, &
distance ) )
4291 shape->Collide( loc, aMaxDistance, &
distance );
4311 ZONE* zone =
static_cast<ZONE*
>( aItem );
4333 catch(
const std::exception& e )
4335 wxFAIL_MSG( wxString::Format( wxT(
"Clipper exception occurred: %s" ), e.what() ) );
4369 static_cast<PAD*
>( aItem )->Padstack().ForEachUniqueLayer(
4372 int layerDistance = INT_MAX;
4398 wxCHECK( settings, );
4401 LSET visibleLayers =
m_frame->GetBoard()->GetVisibleLayers();
4402 LSET enabledLayers =
m_frame->GetBoard()->GetEnabledLayers();
4405 wxCHECK( !enabledLayerStack.empty(), );
4407 auto isZoneFillKeepout =
4412 const ZONE* zone =
static_cast<const ZONE*
>( aItem );
4421 std::vector<LAYER_OPACITY_ITEM> opacityStackup;
4423 for(
int i = 0; i < aCollector.
GetCount(); i++ )
4427 LSET itemLayers = item->
GetLayerSet() & enabledLayers & visibleLayers;
4428 LSEQ itemLayerSeq = itemLayers.
Seq( enabledLayerStack );
4441 opacityItem.
m_Item = item;
4443 if( isZoneFillKeepout( item ) )
4446 opacityStackup.emplace_back( opacityItem );
4450 std::sort( opacityStackup.begin(), opacityStackup.end(),
4453 int retv = enabledLayerStack.TestLayers( aLhs.m_Layer, aRhs.m_Layer );
4458 return aLhs.m_Opacity > aRhs.m_Opacity;
4461 std::set<const BOARD_ITEM*> visibleItems;
4462 std::set<const BOARD_ITEM*> itemsToRemove;
4464 double currentStackupOpacity = 0.0;
4471 currentStackupOpacity = opacityItem.m_Opacity;
4472 lastVisibleLayer = opacityItem.m_Layer;
4473 visibleItems.emplace( opacityItem.m_Item );
4483 wxCHECK( item,
false );
4486 if( visibleItems.count( item ) )
4492 && visibleItems.count( item->
GetParent() ) )
4499 if( isZoneFillKeepout( item ) )
4506 if( opacityItem.m_Layer == enabledLayerStack[0] )
4508 visibleItems.emplace( opacityItem.m_Item );
4512 double itemVisibility = opacityItem.m_Opacity * ( 1.0 - currentStackupOpacity );
4514 if( ( itemVisibility <= minAlphaLimit ) && !ignoreItem() )
4515 itemsToRemove.emplace( opacityItem.m_Item );
4517 visibleItems.emplace( opacityItem.m_Item );
4520 if( opacityItem.m_Layer != lastVisibleLayer )
4522 currentStackupOpacity += opacityItem.m_Opacity * ( 1.0 - currentStackupOpacity );
4523 currentStackupOpacity = std::min( currentStackupOpacity, 1.0 );
4524 lastVisibleLayer = opacityItem.m_Layer;
4528 for(
const BOARD_ITEM* itemToRemove : itemsToRemove )
4530 wxCHECK( aCollector.
GetCount() > 1, );
4531 aCollector.
Remove( itemToRemove );
4554 static std::vector<KICAD_T> singleLayerSilkTypes = {
PCB_FIELD_T,
4566 std::set<BOARD_ITEM*> preferred;
4567 std::set<BOARD_ITEM*> rejected;
4574 if( silkLayers[activeLayer] )
4576 for(
int i = 0; i < aCollector.
GetCount(); ++i )
4580 if( item->
IsType( singleLayerSilkTypes ) && silkLayers[ item->
GetLayer() ] )
4581 preferred.insert( item );
4586 else if( courtyardLayers[activeLayer] && settings->
GetHighContrast() )
4588 for(
int i = 0; i < aCollector.
GetCount(); ++i )
4593 preferred.insert( item );
4597 if( preferred.size() > 0 )
4602 aCollector.
Append( item );
4604 if( preferred.size() == 1 )
4609 constexpr int MAX_SLOP = 5;
4613 int minSlop = INT_MAX;
4615 std::map<BOARD_ITEM*, int> itemsBySloppiness;
4617 for(
int i = 0; i < aCollector.
GetCount(); ++i )
4622 itemsBySloppiness[ item ] = itemSlop;
4624 if( itemSlop < minSlop )
4629 if( minSlop < INT_MAX )
4631 for( std::pair<BOARD_ITEM*, int> pair : itemsBySloppiness )
4633 if( pair.second > minSlop + singlePixel )
4640 constexpr double sizeRatio = 1.5;
4642 std::vector<std::pair<BOARD_ITEM*, double>> itemsByArea;
4644 for(
int i = 0; i < aCollector.
GetCount(); ++i )
4653 area = (double)
SEG::Square( singlePixel ) * MAX_SLOP;
4672 catch(
const std::exception& e )
4674 wxFAIL_MSG( wxString::Format( wxT(
"Clipper exception occurred: %s" ), e.what() ) );
4678 itemsByArea.emplace_back( item, area );
4681 std::sort( itemsByArea.begin(), itemsByArea.end(),
4682 [](
const std::pair<BOARD_ITEM*, double>& lhs,
4683 const std::pair<BOARD_ITEM*, double>& rhs ) ->
bool
4685 return lhs.second < rhs.second;
4688 bool rejecting =
false;
4690 for(
int i = 1; i < (int) itemsByArea.size(); ++i )
4692 if( itemsByArea[i].second > itemsByArea[i-1].second * sizeRatio )
4696 rejected.insert( itemsByArea[i].first );
4701 constexpr double maxCoverRatio = 0.70;
4703 for(
int i = 0; i < aCollector.
GetCount(); ++i )
4707 if( footprint->CoverageRatio( aCollector ) > maxCoverRatio )
4708 rejected.erase( footprint );
4713 if( (
unsigned) aCollector.
GetCount() > rejected.size() )
4725 bool haveItemOnActive =
false;
4728 for(
int i = 0; i < aCollector.
GetCount(); ++i )
4730 if( !aCollector[i]->IsOnLayer( activeLayer ) )
4731 rejected.insert( aCollector[i] );
4733 haveItemOnActive =
true;
4736 if( haveItemOnActive )
4749 m_frame->ShowInfoBarWarning(
_(
"Selection contains locked items. "
4750 "Enable 'Override locks' to operate on them." ),
4763 for(
int i = (
int) aCollector.
GetCount() - 1; i >= 0; --i )
4766 bool lockedDescendant =
false;
4772 lockedDescendant =
true;
4776 if( item->
IsLocked() || lockedDescendant )
4778 aCollector.
Remove( item );
4788 std::unordered_set<EDA_ITEM*> toAdd;
4792 for(
int j = 0; j < aCollector.
GetCount(); j++ )
4794 if( aCollector[j]->GetParent() )
4795 aCollector[j]->GetParent()->ClearFlags(
CANDIDATE );
4797 if( aCollector[j]->GetParentFootprint() )
4798 aCollector[j]->GetParentFootprint()->ClearFlags(
CANDIDATE );
4803 for(
int j = 0; j < aCollector.
GetCount(); j++ )
4807 for(
int j = 0; j < aCollector.
GetCount(); )
4819 aCollector.
Remove( item );
4827 if(
top->AsEdaItem() != item )
4829 toAdd.insert(
top->AsEdaItem() );
4832 aCollector.
Remove( item );
4841 aCollector.
Remove( item );
4850 if( !aCollector.
HasItem( item ) )
4851 aCollector.
Append( item );
4858 std::set<BOARD_ITEM*> to_add;
4861 for(
int i = (
int) aCollector.
GetCount() - 1; i >= 0; --i )
4870 aCollector.
Remove( item );
4875 aCollector.
Append( item );
4880 bool aForcePromotion )
const
4882 std::set<BOARD_ITEM*> to_add;
4885 for(
int i = aCollector.
GetCount() - 1; i >= 0; --i )
4890 && ( !
frame()->GetPcbNewSettings()->m_AllowFreePads || aForcePromotion ) )
4895 aCollector.
Remove( item );
4900 aCollector.
Append( item );
4907 for(
int i = aCollector.
GetCount() - 1; i >= 0; --i )
4912 aCollector.
Remove( item );
4924 bool need_direct_hit =
false;
4932 need_direct_hit =
true;
4940 else if( item->IsBOARD_ITEM() )
4941 fp =
static_cast<BOARD_ITEM*
>( item )->GetParentFootprint();
4947 single_fp =
nullptr;
4950 else if( !single_fp )
4956 else if( single_fp != fp )
4958 single_fp =
nullptr;
4964 auto visibleLayers =
4972 set.
set( layer,
view()->IsLayerVisible( layer ) );
4982 LSET layers = visibleLayers();
4990 for(
int layer : activeLayers )
4993 layers.
set( layer );
4998 for(
int i = aCollector.
GetCount() - 1; i >= 0; --i )
5014 aCollector.
Remove( item );
5016 bool has_hit =
false;
5030 aCollector.
Remove( item );
5035 else if( single_fp )
5037 if( fp == single_fp )
5040 else if( need_direct_hit )
5054 aCollector.
Remove( item );
5071 std::set<std::pair<PCB_TABLE*, int>> columns;
5079 columns.insert( std::make_pair(
table, cell->GetColumn() ) );
5083 for(
auto& [
table, col ] : columns )
5085 for(
int row = 0; row <
table->GetRowCount(); ++row )
5106 std::set<std::pair<PCB_TABLE*, int>> rows;
5114 rows.insert( std::make_pair(
table, cell->GetRow() ) );
5118 for(
auto& [
table, row ] : rows )
5120 for(
int col = 0; col <
table->GetColCount(); ++col )
5141 std::set<PCB_TABLE*> tables;
5147 tables.insert(
static_cast<PCB_TABLE*
>( cell->GetParent() ) );
5154 if( !
table->IsSelected() )
std::function< void(const VECTOR2I &, GENERAL_COLLECTOR &, PCB_SELECTION_TOOL *)> CLIENT_SELECTION_FILTER
constexpr EDA_IU_SCALE pcbIUScale
constexpr BOX2I BOX2ISafe(const BOX2D &aInput)
constexpr BOX2I KiROUND(const BOX2D &aBoxD)
static TOOL_ACTION cancelInteractive
static TOOL_ACTION unselectAll
static TOOL_ACTION selectItem
Select an item (specified as the event parameter).
static TOOL_ACTION cursorLeft
static TOOL_ACTION zoomOutCenter
static TOOL_ACTION unselectItem
static TOOL_ACTION zoomIn
static TOOL_ACTION cursorLeftFast
static TOOL_ACTION selectionCursor
Select a single item under the cursor position.
static TOOL_ACTION selectSetLasso
static TOOL_ACTION selectSetRect
Set lasso selection mode.
static TOOL_ACTION groupEnter
static TOOL_ACTION selectColumns
static TOOL_ACTION cursorDown
static TOOL_ACTION zoomOut
static TOOL_ACTION cursorRightFast
static TOOL_ACTION zoomCenter
static TOOL_ACTION panDown
static TOOL_ACTION cursorDblClick
static TOOL_ACTION selectionActivate
Activation of the selection tool.
static TOOL_ACTION cursorDownFast
static TOOL_ACTION selectionMenu
Run a selection menu to select from a list of items.
static TOOL_ACTION reselectItem
static TOOL_ACTION selectRows
static TOOL_ACTION cursorUpFast
static TOOL_ACTION panLeft
static TOOL_ACTION updateMenu
static TOOL_ACTION doDelete
static TOOL_ACTION selectionTool
static TOOL_ACTION cursorClick
static TOOL_ACTION zoomFitScreen
static TOOL_ACTION increment
static TOOL_ACTION selectionClear
Clear the current selection.
static TOOL_ACTION zoomFitObjects
static TOOL_ACTION zoomInCenter
static TOOL_ACTION panRight
static TOOL_ACTION selectTable
static TOOL_ACTION cursorUp
Cursor control with keyboard.
static TOOL_ACTION groupLeave
static TOOL_ACTION finishInteractive
static TOOL_ACTION cursorRight
static TOOL_ACTION selectAll
static TOOL_ACTION unselectItems
static TOOL_ACTION selectItems
Select a list of items (specified as the event parameter)
static const ADVANCED_CFG & GetCfg()
Get the singleton instance's config, which is shared by all consumers.
BASE_SET & reset(size_t pos)
BASE_SET & set(size_t pos)
virtual void Push(const wxString &aMessage=wxEmptyString, int aCommitFlags=0) override
Execute the changes.
A base class derived from BOARD_ITEM for items that can be connected and have a net,...
static bool ClassOf(const EDA_ITEM *aItem)
Returns information if the object is derived from BOARD_CONNECTED_ITEM.
NETINFO_ITEM * GetNet() const
Return #NET_INFO object for a given item.
A base class for any item which can be embedded within the BOARD container class, and therefore insta...
virtual PCB_LAYER_ID GetLayer() const
Return the primary layer this item is on.
virtual bool IsConnected() const
Returns information if the object is derived from BOARD_CONNECTED_ITEM.
bool IsLocked() const override
virtual VECTOR2I GetCenter() const
This defaults to the center of the bounding box if not overridden.
virtual std::shared_ptr< SHAPE > GetEffectiveShape(PCB_LAYER_ID aLayer=UNDEFINED_LAYER, FLASHING aFlash=FLASHING::DEFAULT) const
Some pad shapes can be complex (rounded/chamfered rectangle), even without considering custom shapes.
FOOTPRINT * GetParentFootprint() const
virtual LSET GetLayerSet() const
Return a std::bitset of all layers on which the item physically resides.
virtual void RunOnChildren(const std::function< void(BOARD_ITEM *)> &aFunction, RECURSE_MODE aMode) const
Invoke a function on all children.
BOARD_ITEM_CONTAINER * GetParent() const
virtual bool IsOnCopperLayer() const
Information pertinent to a Pcbnew printed circuit board.
INSPECT_RESULT Visit(INSPECTOR inspector, void *testData, const std::vector< KICAD_T > &scanTypes) override
May be re-implemented for each derived class in order to handle all the types given by its member dat...
bool IsElementVisible(GAL_LAYER_ID aLayer) const
Test whether a given element category is visible.
const LSET & GetVisibleLayers() const
A proxy function that calls the correspondent function in m_BoardSettings.
FOOTPRINT * GetFirstFootprint() const
Get the first footprint on the board or nullptr.
bool IsLayerVisible(PCB_LAYER_ID aLayer) const
A proxy function that calls the correspondent function in m_BoardSettings tests whether a given layer...
std::shared_ptr< CONNECTIVITY_DATA > GetConnectivity() const
Return a list of missing connections between components/tracks.
constexpr void SetMaximum()
constexpr BOX2< Vec > & Inflate(coord_type dx, coord_type dy)
Inflates the rectangle horizontally by dx and vertically by dy.
constexpr BOX2< Vec > & Normalize()
Ensure that the height and width are positive.
constexpr size_type GetWidth() const
constexpr Vec Centre() const
constexpr size_type GetHeight() const
constexpr bool Contains(const Vec &aPoint) const
constexpr const Vec & GetOrigin() const
constexpr const SizeVec & GetSize() const
CN_ANCHOR represents a physical location that can be connected: a pad or a track/arc/via endpoint.
BOARD_CONNECTED_ITEM * Parent() const
CN_EDGE represents a point-to-point connection, whether realized or unrealized (ie: tracks etc.
CN_ITEM represents a BOARD_CONNETED_ITEM in the connectivity system (ie: a pad, track/arc/via,...
virtual double OnePixelInIU() const =0
void Transfer(int aIndex)
Move the item at aIndex (first position is 0) to the backup list.
void Empty()
Clear the list.
int GetCount() const
Return the number of objects in the list.
bool HasItem(const EDA_ITEM *aItem) const
Tests if aItem has already been collected.
void Remove(int aIndex)
Remove the item at aIndex (first position is 0).
void Append(EDA_ITEM *item)
Add an item to the end of the list.
COMMIT & Remove(EDA_ITEM *aItem, BASE_SCREEN *aScreen=nullptr)
Remove a new item from the model.
A set of EDA_ITEMs (i.e., without duplicates).
std::unordered_set< EDA_ITEM * > & GetItems()
bool HasDesignBlockLink() const
virtual EDA_ITEM * AsEdaItem()=0
A base class for most all the KiCad significant classes used in schematics and boards.
virtual VECTOR2I GetPosition() const
virtual const BOX2I GetBoundingBox() const
Return the orthogonal bounding box of this object for display purposes.
void SetFlags(EDA_ITEM_FLAGS aMask)
virtual EDA_GROUP * GetParentGroup() const
KICAD_T Type() const
Returns the type of object.
void ClearFlags(EDA_ITEM_FLAGS aMask=EDA_ITEM_ALL_FLAGS)
virtual bool IsType(const std::vector< KICAD_T > &aScanTypes) const
Check whether the item is one of the listed types.
virtual bool HitTest(const VECTOR2I &aPosition, int aAccuracy=0) const
Test if aPosition is inside or on the boundary of this item.
EDA_ITEM * GetParent() const
bool HasFlag(EDA_ITEM_FLAGS aFlag) const
EDA_ITEM_FLAGS GetFlags() const
const VECTOR2I & GetEnd() const
Return the ending point of the graphic.
const VECTOR2I & GetStart() const
Return the starting point of the graphic.
virtual std::vector< SHAPE * > MakeEffectiveShapesForHitTesting() const
virtual bool IsVisible() const
std::shared_ptr< SHAPE_COMPOUND > GetEffectiveTextShape(bool aTriangulate=true, const BOX2I &aBBox=BOX2I(), const EDA_ANGLE &aAngle=ANGLE_0) const
build a list of segments (SHAPE_SEGMENT) to describe a text shape.
static const TOOL_EVENT DisambiguatePoint
Used for hotkey feedback.
static const TOOL_EVENT ClearedEvent
static const TOOL_EVENT InhibitSelectionEditing
static const TOOL_EVENT SelectedEvent
static const TOOL_EVENT SelectedItemsModified
Selected items were moved, this can be very high frequency on the canvas, use with care.
static const TOOL_EVENT UninhibitSelectionEditing
Used to inform tool that it should display the disambiguation menu.
static const TOOL_EVENT PointSelectedEvent
static const TOOL_EVENT SelectedItemsMoved
Used to inform tools that the selection should temporarily be non-editable.
static const TOOL_EVENT UnselectedEvent
A general implementation of a COLLECTORS_GUIDE.
void SetIgnoreBlindBuriedVias(bool ignore)
void SetIgnoreTracks(bool ignore)
void SetIgnoreFootprintsOnFront(bool ignore)
void SetIgnoreFPTextOnFront(bool ignore)
void SetIgnoreMicroVias(bool ignore)
void SetIgnoreZoneFills(bool ignore)
void SetIgnorePadsOnBack(bool ignore)
void SetIgnoreFPTextOnBack(bool ignore)
void SetLayerVisibleBits(const LSET &aLayerBits)
void SetIgnoreThroughVias(bool ignore)
void SetIgnoreThroughHolePads(bool ignore)
void SetIgnoreFPReferences(bool ignore)
void SetIgnoreFPValues(bool ignore)
void SetIgnorePadsOnFront(bool ignore)
void SetIgnoreFootprintsOnBack(bool ignore)
Used when the right click button is pressed, or when the select tool is in effect.
void SetGuide(const COLLECTORS_GUIDE *aGuide)
Record which COLLECTORS_GUIDE to use.
const COLLECTORS_GUIDE * GetGuide() const
static const std::vector< KICAD_T > AllBoardItems
A scan list for all editable board items.
void Collect(BOARD_ITEM *aItem, const std::vector< KICAD_T > &aScanList, const VECTOR2I &aRefPos, const COLLECTORS_GUIDE &aGuide)
Scan a BOARD_ITEM using this class's Inspector method, which does the collection.
static const std::vector< KICAD_T > FootprintItems
A scan list for primary footprint items.
A color representation with 4 components: red, green, blue, alpha.
virtual RENDER_SETTINGS * GetSettings()=0
Return a pointer to current settings that are going to be used when drawing items.
virtual void Update(const VIEW_ITEM *aItem, int aUpdateFlags) const override
For dynamic VIEWs, inform the associated VIEW that the graphical representation of this item has chan...
virtual void Add(VIEW_ITEM *aItem, int aDrawPriority=-1) override
Add a VIEW_ITEM to the view.
virtual void Remove(VIEW_ITEM *aItem) override
Remove a VIEW_ITEM from the view.
Represent a selection area (currently a rectangle) in a VIEW, drawn corner-to-corner between two poin...
VECTOR2I GetOrigin() const
void SetMode(SELECTION_MODE aMode)
void SetSubtractive(bool aSubtractive)
SELECTION_MODE GetMode() const
void SetAdditive(bool aAdditive)
void SetPoly(SHAPE_LINE_CHAIN &aPoly)
void SetOrigin(const VECTOR2I &aOrigin)
const BOX2I ViewBBox() const override
Set the origin of the rectangle (the fixed corner)
SHAPE_LINE_CHAIN & GetPoly()
void SetExclusiveOr(bool aExclusiveOr)
void SetEnd(const VECTOR2I &aEnd)
Set the current end of the rectangle (the corner that moves with the cursor.
Container for all the knowledge about how graphical objects are drawn on any output surface/device.
const std::set< int > & GetHighlightNetCodes() const
Return the netcode of currently highlighted net.
const std::set< int > GetHighContrastLayers() const
Returns the set of currently high-contrast layers.
virtual COLOR4D GetColor(const VIEW_ITEM *aItem, int aLayer) const =0
Returns the color that should be used to draw the specific VIEW_ITEM on the specific layer using curr...
bool GetHighContrast() const
void SetHighlight(bool aEnabled, int aNetcode=-1, bool aMulti=false)
Turns on/off highlighting.
virtual void SetCursorPosition(const VECTOR2D &aPosition, bool aWarpView=true, bool aTriggeredByArrows=false, long aArrowCommand=0)=0
Move cursor to the requested position expressed in world coordinates.
virtual void SetAutoPan(bool aEnabled)
Turn on/off auto panning (this feature is used when there is a tool active (eg.
An abstract base class for deriving all objects that can be added to a VIEW.
bool IsBOARD_ITEM() const
Hold a (potentially large) number of VIEW_ITEMs and renders them on a graphics device provided by the...
BOX2D GetViewport() const
Return the current viewport visible area rectangle.
virtual void SetScale(double aScale, VECTOR2D aAnchor={ 0, 0 })
Set the scaling factor, zooming around a given anchor point.
virtual void Add(VIEW_ITEM *aItem, int aDrawPriority=-1)
Add a VIEW_ITEM to the view.
virtual void Remove(VIEW_ITEM *aItem)
Remove a VIEW_ITEM from the view.
void UpdateAllLayersColor()
Apply the new coloring scheme to all layers.
int Query(const BOX2I &aRect, std::vector< LAYER_ITEM_PAIR > &aResult) const
Find all visible items that touch or are within the rectangle aRect.
virtual void Update(const VIEW_ITEM *aItem, int aUpdateFlags) const
For dynamic VIEWs, inform the associated VIEW that the graphical representation of this item has chan...
void Hide(VIEW_ITEM *aItem, bool aHide=true, bool aHideOverlay=false)
Temporarily hide the item in the view (e.g.
bool IsLayerVisible(int aLayer) const
Return information about visibility of a particular layer.
PAINTER * GetPainter() const
Return the painter object used by the view for drawing #VIEW_ITEMS.
void MarkTargetDirty(int aTarget)
Set or clear target 'dirty' flag.
void SetVisible(VIEW_ITEM *aItem, bool aIsVisible=true)
Set the item visibility.
wxString AsString() const
LSEQ is a sequence (and therefore also a set) of PCB_LAYER_IDs.
LSET is a set of PCB_LAYER_IDs.
static const LSET & AllCuMask()
return AllCuMask( MAX_CU_LAYERS );
LSEQ CuStack() const
Return a sequence of copper layers in starting from the front/top and extending to the back/bottom.
LSEQ Seq(const LSEQ &aSequence) const
Return an LSEQ from the union of this LSET and a desired sequence.
LSEQ SeqStackupTop2Bottom(PCB_LAYER_ID aSelectedLayer=UNDEFINED_LAYER) const
Generate a sequence of layers that represent a top to bottom stack of this set of layers.
static const LSET & AllLayersMask()
static const LSET & PhysicalLayersMask()
Return a mask holding all layers which are physically realized.
bool Contains(PCB_LAYER_ID aLayer) const
See if the layer set contains a PCB layer.
const VECTOR2I & GetPos() const
void ShapeToPolygon(SHAPE_LINE_CHAIN &aPolygon, int aScale=-1) const
Return the shape polygon in internal units in a SHAPE_LINE_CHAIN the coordinates are relatives to the...
Handle the data for a net.
const wxString & GetNetChain() const
PAD * GetTerminalPad(int aIndex) const
static TOOL_ACTION deleteLastPoint
static TOOL_ACTION drag45Degree
static TOOL_ACTION selectNetChain
Select all connections belonging to every net in the current item's net chain.
static TOOL_ACTION unrouteSelected
Removes all tracks from the selected items to the first pad.
static TOOL_ACTION saveToLinkedDesignBlock
static TOOL_ACTION grabUnconnected
Select and move nearest unconnected footprint from ratsnest of selection.
static TOOL_ACTION filterSelection
Filter the items in the current selection (invokes dialog)
static TOOL_ACTION setTerminalPad
static TOOL_ACTION highlightNet
static TOOL_ACTION hideLocalRatsnest
static TOOL_ACTION properties
Activation of the edit tool.
static TOOL_ACTION highlightNetChain
static TOOL_ACTION selectOnSheetFromEeschema
Select all components on sheet from Eeschema crossprobing.
static TOOL_ACTION selectConnection
Select tracks between junctions or expands an existing selection to pads or the entire connection.
static TOOL_ACTION applyDesignBlockLayout
static TOOL_ACTION dragFreeAngle
static TOOL_ACTION clearHighlight
static TOOL_ACTION selectUnconnected
Select unconnected footprints from ratsnest of selection.
static TOOL_ACTION unrouteSegment
Removes track segment from the selected item to the next segment.
static TOOL_ACTION moveIndividually
move items one-by-one
static TOOL_ACTION syncSelection
Sets selection to specified items, zooms to fit, if enabled.
static TOOL_ACTION selectSameSheet
Select all components on the same sheet as the selected footprint.
static TOOL_ACTION selectNet
Select all connections belonging to a single net.
static TOOL_ACTION move
move or drag an item
static TOOL_ACTION syncSelectionWithNets
Sets selection to specified items with connected nets, zooms to fit, if enabled.
static TOOL_ACTION deselectNet
Remove all connections belonging to a single net from the active selection.
static TOOL_ACTION placeLinkedDesignBlock
static TOOL_ACTION selectOnSchematic
Select symbols/pins on schematic corresponding to selected footprints/pads.
Common, abstract interface for edit frames.
Base PCB main window class for Pcbnew, Gerbview, and CvPcb footprint viewer.
const PCB_DISPLAY_OPTIONS & GetDisplayOptions() const
Display options control the way tracks, vias, outlines and other things are shown (for instance solid...
double m_TrackOpacity
Opacity override for all tracks.
double m_FilledShapeOpacity
Opacity override for graphic shapes.
double m_ZoneOpacity
Opacity override for filled zone areas.
double m_ImageOpacity
Opacity override for user images.
double m_PadOpacity
Opacity override for SMD pads and PTHs.
double m_ViaOpacity
Opacity override for all types of via.
ZONE_DISPLAY_MODE m_ZoneDisplayMode
virtual KIGFX::PCB_VIEW * GetView() const override
Return a pointer to the #VIEW instance used in the panel.
The main frame for Pcbnew.
A set of BOARD_ITEMs (i.e., without duplicates).
static bool WithinScope(BOARD_ITEM *aItem, PCB_GROUP *aScope, bool isFootprintEditor)
static EDA_GROUP * TopLevelGroup(BOARD_ITEM *aItem, EDA_GROUP *aScope, bool isFootprintEditor)
std::unordered_set< BOARD_ITEM * > GetBoardItems() const
Tool that displays edit points allowing to modify items by dragging the points.
bool HasPoint()
Indicate the cursor is over an edit point.
A PCB_POINT is a 0-dimensional point that is used to mark a position on a PCB, or more usually a foot...
VECTOR2I GetCenter() const override
This defaults to the center of the bounding box if not overridden.
virtual LSET GetLayerSet() const override
Return a std::bitset of all layers on which the item physically resides.
std::vector< VECTOR2I > GetConnectionPoints() const
std::vector< PCB_TABLECELL * > GetCells() const
virtual LSET GetLayerSet() const override
Return a std::bitset of all layers on which the item physically resides.
const VECTOR2I & GetStart() const
const VECTOR2I & GetEnd() const
VECTOR2I GetPosition() const override
int GetWidth() const override
virtual LSET GetLayerSet() const override
Return a std::bitset of all layers on which the item physically resides.
A small class to help profiling.
void Start()
Start or restart the counter.
double msecs(bool aSinceLast=false)
Describe ratsnest for a single net.
const std::vector< CN_EDGE > & GetEdges() const
static SEG::ecoord Square(int a)
static SELECTION_CONDITION HasType(KICAD_T aType)
Create a functor that tests if among the selected items there is at least one of a given type.
static bool NotEmpty(const SELECTION &aSelection)
Test if there are any items selected.
static SELECTION_CONDITION MoreThan(int aNumber)
Create a functor that tests if the number of selected items is greater than the value given as parame...
static SELECTION_CONDITION Count(int aNumber)
Create a functor that tests if the number of selected items is equal to the value given as parameter.
static SELECTION_CONDITION OnlyTypes(std::vector< KICAD_T > aTypes)
Create a functor that tests if the selected items are only of given types.
virtual void Add(EDA_ITEM *aItem)
virtual void Remove(EDA_ITEM *aItem)
void ClearReferencePoint()
bool Empty() const
Checks if there is anything selected.
Represent a polyline containing arcs as well as line segments: A chain of connected line and/or arc s...
void Move(const VECTOR2I &aVector) override
void GenerateBBoxCache() const
void SetClosed(bool aClosed)
Mark the line chain as closed (i.e.
int PointCount() const
Return the number of points (vertices) in this line chain.
virtual bool Collide(const VECTOR2I &aP, int aClearance=0, int *aActual=nullptr, VECTOR2I *aLocation=nullptr) const override
Check if point aP lies closer to us than aClearance.
double Area(bool aAbsolute=true) const
Return the area of this chain.
virtual size_t GetPointCount() const override
void Append(int aX, int aY, bool aAllowDuplication=false)
Append a new point at the end of the line chain.
const VECTOR2I & CLastPoint() const
Return the last point in the line chain.
void Remove(int aStartIndex, int aEndIndex)
Remove the range of points [start_index, end_index] from the line chain.
bool Collide(const SHAPE *aShape, int aClearance=0, int *aActual=nullptr, VECTOR2I *aLocation=nullptr) const override
Check if the boundary of shape (this) lies closer to the shape aShape than aClearance,...
virtual bool Collide(const VECTOR2I &aP, int aClearance=0, int *aActual=nullptr, VECTOR2I *aLocation=nullptr) const
Check if the boundary of shape (this) lies closer to the point aP than aClearance,...
Handle a list of polygons defining a copper zone.
bool GetIsRuleArea() const
Accessors to parameters used in Rule Area zones:
bool HitTestForCorner(const VECTOR2I &refPos, int aAccuracy, SHAPE_POLY_SET::VERTEX_INDEX *aCornerHit=nullptr) const
Test if the given VECTOR2I is near a corner.
bool HitTestForEdge(const VECTOR2I &refPos, int aAccuracy, SHAPE_POLY_SET::VERTEX_INDEX *aCornerHit=nullptr) const
Test if the given VECTOR2I is near a segment defined by 2 corners.
bool IsTeardropArea() const
virtual LSET GetLayerSet() const override
Return a std::bitset of all layers on which the item physically resides.
bool GetDoNotAllowZoneFills() const
A type-safe container of any type.
#define IGNORE_NETS
Function GetConnectedItems() Returns a list of items connected to a source item aItem.
#define DEFAULT_TEXT_SIZE
Ratio of the font height to the baseline of the text above the wire.
static bool empty(const wxTextEntryBase *aCtrl)
std::function< INSPECT_RESULT(EDA_ITEM *aItem, void *aTestData) > INSPECTOR_FUNC
Used to inspect and possibly collect the (search) results of iterating over a list or tree of KICAD_T...
#define BRIGHTENED
item is drawn with a bright contour
#define IS_NEW
New item, just created.
#define SELECTED
Item was manually selected by the user.
#define ENTERED
indicates a group has been entered
#define SKIP_STRUCT
flag indicating that the structure should be ignored
#define CANDIDATE
flag indicating that the structure is connected
#define IS_MOVING
Item being moved.
a few functions useful in geometry calculations.
double m_PcbSelectionVisibilityRatio
Board object selection visibility limit.
@ LAYER_POINTS
PCB reference/manual snap points visibility.
@ LAYER_FOOTPRINTS_FR
Show footprints on front.
@ LAYER_DRAW_BITMAPS
Draw images.
@ LAYER_FP_REFERENCES
Show footprints references (when texts are visible).
@ LAYER_DRC_EXCLUSION
Layer for DRC markers which have been individually excluded.
@ LAYER_ZONES
Control for copper zone opacity/visibility (color ignored).
@ LAYER_PADS
Meta control for all pads opacity/visibility (color ignored).
@ LAYER_FOOTPRINTS_BK
Show footprints on back.
@ LAYER_FP_VALUES
Show footprints values (when texts are visible).
@ LAYER_VIAS
Meta control for all vias opacity/visibility.
PCB_LAYER_ID
A quick note on layer IDs:
PCB_LAYER_ID ToLAYER_ID(int aLayer)
This file contains miscellaneous commonly used macros and functions.
#define KI_FALLTHROUGH
The KI_FALLTHROUGH macro is to be used when switch statement cases should purposely fallthrough from ...
bool BoxHitTest(const VECTOR2I &aHitPoint, const BOX2I &aHittee, int aAccuracy)
Perform a point-to-box hit test.
@ REPAINT
Item needs to be redrawn.
@ TARGET_OVERLAY
Items that may change while the view stays the same (noncached)
@ NPTH
like PAD_PTH, but not plated mechanical use only, no connection allowed
@ PTH
Plated through hole pad.
Class to handle a set of BOARD_ITEMs.
Class that computes missing connections on a PCB.
static float distance(const SFVEC2UI &a, const SFVEC2UI &b)
std::function< bool(const SELECTION &)> SELECTION_CONDITION
Functor type that checks a specific condition for selected items.
Struct that will be set with the result of the user choices in the dialog.
bool includeLockedFootprints
bool includeItemsOnTechLayers
bool includeBoardOutlineLayer
const BOARD_ITEM * m_Item
This file contains data structures that are saved in the project file or project local settings file ...
bool otherItems
Anything not fitting one of the above categories.
bool vias
Vias (all types>
bool keepouts
Keepout zones.
bool graphics
Graphic lines, shapes, polygons.
bool footprints
Allow selecting entire footprints.
bool text
Text (free or attached to a footprint)
bool lockedItems
Allow selecting locked items.
bool tracks
Copper tracks.
bool dimensions
Dimension items.
KIBIS top(path, &reporter)
std::vector< std::vector< std::string > > table
KICAD_T
The set of class identification values stored in EDA_ITEM::m_structType.
@ PCB_SHAPE_T
class PCB_SHAPE, a segment not on copper layers
@ PCB_DIM_ORTHOGONAL_T
class PCB_DIM_ORTHOGONAL, a linear dimension constrained to x/y
@ PCB_DIM_LEADER_T
class PCB_DIM_LEADER, a leader dimension (graphic item)
@ PCB_GENERATOR_T
class PCB_GENERATOR, generator on a layer
@ PCB_VIA_T
class PCB_VIA, a via (like a track segment on a copper layer)
@ PCB_DIM_CENTER_T
class PCB_DIM_CENTER, a center point marking (graphic item)
@ PCB_GROUP_T
class PCB_GROUP, a set of BOARD_ITEMs
@ PCB_TEXTBOX_T
class PCB_TEXTBOX, wrapped text on a layer
@ PCB_ZONE_T
class ZONE, a copper pour area
@ PCB_TEXT_T
class PCB_TEXT, text on a layer
@ PCB_REFERENCE_IMAGE_T
class PCB_REFERENCE_IMAGE, bitmap on a layer
@ PCB_FIELD_T
class PCB_FIELD, text associated with a footprint property
@ NOT_USED
the 3d code uses this value
@ PCB_MARKER_T
class PCB_MARKER, a marker used to show something
@ PCB_BARCODE_T
class PCB_BARCODE, a barcode (graphic item)
@ PCB_TARGET_T
class PCB_TARGET, a target (graphic item)
@ PCB_TABLECELL_T
class PCB_TABLECELL, PCB_TEXTBOX for use in tables
@ PCB_FOOTPRINT_T
class FOOTPRINT, a footprint
@ PCB_DIM_ALIGNED_T
class PCB_DIM_ALIGNED, a linear dimension (graphic item)
@ PCB_PAD_T
class PAD, a pad in a footprint
@ PCB_ARC_T
class PCB_ARC, an arc track segment on a copper layer
@ PCB_TABLE_T
class PCB_TABLE, table of PCB_TABLECELLs
@ PCB_NETINFO_T
class NETINFO_ITEM, a description of a net
@ PCB_POINT_T
class PCB_POINT, a 0-dimensional point
@ PCB_TRACE_T
class PCB_TRACK, a track segment (segment on a copper layer)
@ PCB_DIM_RADIAL_T
class PCB_DIM_RADIAL, a radius or diameter dimension
Casted dyn_cast(From aObject)
A lightweight dynamic downcast.
VECTOR2< int32_t > VECTOR2I
VECTOR2< double > VECTOR2D
VECTOR2D ToVECTOR2D(const wxPoint &aPoint)