30using namespace std::placeholders;
161 std::shared_ptr<SELECT_MENU> selectMenu = std::make_shared<SELECT_MENU>();
162 selectMenu->SetTool(
this );
163 m_menu->RegisterSubMenu( selectMenu );
167 auto& menu =
m_menu->GetMenu();
169 auto activeToolCondition =
184 auto groupEnterCondition =
187 auto inGroupCondition =
199 menu.AddSeparator( 1000 );
210 menu.AddSeparator( haveHighlight, 1 );
216 menu.AddSeparator( 1 );
260 wxMouseState keyboardState = wxGetMouseState();
262 setModifiersState( keyboardState.ShiftDown(), keyboardState.ControlDown(), keyboardState.AltDown() );
285 trackDragAction = cfg->m_TrackDragAction;
299 else if( evt->IsMouseDown(
BUT_LEFT ) )
337 bool selectionCancelled =
false;
341 selectPoint( evt->Position(),
false, &selectionCancelled );
346 m_frame->GetCanvas()->ForceRefresh();
348 if( !selectionCancelled )
354 else if( evt->IsDblClick(
BUT_LEFT ) )
396 const int delta = evt->Parameter<
int>();
456 wxASSERT_MSG(
false, wxT(
"Unknown selection mode" ) );
463 auto zoneFilledAreaFilter =
466 int accuracy = aCollector.GetGuide()->Accuracy();
467 std::set<EDA_ITEM*> remove;
473 ZONE* zone =
static_cast<ZONE*
>( item );
478 remove.insert( zone );
484 aCollector.Remove( item );
490 if( evt->HasPosition() )
493 &&
selectPoint( evt->DragOrigin(),
false,
nullptr, zoneFilledAreaFilter ) )
511 bool routable = ( segs >= 1 || arcs >= 1 || vias == 1 )
512 && ( segs + arcs + vias ==
m_selection.GetSize() );
536 else if( evt->IsCancel() )
545 else if( evt->FirstResponder() ==
this && evt->GetCommandId() == (
int) WXK_ESCAPE )
557 if( controller &&
m_frame->GetPcbNewSettings()->m_ESCClearsNetHighlight )
560 catch(
const std::runtime_error& e )
562 wxCHECK_MSG(
false, 0, e.what() );
573 if(
m_frame->ToolStackIsEmpty() )
579 && evt->HasPosition()
602 wxT(
"EnterGroup called when selection is not a single group" ) );
664 enum DISPOSITION { BEFORE = 1, AFTER,
BOTH };
666 std::map<EDA_ITEM*, DISPOSITION> itemDispositions;
675 itemDispositions[ item ] = BEFORE;
678 aClientFilter(
VECTOR2I(), collector,
this );
682 if( itemDispositions.count( item ) )
683 itemDispositions[ item ] =
BOTH;
685 itemDispositions[ item ] = AFTER;
693 for( std::pair<EDA_ITEM* const, DISPOSITION> itemDisposition : itemDispositions )
695 EDA_ITEM* item = itemDisposition.first;
696 DISPOSITION disposition = itemDisposition.second;
698 if( disposition == BEFORE )
702 for( std::pair<EDA_ITEM* const, DISPOSITION> itemDisposition : itemDispositions )
704 EDA_ITEM* item = itemDisposition.first;
705 DISPOSITION disposition = itemDisposition.second;
709 if( disposition == AFTER || disposition ==
BOTH )
713 m_frame->GetCanvas()->ForceRefresh();
769 for(
int i = collector.
GetCount() - 1; i >= 0; --i )
771 if( !
Selectable( collector[ i ] ) || ( aOnDrag && collector[i]->IsLocked() ) )
777 size_t preFilterCount = collector.
GetCount();
784 if( collector.
GetCount() == 0 && preFilterCount > 0 )
787 editFrame->HighlightSelectionFilter( rejected );
802 aClientFilter( aWhere, collector,
this );
811 for(
int i = collector.
GetCount() - 1; i >= 0; --i )
813 if( !collector[i]->IsSelected() )
825 catch(
const std::exception& exc )
827 wxLogWarning( wxS(
"Exception '%s' occurred attempting to guess selection candidates." ),
841 if( aSelectionCancelledFlag )
842 *aSelectionCancelledFlag =
true;
849 bool anySubtracted =
false;
856 anySubtracted =
true;
862 for(
int i = 0; i < collector.
GetCount(); ++i )
867 anySubtracted =
true;
877 if( addedCount == 1 )
882 else if( addedCount > 1 )
887 else if( anySubtracted )
924 for(
int i = 0; aAllowedActions[i]; ++i )
926 if( aEvent->
IsAction( aAllowedActions[i] ) )
937 bool cancelled =
false;
942 if( cell->IsSelected() )
951 return ( aItem->GetFlags() &
CANDIDATE ) > 0;
956 if( evt->IsCancelInteractive() || evt->IsActivate() )
965 BOX2I selectionRect( evt->DragOrigin(), evt->Position() - evt->DragOrigin() );
970 bool doSelect =
false;
972 if( cell->HitTest( selectionRect,
false ) )
977 doSelect = !wasSelected( cell );
981 else if( wasSelected( cell ) )
986 if( doSelect && !cell->IsSelected() )
988 else if( !doSelect && cell->IsSelected() )
992 else if( evt->IsMouseUp(
BUT_LEFT ) )
996 bool anyAdded =
false;
997 bool anySubtracted =
false;
1001 if( cell->IsSelected() && !wasSelected( cell ) )
1003 else if( wasSelected( cell ) && !cell->IsSelected() )
1004 anySubtracted =
true;
1036 bool cancelled =
false;
1051 if(
view->IsMirroredX() )
1052 greedySelection = !greedySelection;
1057 if( evt->IsCancelInteractive() || evt->IsActivate() )
1076 area.
SetEnd( evt->Position() );
1082 view->SetVisible( &area,
true );
1083 view->Update( &area );
1092 view->SetVisible( &area,
false );
1106 view->Remove( &area );
1138 bool cancelled =
false;
1156 bool isClockwise = shapeArea > 0 ? true :
false;
1158 if(
getView()->IsMirroredX() && shapeArea != 0 )
1159 isClockwise = !isClockwise;
1163 if( evt->IsCancelInteractive() || evt->IsActivate() )
1166 evt->SetPassEvent(
false );
1173 points.
Append( evt->Position() );
1175 else if( evt->IsDblClick(
BUT_LEFT )
1181 evt->SetPassEvent(
false );
1217 area.
SetMode( selectionMode );
1240 bool anyAdded =
false;
1241 bool anySubtracted =
false;
1249 std::vector<KIGFX::VIEW::LAYER_ITEM_PAIR> candidates;
1251 view->Query( selectionBox, candidates );
1255 std::set<EDA_ITEM*> group_items;
1263 std::unordered_set<EDA_ITEM*>& newset =
group->GetItems();
1266 [&](
const BOX2I& aBox )
1268 return boxMode ? selectionBox.
Contains( aBox )
1274 if( containedMode && boxContained(
group->GetBoundingBox() ) && newset.size() )
1276 for(
EDA_ITEM* group_item : newset )
1278 if( !group_item->IsBOARD_ITEM() )
1282 collector.
Append( *newset.begin() );
1286 for(
EDA_ITEM* group_item : newset )
1287 group_items.emplace( group_item );
1293 return boxMode ? aItem->HitTest( selectionBox, containedMode )
1294 : aItem->HitTest( aArea.
GetPoly(), containedMode );
1297 for(
const auto& [item, layer] : candidates )
1299 if( !item->IsBOARD_ITEM() )
1304 if(
Selectable( boardItem ) && hitTest( boardItem )
1305 && ( !containedMode || !group_items.count( boardItem ) ) )
1308 padsCollector.
Append( boardItem );
1310 collector.
Append( boardItem );
1322 collector = padsCollector;
1329 std::sort( collector.
begin(), collector.
end(),
1332 VECTOR2I aPos = a->GetPosition();
1333 VECTOR2I bPos = b->GetPosition();
1335 if( aPos.y == bPos.y )
1336 return aPos.x < bPos.x;
1338 return aPos.y < bPos.y;
1343 if( !i->IsBOARD_ITEM() )
1348 if( aSubtractive || ( aExclusiveOr && item->
IsSelected() ) )
1351 anySubtracted =
true;
1365 else if( anySubtracted )
1372 wxMouseState keyboardState = wxGetMouseState();
1374 setModifiersState( keyboardState.ShiftDown(), keyboardState.ControlDown(), keyboardState.AltDown() );
1418 collection.
Append( item );
1431 m_frame->GetCanvas()->ForceRefresh();
1459 m_frame->GetCanvas()->ForceRefresh();
1469 std::set<int> representedNets;
1471 for(
int i = aCollector.
GetCount() - 1; i >= 0; i-- )
1477 else if ( representedNets.count( item->
GetNetCode() ) )
1480 representedNets.insert( item->
GetNetCode() );
1487 std::deque<EDA_ITEM*> selectedItems =
m_selection.GetItems();
1490 std::vector<BOARD_CONNECTED_ITEM*> toUnroute;
1491 std::set<EDA_ITEM*> toDelete;
1493 for(
EDA_ITEM* item : selectedItems )
1498 toUnroute.push_back(
pad );
1502 toDelete.insert( item );
1518 std::set<int> selectedNets;
1521 if( item->GetNetCode() > 0 )
1522 selectedNets.insert( item->GetNetCode() );
1524 std::set<VECTOR2I> endpointSet;
1530 endpointSet.insert( track->GetStart() );
1531 endpointSet.insert( track->GetEnd() );
1535 endpointSet.insert( item->GetPosition() );
1539 endpointSet.insert( item->GetPosition() );
1543 bool expanded =
true;
1551 if( toDelete.count( gen ) )
1555 std::map<VECTOR2I, int> epCount;
1557 for(
BOARD_ITEM* child : gen->GetBoardItems() )
1561 if( track && selectedNets.count( track->
GetNetCode() ) )
1564 epCount[track->
GetEnd()]++;
1569 bool connected =
false;
1571 for(
auto& [pt, count] : epCount )
1573 if( count == 1 && endpointSet.count( pt ) )
1582 toDelete.insert( gen );
1596 endpointSet.insert( track->GetStart() );
1597 endpointSet.insert( track->GetEnd() );
1620 std::set<BOARD_ITEM*> removed;
1624 if( !item->IsBOARD_ITEM() )
1630 toDelete.insert( bi );
1633 removed.insert( bi );
1639 for(
BOARD_ITEM* child : gen->GetBoardItems() )
1641 if( removed.count( child ) )
1643 toDelete.insert( gen );
1651 if( !item->IsBOARD_ITEM() )
1659 if( removed.find( aItem ) == removed.end() )
1662 removed.insert( aItem );
1667 if( removed.find( boardItem ) == removed.end() )
1668 commit.
Remove( boardItem );
1672 commit.
Push(
_(
"Unroute Selected" ) );
1677 for(
EDA_ITEM* item : selectedItems )
1689 std::deque<EDA_ITEM*> selectedItems =
m_selection.GetItems();
1692 std::vector<BOARD_CONNECTED_ITEM*> toUnroute;
1694 std::set<EDA_ITEM*> toDelete;
1696 for(
EDA_ITEM* item : selectedItems )
1707 if( !toDelete.count( gen ) )
1709 toDelete.insert( gen );
1713 toDelete.insert( generatedItem );
1723 toDelete.insert( item );
1728 toDelete.insert( item );
1732 toDelete.insert( generatedItem );
1743 std::deque<EDA_ITEM*> toSelectAfter;
1747 if( !item->IsBOARD_ITEM() )
1750 if( toDelete.find( item ) == toDelete.end() )
1751 toSelectAfter.push_back( item );
1755 std::set<BOARD_ITEM*> removed;
1759 if( !item->IsBOARD_ITEM() )
1769 if( removed.insert( aItem ).second )
1774 if( removed.insert( boardItem ).second )
1775 commit.
Remove( boardItem );
1779 if( removed.insert( boardItem ).second )
1780 commit.
Remove( boardItem );
1784 commit.
Push(
_(
"Unroute Segment" ) );
1789 for(
EDA_ITEM* item : toSelectAfter )
1791 if( !toDelete.count( item ) )
1804 unsigned initialCount = 0;
1816 if( initialCount == 0 )
1819 std::vector<PCB_SHAPE*> startShapes;
1824 startShapes.push_back(
static_cast<PCB_SHAPE*
>( item ) );
1828 if( !startShapes.empty() )
1834 m_frame->SetStatusText(
_(
"Select/Expand Connection..." ) );
1838 std::deque<EDA_ITEM*> selectedItems =
m_selection.GetItems();
1840 for(
EDA_ITEM* item : selectedItems )
1841 item->ClearTempFlags();
1843 std::vector<BOARD_CONNECTED_ITEM*> startItems;
1845 for(
EDA_ITEM* item : selectedItems )
1852 startItems.push_back(
pad );
1870 if(
m_selection.GetItems().size() > initialCount )
1874 m_frame->SetStatusText( wxEmptyString );
1887 double refreshIntervalMs = 500;
1888 int lastSelectionSize = (int)
m_selection.GetSize();
1892 std::set<PAD*> startPadSet;
1893 std::vector<BOARD_CONNECTED_ITEM*> cleanupItems;
1899 startPadSet.insert(
static_cast<PAD*
>( startItem ) );
1902 if( startItem->IsType( { PCB_TRACE_T, PCB_ARC_T, PCB_VIA_T } ) )
1911 std::map<VECTOR2I, std::vector<PCB_TRACK*>> trackMap;
1912 std::map<VECTOR2I, PCB_VIA*> viaMap;
1913 std::map<VECTOR2I, PAD*> padMap;
1914 std::map<VECTOR2I, std::vector<PCB_SHAPE*>> shapeMap;
1915 std::vector<std::pair<VECTOR2I, LSET>> activePts;
1925 switch( item->Type() )
1931 trackMap[track->
GetStart()].push_back( track );
1932 trackMap[track->
GetEnd()].push_back( track );
1939 viaMap[
via->GetStart()] =
via;
1946 padMap[
pad->GetPosition()] =
pad;
1955 shapeMap[point].push_back( shape );
1966 switch( startItem->Type() )
1979 activePts.push_back( { startItem->GetPosition(), startItem->GetLayerSet() } );
1983 activePts.push_back( { startItem->GetPosition(), startItem->GetLayerSet() } );
1991 activePts.push_back( { point, startItem->GetLayerSet() } );
2004 while( expand && failSafe++ < 100000 )
2008 for(
int i = (
int) activePts.size() - 1; i >= 0; --i )
2016 auto exactIt = viaMap.find( pt );
2018 if( exactIt != viaMap.end() && ( exactIt->second->GetLayerSet() & layerSetCu ).any() )
2020 hitVia = exactIt->second;
2025 for(
auto& [pos,
via] : viaMap )
2027 if( !(
via->GetLayerSet() & layerSetCu ).any() )
2034 int radius =
via->GetWidth( layer ) / 2;
2035 int64_t radiusSq =
static_cast<int64_t
>(
radius ) *
radius;
2037 if( ( pt - pos ).SquaredEuclideanNorm() <= radiusSq )
2052 auto padIt = padMap.find( pt );
2054 bool gotVia = hitVia !=
nullptr;
2055 bool gotPad = padIt != padMap.end() && ( padIt->second->GetLayerSet() & layerSetCu ).any();
2056 bool gotNonStartPad = gotPad && ( startPadSet.find( padIt->second ) == startPadSet.end() );
2060 activePts.erase( activePts.begin() + i );
2066 activePts.erase( activePts.begin() + i );
2072 size_t pt_count = 0;
2076 if( track->GetStart() != track->GetEnd() && layerSetCu.
Contains( track->GetLayer() ) )
2080 if( pt_count > 2 || gotVia || gotNonStartPad )
2082 activePts.erase( activePts.begin() + i );
2088 if( gotNonStartPad )
2090 activePts.erase( activePts.begin() + i );
2097 PAD*
pad = padIt->second;
2102 cleanupItems.push_back(
pad );
2104 activePts.push_back( {
pad->GetPosition(),
pad->GetLayerSet() } );
2111 if( !layerSetCu.
Contains( track->GetLayer() ) )
2117 if( !track->IsSelected() )
2123 cleanupItems.push_back( track );
2125 if( track->GetStart() == pt )
2126 activePts.push_back( { track->GetEnd(), track->GetLayerSet() } );
2128 activePts.push_back( { track->GetStart(), track->GetLayerSet() } );
2137 if( !layerSetCu.
Contains( shape->GetLayer() ) )
2143 if( !shape->IsSelected() )
2149 cleanupItems.push_back( shape );
2151 for(
const VECTOR2I& newPoint : shape->GetConnectionPoints() )
2153 if( newPoint == pt )
2156 activePts.push_back( { newPoint, shape->GetLayerSet() } );
2172 cleanupItems.push_back( hitVia );
2179 maxRadius = std::max( maxRadius, hitVia->
GetWidth( layer ) / 2 );
2181 int64_t maxRadiusSq =
static_cast<int64_t
>( maxRadius ) * maxRadius;
2183 for(
auto& [trkPt, tracks] : trackMap )
2185 if( ( trkPt - viaPos ).SquaredEuclideanNorm() > maxRadiusSq )
2189 bool inside =
false;
2198 int r = hitVia->
GetWidth( trkLayer ) / 2;
2199 int64_t rSq =
static_cast<int64_t
>( r ) * r;
2201 if( ( trkPt - viaPos ).SquaredEuclideanNorm() <= rSq )
2209 activePts.push_back( { trkPt, hitVia->
GetLayerSet() } );
2217 activePts.erase( activePts.begin() + i );
2221 if( refreshTimer.
msecs() >= refreshIntervalMs )
2225 m_frame->GetCanvas()->ForceRefresh();
2229 refreshTimer.
Start();
2234 std::set<EDA_ITEM*> toDeselect;
2235 std::set<EDA_ITEM*> toSelect;
2240 if( !item->IsBOARD_ITEM() )
2248 toDeselect.insert( item );
2293 std::stack<PCB_SHAPE*> toSearch;
2294 std::set<PCB_SHAPE*> toCleanup;
2296 for(
PCB_SHAPE* startItem : aStartItems )
2297 toSearch.push( startItem );
2310 toSearch.push(
static_cast<PCB_SHAPE*
>( item ) );
2314 while( !toSearch.empty() )
2323 toCleanup.insert( shape );
2332 searchPoint( shape->
GetEnd() );
2343 std::vector<PAD*> pads;
2350 pads.push_back(
pad );
2354 pads.push_back(
static_cast<PAD*
>( item ) );
2363 for(
const CN_EDGE& edge : conn->GetRatsnestForPad(
pad ) )
2365 wxCHECK2( edge.GetSourceNode() && !edge.GetSourceNode()->Dirty(),
continue );
2366 wxCHECK2( edge.GetTargetNode() && !edge.GetTargetNode()->Dirty(),
continue );
2371 if( sourceParent ==
pad )
2374 select(
static_cast<PAD*
>( targetParent )->GetParent() );
2376 else if( targetParent ==
pad )
2379 select(
static_cast<PAD*
>( sourceParent )->GetParent() );
2393 std::vector<PAD*> pads;
2400 pads.push_back(
pad );
2404 pads.push_back(
static_cast<PAD*
>( item ) );
2415 const std::vector<CN_EDGE> edges = conn->GetRatsnestForPad(
pad );
2418 if( edges.size() == 0 )
2421 double currentDistance = DBL_MAX;
2425 for(
const CN_EDGE& edge : edges )
2427 if( edge.GetSourceNode()->Parent()->GetParentFootprint()
2428 == edge.GetTargetNode()->Parent()->GetParentFootprint() )
2434 const CN_ANCHOR* other = edge.GetSourceNode()->
Parent() ==
pad ? edge.GetTargetNode().get()
2435 : edge.GetSourceNode().get();
2437 wxCHECK2( other && !other->
Dirty(),
continue );
2443 if( edge.GetLength() < currentDistance )
2445 currentDistance = edge.GetLength();
2450 if( nearest !=
nullptr )
2464 for(
BOARD_ITEM* item : conn->GetNetItems( aNetCode, { PCB_TRACE_T,
2521 std::vector<BOARD_ITEM*> footprints;
2526 if( footprint ==
nullptr )
2529 wxString footprint_path = footprint->GetPath().AsString().BeforeLast(
'/' );
2531 if( footprint_path.IsEmpty() )
2532 footprint_path +=
'/';
2534 if( footprint_path == aSheetPath )
2535 footprints.push_back( footprint );
2551 std::list<int> netcodeList;
2552 std::vector<BOARD_CONNECTED_ITEM*> padList;
2556 switch( item->Type() )
2562 if(
pad->IsConnected() )
2564 netcodeList.push_back(
pad->GetNetCode() );
2565 padList.push_back(
pad );
2576 if(
pad->IsConnected() )
2578 netcodeList.push_back(
pad->GetNetCode() );
2579 padList.push_back(
pad );
2591 std::sort( padList.begin(), padList.end() );
2595 netcodeList.unique();
2601 std::vector<int> removeCodeList;
2604 for(
int netCode : netcodeList )
2608 if( !std::binary_search( padList.begin(), padList.end(),
pad ) )
2612 removeCodeList.push_back( netCode );
2618 for(
int removeCode : removeCodeList )
2619 netcodeList.remove( removeCode );
2621 std::unordered_set<BOARD_ITEM*> localConnectionList;
2623 for(
int netCode : netcodeList )
2625 for(
BOARD_ITEM* item : conn->GetNetItems( netCode, { PCB_TRACE_T,
2630 localConnectionList.insert( item );
2634 for(
BOARD_ITEM* item : localConnectionList )
2641 std::vector<BOARD_ITEM*>* items = aEvent.
Parameter<std::vector<BOARD_ITEM*>*>();
2652 std::vector<BOARD_ITEM*>* items = aEvent.
Parameter<std::vector<BOARD_ITEM*>*>();
2670 if( item->IsMoving() )
2687 if(
m_frame->GetPcbNewSettings()->m_CrossProbing.center_on_items )
2689 if(
m_frame->GetPcbNewSettings()->m_CrossProbing.zoom_to_fit )
2698 m_frame->GetCanvas()->ForceRefresh();
2708 wxString sheetPath = *aEvent.
Parameter<wxString*>();
2734 if( !footprint || footprint->
GetPath().empty() )
2740 wxString sheetPath = footprint->
GetPath().
AsString().BeforeLast(
'/' );
2742 if( sheetPath.IsEmpty() )
2763 screenSize.
x = std::max( 10.0, screenSize.
x );
2764 screenSize.
y = std::max( 10.0, screenSize.
y );
2769 double scale =
view->GetScale() / std::max( fabs( vsize.
x / screenSize.
x ),
2770 fabs( vsize.
y / screenSize.
y ) );
2776 m_frame->GetCanvas()->ForceRefresh();
2792#ifdef DEFAULT_PCBNEW_CODE
2794 auto screenSize =
view->ToWorld( GetCanvas()->GetClientSize(),
false );
2797 screenSize.x = std::max( 10.0, fabs( screenSize.x ) );
2798 screenSize.y = std::max( 10.0, screenSize.y );
2799 double ratio = std::max( fabs( bbSize.x / screenSize.x ), fabs( bbSize.y / screenSize.y ) );
2802 if( crossProbingSettings.zoom_to_fit && ( ratio < 0.5 || ratio > 1.0 ) )
2803 view->SetScale(
view->GetScale() / ratio );
2806#ifndef DEFAULT_PCBNEW_CODE
2823 double compRatio = bbSize.y / currTextHeight;
2826 double compRatioBent = 1.0;
2837 screenSize.
x = std::max( 10.0, fabs( screenSize.
x ) );
2838 screenSize.
y = std::max( 10.0, screenSize.
y );
2839 double ratio = std::max( -1.0, fabs( bbSize.y / screenSize.
y ) );
2842 double kicadRatio = std::max( fabs( bbSize.x / screenSize.
x ),
2843 fabs( bbSize.y / screenSize.
y ) );
2851 std::vector<std::pair<double, double>> lut {
2864 std::vector<std::pair<double, double>>::iterator it;
2866 compRatioBent = lut.back().second;
2868 if( compRatio >= lut.front().first )
2874 for( it = lut.begin(); it < lut.end() - 1; it++ )
2876 if( it->first <= compRatio &&
next( it )->first >= compRatio )
2878 double diffx = compRatio - it->first;
2879 double diffn =
next( it )->first - it->first;
2881 compRatioBent = it->second + (
next( it )->second - it->second ) * diffx / diffn;
2888 compRatioBent = lut.front().second;
2896 if( bbSize.x > screenSize.
x * ratio * compRatioBent )
2900 compRatioBent = 1.0;
2901 wxLogTrace(
"CROSS_PROBE_SCALE",
"Part TOO WIDE for screen. Using normal KiCad zoom ratio: %1.5f", ratio );
2906 ratio *= compRatioBent;
2908 bool alwaysZoom =
false;
2911 if( ( ratio < 0.5 || ratio > 1.0 ) || alwaysZoom )
2912 view->SetScale(
view->GetScale() / ratio );
2919 bool cleared =
false;
2931 switch( aItem->
Type() )
2935 int netCode =
static_cast<NETINFO_ITEM*
>( aItem )->GetNetCode();
2954 double marginFactor = 2;
2963 double scaleX = screenSize.
x /
static_cast<double>( aItem->
GetBoundingBox().GetWidth() );
2964 double scaleY = screenSize.
y /
static_cast<double>( aItem->
GetBoundingBox().GetHeight() );
2966 scaleX /= marginFactor;
2967 scaleY /= marginFactor;
2969 double scale = scaleX > scaleY ? scaleY : scaleX;
2988 m_frame->GetCanvas()->ForceRefresh();
3000 switch( aItem.
Type() )
3055 if( cmd != wxID_OK )
3066 if( !i->IsBOARD_ITEM() )
3088 std::set<BOARD_ITEM*> rejected;
3092 if( !i->IsBOARD_ITEM() )
3098 rejected.insert( item );
3102 aCollector.
Remove( item );
3167 aRejected->
pads =
true;
3179 aRejected->
tracks =
true;
3190 aRejected->
vias =
true;
3199 ZONE* zone =
static_cast<ZONE*
>( aItem );
3209 aRejected->
zones =
true;
3218 if( zone ==
m_frame->GetBoard()->m_SolderMaskBridges )
3249 aRejected->
text =
true;
3285 aRejected->
points =
true;
3333 bool enteredGroupFound =
false;
3336 [&](
EDA_ITEM* item,
void* testData )
3354 enteredGroupFound =
true;
3368 if( !enteredGroupFound )
3381 auto visibleLayers =
3389 set.
set( layer,
view()->IsLayerVisible( layer ) );
3411 bool onActiveLayer =
false;
3413 for(
int layer : activeLayers )
3416 if( layer < PCB_LAYER_ID_COUNT && aItem->IsOnLayer(
ToLAYER_ID( layer ) ) )
3418 onActiveLayer =
true;
3441 && footprint->
Pads().empty()
3442 && footprint->
Zones().empty() )
3459 for(
const ZONE* zone : footprint->
Zones() )
3491 const ZONE* zone =
nullptr;
3493 const PAD*
pad =
nullptr;
3506 switch( aItem->
Type() )
3512 zone =
static_cast<const ZONE*
>( aItem );
3530 if( !layerVisible( aItem->
GetLayer() ) )
3542 if( !( visibleLayers() &
via->GetLayerSet() ).any() )
3548 field =
static_cast<const PCB_FIELD*
>( aItem );
3564 if( !layerVisible(
text->GetLayer() ) )
3575 if(
text->GetText() == wxT(
"${REFERENCE}" ) )
3577 else if(
text->GetText() == wxT(
"${VALUE}" ) )
3580 if( !
view()->IsLayerVisible( controlLayer ) )
3594 if( !layerVisible( aItem->
GetLayer() ) )
3603 if( !layerVisible( aItem->
GetLayer() ) )
3609 if( !layerVisible( aItem->
GetLayer() ) )
3616 if( !layerVisible( aItem->
GetLayer() ) )
3624 if( !layerVisible( aItem->
GetLayer() ) )
3637 if( !layerVisible( aItem->
GetLayer() ) )
3646 pad =
static_cast<const PAD*
>( aItem );
3657 if( !(
pad->GetLayerSet() & visibleLayers() ).
any() )
3664 marker =
static_cast<const PCB_MARKER*
>( aItem );
3672 if( !layerVisible( aItem->
GetLayer() ) )
3726 aGroup->
Add( aItem );
3795 const unsigned GRIP_MARGIN = 20;
3801 if( !item->IsBOARD_ITEM() )
3804 BOX2I itemBox = item->ViewBBox();
3809 if( item->HitTest( aPoint, margin ) )
3816 group->RunOnChildren(
3819 if( aItem->
HitTest( aPoint, margin ) )
3839 SEG loc( aWhere, aWhere );
3841 switch( aItem->
Type() )
3849 if(
text->GetEffectiveTextShape()->Collide( loc, aMaxDistance, &
distance ) )
3871 shape->Collide( loc, aMaxDistance, &
distance );
3891 ZONE* zone =
static_cast<ZONE*
>( aItem );
3913 catch(
const std::exception& e )
3915 wxFAIL_MSG( wxString::Format( wxT(
"Clipper exception occurred: %s" ), e.what() ) );
3949 static_cast<PAD*
>( aItem )->Padstack().ForEachUniqueLayer(
3952 int layerDistance = INT_MAX;
3978 wxCHECK( settings, );
3981 LSET visibleLayers =
m_frame->GetBoard()->GetVisibleLayers();
3982 LSET enabledLayers =
m_frame->GetBoard()->GetEnabledLayers();
3985 wxCHECK( !enabledLayerStack.empty(), );
3987 auto isZoneFillKeepout =
3992 const ZONE* zone =
static_cast<const ZONE*
>( aItem );
4001 std::vector<LAYER_OPACITY_ITEM> opacityStackup;
4003 for(
int i = 0; i < aCollector.
GetCount(); i++ )
4007 LSET itemLayers = item->
GetLayerSet() & enabledLayers & visibleLayers;
4008 LSEQ itemLayerSeq = itemLayers.
Seq( enabledLayerStack );
4021 opacityItem.
m_Item = item;
4023 if( isZoneFillKeepout( item ) )
4026 opacityStackup.emplace_back( opacityItem );
4030 std::sort( opacityStackup.begin(), opacityStackup.end(),
4033 int retv = enabledLayerStack.TestLayers( aLhs.m_Layer, aRhs.m_Layer );
4038 return aLhs.m_Opacity > aRhs.m_Opacity;
4041 std::set<const BOARD_ITEM*> visibleItems;
4042 std::set<const BOARD_ITEM*> itemsToRemove;
4044 double currentStackupOpacity = 0.0;
4051 currentStackupOpacity = opacityItem.m_Opacity;
4052 lastVisibleLayer = opacityItem.m_Layer;
4053 visibleItems.emplace( opacityItem.m_Item );
4063 wxCHECK( item,
false );
4066 if( visibleItems.count( item ) )
4072 && visibleItems.count( item->
GetParent() ) )
4079 if( isZoneFillKeepout( item ) )
4086 if( opacityItem.m_Layer == enabledLayerStack[0] )
4088 visibleItems.emplace( opacityItem.m_Item );
4092 double itemVisibility = opacityItem.m_Opacity * ( 1.0 - currentStackupOpacity );
4094 if( ( itemVisibility <= minAlphaLimit ) && !ignoreItem() )
4095 itemsToRemove.emplace( opacityItem.m_Item );
4097 visibleItems.emplace( opacityItem.m_Item );
4100 if( opacityItem.m_Layer != lastVisibleLayer )
4102 currentStackupOpacity += opacityItem.m_Opacity * ( 1.0 - currentStackupOpacity );
4103 currentStackupOpacity = std::min( currentStackupOpacity, 1.0 );
4104 lastVisibleLayer = opacityItem.m_Layer;
4108 for(
const BOARD_ITEM* itemToRemove : itemsToRemove )
4110 wxCHECK( aCollector.
GetCount() > 1, );
4111 aCollector.
Remove( itemToRemove );
4134 static std::vector<KICAD_T> singleLayerSilkTypes = {
PCB_FIELD_T,
4146 std::set<BOARD_ITEM*> preferred;
4147 std::set<BOARD_ITEM*> rejected;
4154 if( silkLayers[activeLayer] )
4156 for(
int i = 0; i < aCollector.
GetCount(); ++i )
4160 if( item->
IsType( singleLayerSilkTypes ) && silkLayers[ item->
GetLayer() ] )
4161 preferred.insert( item );
4166 else if( courtyardLayers[activeLayer] && settings->
GetHighContrast() )
4168 for(
int i = 0; i < aCollector.
GetCount(); ++i )
4173 preferred.insert( item );
4177 if( preferred.size() > 0 )
4182 aCollector.
Append( item );
4184 if( preferred.size() == 1 )
4189 constexpr int MAX_SLOP = 5;
4193 int minSlop = INT_MAX;
4195 std::map<BOARD_ITEM*, int> itemsBySloppiness;
4197 for(
int i = 0; i < aCollector.
GetCount(); ++i )
4202 itemsBySloppiness[ item ] = itemSlop;
4204 if( itemSlop < minSlop )
4209 if( minSlop < INT_MAX )
4211 for( std::pair<BOARD_ITEM*, int> pair : itemsBySloppiness )
4213 if( pair.second > minSlop + singlePixel )
4220 constexpr double sizeRatio = 1.5;
4222 std::vector<std::pair<BOARD_ITEM*, double>> itemsByArea;
4224 for(
int i = 0; i < aCollector.
GetCount(); ++i )
4233 area = (double)
SEG::Square( singlePixel ) * MAX_SLOP;
4252 catch(
const std::exception& e )
4254 wxFAIL_MSG( wxString::Format( wxT(
"Clipper exception occurred: %s" ), e.what() ) );
4258 itemsByArea.emplace_back( item, area );
4261 std::sort( itemsByArea.begin(), itemsByArea.end(),
4262 [](
const std::pair<BOARD_ITEM*, double>& lhs,
4263 const std::pair<BOARD_ITEM*, double>& rhs ) ->
bool
4265 return lhs.second < rhs.second;
4268 bool rejecting =
false;
4270 for(
int i = 1; i < (int) itemsByArea.size(); ++i )
4272 if( itemsByArea[i].second > itemsByArea[i-1].second * sizeRatio )
4276 rejected.insert( itemsByArea[i].first );
4281 constexpr double maxCoverRatio = 0.70;
4283 for(
int i = 0; i < aCollector.
GetCount(); ++i )
4287 if( footprint->CoverageRatio( aCollector ) > maxCoverRatio )
4288 rejected.erase( footprint );
4293 if( (
unsigned) aCollector.
GetCount() > rejected.size() )
4305 bool haveItemOnActive =
false;
4308 for(
int i = 0; i < aCollector.
GetCount(); ++i )
4310 if( !aCollector[i]->IsOnLayer( activeLayer ) )
4311 rejected.insert( aCollector[i] );
4313 haveItemOnActive =
true;
4316 if( haveItemOnActive )
4330 for(
int i = (
int) aCollector.
GetCount() - 1; i >= 0; --i )
4333 bool lockedDescendant =
false;
4339 lockedDescendant =
true;
4343 if( item->
IsLocked() || lockedDescendant )
4344 aCollector.
Remove( item );
4352 std::unordered_set<EDA_ITEM*> toAdd;
4356 for(
int j = 0; j < aCollector.
GetCount(); j++ )
4358 if( aCollector[j]->GetParent() )
4359 aCollector[j]->GetParent()->ClearFlags(
CANDIDATE );
4361 if( aCollector[j]->GetParentFootprint() )
4362 aCollector[j]->GetParentFootprint()->ClearFlags(
CANDIDATE );
4367 for(
int j = 0; j < aCollector.
GetCount(); j++ )
4371 for(
int j = 0; j < aCollector.
GetCount(); )
4383 aCollector.
Remove( item );
4391 if(
top->AsEdaItem() != item )
4393 toAdd.insert(
top->AsEdaItem() );
4396 aCollector.
Remove( item );
4405 aCollector.
Remove( item );
4414 if( !aCollector.
HasItem( item ) )
4415 aCollector.
Append( item );
4422 std::set<BOARD_ITEM*> to_add;
4425 for(
int i = (
int) aCollector.
GetCount() - 1; i >= 0; --i )
4434 aCollector.
Remove( item );
4439 aCollector.
Append( item );
4444 bool aForcePromotion )
const
4446 std::set<BOARD_ITEM*> to_add;
4449 for(
int i = aCollector.
GetCount() - 1; i >= 0; --i )
4454 && ( !
frame()->GetPcbNewSettings()->m_AllowFreePads || aForcePromotion ) )
4459 aCollector.
Remove( item );
4464 aCollector.
Append( item );
4471 for(
int i = aCollector.
GetCount() - 1; i >= 0; --i )
4476 aCollector.
Remove( item );
4488 bool need_direct_hit =
false;
4496 need_direct_hit =
true;
4504 else if( item->IsBOARD_ITEM() )
4505 fp =
static_cast<BOARD_ITEM*
>( item )->GetParentFootprint();
4511 single_fp =
nullptr;
4514 else if( !single_fp )
4520 else if( single_fp != fp )
4522 single_fp =
nullptr;
4528 auto visibleLayers =
4536 set.
set( layer,
view()->IsLayerVisible( layer ) );
4546 LSET layers = visibleLayers();
4554 for(
int layer : activeLayers )
4557 layers.
set( layer );
4562 for(
int i = aCollector.
GetCount() - 1; i >= 0; --i )
4578 aCollector.
Remove( item );
4580 bool has_hit =
false;
4594 aCollector.
Remove( item );
4599 else if( single_fp )
4601 if( fp == single_fp )
4604 else if( need_direct_hit )
4618 aCollector.
Remove( item );
4635 std::set<std::pair<PCB_TABLE*, int>> columns;
4643 columns.insert( std::make_pair(
table, cell->GetColumn() ) );
4647 for(
auto& [
table, col ] : columns )
4649 for(
int row = 0; row <
table->GetRowCount(); ++row )
4670 std::set<std::pair<PCB_TABLE*, int>> rows;
4678 rows.insert( std::make_pair(
table, cell->GetRow() ) );
4682 for(
auto& [
table, row ] : rows )
4684 for(
int col = 0; col <
table->GetColCount(); ++col )
4705 std::set<PCB_TABLE*> tables;
4711 tables.insert(
static_cast<PCB_TABLE*
>( cell->GetParent() ) );
4718 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.
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.
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()
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.
static TOOL_ACTION deleteLastPoint
static TOOL_ACTION drag45Degree
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 highlightNet
static TOOL_ACTION hideLocalRatsnest
static TOOL_ACTION properties
Activation of the edit tool.
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.
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...
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()
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 that computes missing connections on a PCB.
static float distance(const SFVEC2UI &a, const SFVEC2UI &b)
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)