31using namespace std::placeholders;
132 m_isFootprintEditor( false ),
134 m_enteredGroup( nullptr ),
135 m_priv(
std::make_unique<
PRIV>() )
171 std::shared_ptr<SELECT_MENU> selectMenu = std::make_shared<SELECT_MENU>();
172 selectMenu->SetTool(
this );
173 m_menu->RegisterSubMenu( selectMenu );
177 auto& menu =
m_menu->GetMenu();
179 auto activeToolCondition =
193 auto groupEnterCondition =
196 auto inGroupCondition =
208 menu.AddSeparator( 1000 );
216 menu.AddSeparator( haveHighlight, 1 );
222 menu.AddSeparator( 1 );
237 m_frame = getEditFrame<PCB_BASE_FRAME>();
266 wxMouseState keyboardState = wxGetMouseState();
269 keyboardState.AltDown() );
295 catch(
const std::runtime_error& e )
297 wxFAIL_MSG( e.what() );
302 evt->Modifier(
MD_ALT ) );
313 else if( evt->IsMouseDown(
BUT_LEFT ) )
351 bool selectionCancelled =
false;
355 selectPoint( evt->Position(),
false, &selectionCancelled );
362 if( !selectionCancelled )
368 else if( evt->IsDblClick(
BUT_LEFT ) )
410 const int delta = evt->Parameter<
int>();
440 if(
board()->GetFirstFootprint() )
443 evt->DragOrigin(), guide );
462 else if(
hasModifier() || dragAction == MOUSE_DRAG_ACTION::SELECT )
473 auto zoneFilledAreaFilter =
477 int accuracy = aCollector.GetGuide()->Accuracy();
478 std::set<EDA_ITEM*> remove;
484 ZONE* zone =
static_cast<ZONE*
>( item );
489 remove.insert( zone );
495 aCollector.Remove( item );
501 if( evt->HasPosition() )
504 &&
selectPoint( evt->DragOrigin(),
false,
nullptr, zoneFilledAreaFilter ) )
521 if( isTracks && trackDragAction == TRACK_DRAG_ACTION::DRAG )
523 else if( isTracks && trackDragAction == TRACK_DRAG_ACTION::DRAG_FREE_ANGLE )
535 else if( evt->IsCancel() )
544 else if( evt->FirstResponder() ==
this && evt->GetCommandId() == (
int) WXK_ESCAPE )
559 catch(
const std::runtime_error& e )
561 wxCHECK_MSG(
false, 0, e.what() );
576 && dragAction == MOUSE_DRAG_ACTION::DRAG_SELECTED
578 && evt->HasPosition()
601 wxT(
"EnterGroup called when selection is not a single group" ) );
652 bool aConfirmLockedItems )
665 enum DISPOSITION { BEFORE = 1, AFTER, BOTH };
667 std::map<EDA_ITEM*, DISPOSITION> itemDispositions;
676 itemDispositions[ item ] = BEFORE;
679 aClientFilter(
VECTOR2I(), collector,
this );
683 if( itemDispositions.count( item ) )
684 itemDispositions[ item ] = BOTH;
686 itemDispositions[ item ] = AFTER;
694 for( std::pair<EDA_ITEM* const, DISPOSITION> itemDisposition : itemDispositions )
696 EDA_ITEM* item = itemDisposition.first;
697 DISPOSITION disposition = itemDisposition.second;
699 if( disposition == BEFORE )
703 for( std::pair<EDA_ITEM* const, DISPOSITION> itemDisposition : itemDispositions )
705 EDA_ITEM* item = itemDisposition.first;
706 DISPOSITION disposition = itemDisposition.second;
710 if( disposition == AFTER || disposition == BOTH )
717 if( aConfirmLockedItems )
719 std::vector<BOARD_ITEM*> lockedItems;
724 bool lockedDescendant =
false;
730 lockedDescendant =
true;
733 if( boardItem->
IsLocked() || lockedDescendant )
734 lockedItems.push_back( boardItem );
801 bool* aSelectionCancelledFlag,
818 for(
int i = collector.
GetCount() - 1; i >= 0; --i )
820 if( !
Selectable( collector[ i ] ) || ( aOnDrag && collector[i]->IsLocked() ) )
832 aClientFilter( aWhere, collector,
this );
841 for(
int i = collector.
GetCount() - 1; i >= 0; --i )
843 if( !collector[i]->IsSelected() )
855 catch(
const std::exception& exc )
857 wxLogWarning( wxS(
"Exception \"%s\" occurred attempting to guess selection "
858 "candidates." ), exc.what() );
871 if( aSelectionCancelledFlag )
872 *aSelectionCancelledFlag =
true;
879 bool anySubtracted =
false;
886 anySubtracted =
true;
892 for(
int i = 0; i < collector.
GetCount(); ++i )
897 anySubtracted =
true;
907 if( addedCount == 1 )
912 else if( addedCount > 1 )
917 else if( anySubtracted )
954 bool cancelled =
false;
959 if( cell->IsSelected() )
968 return ( aItem->GetFlags() &
CANDIDATE ) > 0;
973 if( evt->IsCancelInteractive() || evt->IsActivate() )
982 BOX2I selectionRect( evt->DragOrigin(), evt->Position() - evt->DragOrigin() );
987 bool doSelect =
false;
989 if( cell->HitTest( selectionRect,
false ) )
994 doSelect = !wasSelected( cell );
998 else if( wasSelected( cell ) )
1003 if( doSelect && !cell->IsSelected() )
1005 else if( !doSelect && cell->IsSelected() )
1009 else if( evt->IsMouseUp(
BUT_LEFT ) )
1013 bool anyAdded =
false;
1014 bool anySubtracted =
false;
1018 if( cell->IsSelected() && !wasSelected( cell ) )
1020 else if( wasSelected( cell ) && !cell->IsSelected() )
1021 anySubtracted =
true;
1040 evt->SetPassEvent();
1060 bool cancelled =
false;
1067 bool anyAdded =
false;
1068 bool anySubtracted =
false;
1078 bool greedySelection = width >= 0 ? false :
true;
1081 greedySelection = !greedySelection;
1084 : KICURSOR::SELECT_LASSO );
1086 if( evt->IsCancelInteractive() || evt->IsActivate() )
1098 anySubtracted =
true;
1105 area.
SetEnd( evt->Position() );
1122 std::vector<KIGFX::VIEW::LAYER_ITEM_PAIR> candidates;
1124 view->
Query( selectionBox, candidates );
1135 std::set<BOARD_ITEM*> group_items;
1143 std::unordered_set<BOARD_ITEM*>& newset =
group->GetItems();
1147 if( !greedySelection && selectionRect.
Contains(
group->GetBoundingBox() )
1153 collector.
Append( *newset.begin() );
1158 group_items.emplace( group_item );
1165 if( item &&
Selectable( item ) && item->
HitTest( selectionRect, !greedySelection )
1166 && ( greedySelection || !group_items.count( item ) ) )
1169 padsCollector.
Append( item );
1171 collector.
Append( item );
1183 collector = padsCollector;
1195 anySubtracted =
true;
1209 else if( anySubtracted )
1220 evt->SetPassEvent();
1243 wxMouseState keyboardState = wxGetMouseState();
1246 keyboardState.AltDown() );
1290 collection.
Append( item );
1338 std::set<int> representedNets;
1340 for(
int i = aCollector.
GetCount() - 1; i >= 0; i-- )
1346 else if ( representedNets.count( item->
GetNetCode() ) )
1349 representedNets.insert( item->
GetNetCode() );
1359 std::vector<BOARD_CONNECTED_ITEM*> toUnroute;
1361 for(
EDA_ITEM* item : selectedItems )
1366 toUnroute.push_back(
pad );
1382 for(
EDA_ITEM* item : selectedItems )
1397 unsigned initialCount = 0;
1409 if( initialCount == 0 )
1412 std::vector<PCB_SHAPE*> startShapes;
1417 startShapes.push_back(
static_cast<PCB_SHAPE*
>( item ) );
1421 if( !startShapes.empty() )
1427 m_frame->SetStatusText(
_(
"Select/Expand Connection..." ) );
1433 for(
EDA_ITEM* item : selectedItems )
1434 item->ClearTempFlags();
1436 std::vector<BOARD_CONNECTED_ITEM*> startItems;
1438 for(
EDA_ITEM* item : selectedItems )
1445 startItems.push_back(
pad );
1467 m_frame->SetStatusText( wxEmptyString );
1477 const std::vector<BOARD_CONNECTED_ITEM*>& aStartItems,
STOP_CONDITION aStopCondition )
1482 double refreshIntervalMs = 500;
1487 std::map<VECTOR2I, std::vector<PCB_TRACK*>> trackMap;
1488 std::map<VECTOR2I, PCB_VIA*> viaMap;
1489 std::map<VECTOR2I, PAD*> padMap;
1490 std::map<VECTOR2I, std::vector<PCB_SHAPE*>> shapeMap;
1491 std::set<PAD*> startPadSet;
1492 std::vector<BOARD_CONNECTED_ITEM*> cleanupItems;
1493 std::vector<std::pair<VECTOR2I, LSET>> activePts;
1499 startPadSet.insert(
static_cast<PAD*
>( startItem ) );
1502 if( startItem->IsType( { PCB_TRACE_T, PCB_ARC_T, PCB_VIA_T } ) )
1511 auto connectedItems = connectivity->GetConnectedItems( startItem,
1517 switch( item->Type() )
1523 trackMap[track->
GetStart()].push_back( track );
1524 trackMap[track->
GetEnd()].push_back( track );
1531 viaMap[
via->GetStart()] =
via;
1538 padMap[
pad->GetPosition()] =
pad;
1547 shapeMap[point].push_back( shape );
1558 switch( startItem->Type() )
1571 activePts.push_back( { startItem->GetPosition(), startItem->GetLayerSet() } );
1575 activePts.push_back( { startItem->GetPosition(), startItem->GetLayerSet() } );
1583 activePts.push_back( { point, startItem->GetLayerSet() } );
1596 while( expand && failSafe++ < 100000 )
1600 for(
int i = (
int) activePts.size() - 1; i >= 0; --i )
1603 LSET layerSetCu = activePts[i].second & allCuMask;
1605 auto viaIt = viaMap.find( pt );
1606 auto padIt = padMap.find( pt );
1608 bool gotVia = ( viaIt != viaMap.end() )
1609 && ( layerSetCu & ( viaIt->second->GetLayerSet() ) ).any();
1611 bool gotPad = ( padIt != padMap.end() )
1612 && ( layerSetCu & ( padIt->second->GetLayerSet() ) ).any();
1614 bool gotNonStartPad =
1615 gotPad && ( startPadSet.find( padIt->second ) == startPadSet.end() );
1619 size_t pt_count = 0;
1623 if( track->GetStart() != track->GetEnd()
1624 && layerSetCu.
Contains( track->GetLayer() ) )
1630 if( pt_count > 2 || gotVia || gotNonStartPad )
1632 activePts.erase( activePts.begin() + i );
1638 if( gotNonStartPad )
1640 activePts.erase( activePts.begin() + i );
1647 PAD*
pad = padIt->second;
1652 cleanupItems.push_back(
pad );
1654 activePts.push_back( {
pad->GetPosition(),
pad->GetLayerSet() } );
1661 if( !layerSetCu.
Contains( track->GetLayer() ) )
1664 if( !track->IsSelected() )
1670 cleanupItems.push_back( track );
1672 if( track->GetStart() == pt )
1673 activePts.push_back( { track->GetEnd(), track->GetLayerSet() } );
1675 activePts.push_back( { track->GetStart(), track->GetLayerSet() } );
1683 if( !layerSetCu.Contains( shape->GetLayer() ) )
1686 if( !shape->IsSelected() )
1692 cleanupItems.push_back( shape );
1694 for(
const VECTOR2I& newPoint : shape->GetConnectionPoints() )
1696 if( newPoint == pt )
1699 activePts.push_back( { newPoint, shape->GetLayerSet() } );
1706 if( viaMap.count( pt ) )
1710 if( !
via->IsSelected() )
1716 cleanupItems.push_back(
via );
1718 activePts.push_back( {
via->GetPosition(),
via->GetLayerSet() } );
1723 activePts.erase( activePts.begin() + i );
1727 if( refreshTimer.
msecs() >= refreshIntervalMs )
1735 refreshTimer.
Start();
1740 std::set<EDA_ITEM*> toDeselect;
1741 std::set<EDA_ITEM*> toSelect;
1744 for(
EDA_ITEM* item : m_selection )
1746 if( !item->IsBOARD_ITEM() )
1754 toDeselect.insert( item );
1757 toSelect.insert( parent );
1780 case SHAPE_T::SEGMENT:
1782 case SHAPE_T::BEZIER:
1799 std::stack<PCB_SHAPE*> toSearch;
1800 std::set<PCB_SHAPE*> toCleanup;
1802 for(
PCB_SHAPE* startItem : aStartItems )
1803 toSearch.push( startItem );
1808 auto searchPoint = [&](
const VECTOR2I& aWhere )
1815 toSearch.push(
static_cast<PCB_SHAPE*
>( item ) );
1819 while( !toSearch.empty() )
1829 toCleanup.insert( shape );
1834 searchPoint( shape->
GetEnd() );
1845 std::vector<PAD*> pads;
1852 pads.push_back(
pad );
1856 pads.push_back(
static_cast<PAD*
>( item ) );
1865 for(
const CN_EDGE& edge : conn->GetRatsnestForPad(
pad ) )
1867 wxCHECK2( edge.GetSourceNode() && !edge.GetSourceNode()->Dirty(),
continue );
1868 wxCHECK2( edge.GetTargetNode() && !edge.GetTargetNode()->Dirty(),
continue );
1873 if( sourceParent ==
pad )
1876 select(
static_cast<PAD*
>( targetParent )->GetParent() );
1878 else if( targetParent ==
pad )
1881 select(
static_cast<PAD*
>( sourceParent )->GetParent() );
1895 std::vector<PAD*> pads;
1902 pads.push_back(
pad );
1906 pads.push_back(
static_cast<PAD*
>( item ) );
1917 const std::vector<CN_EDGE> edges = conn->GetRatsnestForPad(
pad );
1920 if( edges.size() == 0 )
1923 double currentDistance = DBL_MAX;
1927 for(
const CN_EDGE& edge : edges )
1929 if( edge.GetSourceNode()->Parent()->GetParentFootprint()
1930 == edge.GetTargetNode()->Parent()->GetParentFootprint() )
1936 const CN_ANCHOR* other = edge.GetSourceNode()->
Parent() ==
pad ? edge.GetTargetNode().get()
1937 : edge.GetSourceNode().get();
1939 wxCHECK2( other && !other->
Dirty(),
continue );
1945 if( edge.GetLength() < currentDistance )
1947 currentDistance = edge.GetLength();
1952 if( nearest !=
nullptr )
1966 for(
BOARD_ITEM* item : conn->GetNetItems( aNetCode, { PCB_TRACE_T,
2023 std::vector<BOARD_ITEM*> footprints;
2028 if( footprint ==
nullptr )
2031 wxString footprint_path = footprint->GetPath().AsString().BeforeLast(
'/' );
2033 if( footprint_path.IsEmpty() )
2034 footprint_path +=
'/';
2036 if( footprint_path == aSheetPath )
2037 footprints.push_back( footprint );
2053 std::list<int> netcodeList;
2054 std::vector<BOARD_CONNECTED_ITEM*> padList;
2058 switch( item->Type() )
2064 if(
pad->IsConnected() )
2066 netcodeList.push_back(
pad->GetNetCode() );
2067 padList.push_back(
pad );
2078 if(
pad->IsConnected() )
2080 netcodeList.push_back(
pad->GetNetCode() );
2081 padList.push_back(
pad );
2093 std::sort( padList.begin(), padList.end() );
2097 netcodeList.unique();
2103 std::vector<int> removeCodeList;
2106 for(
int netCode : netcodeList )
2110 if( !std::binary_search( padList.begin(), padList.end(),
pad ) )
2114 removeCodeList.push_back( netCode );
2120 for(
int removeCode : removeCodeList )
2121 netcodeList.remove( removeCode );
2123 std::unordered_set<BOARD_ITEM*> localConnectionList;
2125 for(
int netCode : netcodeList )
2127 for(
BOARD_ITEM* item : conn->GetNetItems( netCode, { PCB_TRACE_T,
2132 localConnectionList.insert( item );
2136 for(
BOARD_ITEM* item : localConnectionList )
2143 std::vector<BOARD_ITEM*>* items = aEvent.
Parameter<std::vector<BOARD_ITEM*>*>();
2154 std::vector<BOARD_ITEM*>* items = aEvent.
Parameter<std::vector<BOARD_ITEM*>*>();
2199 wxString sheetPath = *aEvent.
Parameter<wxString*>();
2225 if( !footprint || footprint->
GetPath().empty() )
2231 wxString sheetPath = footprint->
GetPath().
AsString().BeforeLast(
'/' );
2233 if( sheetPath.IsEmpty() )
2254 screenSize.
x = std::max( 10.0, screenSize.
x );
2255 screenSize.
y = std::max( 10.0, screenSize.
y );
2261 fabs( vsize.
y / screenSize.
y ) );
2283#ifdef DEFAULT_PCBNEW_CODE
2285 auto screenSize =
view->
ToWorld( GetCanvas()->GetClientSize(),
false );
2288 screenSize.
x = std::max( 10.0, fabs( screenSize.x ) );
2289 screenSize.y = std::max( 10.0, screenSize.y );
2290 double ratio = std::max( fabs( bbSize.x / screenSize.x ), fabs( bbSize.y / screenSize.y ) );
2293 if( crossProbingSettings.zoom_to_fit && ( ratio < 0.5 || ratio > 1.0 ) )
2297#ifndef DEFAULT_PCBNEW_CODE
2315 double compRatio = bbSize.y / currTextHeight;
2318 double compRatioBent = 1.0;
2329 screenSize.
x = std::max( 10.0, fabs( screenSize.
x ) );
2330 screenSize.
y = std::max( 10.0, screenSize.
y );
2331 double ratio = std::max( -1.0, fabs( bbSize.y / screenSize.
y ) );
2334 double kicadRatio = std::max( fabs( bbSize.x / screenSize.
x ),
2335 fabs( bbSize.y / screenSize.
y ) );
2343 std::vector<std::pair<double, double>> lut {
2356 std::vector<std::pair<double, double>>::iterator it;
2358 compRatioBent = lut.back().second;
2360 if( compRatio >= lut.front().first )
2366 for( it = lut.begin(); it < lut.end() - 1; it++ )
2368 if( it->first <= compRatio &&
next( it )->first >= compRatio )
2370 double diffx = compRatio - it->first;
2371 double diffn =
next( it )->first - it->first;
2373 compRatioBent = it->second + (
next( it )->second - it->second ) * diffx / diffn;
2380 compRatioBent = lut.front().second;
2388 if( bbSize.x > screenSize.
x * ratio * compRatioBent )
2392 compRatioBent = 1.0;
2393 wxLogTrace(
"CROSS_PROBE_SCALE",
2394 "Part TOO WIDE for screen. Using normal KiCad zoom ratio: %1.5f", ratio );
2399 ratio *= compRatioBent;
2401 bool alwaysZoom =
false;
2404 if( ( ratio < 0.5 || ratio > 1.0 ) || alwaysZoom )
2412 bool cleared =
false;
2424 switch( aItem->
Type() )
2428 int netCode =
static_cast<NETINFO_ITEM*
>( aItem )->GetNetCode();
2447 double marginFactor = 2;
2456 double scaleX = screenSize.
x /
2458 double scaleY = screenSize.
y /
2461 scaleX /= marginFactor;
2462 scaleY /= marginFactor;
2464 double scale = scaleX > scaleY ? scaleY : scaleX;
2495 switch( aItem.
Type() )
2550 if( cmd != wxID_OK )
2579 std::set<BOARD_ITEM*> rejected;
2586 rejected.insert( item );
2590 aCollector.
Remove( item );
2626 itemType = ( *
static_cast<PCB_GENERATOR*
>( aItem )->GetItems().begin() )->Type();
2659 ZONE* zone =
static_cast<ZONE*
>( aItem );
2748 bool enteredGroupFound =
false;
2751 [&](
EDA_ITEM* item,
void* testData )
2759 return INSPECT_RESULT::CONTINUE;
2769 enteredGroupFound =
true;
2777 return INSPECT_RESULT::CONTINUE;
2783 if( !enteredGroupFound )
2796 auto visibleLayers =
2826 bool onActiveLayer =
false;
2828 for(
int layer : activeLayers )
2831 if( layer < PCB_LAYER_ID_COUNT && aItem->IsOnLayer(
ToLAYER_ID( layer ) ) )
2833 onActiveLayer =
true;
2858 if( !( visibleLayers() & boardSide ).any() )
2865 && footprint->
Pads().empty()
2866 && footprint->
Zones().empty() )
2883 for(
const ZONE* zone : footprint->
Zones() )
2909 const ZONE* zone =
nullptr;
2911 const PAD*
pad =
nullptr;
2925 switch( aItem->
Type() )
2931 zone =
static_cast<const ZONE*
>( aItem );
2939 if( !( zone->
GetLayerSet() & visibleLayers() ).any() )
2949 if( !layerVisible( aItem->
GetLayer() ) )
2961 if( !( visibleLayers() &
via->GetLayerSet() ).any() )
2967 field =
static_cast<const PCB_FIELD*
>( aItem );
2980 if( !
text->IsVisible() )
2986 if( !layerVisible(
text->GetLayer() ) )
2997 if(
text->GetText() == wxT(
"${REFERENCE}" ) )
2999 else if(
text->GetText() == wxT(
"${VALUE}" ) )
3030 if( !layerVisible( aItem->
GetLayer() ) )
3048 if( !layerVisible( aItem->
GetLayer() ) )
3057 pad =
static_cast<const PAD*
>( aItem );
3059 if(
pad->GetAttribute() == PAD_ATTRIB::PTH ||
pad->GetAttribute() == PAD_ATTRIB::NPTH )
3068 if( !(
pad->GetLayerSet() & visibleLayers() ).any() )
3121 aGroup->
Add( aItem );
3147 aMode, aUsingOverlay ) );
3183 aMode, aUsingOverlay ) );
3190 const unsigned GRIP_MARGIN = 20;
3196 BOX2I itemBox = item->ViewBBox();
3201 if( item->HitTest( aPoint, margin ) )
3208 group->RunOnDescendants(
3211 if( aItem->
HitTest( aPoint, margin ) )
3226 int aMaxDistance )
const
3231 SEG loc( aWhere, aWhere );
3233 switch( aItem->
Type() )
3241 if(
text->GetEffectiveTextShape()->Collide( loc, aMaxDistance, &
distance ) )
3266 if( cell->GetEffectiveTextShape()->Collide( loc, aMaxDistance, &
distance ) )
3275 ZONE* zone =
static_cast<ZONE*
>( aItem );
3297 catch(
const std::exception& e )
3299 wxFAIL_MSG( wxString::Format( wxT(
"Clipper exception occurred: %s" ), e.what() ) );
3333 static_cast<PAD*
>( aItem )->Padstack().ForEachUniqueLayer(
3336 int layerDistance = INT_MAX;
3337 aItem->
GetEffectiveShape( aLayer )->Collide( loc, aMaxDistance, &layerDistance );
3362 wxCHECK( settings, );
3369 wxCHECK( !enabledLayerStack.empty(), );
3371 auto isCopperPourKeepoutZone = [](
const BOARD_ITEM* aItem ) ->
bool
3375 const ZONE* zone =
static_cast<const ZONE*
>( aItem );
3377 wxCHECK( zone,
false );
3387 std::vector<LAYER_OPACITY_ITEM> opacityStackup;
3389 for(
int i = 0; i < aCollector.
GetCount(); i++ )
3393 LSET itemLayers = item->
GetLayerSet() & enabledLayers & visibleLayers;
3394 LSEQ itemLayerSeq = itemLayers.
Seq( enabledLayerStack );
3407 opacityItem.
m_Item = item;
3409 if( isCopperPourKeepoutZone( item ) )
3412 opacityStackup.emplace_back( opacityItem );
3416 std::sort( opacityStackup.begin(), opacityStackup.end(),
3419 int retv = enabledLayerStack.TestLayers( aLhs.m_Layer, aRhs.m_Layer );
3424 return aLhs.m_Opacity > aRhs.m_Opacity;
3427 std::set<const BOARD_ITEM*> visibleItems;
3428 std::set<const BOARD_ITEM*> itemsToRemove;
3430 double currentStackupOpacity = 0.0;
3431 PCB_LAYER_ID lastVisibleLayer = PCB_LAYER_ID::UNDEFINED_LAYER;
3435 if( lastVisibleLayer == PCB_LAYER_ID::UNDEFINED_LAYER )
3437 currentStackupOpacity = opacityItem.m_Opacity;
3438 lastVisibleLayer = opacityItem.m_Layer;
3439 visibleItems.emplace( opacityItem.m_Item );
3444 auto ignoreItem = [&]()
3448 wxCHECK( item,
false );
3451 if( visibleItems.count( item ) )
3457 && visibleItems.count( item->
GetParent() ) )
3463 if( isCopperPourKeepoutZone( item ) )
3470 if( opacityItem.m_Layer == enabledLayerStack[0] )
3472 visibleItems.emplace( opacityItem.m_Item );
3476 double itemVisibility = opacityItem.m_Opacity * ( 1.0 - currentStackupOpacity );
3478 if( ( itemVisibility <= minAlphaLimit ) && !ignoreItem() )
3479 itemsToRemove.emplace( opacityItem.m_Item );
3481 visibleItems.emplace( opacityItem.m_Item );
3484 if( opacityItem.m_Layer != lastVisibleLayer )
3486 currentStackupOpacity += opacityItem.m_Opacity * ( 1.0 - currentStackupOpacity );
3487 currentStackupOpacity = std::min( currentStackupOpacity, 1.0 );
3488 lastVisibleLayer = opacityItem.m_Layer;
3492 for(
const BOARD_ITEM* itemToRemove : itemsToRemove )
3494 wxCHECK( aCollector.
GetCount() > 1, );
3495 aCollector.
Remove( itemToRemove );
3518 static std::vector<KICAD_T> singleLayerSilkTypes = {
PCB_FIELD_T,
3529 std::set<BOARD_ITEM*> preferred;
3530 std::set<BOARD_ITEM*> rejected;
3537 if( silkLayers[activeLayer] )
3539 for(
int i = 0; i < aCollector.
GetCount(); ++i )
3543 if( item->
IsType( singleLayerSilkTypes ) && silkLayers[ item->
GetLayer() ] )
3544 preferred.insert( item );
3549 else if( courtyardLayers[activeLayer] && settings->
GetHighContrast() )
3551 for(
int i = 0; i < aCollector.
GetCount(); ++i )
3556 preferred.insert( item );
3560 if( preferred.size() > 0 )
3565 aCollector.
Append( item );
3567 if( preferred.size() == 1 )
3572 constexpr int MAX_SLOP = 5;
3576 int minSlop = INT_MAX;
3578 std::map<BOARD_ITEM*, int> itemsBySloppiness;
3580 for(
int i = 0; i < aCollector.
GetCount(); ++i )
3585 itemsBySloppiness[ item ] = itemSlop;
3587 if( itemSlop < minSlop )
3592 if( minSlop < INT_MAX )
3594 for( std::pair<BOARD_ITEM*, int> pair : itemsBySloppiness )
3596 if( pair.second > minSlop + singlePixel )
3603 constexpr double sizeRatio = 1.5;
3605 std::vector<std::pair<BOARD_ITEM*, double>> itemsByArea;
3607 for(
int i = 0; i < aCollector.
GetCount(); ++i )
3616 area = (double)
SEG::Square( singlePixel ) * MAX_SLOP;
3635 catch(
const std::exception& e )
3637 wxFAIL_MSG( wxString::Format( wxT(
"Clipper exception occurred: %s" ), e.what() ) );
3641 itemsByArea.emplace_back( item, area );
3644 std::sort( itemsByArea.begin(), itemsByArea.end(),
3645 [](
const std::pair<BOARD_ITEM*, double>& lhs,
3646 const std::pair<BOARD_ITEM*, double>& rhs ) ->
bool
3648 return lhs.second < rhs.second;
3651 bool rejecting =
false;
3653 for(
int i = 1; i < (int) itemsByArea.size(); ++i )
3655 if( itemsByArea[i].second > itemsByArea[i-1].second * sizeRatio )
3659 rejected.insert( itemsByArea[i].first );
3664 constexpr double maxCoverRatio = 0.70;
3666 for(
int i = 0; i < aCollector.
GetCount(); ++i )
3670 if( footprint->CoverageRatio( aCollector ) > maxCoverRatio )
3671 rejected.erase( footprint );
3676 if( (
unsigned) aCollector.
GetCount() > rejected.size() )
3688 bool haveItemOnActive =
false;
3691 for(
int i = 0; i < aCollector.
GetCount(); ++i )
3693 if( !aCollector[i]->IsOnLayer( activeLayer ) )
3694 rejected.insert( aCollector[i] );
3696 haveItemOnActive =
true;
3699 if( haveItemOnActive )
3709 bool aMultiselect )
const
3711 std::unordered_set<BOARD_ITEM*> toAdd;
3715 for(
int j = 0; j < aCollector.
GetCount(); j++ )
3717 if( aCollector[j]->GetParent() )
3718 aCollector[j]->GetParent()->ClearFlags(
CANDIDATE );
3723 for(
int j = 0; j < aCollector.
GetCount(); j++ )
3727 for(
int j = 0; j < aCollector.
GetCount(); )
3739 aCollector.
Remove( item );
3750 toAdd.insert( top );
3753 aCollector.
Remove( item );
3762 aCollector.
Remove( item );
3771 if( !aCollector.
HasItem( item ) )
3772 aCollector.
Append( item );
3779 std::set<BOARD_ITEM*> to_add;
3782 for(
int i = (
int) aCollector.
GetCount() - 1; i >= 0; --i )
3791 aCollector.
Remove( item );
3796 aCollector.
Append( item );
3801 bool aForcePromotion )
const
3803 std::set<BOARD_ITEM*> to_add;
3806 for(
int i = aCollector.
GetCount() - 1; i >= 0; --i )
3811 && ( !
frame()->GetPcbNewSettings()->m_AllowFreePads || aForcePromotion ) )
3816 aCollector.
Remove( item );
3821 aCollector.
Append( item );
3828 for(
int i = aCollector.
GetCount() - 1; i >= 0; --i )
3833 aCollector.
Remove( item );
3845 bool need_direct_hit =
false;
3853 need_direct_hit =
true;
3860 fp =
static_cast<BOARD_ITEM*
>( item )->GetParentFootprint();
3868 single_fp =
nullptr;
3871 else if( !single_fp )
3877 else if( single_fp != fp )
3879 single_fp =
nullptr;
3885 auto visibleLayers =
3903 LSET layers = visibleLayers();
3911 for(
int layer : activeLayers )
3914 layers.
set( layer );
3919 for(
int i = aCollector.
GetCount() - 1; i >= 0; --i )
3922 FOOTPRINT* fp = dyn_cast<FOOTPRINT*>( item );
3935 aCollector.
Remove( item );
3937 bool has_hit =
false;
3951 aCollector.
Remove( item );
3956 else if( single_fp )
3958 if( fp == single_fp )
3961 else if( need_direct_hit )
3975 aCollector.
Remove( item );
3992 std::set<std::pair<PCB_TABLE*, int>> columns;
4000 columns.insert( std::make_pair( table, cell->GetColumn() ) );
4004 for(
auto& [ table, col ] : columns )
4006 for(
int row = 0; row < table->GetRowCount(); ++row )
4012 select( table->GetCell( row, col ) );
4027 std::set<std::pair<PCB_TABLE*, int>> rows;
4035 rows.insert( std::make_pair( table, cell->GetRow() ) );
4039 for(
auto& [ table, row ] : rows )
4041 for(
int col = 0; col < table->GetColCount(); ++col )
4047 select( table->GetCell( row, col ) );
4062 std::set<PCB_TABLE*> tables;
4068 tables.insert(
static_cast<PCB_TABLE*
>( cell->GetParent() ) );
4075 if( !table->IsSelected() )
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 cursorLeft
static TOOL_ACTION zoomOutCenter
static TOOL_ACTION zoomIn
static TOOL_ACTION cursorLeftFast
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 cursorDownFast
static TOOL_ACTION selectRows
static TOOL_ACTION cursorUpFast
static TOOL_ACTION panLeft
static TOOL_ACTION updateMenu
static TOOL_ACTION doDelete
static TOOL_ACTION zoomFitScreen
static TOOL_ACTION increment
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 cursorRight
static TOOL_ACTION selectAll
static const ADVANCED_CFG & GetCfg()
Get the singleton instance's config, which is shared by all consumers.
CROSS_PROBING_SETTINGS m_CrossProbing
BASE_SET & reset(size_t pos)
BASE_SET & set(size_t pos)
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.
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.
PCB_GROUP * GetParentGroup() const
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 bool IsLocked() const
BOARD_ITEM_CONTAINER * GetParent() const
virtual bool IsOnCopperLayer() const
virtual void RunOnDescendants(const std::function< void(BOARD_ITEM *)> &aFunction, int aDepth=0) const
Invoke a function on all descendants.
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...
ZONE * m_SolderMaskBridges
LSET GetEnabledLayers() const
A proxy function that calls the corresponding function in m_BoardSettings.
LSET GetVisibleLayers() const
A proxy function that calls the correspondent function in m_BoardSettings.
bool IsElementVisible(GAL_LAYER_ID aLayer) const
Test whether a given element category is visible.
bool IsLayerVisible(PCB_LAYER_ID aLayer) const
A proxy function that calls the correspondent function in m_BoardSettings tests whether a given layer...
bool LegacyTeardrops() const
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.
bool IsType(FRAME_T aType) const
void AddStandardSubMenus(TOOL_MENU &aMenu)
Construct a "basic" menu for a tool, containing only items that apply to all tools (e....
void FocusOnLocation(const VECTOR2I &aPos)
Useful to focus on a particular location, in find functions.
void ForceRefresh()
Force a redraw.
void SetCurrentCursor(KICURSOR aCursor)
Set the current cursor shape for this panel.
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)
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.
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 SetIgnoreThroughVias(bool ignore)
void SetIgnoreThroughHolePads(bool ignore)
void SetLayerVisibleBits(LSET aLayerBits)
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 SetSubtractive(bool aSubtractive)
void SetAdditive(bool aAdditive)
void SetOrigin(const VECTOR2I &aOrigin)
const BOX2I ViewBBox() const override
Set the origin of the rectangle (the fixed corner)
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 SetAutoPan(bool aEnabled)
Turn on/off auto panning (this feature is used when there is a tool active (eg.
virtual void Clear()
Remove all the stored items from the group.
virtual void Add(VIEW_ITEM *aItem)
Add an item to the group.
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 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...
VECTOR2D ToWorld(const VECTOR2D &aCoord, bool aAbsolute=true) const
Converts a screen space point/vector to a point/vector in world space coordinates.
bool IsMirroredX() const
Return true if view is flipped across the X axis.
std::pair< VIEW_ITEM *, int > LAYER_ITEM_PAIR
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 SetCenter(const VECTOR2D &aCenter)
Set the center point of the VIEW (i.e.
void MarkTargetDirty(int aTarget)
Set or clear target 'dirty' flag.
bool IsVisible(const VIEW_ITEM *aItem) const
Return information if the item is visible (or not).
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 LSET AllLayersMask()
static LSET AllCuMask(int aCuLayerCount=MAX_CU_LAYERS)
Return a mask holding the requested number of Cu PCB_LAYER_IDs.
static LSET PhysicalLayersMask()
Return a mask holding all layers which are physically realized.
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 LSET FrontMask()
Return a mask holding all technical layers and the external CU layer on front side.
static LSET BackMask()
Return a mask holding all technical layers and the external CU layer on back side.
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.
bool m_CtrlClickHighlight
TRACK_DRAG_ACTION m_TrackDragAction
LOCKING_OPTIONS m_LockingOptions
bool m_ESCClearsNetHighlight
static TOOL_ACTION drag45Degree
static TOOL_ACTION unrouteSelected
Removes all tracks from the selected items to the first pad.
static TOOL_ACTION selectionCursor
Select a single item under the cursor position.
static TOOL_ACTION groupLeave
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 highlightNet
static TOOL_ACTION unselectItem
static TOOL_ACTION hideLocalRatsnest
static TOOL_ACTION properties
Activation of the edit tool.
static TOOL_ACTION selectionClear
Clear the current selection.
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 dragFreeAngle
static TOOL_ACTION clearHighlight
static TOOL_ACTION unselectItems
static TOOL_ACTION selectUnconnected
Select unconnected footprints from ratsnest of selection.
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 groupEnter
static TOOL_ACTION selectItem
Select an item (specified as the event parameter).
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 selectionActivate
Activation of the selection tool.
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 selectItems
Select a list of items (specified as the event parameter)
static TOOL_ACTION deselectNet
Remove all connections belonging to a single net from the active selection.
static TOOL_ACTION selectionMenu
Run a selection menu to select from a list of items.
static TOOL_ACTION reselectItem
static TOOL_ACTION selectOnSchematic
Select symbols/pins on schematic corresponding to selected footprints/pads.
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...
PCBNEW_SETTINGS * GetPcbNewSettings() const
virtual PCB_LAYER_ID GetActiveLayer() const
PCB_DRAW_PANEL_GAL * GetCanvas() const override
Return a pointer to GAL-based canvas of given EDA draw frame.
void FocusOnItem(BOARD_ITEM *aItem, PCB_LAYER_ID aLayer=UNDEFINED_LAYER)
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.
A set of BOARD_ITEMs (i.e., without duplicates).
const BOX2I GetBoundingBox() const override
Return the orthogonal bounding box of this object for display purposes.
static bool WithinScope(BOARD_ITEM *aItem, PCB_GROUP *aScope, bool isFootprintEditor)
static PCB_GROUP * TopLevelGroup(BOARD_ITEM *aItem, PCB_GROUP *aScope, bool isFootprintEditor)
std::unordered_set< BOARD_ITEM * > & GetItems()
void RunOnChildren(const std::function< void(BOARD_ITEM *)> &aFunction) const override
Invoke a function on all descendants.
Tool that displays edit points allowing to modify items by dragging the points.
bool HasPoint()
Indicate the cursor is over an edit point.
BOX2I GetBoundingBox() const override
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
int GetDrill() const
Return the local drill setting for this PCB_VIA.
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 KIGFX::VIEW_ITEM * GetItem(unsigned int aIdx) const override
const std::deque< EDA_ITEM * > GetItems() const
void SetIsHover(bool aIsHover)
virtual void Remove(EDA_ITEM *aItem)
virtual unsigned int GetSize() const override
Return the number of stored items.
virtual void Clear() override
Remove all the stored items from the group.
int Size() const
Returns the number of selected parts.
void ClearReferencePoint()
bool OnlyContains(std::vector< KICAD_T > aList) const
Checks if all items in the selection have a type in aList.
bool Empty() const
Checks if there is anything selected.
bool Contains(EDA_ITEM *aItem) const
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
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.
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,...
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 GetDoNotAllowCopperPour() const
#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.
int m_DisambiguationMenuDelay
The number of milliseconds to wait in a click before showing a disambiguation menu.
double m_PcbSelectionVisibilityRatio
Board object selection visibility limit.
@ LAYER_FOOTPRINTS_FR
Show footprints on front.
@ LAYER_DRAW_BITMAPS
Draw images.
@ LAYER_FP_REFERENCES
Show footprints references (when texts are visible).
@ 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 ...
@ REPAINT
Item needs to be redrawn.
@ TARGET_OVERLAY
Items that may change while the view stays the same (noncached)
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)
bool zoom_to_fit
Zoom to fit items (ignored if center_on_items is off).
bool center_on_items
Automatically pan to cross-probed items.
Struct that will be set with the result of the user choices in the dialog.
bool includeItemsOnTechLayers
bool includeLockedModules
bool includeBoardOutlineLayer
constexpr int mmToIU(double mm) const
const BOARD_ITEM * m_Item
bool m_sessionSkipPrompts
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.
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_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_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
VECTOR2< int32_t > VECTOR2I
VECTOR2D ToVECTOR2D(const wxPoint &aPoint)