27using namespace std::placeholders;
71 if( aDirection.
x != 0 || aDirection.
y != 0 )
72 aDirections.push_back( aDirection );
77 std::vector<VECTOR2I> directions;
87 else if(
dynamic_cast<EC_45DEGREE*
>( aConstraint ) )
94 else if(
dynamic_cast<EC_VERTICAL*
>( aConstraint ) )
102 else if(
EC_LINE* lineConstraint =
dynamic_cast<EC_LINE*
>( aConstraint ) )
185 wxArrayString strings;
207 return wxT(
"RECT_RADIUS_TEXT_ITEM" );
243 if( aPoints.
SwapX() )
244 std::swap( topLeft.
x, botRight.
x );
246 if( aPoints.
SwapY() )
247 std::swap( topLeft.
y, botRight.
y );
300 PinEditedCorner( aEditedPoint, aPoints, topLeft, topRight, botLeft, botRight,
301 { 0, 0 }, { 0, 0 }, aMinSize );
309 setLeft( topLeft.
x );
310 setRight( botRight.
x );
311 setBottom( botRight.
y );
316 aRectangle.
Move( moveVector );
320 int width =
std::abs( botRight.
x - topLeft.
x );
321 int height =
std::abs( botRight.
y - topLeft.
y );
322 int maxRadius = std::min( width, height ) / 2;
324 x = std::clamp( x, botRight.
x - maxRadius, botRight.
x );
336 setLeft( topLeft.
x );
341 setBottom( botRight.
y );
346 setRight( botRight.
x );
349 for(
unsigned i = 0; i < aPoints.
LinesSize(); ++i )
366 if( aPoints.
SwapX() )
367 std::swap( topLeft.
x, botRight.
x );
369 if( aPoints.
SwapY() )
370 std::swap( topLeft.
y, botRight.
y );
397 std::vector<EDA_ITEM*>& aUpdatedItems )
override
418 const VECTOR2I& aMinSize = { 0, 0 } )
428 aTopLeft.
x = std::min( aTopLeft.
x, aHole.x - aHoleSize.
x / 2 - minWidth );
429 aTopLeft.
y = std::min( aTopLeft.
y, aHole.y - aHoleSize.
y / 2 - minHeight );
434 aTopLeft.
x = std::min( aTopLeft.
x, aBotRight.
x - minWidth );
435 aTopLeft.
y = std::min( aTopLeft.
y, aBotRight.
y - minHeight );
439 aTopRight.
y = aTopLeft.
y;
440 aBotLeft.
x = aTopLeft.
x;
447 aTopRight.
x = std::max( aTopRight.
x, aHole.x + aHoleSize.
x / 2 + minWidth );
448 aTopRight.
y = std::min( aTopRight.
y, aHole.y - aHoleSize.
y / 2 - minHeight );
453 aTopRight.
x = std::max( aTopRight.
x, aBotLeft.
x + minWidth );
454 aTopRight.
y = std::min( aTopRight.
y, aBotLeft.
y - minHeight );
458 aTopLeft.
y = aTopRight.
y;
459 aBotRight.
x = aTopRight.
x;
466 aBotLeft.
x = std::min( aBotLeft.
x, aHole.x - aHoleSize.
x / 2 - minWidth );
467 aBotLeft.
y = std::max( aBotLeft.
y, aHole.y + aHoleSize.
y / 2 + minHeight );
472 aBotLeft.
x = std::min( aBotLeft.
x, aTopRight.
x - minWidth );
473 aBotLeft.
y = std::max( aBotLeft.
y, aTopRight.
y + minHeight );
477 aBotRight.
y = aBotLeft.
y;
478 aTopLeft.
x = aBotLeft.
x;
485 aBotRight.
x = std::max( aBotRight.
x, aHole.x + aHoleSize.
x / 2 + minWidth );
486 aBotRight.
y = std::max( aBotRight.
y, aHole.y + aHoleSize.
y / 2 + minHeight );
491 aBotRight.
x = std::max( aBotRight.
x, aTopLeft.
x + minWidth );
492 aBotRight.
y = std::max( aBotRight.
y, aTopLeft.
y + minHeight );
496 aBotLeft.
y = aBotRight.
y;
497 aTopRight.
x = aBotRight.
x;
501 aTopLeft.
y = std::min( aTopLeft.
y, aBotRight.
y - minHeight );
505 aTopLeft.
x = std::min( aTopLeft.
x, aBotRight.
x - minWidth );
509 aBotRight.
y = std::max( aBotRight.
y, aTopLeft.
y + minHeight );
513 aBotRight.
x = std::max( aBotRight.
x, aTopLeft.
x + minWidth );
531 std::vector<EDA_ITEM*>& aUpdatedItems )
override
593 std::vector<EDA_ITEM*>& aUpdatedItems )
override
609 const VECTOR2I newOffset = xfrmOrigin - ( topLeft + botRight ) / 2;
624 oldCorner -= oldSize / 2;
628 newCorner = topRight;
629 oldCorner -=
VECTOR2I( -oldSize.
x, oldSize.
y ) / 2;
634 oldCorner -=
VECTOR2I( oldSize.
x, -oldSize.
y ) / 2;
638 newCorner = botRight;
639 oldCorner += oldSize / 2;
645 *newCorner -= xfrmOrigin;
646 oldCorner -= oldOrigin;
649 if(
sign( newCorner->x ) !=
sign( oldCorner.
x ) ||
sign( newCorner->y ) !=
sign( oldCorner.
y ) )
657 double ratio = oldLength > 0 ? ( newLength / oldLength ) : 1.0;
663 ratio = std::min( newWidth / oldSize.
x, newHeight / oldSize.
y );
700 auto set45Constraint =
729 std::vector<EDA_ITEM*>& aUpdatedItems )
override
758 std::vector<EDA_ITEM*>& aUpdatedItems )
override
764 aUpdatedItems.push_back( &
table );
766 if( !
m_cell.GetTextAngle().IsHorizontal() )
774 for(
int ii = 0; ii <
m_cell.GetColSpan() - 1; ++ii )
775 colWidth -=
table.GetColWidth(
m_cell.GetColumn() + ii );
783 int rowHeight =
m_cell.GetRectangleWidth();
785 for(
int ii = 0; ii <
m_cell.GetRowSpan() - 1; ++ii )
786 rowHeight -=
table.GetRowHeight(
m_cell.GetRow() + ii );
797 int colWidth =
m_cell.GetRectangleWidth();
799 for(
int ii = 0; ii <
m_cell.GetColSpan() - 1; ++ii )
800 colWidth -=
table.GetColWidth(
m_cell.GetColumn() + ii );
808 int rowHeight =
m_cell.GetRectangleHeight();
810 for(
int ii = 0; ii <
m_cell.GetRowSpan() - 1; ++ii )
811 rowHeight -=
table.GetRowHeight(
m_cell.GetRow() + ii );
838 if(
m_pad.IsLocked() )
853 if( !
m_pad.GetOrientation().IsCardinal() )
856 if(
m_pad.GetOrientation().IsVertical() )
857 std::swap( halfSize.
x, halfSize.
y );
860 aPoints.
AddPoint( shapePos - halfSize );
862 aPoints.
AddPoint( shapePos + halfSize );
882 int target =
locked ? 0 : 1;
890 else if( target == 1 )
892 shapePos.
x += halfSize.
x;
905 int target =
locked || !
m_pad.GetOrientation().IsCardinal() ? 0 : 4;
912 else if( target == 4 )
914 if(
m_pad.GetOrientation().IsVertical() )
915 std::swap( halfSize.
x, halfSize.
y );
919 shapePos.
y - halfSize.
y ) );
922 shapePos.
y + halfSize.
y ) );
936 std::vector<EDA_ITEM*>& aUpdatedItems )
override
963 botLeft, botRight, holeCenter, holeSize );
966 || (
m_pad.GetDrillSize().x &&
m_pad.GetDrillSize().y ) )
976 dist[0] =
center.x - topLeft.
x;
977 dist[1] =
center.y - topLeft.
y;
978 dist[2] = botRight.
x -
center.x;
979 dist[3] = botRight.
y -
center.y;
983 dist[0] =
center.x - botLeft.
x;
984 dist[1] =
center.y - topRight.
y;
985 dist[2] = topRight.
x -
center.x;
986 dist[3] = botLeft.
y -
center.y;
989 VECTOR2I padSize( dist[0] + dist[2], dist[1] + dist[3] );
990 VECTOR2I deltaOffset( padSize.
x / 2 - dist[2], padSize.
y / 2 - dist[3] );
992 if(
m_pad.GetOrientation().IsVertical() )
993 std::swap( padSize.
x, padSize.
y );
1012 bottom = botRight.
y;
1024 if(
m_pad.GetOrientation().IsVertical() )
1025 std::swap( padSize.
x, padSize.
y );
1067 std::vector<EDA_ITEM*>& aUpdatedItems )
override
1091 m_oldCrossBar(
SEG{ aDimension.GetCrossbarStart(), aDimension.GetCrossbarEnd() } )
1114 const VECTOR2I newProject = newCrossBar.LineProject( newTextPos );
1116 const VECTOR2I oldProjectedOffset =
1118 const VECTOR2I newProjectedOffset = newProject - newCrossBar.NearestPoint( newProject );
1120 const bool textWasLeftOf = oldProjectedOffset.
x < 0
1121 || ( oldProjectedOffset.
x == 0 && oldProjectedOffset.
y > 0 );
1122 const bool textIsLeftOf = newProjectedOffset.
x < 0
1123 || ( newProjectedOffset.
x == 0 && newProjectedOffset.
y > 0 );
1125 if( textWasLeftOf != textIsLeftOf )
1145 const EDA_ANGLE rotation = oldAngle - newAngle;
1158 rotTextOffsetFromCbCenter,
1159 newCrossBar.Center() );
1165 return newCbRefPt + rotTextOffsetFromCbEnd;
1178 const VECTOR2I newProjected = newCrossBar.A + ( newCrossBar.B - newCrossBar.A ) * oldRatio;
1179 return newProjected + rotCbNormalToText;
1232 std::vector<EDA_ITEM*>& aUpdatedItems )
override
1269 if( featureLine.
Cross( crossBar ) > 0 )
1281 if( featureLine.
Cross( crossBar ) > 0 )
1337 VECTOR2I direction = ( directionA < directionB ) ? directionA : directionB;
1343 if( !bounds.
Contains( cursorPos ) )
1366 m_dimension.SetHeight( vert ? featureLine.
x : featureLine.
y );
1422 std::vector<EDA_ITEM*>& aUpdatedItems )
override
1439 return std::nullopt;
1485 std::vector<EDA_ITEM*>& aUpdatedItems )
override
1535 return std::nullopt;
1575 std::vector<EDA_ITEM*>& aUpdatedItems )
override
1635 std::vector<EDA_ITEM*>& aUpdatedItems )
override
1658 if( item->Type() == PCB_SHAPE_T )
1660 PCB_SHAPE* shape = static_cast<PCB_SHAPE*>( item );
1661 m_shapes.push_back( shape );
1662 m_originalWidths[shape] = static_cast<double>( shape->GetWidth() );
1709 std::vector<EDA_ITEM*>& aUpdatedItems )
override
1728 shape->Move(
delta );
1733 aUpdatedItems.push_back( shape );
1746 double sx =
static_cast<double>( br.
x - tl.
x ) /
static_cast<double>( oldBox.
GetWidth() );
1747 double sy =
static_cast<double>( br.
y - tl.
y ) /
static_cast<double>( oldBox.
GetHeight() );
1748 double scale = ( sx + sy ) / 2.0;
1761 shape->Move( -oldCenter );
1762 shape->Scale(
scale );
1763 shape->Move( oldCenter );
1767 shapeIt->second = shapeIt->second *
scale;
1768 shape->SetWidth(
KiROUND( shapeIt->second ) );
1772 shape->SetWidth(
KiROUND( shape->GetWidth() *
scale ) );
1775 aUpdatedItems.push_back( shape );
1789 bbox.
Merge( shape->GetBoundingBox() );
1864 const auto type = aItem.
Type();
1883 double angleRad = aAngleDeg *
M_PI / 180.0;
1886 double chord = (
next - prev ).EuclideanNorm();
1887 double sinA = sin( angleRad );
1889 if( chord == 0.0 || fabs( sinA ) < 1e-9 )
1892 double radius = chord / ( 2.0 * sinA );
1897 double h_sq =
radius *
radius - ( chord * chord ) / 4.0;
1898 double h = h_sq > 0.0 ? sqrt( h_sq ) : 0.0;
1922 return d1 < d2 ? p1 : p2;
1931 wxASSERT_MSG(
m_selectionTool, wxT(
"pcbnew.InteractiveSelection tool is not available" ) );
1933 const auto arcIsEdited =
1934 [](
const SELECTION& aSelection ) ->
bool
1936 const EDA_ITEM* item = aSelection.Front();
1953 std::shared_ptr<EDIT_POINTS> points = std::make_shared<EDIT_POINTS>( aItem );
1961 switch( aItem->
Type() )
1966 m_editorBehavior = std::make_unique<REFERENCE_IMAGE_POINT_EDIT_BEHAVIOR>( refImage );
1972 m_editorBehavior = std::make_unique<BARCODE_POINT_EDIT_BEHAVIOR>( barcode );
1978 m_editorBehavior = std::make_unique<TEXTBOX_POINT_EDIT_BEHAVIOR>( textbox );
1988 m_editorBehavior = std::make_unique<EDA_SEGMENT_POINT_EDIT_BEHAVIOR>( *shape );
1992 m_editorBehavior = std::make_unique<RECTANGLE_POINT_EDIT_BEHAVIOR>( *shape );
2002 m_editorBehavior = std::make_unique<EDA_CIRCLE_POINT_EDIT_BEHAVIOR>( *shape );
2006 m_editorBehavior = std::make_unique<EDA_POLYGON_POINT_EDIT_BEHAVIOR>( *shape );
2010 m_editorBehavior = std::make_unique<EDA_BEZIER_POINT_EDIT_BEHAVIOR>( *shape,
2016 m_editorBehavior = std::make_unique<EDA_ELLIPSE_POINT_EDIT_BEHAVIOR>( *shape );
2029 bool shapesOnly =
true;
2054 m_editorBehavior = std::make_unique<PCB_TABLECELL_POINT_EDIT_BEHAVIOR>( *cell );
2078 ZONE& zone =
static_cast<ZONE&
>( *aItem );
2086 m_editorBehavior = std::make_unique<GENERATOR_POINT_EDIT_BEHAVIOR>( *generator );
2094 m_editorBehavior = std::make_unique<ALIGNED_DIMENSION_POINT_EDIT_BEHAVIOR>( dimension );
2101 m_editorBehavior = std::make_unique<DIM_CENTER_POINT_EDIT_BEHAVIOR>( dimension );
2108 m_editorBehavior = std::make_unique<DIM_RADIAL_POINT_EDIT_BEHAVIOR>( dimension );
2115 m_editorBehavior = std::make_unique<DIM_LEADER_POINT_EDIT_BEHAVIOR>( dimension );
2190 if( selItem->GetEditFlags() || !selItem->IsBOARD_ITEM() )
2206 std::vector<std::unique_ptr<BOARD_ITEM>> clones;
2213 std::vector<PCB_SHAPE*> shapes;
2214 bool allShapes =
true;
2215 bool anyLocked =
false;
2222 shapes.push_back( shape );
2233 if( allShapes && shapes.size() > 1 && !anyLocked )
2236 std::move( shapes ), item );
2276 bool inDrag =
false;
2277 bool isConstrained =
false;
2278 bool haveSnapLineDirections =
false;
2280 auto updateSnapLineDirections =
2283 std::vector<VECTOR2I> directions;
2297 if( directions.empty() )
2299 grid.SetSnapLineDirections( {} );
2300 grid.SetSnapLineEnd( std::nullopt );
2301 haveSnapLineDirections =
false;
2307 grid.SetSnapLineDirections( directions );
2308 grid.SetSnapLineOrigin( origin );
2309 grid.SetSnapLineEnd( std::nullopt );
2310 haveSnapLineDirections =
true;
2320 grid.SetUseGrid(
getView()->GetGAL()->GetGridSnapping() && !evt->DisableGridSnapping() );
2349 frame()->UndoRedoBlock(
true );
2367 for(
size_t ii = 0; ii <
m_editPoints->PointsSize(); ++ii )
2383 shape->UpdateHatching();
2388 clones.emplace_back( clone );
2389 grid.AddConstructionItems( { clone },
false, true );
2391 updateSnapLineDirections();
2395 bool ctrlHeld = evt->Modifier(
MD_CTRL );
2399 if( isConstrained != need_constraint )
2402 isConstrained = need_constraint;
2403 updateSnapLineDirections();
2410 bool isPoly =
false;
2412 switch( item->
Type() )
2436 if( constraint->
GetMode() != targetMode )
2437 constraint->
SetMode( targetMode );
2455 if(
grid.GetUseGrid() )
2460 bool snappedAlongPerp =
false;
2462 if( convergingConstraint )
2482 double step = std::hypot( gridSize.
x * perpUnit.
x,
2483 gridSize.
y * perpUnit.
y );
2487 double offset =
VECTOR2D( pos - origCenter ).
Dot( perpUnit );
2488 double snapped = std::round( offset / step ) * step;
2491 snappedAlongPerp =
true;
2496 if( !snappedAlongPerp )
2503 VECTOR2I deltaGrid = gridPt -
grid.BestSnapAnchor( last, {},
2504 grid.GetItemGrid( item ),
2507 if( abs(
delta.x ) >
grid.GetGrid().x / 2 )
2508 pos.
x = last.
x + deltaGrid.
x;
2512 if( abs(
delta.y ) >
grid.GetGrid().y / 2 )
2513 pos.
y = last.
y + deltaGrid.
y;
2535 bool isFreePolygon =
2543 if( idx != wxNOT_FOUND )
2546 int nextIdx = ( idx + 1 ) %
m_editPoints->PointsSize();
2549 SEG segA( pos, prev );
2552 double snapAng = 45.0 * std::round( ang / 45.0 );
2554 if(
std::abs( ang - snapAng ) < 2.0 )
2560 VECTOR2I gridded =
grid.BestSnapAnchor( snapped, {},
grid.GetItemGrid( item ), { item } );
2563 snapped =
std::abs( griddedAng - snapAng ) < 2.0 ? gridded : pos;
2566 if( snapped != pos )
2577 bool constraintSnapped =
false;
2584 constraintSnapped =
true;
2588 if(
grid.GetSnap() && !snapLayers.empty() )
2591 VECTOR2I snapPos =
grid.BestSnapAnchor( constrainedPos, snapLayers,
2592 grid.GetItemGrid( item ), { item } );
2594 if( snapPos != constrainedPos )
2601 if( ( projectedPos - snapPos ).EuclideanNorm() > snapTolerance )
2610 constraintSnapped =
true;
2615 if(
grid.GetSnap() && !snapLayers.empty() )
2618 VECTOR2I snapPos =
grid.BestSnapAnchor( constrainedPos, snapLayers,
2619 grid.GetItemGrid( item ), { item } );
2624 if( snapPos != constrainedPos )
2634 if( ( projectedPos - snapPos ).EuclideanNorm() > snapTolerance )
2649 if( haveSnapLineDirections )
2652 grid.SetSnapLineOrigin( snapOrigin );
2654 if( constraintSnapped )
2657 grid.SetSnapLineEnd( std::nullopt );
2671 int radius = rect->GetCornerRadius();
2673 VECTOR2I topLeft = rect->GetTopLeft();
2674 VECTOR2I botRight = rect->GetBotRight();
2692 for(
size_t ii = 0; ii <
m_editPoints->PointsSize(); ++ii )
2705 else if( inDrag && evt->IsMouseUp(
BUT_LEFT ) )
2723 updateSnapLineDirections();
2740 commit.
Push(
_(
"Resize Table Cells" ) );
2744 commit.
Push(
_(
"Move Point" ) );
2750 shape->UpdateHatching();
2754 frame()->UndoRedoBlock(
false );
2755 updateSnapLineDirections();
2759 else if( evt->IsCancelInteractive() || evt->IsActivate() )
2774 shape->UpdateHatching();
2778 frame()->UndoRedoBlock(
false );
2779 updateSnapLineDirections();
2785 if( evt->IsActivate() && !evt->IsMoveTool() )
2816 evt->SetPassEvent();
2823 shape->UpdateHatching();
2845 grid.SetSnapLineDirections( {} );
2867 title =
_(
"Move Midpoint to Location" );
2868 msg =
_(
"Move Midpoint" );
2872 title =
_(
"Move Corner to Location" );
2873 msg =
_(
"Move Corner" );
2898 std::vector<EDA_ITEM*> updatedItems = { item };
2909 switch( item->
Type() )
2920 if(
pad->IsEntered() )
2927 textBox->ClearRenderCache();
2955 for(
EDA_ITEM* updatedItem : updatedItems )
2958 frame()->SetMsgPanel( item );
2975 int editedIndex = -1;
2976 bool editingLine =
false;
2981 for(
unsigned ii = 0; ii <
m_editPoints->PointsSize(); ++ii )
2991 if( editedIndex == -1 )
2993 for(
unsigned ii = 0; ii <
m_editPoints->LinesSize(); ++ii )
3014 if( editedIndex >= 0 )
3016 if( editingLine && editedIndex < (
int)
m_editPoints->LinesSize() )
3018 else if( !editingLine && editedIndex < (
int)
m_editPoints->PointsSize() )
3047 if(
frame()->ToolStackIsEmpty() )
3050 controls->ForceCursorPosition(
false );
3061 bool isPoly =
false;
3065 switch( parent->
Type() )
3082 if( line && isPoly )
3106 if( line && isPoly )
3141 auto vertexIdx = it.GetIndex();
3144 return std::make_pair(
true, vertexIdx );
3162 switch( item->
Type() )
3165 polyset =
static_cast<ZONE*
>( item )->Outline();
3170 polyset = &
static_cast<PCB_SHAPE*
>( item )->GetPolyShape();
3223 unsigned int nearestIdx = 0;
3224 unsigned int nextNearestIdx = 0;
3225 unsigned int nearestDist = INT_MAX;
3226 unsigned int firstPointInContour = 0;
3231 ZONE* zone =
static_cast<ZONE*
>( item );
3232 zoneOutline = zone->
Outline();
3251 for( ; iterator; iterator++, curr_idx++ )
3253 int jj = curr_idx+1;
3257 jj = firstPointInContour;
3258 firstPointInContour = curr_idx+1;
3261 SEG curr_segment( zoneOutline->
CVertex( curr_idx ), zoneOutline->
CVertex( jj ) );
3268 nearestIdx = curr_idx;
3269 nextNearestIdx = jj;
3276 SEG nearestSide( sideOrigin, sideEnd );
3281 if( nearestPoint == sideOrigin || nearestPoint == sideEnd )
3282 nearestPoint = ( sideOrigin + sideEnd ) / 2;
3284 zoneOutline->
InsertVertex( nextNearestIdx, nearestPoint );
3287 static_cast<ZONE*
>( item )->HatchBorder();
3289 commit.
Push(
_(
"Add Zone Corner" ) );
3291 else if( graphicItem )
3297 commit.
Modify( graphicItem );
3303 graphicItem->
SetEnd( nearestPoint );
3308 newSegment->
SetStart( nearestPoint );
3311 commit.
Add( newSegment );
3312 commit.
Push(
_(
"Split Segment" ) );
3317 commit.
Modify( graphicItem );
3323 graphicItem->
SetEnd( nearestPoint );
3332 commit.
Add( newArc );
3333 commit.
Push(
_(
"Split Arc" ) );
3361 ZONE* zone =
static_cast<ZONE*
>( item );
3382 const auto& vertexIdx = vertex.second;
3383 auto& outline = polygon->
Polygon( vertexIdx.m_polygon )[vertexIdx.m_contour];
3385 if( outline.PointCount() > 3 )
3394 if( vertexIdx.m_contour > 0 )
3410 commit.
Push(
_(
"Remove Zone Corner" ) );
3412 commit.
Push(
_(
"Remove Polygon Corner" ) );
3415 static_cast<ZONE*
>( item )->HatchBorder();
3438 ZONE* zone =
static_cast<ZONE*
>( item );
3459 unsigned int nearestIdx = 0;
3460 unsigned int nearestDist = INT_MAX;
3468 for( ; iterator; iterator++, curr_idx++ )
3475 nearestIdx = curr_idx;
3479 int prevIdx, nextIdx;
3487 setback = std::min( setback, (
int) ( segA.Length() * 0.25 ) );
3488 setback = std::min( setback, (
int) ( segB.Length() * 0.25 ) );
3492 std::optional<CHAMFER_RESULT> chamferResult =
ComputeChamferPoints( segA, segB, chamferParams );
3494 if( chamferResult && chamferResult->m_updated_seg_a && chamferResult->m_updated_seg_b )
3500 polygon->
InsertVertex( nearestIdx, chamferResult->m_updated_seg_b->B );
3501 polygon->
InsertVertex( nearestIdx, chamferResult->m_updated_seg_a->B );
3508 commit.
Push(
_(
"Break Zone Corner" ) );
3510 commit.
Push(
_(
"Break Polygon Corner" ) );
3513 static_cast<ZONE*
>( item )->HatchBorder();
ARC_EDIT_MODE
Settings for arc editing.
@ KEEP_CENTER_ADJUST_ANGLE_RADIUS
When editing endpoints, the angle and radius are adjusted.
constexpr EDA_IU_SCALE pcbIUScale
constexpr BOX2I KiROUND(const BOX2D &aBoxD)
static TOOL_ACTION cycleArcEditMode
static TOOL_ACTION pointEditorArcKeepCenter
static TOOL_ACTION pointEditorArcKeepRadius
static TOOL_ACTION reselectItem
static TOOL_ACTION activatePointEditor
static TOOL_ACTION selectionClear
Clear the current selection.
static TOOL_ACTION pointEditorArcKeepEndpoint
PCB_DIM_ALIGNED & m_dimension
void updateOrthogonalDimension(const EDIT_POINT &aEditedPoint, EDIT_POINTS &aPoints)
Update orthogonal dimension points.
ALIGNED_DIMENSION_POINT_EDIT_BEHAVIOR(PCB_DIM_ALIGNED &aDimension)
void updateAlignedDimension(const EDIT_POINT &aEditedPoint, EDIT_POINTS &aPoints)
Update non-orthogonal dimension points.
void MakePoints(EDIT_POINTS &aPoints) override
Construct the initial set of edit points for the item and append to the given list.
void UpdateItem(const EDIT_POINT &aEditedPoint, EDIT_POINTS &aPoints, COMMIT &aCommit, std::vector< EDA_ITEM * > &aUpdatedItems) override
Update the item with the new positions of the edit points.
OPT_VECTOR2I Get45DegreeConstrainer(const EDIT_POINT &aEditedPoint, EDIT_POINTS &aPoints) const override
Get the 45-degree constrainer for the item, when the given point is moved.
bool UpdatePoints(EDIT_POINTS &aPoints) override
Update the list of the edit points for the item.
bool UpdatePoints(EDIT_POINTS &aPoints) override
Update the list of the edit points for the item.
BARCODE_POINT_EDIT_BEHAVIOR(PCB_BARCODE &aBarcode)
void MakePoints(EDIT_POINTS &aPoints) override
Construct the initial set of edit points for the item and append to the given list.
PCB_SHAPE makeDummyRect()
void UpdateItem(const EDIT_POINT &aEditedPoint, EDIT_POINTS &aPoints, COMMIT &aCommit, std::vector< EDA_ITEM * > &aUpdatedItems) override
Update the item with the new positions of the edit points.
virtual void Push(const wxString &aMessage=wxEmptyString, int aCommitFlags=0) override
Execute the changes.
COMMIT & Stage(EDA_ITEM *aItem, CHANGE_TYPE aChangeType, BASE_SCREEN *aScreen=nullptr, RECURSE_MODE aRecurse=RECURSE_MODE::NO_RECURSE) override
Add a change of the item aItem of type aChangeType to the change list.
virtual void Revert() override
Revert the commit by restoring the modified items state.
A base class for any item which can be embedded within the BOARD container class, and therefore insta...
virtual BOARD_ITEM * Duplicate(bool addToParentGroup, BOARD_COMMIT *aCommit=nullptr) const
Create a copy of this BOARD_ITEM.
bool IsLocked() const override
FOOTPRINT * GetParentFootprint() const
virtual LSET GetLayerSet() const
Return a std::bitset of all layers on which the item physically resides.
constexpr void SetMaximum()
constexpr const Vec GetEnd() const
constexpr size_type GetWidth() const
constexpr Vec Centre() const
constexpr BOX2< Vec > & Merge(const BOX2< Vec > &aRect)
Modify the position and size of the rectangle in order to contain aRect.
constexpr size_type GetHeight() const
constexpr coord_type GetLeft() const
constexpr bool Contains(const Vec &aPoint) const
constexpr const Vec & GetOrigin() const
constexpr coord_type GetRight() const
constexpr coord_type GetTop() const
constexpr coord_type GetBottom() const
Represent a set of changes (additions, deletions or modifications) of a data model (e....
COMMIT & Remove(EDA_ITEM *aItem, BASE_SCREEN *aScreen=nullptr)
Remove a new item from the model.
COMMIT & Modify(EDA_ITEM *aItem, BASE_SCREEN *aScreen=nullptr, RECURSE_MODE aRecurse=RECURSE_MODE::NO_RECURSE)
Modify a given item in the model.
COMMIT & Add(EDA_ITEM *aItem, BASE_SCREEN *aScreen=nullptr)
Add a new item to the model.
Class to help update the text position of a dimension when the crossbar changes.
DIM_ALIGNED_TEXT_UPDATER(PCB_DIM_ALIGNED &aDimension)
VECTOR2I getDimensionNewTextPosition()
PCB_DIM_ALIGNED & m_dimension
const VECTOR2I m_originalTextPos
void UpdateTextAfterChange()
void MakePoints(EDIT_POINTS &aPoints) override
Construct the initial set of edit points for the item and append to the given list.
PCB_DIM_CENTER & m_dimension
OPT_VECTOR2I Get45DegreeConstrainer(const EDIT_POINT &aEditedPoint, EDIT_POINTS &aPoints) const override
Get the 45-degree constrainer for the item, when the given point is moved.
void UpdateItem(const EDIT_POINT &aEditedPoint, EDIT_POINTS &aPoints, COMMIT &aCommit, std::vector< EDA_ITEM * > &aUpdatedItems) override
Update the item with the new positions of the edit points.
bool UpdatePoints(EDIT_POINTS &aPoints) override
Update the list of the edit points for the item.
DIM_CENTER_POINT_EDIT_BEHAVIOR(PCB_DIM_CENTER &aDimension)
DIM_LEADER_POINT_EDIT_BEHAVIOR(PCB_DIM_LEADER &aDimension)
void MakePoints(EDIT_POINTS &aPoints) override
Construct the initial set of edit points for the item and append to the given list.
PCB_DIM_LEADER & m_dimension
void UpdateItem(const EDIT_POINT &aEditedPoint, EDIT_POINTS &aPoints, COMMIT &aCommit, std::vector< EDA_ITEM * > &aUpdatedItems) override
Update the item with the new positions of the edit points.
bool UpdatePoints(EDIT_POINTS &aPoints) override
Update the list of the edit points for the item.
DIM_RADIAL_POINT_EDIT_BEHAVIOR(PCB_DIM_RADIAL &aDimension)
void MakePoints(EDIT_POINTS &aPoints) override
Construct the initial set of edit points for the item and append to the given list.
void UpdateItem(const EDIT_POINT &aEditedPoint, EDIT_POINTS &aPoints, COMMIT &aCommit, std::vector< EDA_ITEM * > &aUpdatedItems) override
Update the item with the new positions of the edit points.
bool UpdatePoints(EDIT_POINTS &aPoints) override
Update the list of the edit points for the item.
OPT_VECTOR2I Get45DegreeConstrainer(const EDIT_POINT &aEditedPoint, EDIT_POINTS &aPoints) const override
Get the 45-degree constrainer for the item, when the given point is moved.
PCB_DIM_RADIAL & m_dimension
EDIT_CONSTRAINT that imposes a constraint that two points have to be located at angle of 45 degree mu...
EDIT_CONSTRAINT that imposes a constraint that a point has to be located at angle of 90 degree multip...
EDIT_CONSTRAINT for polygon line dragging.
const VECTOR2I & GetPerpVector() const
Perpendicular direction of motion for the dragged line, captured at drag start.
POLYGON_LINE_MODE GetMode() const
Get the current constraint mode.
const VECTOR2I & GetOriginalCenter() const
Original center of the dragged line, captured at drag start.
void SetMode(POLYGON_LINE_MODE aMode)
Set the constraint mode (allows switching between converging and fixed-length)
EDIT_CONSTRAINT that imposes a constraint that two points have to have the same Y coordinate.
EDIT_CONSTRAINT that imposes a constraint that a point has to lie on a line (determined by 2 points).
EDIT_CONSTRAINT for a EDIT_LINE, that constrains the line to move perpendicular to the line itself.
EDIT_CONSTRAINT that imposes a constraint that two points have to have the same X coordinate.
bool IsType(FRAME_T aType) const
A base class for most all the KiCad significant classes used in schematics and boards.
KICAD_T Type() const
Returns the type of object.
virtual EDA_ITEM * Clone() const
Create a duplicate of this item with linked list members set to NULL.
virtual void SetParent(EDA_ITEM *aParent)
EDA_ITEM(EDA_ITEM *parent, KICAD_T idType, bool isSCH_ITEM=false, bool isBOARD_ITEM=false)
virtual VECTOR2I GetTopLeft() const
void SetCornerRadius(int aRadius)
SHAPE_POLY_SET & GetPolyShape()
virtual VECTOR2I GetBotRight() const
virtual void SetBottom(int val)
virtual void SetTop(int val)
const VECTOR2I & GetEnd() const
Return the ending point of the graphic.
const VECTOR2I & GetStart() const
Return the starting point of the graphic.
virtual void SetLeft(int val)
virtual void SetRight(int val)
int GetCornerRadius() const
VECTOR2I GetArcMid() const
EDA_TABLECELL_POINT_EDIT_BEHAVIOR(EDA_SHAPE &aCell)
Describe constraints between two edit handles.
Represent a line connecting two EDIT_POINTs.
void SetConstraint(EDIT_CONSTRAINT< EDIT_LINE > *aConstraint)
Set a constraint for and EDIT_POINT.
EDIT_CONSTRAINT< EDIT_LINE > * GetConstraint() const
Return the constraint imposed on an EDIT_POINT.
EDIT_POINTS is a VIEW_ITEM that manages EDIT_POINTs and EDIT_LINEs and draws them.
unsigned int PointsSize() const
Return number of stored EDIT_POINTs.
void AddPoint(const EDIT_POINT &aPoint)
Add an EDIT_POINT.
void SetSwapY(bool aSwap)
void Clear()
Clear all stored EDIT_POINTs and EDIT_LINEs.
EDIT_LINE & Line(unsigned int aIndex)
void AddIndicatorLine(EDIT_POINT &aOrigin, EDIT_POINT &aEnd)
Adds an EDIT_LINE that is shown as an indicator, rather than an editable line (no center point drag,...
void SetSwapX(bool aSwap)
unsigned int LinesSize() const
Return number of stored EDIT_LINEs.
EDIT_POINT & Point(unsigned int aIndex)
void AddLine(const EDIT_LINE &aLine)
Adds an EDIT_LINE.
Represent a single point that can be used for modifying items.
int GetY() const
Return Y coordinate of an EDIT_POINT.
virtual void SetPosition(const VECTOR2I &aPosition)
Set new coordinates for an EDIT_POINT.
virtual VECTOR2I GetPosition() const
Return coordinates of an EDIT_POINT.
void SetSnapConstraint(SNAP_CONSTRAINT_TYPE aConstraint)
void SetConstraint(EDIT_CONSTRAINT< EDIT_POINT > *aConstraint)
Set a constraint for an EDIT_POINT.
int GetX() const
Return X coordinate of an EDIT_POINT.
void SetActive(bool aActive=true)
void SetDrawCircle(bool aDrawCircle=true)
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
bool UpdatePoints(EDIT_POINTS &aPoints) override
Update the list of the edit points for the item.
PCB_GENERATOR & m_generator
void UpdateItem(const EDIT_POINT &aEditedPoint, EDIT_POINTS &aPoints, COMMIT &aCommit, std::vector< EDA_ITEM * > &aUpdatedItems) override
Update the item with the new positions of the edit points.
GENERATOR_POINT_EDIT_BEHAVIOR(PCB_GENERATOR &aGenerator)
void MakePoints(EDIT_POINTS &aPoints) override
Construct the initial set of edit points for the item and append to the given list.
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...
An interface for classes handling user events controlling the view behavior such as zooming,...
virtual void ForceCursorPosition(bool aEnabled, const VECTOR2D &aPosition=VECTOR2D(0, 0))
Place the cursor immediately at a given point.
virtual void ShowCursor(bool aEnabled)
Enable or disables display of cursor.
VECTOR2D GetCursorPosition() const
Return the current cursor position in world coordinates.
virtual void SetAutoPan(bool aEnabled)
Turn on/off auto panning (this feature is used when there is a tool active (eg.
Hold a (potentially large) number of VIEW_ITEMs and renders them on a graphics device provided by the...
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.
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...
LSET is a set of PCB_LAYER_IDs.
static const LSET & AllLayersMask()
static constexpr PCB_LAYER_ID ALL_LAYERS
! Temporary layer identifier to identify code that is not padstack-aware
void MakePoints(EDIT_POINTS &aPoints) override
Construct the initial set of edit points for the item and append to the given list.
void UpdateItem(const EDIT_POINT &aEditedPoint, EDIT_POINTS &aPoints, COMMIT &aCommit, std::vector< EDA_ITEM * > &aUpdatedItems) override
Update the item with the new positions of the edit points.
bool UpdatePoints(EDIT_POINTS &aPoints) override
Update the list of the edit points for the item.
PAD_POINT_EDIT_BEHAVIOR(PAD &aPad, PCB_LAYER_ID aLayer)
ARC_EDIT_MODE m_ArcEditMode
static TOOL_ACTION layerChanged
static TOOL_ACTION pointEditorMoveMidpoint
static TOOL_ACTION genFinishEdit
static TOOL_ACTION genStartEdit
static TOOL_ACTION pointEditorMoveCorner
static TOOL_ACTION genCancelEdit
static TOOL_ACTION genUpdateEdit
static TOOL_ACTION pointEditorChamferCorner
static TOOL_ACTION pointEditorRemoveCorner
static TOOL_ACTION pointEditorAddCorner
Common, abstract interface for edit frames.
Base PCB main window class for Pcbnew, Gerbview, and CvPcb footprint viewer.
PCBNEW_SETTINGS * GetPcbNewSettings() const
virtual MAGNETIC_SETTINGS * GetMagneticItemsSettings()
FOOTPRINT_EDITOR_SETTINGS * GetFootprintEditorSettings() const
For better understanding of the points that make a dimension:
Mark the center of a circle or arc with a cross shape.
A leader is a dimension-like object pointing to a specific point.
An orthogonal dimension is like an aligned dimension, but the extension lines are locked to the X or ...
void SetOrientation(DIR aOrientation)
Set the orientation of the dimension line (so, perpendicular to the feature lines).
DIR GetOrientation() const
A radial dimension indicates either the radius or diameter of an arc or circle.
virtual wxString GetCommitMessage() const =0
A set of BOARD_ITEMs (i.e., without duplicates).
std::unordered_set< BOARD_ITEM * > GetBoardItems() const
int changeArcEditMode(const TOOL_EVENT &aEvent)
bool CanRemoveCorner(const SELECTION &aSelection)
Condition to display "Remove Corner" context menu entry.
void updateItem(BOARD_COMMIT &aCommit)
Update edit points with item's points.
VECTOR2I m_stickyDisplacement
int OnSelectionChange(const TOOL_EVENT &aEvent)
Change selection event handler.
void setAltConstraint(bool aEnabled)
Return a point that should be used as a constrainer for 45 degrees mode.
static const unsigned int COORDS_PADDING
EDIT_POINT * m_hoveredPoint
int addCorner(const TOOL_EVENT &aEvent)
bool HasPoint()
Indicate the cursor is over an edit point.
EDIT_POINT m_original
Original pos for the current drag point.
static bool CanChamferCorner(const EDA_ITEM &aItem)
Check if a corner of the given item can be chamfered (zones, polys only).
EDIT_POINT get45DegConstrainer() const
int modifiedSelection(const TOOL_EVENT &aEvent)
Change the edit method for arcs.
void Reset(RESET_REASON aReason) override
Bring the tool to a known, initial state.
std::unique_ptr< POINT_EDIT_BEHAVIOR > m_editorBehavior
int removeCorner(const TOOL_EVENT &aEvent)
bool Init() override
Init() is called once upon a registration of the tool.
RECT_RADIUS_TEXT_ITEM * m_radiusHelper
int movePoint(const TOOL_EVENT &aEvent)
TOOL_ACTION handlers.
static bool CanAddCorner(const EDA_ITEM &aItem)
Check if a corner can be added to the given item (zones, polys, segments, arcs).
void setEditedPoint(EDIT_POINT *aPoint)
EDIT_POINT m_altConstrainer
ARC_EDIT_MODE m_arcEditMode
std::unique_ptr< KIGFX::PREVIEW::ANGLE_ITEM > m_angleItem
EDIT_POINT * m_editedPoint
void updateEditedPoint(const TOOL_EVENT &aEvent)
Set the current point being edited. NULL means none.
std::shared_ptr< EDIT_CONSTRAINT< EDIT_POINT > > m_altConstraint
int getEditedPointIndex() const
Return true if aPoint is the currently modified point.
void updatePoints()
Update which point is being edited.
int chamferCorner(const TOOL_EVENT &aEvent)
void setTransitions() override
< Set up handlers for various events.
std::shared_ptr< EDIT_POINTS > m_editPoints
std::shared_ptr< EDIT_POINTS > makePoints(EDA_ITEM *aItem)
Update item's points with edit points.
PCB_SELECTION_TOOL * m_selectionTool
Object to handle a bitmap image that can be inserted in a PCB.
VECTOR2I GetCenter() const override
This defaults to the center of the bounding box if not overridden.
void SetEnd(const VECTOR2I &aEnd) override
bool IsProxyItem() const override
void Move(const VECTOR2I &aMoveVector) override
Move this object.
void SetStart(const VECTOR2I &aStart) override
PCB_TABLECELL_POINT_EDIT_BEHAVIOR(PCB_TABLECELL &aCell)
void UpdateItem(const EDIT_POINT &aEditedPoint, EDIT_POINTS &aPoints, COMMIT &aCommit, std::vector< EDA_ITEM * > &aUpdatedItems) override
Update the item with the new positions of the edit points.
A helper class interface to manage the edit points for a single item.
static bool isModified(const EDIT_POINT &aEditedPoint, const EDIT_POINT &aPoint)
Checks if two points are the same instance - which means the point is being edited.
POLYGON_POINT_EDIT_BEHAVIOR(SHAPE_POLY_SET &aPolygon)
void UpdateItem(const EDIT_POINT &aEditedPoint, EDIT_POINTS &aPoints, COMMIT &aCommit, std::vector< EDA_ITEM * > &aUpdatedItems) override
Update the item with the new positions of the edit points.
static void UpdateItem(SCH_SHAPE &aRect, const EDIT_POINT &aEditedPoint, EDIT_POINTS &aPoints, const VECTOR2I &aMinSize={ 0, 0 })
bool UpdatePoints(EDIT_POINTS &aPoints) override
Update the list of the edit points for the item.
static void UpdateItem(PCB_SHAPE &aRectangle, const EDIT_POINT &aEditedPoint, EDIT_POINTS &aPoints, const VECTOR2I &aMinSize={ 0, 0 })
static void UpdatePoints(SCH_SHAPE &aRect, EDIT_POINTS &aPoints)
static void PinEditedCorner(const EDIT_POINT &aEditedPoint, const EDIT_POINTS &aPoints, int minWidth, int minHeight, VECTOR2I &topLeft, VECTOR2I &topRight, VECTOR2I &botLeft, VECTOR2I &botRight)
Update the coordinates of 4 corners of a rectangle, according to constraints and the moved corner.
static void PinEditedCorner(const EDIT_POINT &aEditedPoint, const EDIT_POINTS &aEditPoints, VECTOR2I &aTopLeft, VECTOR2I &aTopRight, VECTOR2I &aBotLeft, VECTOR2I &aBotRight, const VECTOR2I &aHole={ 0, 0 }, const VECTOR2I &aHoleSize={ 0, 0 }, const VECTOR2I &aMinSize={ 0, 0 })
Update the coordinates of 4 corners of a rectangle, according to constraints and the moved corner.
static void MakePoints(SCH_SHAPE &aRect, EDIT_POINTS &aPoints)
void UpdateItem(const EDIT_POINT &aEditedPoint, EDIT_POINTS &aPoints, COMMIT &aCommit, std::vector< EDA_ITEM * > &aUpdatedItems) override
Update the item with the new positions of the edit points.
void MakePoints(EDIT_POINTS &aPoints) override
Construct the initial set of edit points for the item and append to the given list.
static void MakePoints(const PCB_SHAPE &aRectangle, EDIT_POINTS &aPoints)
Standard rectangle points construction utility (other shapes may use this as well)
static void UpdatePoints(const PCB_SHAPE &aRectangle, EDIT_POINTS &aPoints)
RECTANGLE_POINT_EDIT_BEHAVIOR(PCB_SHAPE &aRectangle)
const EDA_IU_SCALE & m_iuScale
wxString GetClass() const override
Return the class name.
std::vector< int > ViewGetLayers() const override
Return the all the layers within the VIEW the object is painted on.
const BOX2I ViewBBox() const override
Return the bounding box of the item covering all its layers.
void Set(int aRadius, const VECTOR2I &aCorner, const VECTOR2I &aQuadrant, EDA_UNITS aUnits)
RECT_RADIUS_TEXT_ITEM(const EDA_IU_SCALE &aIuScale, EDA_UNITS aUnits)
void ViewDraw(int aLayer, KIGFX::VIEW *aView) const override
Draw the parts of the object belonging to layer aLayer.
REFERENCE_IMAGE_POINT_EDIT_BEHAVIOR(PCB_REFERENCE_IMAGE &aRefImage)
bool UpdatePoints(EDIT_POINTS &aPoints) override
Update the list of the edit points for the item.
void MakePoints(EDIT_POINTS &aPoints) override
Construct the initial set of edit points for the item and append to the given list.
void UpdateItem(const EDIT_POINT &aEditedPoint, EDIT_POINTS &aPoints, COMMIT &aCommit, std::vector< EDA_ITEM * > &aUpdatedItems) override
Update the item with the new positions of the edit points.
PCB_REFERENCE_IMAGE & m_refImage
A REFERENCE_IMAGE is a wrapper around a BITMAP_IMAGE that is displayed in an editor as a reference fo...
void SetTransformOriginOffset(const VECTOR2I &aCenter)
VECTOR2I GetTransformOriginOffset() const
Get the center of scaling, etc, relative to the image center (GetPosition()).
VECTOR2I GetPosition() const
double GetImageScale() const
void SetImageScale(double aScale)
Set the image "zoom" value.
const VECTOR2I NearestPoint(const VECTOR2I &aP) const
Compute a point on the segment (this) that is closest to point aP.
int Distance(const SEG &aSeg) const
Compute minimum Euclidean distance to segment aSeg.
EDA_ANGLE Angle(const SEG &aOther) const
Determine the smallest angle between two segments.
Class that groups generic conditions for selected items.
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.
VECTOR2I NearestPoint(const VECTOR2I &aP) const
const VECTOR2I & GetP1() const
SHAPE_GROUP_POINT_EDIT_BEHAVIOR(PCB_GROUP &aGroup)
SHAPE_GROUP_POINT_EDIT_BEHAVIOR(std::vector< PCB_SHAPE * > aShapes, BOARD_ITEM *aParent)
BOARD_ITEM * GetParent() const
void MakePoints(EDIT_POINTS &aPoints) override
Construct the initial set of edit points for the item and append to the given list.
std::unordered_map< PCB_SHAPE *, double > m_originalWidths
std::vector< PCB_SHAPE * > m_shapes
void UpdateItem(const EDIT_POINT &aEditedPoint, EDIT_POINTS &aPoints, COMMIT &aCommit, std::vector< EDA_ITEM * > &aUpdatedItems) override
Update the item with the new positions of the edit points.
bool UpdatePoints(EDIT_POINTS &aPoints) override
Update the list of the edit points for the item.
BOX2I getBoundingBox() const
bool IsEndContour() const
Represent a set of closed polygons.
ITERATOR_TEMPLATE< VECTOR2I > ITERATOR
ITERATOR IterateWithHoles(int aOutline)
void InsertVertex(int aGlobalIndex, const VECTOR2I &aNewVertex)
Adds a vertex in the globally indexed position aGlobalIndex.
POLYGON & Polygon(int aIndex)
Return the aIndex-th subpolygon in the set.
void RemoveVertex(int aGlobalIndex)
Delete the aGlobalIndex-th vertex.
void RemoveContour(int aContourIdx, int aPolygonIdx=-1)
Delete the aContourIdx-th contour of the aPolygonIdx-th polygon in the set.
bool GetNeighbourIndexes(int aGlobalIndex, int *aPrevious, int *aNext) const
Return the global indexes of the previous and the next corner of the aGlobalIndex-th corner of a cont...
ITERATOR Iterate(int aFirst, int aLast, bool aIterateHoles=false)
Return an object to iterate through the points of the polygons between aFirst and aLast.
const VECTOR2I & CVertex(int aIndex, int aOutline, int aHole) const
Return the index-th vertex in a given hole outline within a given outline.
int OutlineCount() const
Return the number of outlines in the set.
A textbox is edited as a rectnagle when it is orthogonally aligned.
TEXTBOX_POINT_EDIT_BEHAVIOR(PCB_TEXTBOX &aTextbox)
void MakePoints(EDIT_POINTS &aPoints) override
Construct the initial set of edit points for the item and append to the given list.
bool UpdatePoints(EDIT_POINTS &aPoints) override
Update the list of the edit points for the item.
void UpdateItem(const EDIT_POINT &aEditedPoint, EDIT_POINTS &aPoints, COMMIT &aCommit, std::vector< EDA_ITEM * > &aUpdatedItems) override
Update the item with the new positions of the edit points.
EDA_UNITS GetUserUnits() const
constexpr extended_type Cross(const VECTOR2< T > &aVector) const
Compute cross product of self with aVector.
double Distance(const VECTOR2< extended_type > &aVector) const
Compute the distance between two vectors.
T EuclideanNorm() const
Compute the Euclidean norm of the vector, which is defined as sqrt(x ** 2 + y ** 2).
constexpr extended_type Dot(const VECTOR2< T > &aVector) const
Compute dot product of self with aVector.
VECTOR2< T > Resize(T aNewLength) const
Return a vector of the same direction, but length specified in aNewLength.
VECTOR2I GetValue()
Return the value in internal units.
ZONE_POINT_EDIT_BEHAVIOR(ZONE &aZone)
void UpdateItem(const EDIT_POINT &aEditedPoint, EDIT_POINTS &aPoints, COMMIT &aCommit, std::vector< EDA_ITEM * > &aUpdatedItems) override
Update the item with the new positions of the edit points.
Handle a list of polygons defining a copper zone.
void SetNeedRefill(bool aNeedRefill)
SHAPE_POLY_SET * Outline()
This file is part of the common library.
std::optional< CHAMFER_RESULT > ComputeChamferPoints(const SEG &aSegA, const SEG &aSegB, const CHAMFER_PARAMS &aChamferParams)
Compute the chamfer points for a given line pair and chamfer parameters.
static constexpr double MIN_SCALE
const int minSize
Push and Shove router track width and via size dialog.
#define IS_MOVING
Item being moved.
@ RECTANGLE
Use RECTANGLE instead of RECT to avoid collision in a Windows header.
POLYGON_LINE_MODE
Mode for polygon line edge constraints.
@ CONVERGING
Adjacent lines converge/diverge, dragged line length changes.
@ FIXED_LENGTH
Dragged line maintains its length, adjacent lines adjust angles.
a few functions useful in geometry calculations.
VECTOR2< ret_type > GetClampedCoords(const VECTOR2< in_type > &aCoords, pad_type aPadding=1u)
Clamps a vector to values that can be negated, respecting numeric limits of coordinates data type wit...
bool IsFrontLayer(PCB_LAYER_ID aLayerId)
Layer classification: check if it's a front layer.
bool IsCopperLayer(int aLayerId)
Test whether a layer is a copper layer.
@ LAYER_GP_OVERLAY
General purpose overlay.
@ LAYER_SELECT_OVERLAY
Selected items overlay.
PCB_LAYER_ID
A quick note on layer IDs:
constexpr int Mils2IU(const EDA_IU_SCALE &aIuScale, int mils)
bool PointProjectsOntoSegment(const VECTOR2I &aPoint, const SEG &aSeg)
Determine if a point projects onto a segment.
double GetLengthRatioFromStart(const VECTOR2I &aPoint, const SEG &aSeg)
Get the ratio of the vector to a point from the segment's start, compared to the segment's length.
const VECTOR2I & GetNearestEndpoint(const SEG &aSeg, const VECTOR2I &aPoint)
Get the nearest end of a segment to a point.
bool PointIsInDirection(const VECTOR2< T > &aPoint, const VECTOR2< T > &aDirection, const VECTOR2< T > &aFrom)
void DrawTextNextToCursor(KIGFX::VIEW *aView, const VECTOR2D &aCursorPos, const VECTOR2D &aTextQuadrant, const wxArrayString &aStrings, bool aDrawingDropShadows)
Draw strings next to the cursor.
wxString DimensionLabel(const wxString &prefix, double aVal, const EDA_IU_SCALE &aIuScale, EDA_UNITS aUnits, bool aIncludeUnits=true)
Get a formatted string showing a dimension to a sane precision with an optional prefix and unit suffi...
EDA_ANGLE abs(const EDA_ANGLE &aAngle)
BARCODE class definition.
@ MANUAL
Text placement is manually set by the user.
#define STATUS_ITEMS_ONLY
Class to handle a set of BOARD_ITEMs.
static VECTOR2I snapCorner(const VECTOR2I &aPrev, const VECTOR2I &aNext, const VECTOR2I &aGuess, double aAngleDeg)
static std::pair< bool, SHAPE_POLY_SET::VERTEX_INDEX > findVertex(SHAPE_POLY_SET &aPolySet, const EDIT_POINT &aPoint)
static std::vector< VECTOR2I > getConstraintDirections(EDIT_CONSTRAINT< EDIT_POINT > *aConstraint)
static void appendDirection(std::vector< VECTOR2I > &aDirections, const VECTOR2I &aDirection)
ARC_EDIT_MODE IncrementArcEditMode(ARC_EDIT_MODE aMode)
#define CHECK_POINT_COUNT(aPoints, aExpected)
#define CHECK_POINT_COUNT_GE(aPoints, aExpected)
static float distance(const SFVEC2UI &a, const SFVEC2UI &b)
std::optional< VECTOR2I > OPT_VECTOR2I
std::vector< FAB_LAYER_COLOR > dummy
Parameters that define a simple chamfer operation.
Structure to hold the necessary information in order to index a vertex on a SHAPE_POLY_SET object: th...
KIBIS top(path, &reporter)
std::vector< std::vector< std::string > > table
GR_TEXT_H_ALIGN_T
This is API surface mapped to common.types.HorizontalAlignment.
VECTOR2I GetRotated(const VECTOR2I &aVector, const EDA_ANGLE &aAngle)
Return a new VECTOR2I that is the result of rotating aVector by aAngle.
void RotatePoint(int *pX, int *pY, const EDA_ANGLE &aAngle)
Calculate the new point of coord coord pX, pY, for a rotation center 0, 0.
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_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_REFERENCE_IMAGE_T
class PCB_REFERENCE_IMAGE, bitmap on a layer
@ NOT_USED
the 3d code uses this value
@ PCB_BARCODE_T
class PCB_BARCODE, a barcode (graphic item)
@ PCB_TABLECELL_T
class PCB_TABLECELL, PCB_TEXTBOX for use in tables
@ PCB_DIM_ALIGNED_T
class PCB_DIM_ALIGNED, a linear dimension (graphic item)
@ PCB_PAD_T
class PAD, a pad in a footprint
@ PCB_DIM_RADIAL_T
class PCB_DIM_RADIAL, a radius or diameter dimension
constexpr int sign(T val)
VECTOR2< int32_t > VECTOR2I
VECTOR2< double > VECTOR2D
Supplemental functions for working with vectors and simple objects that interact with vectors.