30using namespace std::placeholders;
161 if( oldA && oldA->
m_Uuid == newId )
162 itemA->Enable(
false );
164 if( oldB && oldB->
m_Uuid == newId )
165 itemB->Enable(
false );
270 std::shared_ptr<SELECT_MENU> selectMenu = std::make_shared<SELECT_MENU>();
271 selectMenu->SetTool(
this );
272 m_menu->RegisterSubMenu( selectMenu );
274 std::shared_ptr<NET_CHAINS_MENU> netChainsMenu = std::make_shared<NET_CHAINS_MENU>();
275 netChainsMenu->SetTool(
this );
276 m_menu->RegisterSubMenu( netChainsMenu );
280 auto& menu =
m_menu->GetMenu();
282 auto activeToolCondition =
297 auto groupEnterCondition =
300 auto applyDesignBlockLayoutCondition = [](
const SELECTION& aSel )
313 auto inGroupCondition =
324 if( aSel.GetSize() != 1 )
334 menu.AddMenu( netChainsMenu.get(), netItemSelection );
335 menu.AddSeparator( 1000 );
346 menu.AddSeparator( haveHighlight, 1 );
352 menu.AddSeparator( 1 );
396 wxMouseState keyboardState = wxGetMouseState();
398 setModifiersState( keyboardState.ShiftDown(), keyboardState.ControlDown(), keyboardState.AltDown() );
421 trackDragAction = cfg->m_TrackDragAction;
435 else if( evt->IsMouseDown(
BUT_LEFT ) )
484 bool selectionCancelled =
false;
488 selectPoint( evt->Position(),
false, &selectionCancelled );
493 m_frame->GetCanvas()->ForceRefresh();
495 if( !selectionCancelled )
501 else if( evt->IsDblClick(
BUT_LEFT ) )
543 const int delta = evt->Parameter<
int>();
594 wxASSERT_MSG(
false, wxT(
"Unknown selection mode" ) );
601 auto zoneFilledAreaFilter =
604 int accuracy = aCollector.GetGuide()->Accuracy();
605 std::set<EDA_ITEM*> remove;
611 ZONE* zone =
static_cast<ZONE*
>( item );
616 remove.insert( zone );
622 aCollector.Remove( item );
628 if( evt->HasPosition() )
631 &&
selectPoint( evt->DragOrigin(),
false,
nullptr, zoneFilledAreaFilter ) )
649 bool routable = ( segs >= 1 || arcs >= 1 || vias == 1 )
650 && ( segs + arcs + vias ==
m_selection.GetSize() );
674 else if( evt->IsCancel() )
683 else if( evt->FirstResponder() ==
this && evt->GetCommandId() == (
int) WXK_ESCAPE )
695 if( controller &&
m_frame->GetPcbNewSettings()->m_ESCClearsNetHighlight )
698 catch(
const std::runtime_error& e )
700 wxCHECK_MSG(
false, 0, e.what() );
711 if(
m_frame->ToolStackIsEmpty() )
717 && evt->HasPosition()
741 wxT(
"EnterGroup called when selection is not a single group" ) );
804 enum DISPOSITION { BEFORE = 1, AFTER,
BOTH };
806 std::map<EDA_ITEM*, DISPOSITION> itemDispositions;
815 itemDispositions[ item ] = BEFORE;
818 aClientFilter(
VECTOR2I(), collector,
this );
822 if( itemDispositions.count( item ) )
823 itemDispositions[ item ] =
BOTH;
825 itemDispositions[ item ] = AFTER;
833 for( std::pair<EDA_ITEM* const, DISPOSITION> itemDisposition : itemDispositions )
835 EDA_ITEM* item = itemDisposition.first;
836 DISPOSITION disposition = itemDisposition.second;
838 if( disposition == BEFORE )
842 for( std::pair<EDA_ITEM* const, DISPOSITION> itemDisposition : itemDispositions )
844 EDA_ITEM* item = itemDisposition.first;
845 DISPOSITION disposition = itemDisposition.second;
849 if( disposition == AFTER || disposition ==
BOTH )
853 m_frame->GetCanvas()->ForceRefresh();
909 for(
int i = collector.
GetCount() - 1; i >= 0; --i )
911 if( !
Selectable( collector[ i ] ) || ( aOnDrag && collector[i]->IsLocked() ) )
917 size_t preFilterCount = collector.
GetCount();
924 if( collector.
GetCount() == 0 && preFilterCount > 0 )
927 editFrame->HighlightSelectionFilter( rejected );
942 aClientFilter( aWhere, collector,
this );
951 for(
int i = collector.
GetCount() - 1; i >= 0; --i )
953 if( !collector[i]->IsSelected() )
965 catch(
const std::exception& exc )
967 wxLogWarning( wxS(
"Exception '%s' occurred attempting to guess selection candidates." ),
981 if( aSelectionCancelledFlag )
982 *aSelectionCancelledFlag =
true;
989 bool anySubtracted =
false;
996 anySubtracted =
true;
1002 for(
int i = 0; i < collector.
GetCount(); ++i )
1007 anySubtracted =
true;
1017 if( addedCount == 1 )
1022 else if( addedCount > 1 )
1027 else if( anySubtracted )
1064 for(
int i = 0; aAllowedActions[i]; ++i )
1066 if( aEvent->
IsAction( aAllowedActions[i] ) )
1079 if( cell->IsSelected() )
1090 BOX2I selectionRect( aStart, aEnd );
1096 return ( aItem->GetFlags() &
CANDIDATE ) > 0;
1101 bool doSelect =
false;
1103 if( cell->HitTest( selectionRect,
false ) )
1108 doSelect = !wasSelected( cell );
1112 else if( wasSelected( cell ) )
1117 if( doSelect && !cell->IsSelected() )
1119 else if( !doSelect && cell->IsSelected() )
1167 std::set<EDA_ITEM*> previousSelection;
1170 previousSelection.insert( item );
1182 VECTOR2D topLeft( std::min( start.
x,
end.x ), std::min( start.
y,
end.y ) );
1183 VECTOR2D bottomRight( std::max( start.
x,
end.x ), std::max( start.
y,
end.y ) );
1187 bool anyAdded =
false;
1188 bool anySubtracted =
false;
1192 bool wasInPrevious = previousSelection.count( cell ) > 0;
1194 if( cell->IsSelected() && !wasInPrevious )
1196 else if( wasInPrevious && !cell->IsSelected() )
1197 anySubtracted =
true;
1248 if( !cell || cell->
GetParent() != selectedTable )
1260 if( clickedCell->
GetParent() != selectedTable )
1283 bool cancelled =
false;
1289 bool haveAnchorStart =
false;
1296 haveAnchorStart =
true;
1308 return ( aItem->GetFlags() &
CANDIDATE ) > 0;
1313 if( evt->IsCancelInteractive() || evt->IsActivate() )
1322 VECTOR2D start = haveAnchorStart ? anchorStart :
VECTOR2D( evt->DragOrigin() );
1327 else if( evt->IsMouseUp(
BUT_LEFT ) )
1331 bool anyAdded =
false;
1332 bool anySubtracted =
false;
1336 if( cell->IsSelected() && !wasSelected( cell ) )
1338 else if( wasSelected( cell ) && !cell->IsSelected() )
1339 anySubtracted =
true;
1371 bool cancelled =
false;
1386 if(
view->IsMirroredX() )
1387 greedySelection = !greedySelection;
1392 if( evt->IsCancelInteractive() || evt->IsActivate() )
1411 area.
SetEnd( evt->Position() );
1417 view->SetVisible( &area,
true );
1418 view->Update( &area );
1427 view->SetVisible( &area,
false );
1441 view->Remove( &area );
1473 bool cancelled =
false;
1491 bool isClockwise = shapeArea > 0 ? true :
false;
1493 if(
getView()->IsMirroredX() && shapeArea != 0 )
1494 isClockwise = !isClockwise;
1498 if( evt->IsCancelInteractive() || evt->IsActivate() )
1501 evt->SetPassEvent(
false );
1508 points.
Append( evt->Position() );
1510 else if( evt->IsDblClick(
BUT_LEFT )
1516 evt->SetPassEvent(
false );
1552 area.
SetMode( selectionMode );
1575 bool anyAdded =
false;
1576 bool anySubtracted =
false;
1584 std::vector<KIGFX::VIEW::LAYER_ITEM_PAIR> candidates;
1586 view->Query( selectionBox, candidates );
1590 std::set<EDA_ITEM*> group_items;
1598 std::unordered_set<EDA_ITEM*>& newset =
group->GetItems();
1601 [&](
const BOX2I& aBox )
1603 return boxMode ? selectionBox.
Contains( aBox )
1609 if( containedMode && boxContained(
group->GetBoundingBox() ) && newset.size() )
1611 for(
EDA_ITEM* group_item : newset )
1613 if( !group_item->IsBOARD_ITEM() )
1617 collector.
Append( *newset.begin() );
1621 for(
EDA_ITEM* group_item : newset )
1622 group_items.emplace( group_item );
1628 return boxMode ? aItem->HitTest( selectionBox, containedMode )
1629 : aItem->HitTest( aArea.
GetPoly(), containedMode );
1632 for(
const auto& [item, layer] : candidates )
1634 if( !item->IsBOARD_ITEM() )
1639 if(
Selectable( boardItem ) && hitTest( boardItem )
1640 && ( !containedMode || !group_items.count( boardItem ) ) )
1643 padsCollector.
Append( boardItem );
1645 collector.
Append( boardItem );
1657 collector = padsCollector;
1664 std::sort( collector.
begin(), collector.
end(),
1667 VECTOR2I aPos = a->GetPosition();
1668 VECTOR2I bPos = b->GetPosition();
1670 if( aPos.y == bPos.y )
1671 return aPos.x < bPos.x;
1673 return aPos.y < bPos.y;
1678 if( !i->IsBOARD_ITEM() )
1683 if( aSubtractive || ( aExclusiveOr && item->
IsSelected() ) )
1686 anySubtracted =
true;
1700 else if( anySubtracted )
1707 wxMouseState keyboardState = wxGetMouseState();
1709 setModifiersState( keyboardState.ShiftDown(), keyboardState.ControlDown(), keyboardState.AltDown() );
1753 collection.
Append( item );
1766 m_frame->GetCanvas()->ForceRefresh();
1794 m_frame->GetCanvas()->ForceRefresh();
1804 std::set<int> representedNets;
1806 for(
int i = aCollector.
GetCount() - 1; i >= 0; i-- )
1812 else if ( representedNets.count( item->
GetNetCode() ) )
1815 representedNets.insert( item->
GetNetCode() );
1822 std::deque<EDA_ITEM*> selectedItems =
m_selection.GetItems();
1825 std::vector<BOARD_CONNECTED_ITEM*> toUnroute;
1826 std::set<EDA_ITEM*> toDelete;
1828 for(
EDA_ITEM* item : selectedItems )
1833 toUnroute.push_back(
pad );
1837 toDelete.insert( item );
1853 std::set<int> selectedNets;
1856 if( item->GetNetCode() > 0 )
1857 selectedNets.insert( item->GetNetCode() );
1859 std::set<VECTOR2I> endpointSet;
1865 endpointSet.insert( track->GetStart() );
1866 endpointSet.insert( track->GetEnd() );
1870 endpointSet.insert( item->GetPosition() );
1874 endpointSet.insert( item->GetPosition() );
1878 bool expanded =
true;
1886 if( toDelete.count( gen ) )
1890 std::map<VECTOR2I, int> epCount;
1892 for(
BOARD_ITEM* child : gen->GetBoardItems() )
1896 if( track && selectedNets.count( track->
GetNetCode() ) )
1899 epCount[track->
GetEnd()]++;
1904 bool connected =
false;
1906 for(
auto& [pt, count] : epCount )
1908 if( count == 1 && endpointSet.count( pt ) )
1917 toDelete.insert( gen );
1931 endpointSet.insert( track->GetStart() );
1932 endpointSet.insert( track->GetEnd() );
1955 std::set<BOARD_ITEM*> removed;
1959 if( !item->IsBOARD_ITEM() )
1965 toDelete.insert( bi );
1968 removed.insert( bi );
1974 for(
BOARD_ITEM* child : gen->GetBoardItems() )
1976 if( removed.count( child ) )
1978 toDelete.insert( gen );
1986 if( !item->IsBOARD_ITEM() )
1994 if( removed.find( aItem ) == removed.end() )
1997 removed.insert( aItem );
2002 if( removed.find( boardItem ) == removed.end() )
2003 commit.
Remove( boardItem );
2007 commit.
Push(
_(
"Unroute Selected" ) );
2012 for(
EDA_ITEM* item : selectedItems )
2024 std::deque<EDA_ITEM*> selectedItems =
m_selection.GetItems();
2027 std::vector<BOARD_CONNECTED_ITEM*> toUnroute;
2029 std::set<EDA_ITEM*> toDelete;
2031 for(
EDA_ITEM* item : selectedItems )
2042 if( !toDelete.count( gen ) )
2044 toDelete.insert( gen );
2048 toDelete.insert( generatedItem );
2058 toDelete.insert( item );
2063 toDelete.insert( item );
2067 toDelete.insert( generatedItem );
2078 std::deque<EDA_ITEM*> toSelectAfter;
2082 if( !item->IsBOARD_ITEM() )
2085 if( toDelete.find( item ) == toDelete.end() )
2086 toSelectAfter.push_back( item );
2090 std::set<BOARD_ITEM*> removed;
2094 if( !item->IsBOARD_ITEM() )
2104 if( removed.insert( aItem ).second )
2109 if( removed.insert( boardItem ).second )
2110 commit.
Remove( boardItem );
2114 if( removed.insert( boardItem ).second )
2115 commit.
Remove( boardItem );
2119 commit.
Push(
_(
"Unroute Segment" ) );
2124 for(
EDA_ITEM* item : toSelectAfter )
2126 if( !toDelete.count( item ) )
2139 unsigned initialCount = 0;
2151 if( initialCount == 0 )
2154 std::vector<PCB_SHAPE*> startShapes;
2159 startShapes.push_back(
static_cast<PCB_SHAPE*
>( item ) );
2163 if( !startShapes.empty() )
2169 m_frame->SetStatusText(
_(
"Select/Expand Connection..." ) );
2173 std::deque<EDA_ITEM*> selectedItems =
m_selection.GetItems();
2175 for(
EDA_ITEM* item : selectedItems )
2176 item->ClearTempFlags();
2178 std::vector<BOARD_CONNECTED_ITEM*> startItems;
2180 for(
EDA_ITEM* item : selectedItems )
2187 startItems.push_back(
pad );
2205 if(
m_selection.GetItems().size() > initialCount )
2209 m_frame->SetStatusText( wxEmptyString );
2222 double refreshIntervalMs = 500;
2223 int lastSelectionSize = (int)
m_selection.GetSize();
2227 std::set<PAD*> startPadSet;
2228 std::vector<BOARD_CONNECTED_ITEM*> cleanupItems;
2234 startPadSet.insert(
static_cast<PAD*
>( startItem ) );
2237 if( startItem->IsType( { PCB_TRACE_T, PCB_ARC_T, PCB_VIA_T } ) )
2246 std::map<VECTOR2I, std::vector<PCB_TRACK*>> trackMap;
2247 std::map<VECTOR2I, PCB_VIA*> viaMap;
2248 std::map<VECTOR2I, PAD*> padMap;
2249 std::map<VECTOR2I, std::vector<PCB_SHAPE*>> shapeMap;
2250 std::vector<std::pair<VECTOR2I, LSET>> activePts;
2260 switch( item->Type() )
2266 trackMap[track->
GetStart()].push_back( track );
2267 trackMap[track->
GetEnd()].push_back( track );
2274 viaMap[
via->GetStart()] =
via;
2281 padMap[
pad->GetPosition()] =
pad;
2290 shapeMap[point].push_back( shape );
2301 switch( startItem->Type() )
2314 activePts.push_back( { startItem->GetPosition(), startItem->GetLayerSet() } );
2318 activePts.push_back( { startItem->GetPosition(), startItem->GetLayerSet() } );
2326 activePts.push_back( { point, startItem->GetLayerSet() } );
2339 while( expand && failSafe++ < 100000 )
2343 for(
int i = (
int) activePts.size() - 1; i >= 0; --i )
2351 auto exactIt = viaMap.find( pt );
2353 if( exactIt != viaMap.end() && ( exactIt->second->GetLayerSet() & layerSetCu ).any() )
2355 hitVia = exactIt->second;
2360 for(
auto& [pos,
via] : viaMap )
2362 if( !(
via->GetLayerSet() & layerSetCu ).any() )
2369 int radius =
via->GetWidth( layer ) / 2;
2370 int64_t radiusSq =
static_cast<int64_t
>(
radius ) *
radius;
2372 if( ( pt - pos ).SquaredEuclideanNorm() <= radiusSq )
2387 auto padIt = padMap.find( pt );
2389 bool gotVia = hitVia !=
nullptr;
2390 bool gotPad = padIt != padMap.end() && ( padIt->second->GetLayerSet() & layerSetCu ).any();
2391 bool gotNonStartPad = gotPad && ( startPadSet.find( padIt->second ) == startPadSet.end() );
2395 activePts.erase( activePts.begin() + i );
2401 activePts.erase( activePts.begin() + i );
2407 size_t pt_count = 0;
2411 if( track->GetStart() != track->GetEnd() && layerSetCu.
Contains( track->GetLayer() ) )
2415 if( pt_count > 2 || gotVia || gotNonStartPad )
2417 activePts.erase( activePts.begin() + i );
2423 if( gotNonStartPad )
2425 activePts.erase( activePts.begin() + i );
2432 PAD*
pad = padIt->second;
2437 cleanupItems.push_back(
pad );
2439 activePts.push_back( {
pad->GetPosition(),
pad->GetLayerSet() } );
2446 if( !layerSetCu.
Contains( track->GetLayer() ) )
2452 if( !track->IsSelected() )
2458 cleanupItems.push_back( track );
2460 if( track->GetStart() == pt )
2461 activePts.push_back( { track->GetEnd(), track->GetLayerSet() } );
2463 activePts.push_back( { track->GetStart(), track->GetLayerSet() } );
2472 if( !layerSetCu.
Contains( shape->GetLayer() ) )
2478 if( !shape->IsSelected() )
2484 cleanupItems.push_back( shape );
2486 for(
const VECTOR2I& newPoint : shape->GetConnectionPoints() )
2488 if( newPoint == pt )
2491 activePts.push_back( { newPoint, shape->GetLayerSet() } );
2507 cleanupItems.push_back( hitVia );
2514 maxRadius = std::max( maxRadius, hitVia->
GetWidth( layer ) / 2 );
2516 int64_t maxRadiusSq =
static_cast<int64_t
>( maxRadius ) * maxRadius;
2518 for(
auto& [trkPt, tracks] : trackMap )
2520 if( ( trkPt - viaPos ).SquaredEuclideanNorm() > maxRadiusSq )
2524 bool inside =
false;
2533 int r = hitVia->
GetWidth( trkLayer ) / 2;
2534 int64_t rSq =
static_cast<int64_t
>( r ) * r;
2536 if( ( trkPt - viaPos ).SquaredEuclideanNorm() <= rSq )
2544 activePts.push_back( { trkPt, hitVia->
GetLayerSet() } );
2552 activePts.erase( activePts.begin() + i );
2556 if( refreshTimer.
msecs() >= refreshIntervalMs )
2560 m_frame->GetCanvas()->ForceRefresh();
2564 refreshTimer.
Start();
2569 std::set<EDA_ITEM*> toDeselect;
2570 std::set<EDA_ITEM*> toSelect;
2575 if( !item->IsBOARD_ITEM() )
2583 toDeselect.insert( item );
2628 std::stack<PCB_SHAPE*> toSearch;
2629 std::set<PCB_SHAPE*> toCleanup;
2631 for(
PCB_SHAPE* startItem : aStartItems )
2632 toSearch.push( startItem );
2645 toSearch.push(
static_cast<PCB_SHAPE*
>( item ) );
2649 while( !toSearch.empty() )
2658 toCleanup.insert( shape );
2667 searchPoint( shape->
GetEnd() );
2678 std::vector<PAD*> pads;
2685 pads.push_back(
pad );
2689 pads.push_back(
static_cast<PAD*
>( item ) );
2698 for(
const CN_EDGE& edge : conn->GetRatsnestForPad(
pad ) )
2700 wxCHECK2( edge.GetSourceNode() && !edge.GetSourceNode()->Dirty(),
continue );
2701 wxCHECK2( edge.GetTargetNode() && !edge.GetTargetNode()->Dirty(),
continue );
2706 if( sourceParent ==
pad )
2709 select(
static_cast<PAD*
>( targetParent )->GetParent() );
2711 else if( targetParent ==
pad )
2714 select(
static_cast<PAD*
>( sourceParent )->GetParent() );
2728 std::vector<PAD*> pads;
2735 pads.push_back(
pad );
2739 pads.push_back(
static_cast<PAD*
>( item ) );
2750 const std::vector<CN_EDGE> edges = conn->GetRatsnestForPad(
pad );
2753 if( edges.size() == 0 )
2756 double currentDistance = DBL_MAX;
2760 for(
const CN_EDGE& edge : edges )
2762 if( edge.GetSourceNode()->Parent()->GetParentFootprint()
2763 == edge.GetTargetNode()->Parent()->GetParentFootprint() )
2769 const CN_ANCHOR* other = edge.GetSourceNode()->
Parent() ==
pad ? edge.GetTargetNode().get()
2770 : edge.GetSourceNode().get();
2772 wxCHECK2( other && !other->
Dirty(),
continue );
2778 if( edge.GetLength() < currentDistance )
2780 currentDistance = edge.GetLength();
2785 if( nearest !=
nullptr )
2799 for(
BOARD_ITEM* item : conn->GetNetItems( aNetCode, { PCB_TRACE_T,
2873 const wxString& chainName = netInfo->
GetNetChain();
2875 if( chainName.IsEmpty() )
2884 if( candidate && candidate->GetNetChain() == chainName )
2900 std::vector<BOARD_ITEM*> footprints;
2905 if( footprint ==
nullptr )
2908 wxString footprint_path = footprint->GetPath().AsString().BeforeLast(
'/' );
2910 if( footprint_path.IsEmpty() )
2911 footprint_path +=
'/';
2913 if( footprint_path == aSheetPath )
2914 footprints.push_back( footprint );
2930 std::list<int> netcodeList;
2931 std::vector<BOARD_CONNECTED_ITEM*> padList;
2935 switch( item->Type() )
2941 if(
pad->IsConnected() )
2943 netcodeList.push_back(
pad->GetNetCode() );
2944 padList.push_back(
pad );
2955 if(
pad->IsConnected() )
2957 netcodeList.push_back(
pad->GetNetCode() );
2958 padList.push_back(
pad );
2970 std::sort( padList.begin(), padList.end() );
2974 netcodeList.unique();
2980 std::vector<int> removeCodeList;
2983 for(
int netCode : netcodeList )
2987 if( !std::binary_search( padList.begin(), padList.end(),
pad ) )
2991 removeCodeList.push_back( netCode );
2997 for(
int removeCode : removeCodeList )
2998 netcodeList.remove( removeCode );
3000 std::unordered_set<BOARD_ITEM*> localConnectionList;
3002 for(
int netCode : netcodeList )
3004 for(
BOARD_ITEM* item : conn->GetNetItems( netCode, { PCB_TRACE_T,
3009 localConnectionList.insert( item );
3013 for(
BOARD_ITEM* item : localConnectionList )
3020 std::vector<BOARD_ITEM*>* items = aEvent.
Parameter<std::vector<BOARD_ITEM*>*>();
3031 std::vector<BOARD_ITEM*>* items = aEvent.
Parameter<std::vector<BOARD_ITEM*>*>();
3049 if( item->IsMoving() )
3066 if(
m_frame->GetPcbNewSettings()->m_CrossProbing.center_on_items )
3068 if(
m_frame->GetPcbNewSettings()->m_CrossProbing.zoom_to_fit )
3077 m_frame->GetCanvas()->ForceRefresh();
3087 wxString sheetPath = *aEvent.
Parameter<wxString*>();
3113 if( !footprint || footprint->
GetPath().empty() )
3119 wxString sheetPath = footprint->
GetPath().
AsString().BeforeLast(
'/' );
3121 if( sheetPath.IsEmpty() )
3142 screenSize.
x = std::max( 10.0, screenSize.
x );
3143 screenSize.
y = std::max( 10.0, screenSize.
y );
3148 double scale =
view->GetScale() / std::max( fabs( vsize.
x / screenSize.
x ),
3149 fabs( vsize.
y / screenSize.
y ) );
3155 m_frame->GetCanvas()->ForceRefresh();
3171#ifdef DEFAULT_PCBNEW_CODE
3173 auto screenSize =
view->ToWorld( GetCanvas()->GetClientSize(),
false );
3176 screenSize.x = std::max( 10.0, fabs( screenSize.x ) );
3177 screenSize.y = std::max( 10.0, screenSize.y );
3178 double ratio = std::max( fabs( bbSize.x / screenSize.x ), fabs( bbSize.y / screenSize.y ) );
3181 if( crossProbingSettings.zoom_to_fit && ( ratio < 0.5 || ratio > 1.0 ) )
3182 view->SetScale(
view->GetScale() / ratio );
3185#ifndef DEFAULT_PCBNEW_CODE
3202 double compRatio = bbSize.y / currTextHeight;
3205 double compRatioBent = 1.0;
3216 screenSize.
x = std::max( 10.0, fabs( screenSize.
x ) );
3217 screenSize.
y = std::max( 10.0, screenSize.
y );
3218 double ratio = std::max( -1.0, fabs( bbSize.y / screenSize.
y ) );
3221 double kicadRatio = std::max( fabs( bbSize.x / screenSize.
x ),
3222 fabs( bbSize.y / screenSize.
y ) );
3230 std::vector<std::pair<double, double>> lut {
3243 std::vector<std::pair<double, double>>::iterator it;
3245 compRatioBent = lut.back().second;
3247 if( compRatio >= lut.front().first )
3253 for( it = lut.begin(); it < lut.end() - 1; it++ )
3255 if( it->first <= compRatio &&
next( it )->first >= compRatio )
3257 double diffx = compRatio - it->first;
3258 double diffn =
next( it )->first - it->first;
3260 compRatioBent = it->second + (
next( it )->second - it->second ) * diffx / diffn;
3267 compRatioBent = lut.front().second;
3275 if( bbSize.x > screenSize.
x * ratio * compRatioBent )
3279 compRatioBent = 1.0;
3280 wxLogTrace(
"CROSS_PROBE_SCALE",
"Part TOO WIDE for screen. Using normal KiCad zoom ratio: %1.5f", ratio );
3285 ratio *= compRatioBent;
3287 bool alwaysZoom =
false;
3290 if( ( ratio < 0.5 || ratio > 1.0 ) || alwaysZoom )
3291 view->SetScale(
view->GetScale() / ratio );
3298 bool cleared =
false;
3310 switch( aItem->
Type() )
3314 int netCode =
static_cast<NETINFO_ITEM*
>( aItem )->GetNetCode();
3333 double marginFactor = 2;
3342 double scaleX = screenSize.
x /
static_cast<double>( aItem->
GetBoundingBox().GetWidth() );
3343 double scaleY = screenSize.
y /
static_cast<double>( aItem->
GetBoundingBox().GetHeight() );
3345 scaleX /= marginFactor;
3346 scaleY /= marginFactor;
3348 double scale = scaleX > scaleY ? scaleY : scaleX;
3367 m_frame->GetCanvas()->ForceRefresh();
3379 switch( aItem.
Type() )
3434 if( cmd != wxID_OK )
3445 if( !i->IsBOARD_ITEM() )
3467 std::set<BOARD_ITEM*> rejected;
3471 if( !i->IsBOARD_ITEM() )
3477 rejected.insert( item );
3481 aCollector.
Remove( item );
3546 aRejected->
pads =
true;
3558 aRejected->
tracks =
true;
3569 aRejected->
vias =
true;
3578 ZONE* zone =
static_cast<ZONE*
>( aItem );
3588 aRejected->
zones =
true;
3597 if( zone ==
m_frame->GetBoard()->m_SolderMaskBridges )
3628 aRejected->
text =
true;
3664 aRejected->
points =
true;
3720 bool enteredGroupFound =
false;
3723 [&](
EDA_ITEM* item,
void* testData )
3741 enteredGroupFound =
true;
3755 if( !enteredGroupFound )
3768 auto visibleLayers =
3776 set.
set( layer,
view()->IsLayerVisible( layer ) );
3798 bool onActiveLayer =
false;
3800 for(
int layer : activeLayers )
3803 if( layer < PCB_LAYER_ID_COUNT && aItem->IsOnLayer(
ToLAYER_ID( layer ) ) )
3805 onActiveLayer =
true;
3828 && footprint->
Pads().empty()
3829 && footprint->
Zones().empty() )
3846 for(
const ZONE* zone : footprint->
Zones() )
3878 const ZONE* zone =
nullptr;
3880 const PAD*
pad =
nullptr;
3893 switch( aItem->
Type() )
3899 zone =
static_cast<const ZONE*
>( aItem );
3917 if( !layerVisible( aItem->
GetLayer() ) )
3929 if( !( visibleLayers() &
via->GetLayerSet() ).any() )
3935 field =
static_cast<const PCB_FIELD*
>( aItem );
3951 if( !layerVisible(
text->GetLayer() ) )
3962 if(
text->GetText() == wxT(
"${REFERENCE}" ) )
3964 else if(
text->GetText() == wxT(
"${VALUE}" ) )
3967 if( !
view()->IsLayerVisible( controlLayer ) )
3981 if( !layerVisible( aItem->
GetLayer() ) )
3990 if( !layerVisible( aItem->
GetLayer() ) )
3996 if( !layerVisible( aItem->
GetLayer() ) )
4003 if( !layerVisible( aItem->
GetLayer() ) )
4011 if( !layerVisible( aItem->
GetLayer() ) )
4024 if( !layerVisible( aItem->
GetLayer() ) )
4033 pad =
static_cast<const PAD*
>( aItem );
4044 if( !(
pad->GetLayerSet() & visibleLayers() ).
any() )
4051 marker =
static_cast<const PCB_MARKER*
>( aItem );
4059 if( !layerVisible( aItem->
GetLayer() ) )
4113 aGroup->
Add( aItem );
4182 const unsigned GRIP_MARGIN = 20;
4188 if( !item->IsBOARD_ITEM() )
4191 BOX2I itemBox = item->ViewBBox();
4196 if( item->HitTest( aPoint, margin ) )
4203 group->RunOnChildren(
4206 if( aItem->
HitTest( aPoint, margin ) )
4226 SEG loc( aWhere, aWhere );
4228 switch( aItem->
Type() )
4236 if(
text->GetEffectiveTextShape()->Collide( loc, aMaxDistance, &
distance ) )
4258 shape->Collide( loc, aMaxDistance, &
distance );
4278 ZONE* zone =
static_cast<ZONE*
>( aItem );
4300 catch(
const std::exception& e )
4302 wxFAIL_MSG( wxString::Format( wxT(
"Clipper exception occurred: %s" ), e.what() ) );
4336 static_cast<PAD*
>( aItem )->Padstack().ForEachUniqueLayer(
4339 int layerDistance = INT_MAX;
4365 wxCHECK( settings, );
4368 LSET visibleLayers =
m_frame->GetBoard()->GetVisibleLayers();
4369 LSET enabledLayers =
m_frame->GetBoard()->GetEnabledLayers();
4372 wxCHECK( !enabledLayerStack.empty(), );
4374 auto isZoneFillKeepout =
4379 const ZONE* zone =
static_cast<const ZONE*
>( aItem );
4388 std::vector<LAYER_OPACITY_ITEM> opacityStackup;
4390 for(
int i = 0; i < aCollector.
GetCount(); i++ )
4394 LSET itemLayers = item->
GetLayerSet() & enabledLayers & visibleLayers;
4395 LSEQ itemLayerSeq = itemLayers.
Seq( enabledLayerStack );
4408 opacityItem.
m_Item = item;
4410 if( isZoneFillKeepout( item ) )
4413 opacityStackup.emplace_back( opacityItem );
4417 std::sort( opacityStackup.begin(), opacityStackup.end(),
4420 int retv = enabledLayerStack.TestLayers( aLhs.m_Layer, aRhs.m_Layer );
4425 return aLhs.m_Opacity > aRhs.m_Opacity;
4428 std::set<const BOARD_ITEM*> visibleItems;
4429 std::set<const BOARD_ITEM*> itemsToRemove;
4431 double currentStackupOpacity = 0.0;
4438 currentStackupOpacity = opacityItem.m_Opacity;
4439 lastVisibleLayer = opacityItem.m_Layer;
4440 visibleItems.emplace( opacityItem.m_Item );
4450 wxCHECK( item,
false );
4453 if( visibleItems.count( item ) )
4459 && visibleItems.count( item->
GetParent() ) )
4466 if( isZoneFillKeepout( item ) )
4473 if( opacityItem.m_Layer == enabledLayerStack[0] )
4475 visibleItems.emplace( opacityItem.m_Item );
4479 double itemVisibility = opacityItem.m_Opacity * ( 1.0 - currentStackupOpacity );
4481 if( ( itemVisibility <= minAlphaLimit ) && !ignoreItem() )
4482 itemsToRemove.emplace( opacityItem.m_Item );
4484 visibleItems.emplace( opacityItem.m_Item );
4487 if( opacityItem.m_Layer != lastVisibleLayer )
4489 currentStackupOpacity += opacityItem.m_Opacity * ( 1.0 - currentStackupOpacity );
4490 currentStackupOpacity = std::min( currentStackupOpacity, 1.0 );
4491 lastVisibleLayer = opacityItem.m_Layer;
4495 for(
const BOARD_ITEM* itemToRemove : itemsToRemove )
4497 wxCHECK( aCollector.
GetCount() > 1, );
4498 aCollector.
Remove( itemToRemove );
4521 static std::vector<KICAD_T> singleLayerSilkTypes = {
PCB_FIELD_T,
4533 std::set<BOARD_ITEM*> preferred;
4534 std::set<BOARD_ITEM*> rejected;
4541 if( silkLayers[activeLayer] )
4543 for(
int i = 0; i < aCollector.
GetCount(); ++i )
4547 if( item->
IsType( singleLayerSilkTypes ) && silkLayers[ item->
GetLayer() ] )
4548 preferred.insert( item );
4553 else if( courtyardLayers[activeLayer] && settings->
GetHighContrast() )
4555 for(
int i = 0; i < aCollector.
GetCount(); ++i )
4560 preferred.insert( item );
4564 if( preferred.size() > 0 )
4569 aCollector.
Append( item );
4571 if( preferred.size() == 1 )
4576 constexpr int MAX_SLOP = 5;
4580 int minSlop = INT_MAX;
4582 std::map<BOARD_ITEM*, int> itemsBySloppiness;
4584 for(
int i = 0; i < aCollector.
GetCount(); ++i )
4589 itemsBySloppiness[ item ] = itemSlop;
4591 if( itemSlop < minSlop )
4596 if( minSlop < INT_MAX )
4598 for( std::pair<BOARD_ITEM*, int> pair : itemsBySloppiness )
4600 if( pair.second > minSlop + singlePixel )
4607 constexpr double sizeRatio = 1.5;
4609 std::vector<std::pair<BOARD_ITEM*, double>> itemsByArea;
4611 for(
int i = 0; i < aCollector.
GetCount(); ++i )
4620 area = (double)
SEG::Square( singlePixel ) * MAX_SLOP;
4639 catch(
const std::exception& e )
4641 wxFAIL_MSG( wxString::Format( wxT(
"Clipper exception occurred: %s" ), e.what() ) );
4645 itemsByArea.emplace_back( item, area );
4648 std::sort( itemsByArea.begin(), itemsByArea.end(),
4649 [](
const std::pair<BOARD_ITEM*, double>& lhs,
4650 const std::pair<BOARD_ITEM*, double>& rhs ) ->
bool
4652 return lhs.second < rhs.second;
4655 bool rejecting =
false;
4657 for(
int i = 1; i < (int) itemsByArea.size(); ++i )
4659 if( itemsByArea[i].second > itemsByArea[i-1].second * sizeRatio )
4663 rejected.insert( itemsByArea[i].first );
4668 constexpr double maxCoverRatio = 0.70;
4670 for(
int i = 0; i < aCollector.
GetCount(); ++i )
4674 if( footprint->CoverageRatio( aCollector ) > maxCoverRatio )
4675 rejected.erase( footprint );
4680 if( (
unsigned) aCollector.
GetCount() > rejected.size() )
4692 bool haveItemOnActive =
false;
4695 for(
int i = 0; i < aCollector.
GetCount(); ++i )
4697 if( !aCollector[i]->IsOnLayer( activeLayer ) )
4698 rejected.insert( aCollector[i] );
4700 haveItemOnActive =
true;
4703 if( haveItemOnActive )
4716 m_frame->ShowInfoBarWarning(
_(
"Selection contains locked items. "
4717 "Enable 'Override locks' to operate on them." ),
4730 for(
int i = (
int) aCollector.
GetCount() - 1; i >= 0; --i )
4733 bool lockedDescendant =
false;
4739 lockedDescendant =
true;
4743 if( item->
IsLocked() || lockedDescendant )
4745 aCollector.
Remove( item );
4755 std::unordered_set<EDA_ITEM*> toAdd;
4759 for(
int j = 0; j < aCollector.
GetCount(); j++ )
4761 if( aCollector[j]->GetParent() )
4762 aCollector[j]->GetParent()->ClearFlags(
CANDIDATE );
4764 if( aCollector[j]->GetParentFootprint() )
4765 aCollector[j]->GetParentFootprint()->ClearFlags(
CANDIDATE );
4770 for(
int j = 0; j < aCollector.
GetCount(); j++ )
4774 for(
int j = 0; j < aCollector.
GetCount(); )
4786 aCollector.
Remove( item );
4794 if(
top->AsEdaItem() != item )
4796 toAdd.insert(
top->AsEdaItem() );
4799 aCollector.
Remove( item );
4808 aCollector.
Remove( item );
4817 if( !aCollector.
HasItem( item ) )
4818 aCollector.
Append( item );
4825 std::set<BOARD_ITEM*> to_add;
4828 for(
int i = (
int) aCollector.
GetCount() - 1; i >= 0; --i )
4837 aCollector.
Remove( item );
4842 aCollector.
Append( item );
4847 bool aForcePromotion )
const
4849 std::set<BOARD_ITEM*> to_add;
4852 for(
int i = aCollector.
GetCount() - 1; i >= 0; --i )
4857 && ( !
frame()->GetPcbNewSettings()->m_AllowFreePads || aForcePromotion ) )
4862 aCollector.
Remove( item );
4867 aCollector.
Append( item );
4874 for(
int i = aCollector.
GetCount() - 1; i >= 0; --i )
4879 aCollector.
Remove( item );
4891 bool need_direct_hit =
false;
4899 need_direct_hit =
true;
4907 else if( item->IsBOARD_ITEM() )
4908 fp =
static_cast<BOARD_ITEM*
>( item )->GetParentFootprint();
4914 single_fp =
nullptr;
4917 else if( !single_fp )
4923 else if( single_fp != fp )
4925 single_fp =
nullptr;
4931 auto visibleLayers =
4939 set.
set( layer,
view()->IsLayerVisible( layer ) );
4949 LSET layers = visibleLayers();
4957 for(
int layer : activeLayers )
4960 layers.
set( layer );
4965 for(
int i = aCollector.
GetCount() - 1; i >= 0; --i )
4981 aCollector.
Remove( item );
4983 bool has_hit =
false;
4997 aCollector.
Remove( item );
5002 else if( single_fp )
5004 if( fp == single_fp )
5007 else if( need_direct_hit )
5021 aCollector.
Remove( item );
5038 std::set<std::pair<PCB_TABLE*, int>> columns;
5046 columns.insert( std::make_pair(
table, cell->GetColumn() ) );
5050 for(
auto& [
table, col ] : columns )
5052 for(
int row = 0; row <
table->GetRowCount(); ++row )
5073 std::set<std::pair<PCB_TABLE*, int>> rows;
5081 rows.insert( std::make_pair(
table, cell->GetRow() ) );
5085 for(
auto& [
table, row ] : rows )
5087 for(
int col = 0; col <
table->GetColCount(); ++col )
5108 std::set<PCB_TABLE*> tables;
5114 tables.insert(
static_cast<PCB_TABLE*
>( cell->GetParent() ) );
5121 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.
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)
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)