207 int originalLayer = aLayer;
225 const PAD*
pad =
dynamic_cast<const PAD*
>( aItem );
227 int holeLayer = aLayer;
234 if( !copperLayers.empty() )
235 annularRingLayer = copperLayers.
Seq().front();
239 annularRingLayer =
F_Cu;
268 const PAD*
pad =
static_cast<const PAD*
>( aItem );
271 if(
pcbconfig()->m_Display.m_UseViaColorForNormalTHPadstacks
315 if( visibleLayers.any() )
316 aLayer = visibleLayers.
Seq().back();
336 return itemLayerIter->second;
376 netColor = ii->second;
427 switch( originalLayer )
431 const PAD*
pad =
static_cast<const PAD*
>( aItem );
433 if(
pad->IsOnLayer( primary ) && !
pad->FlashLayer( primary ) )
454 if(
via->GetLayerSet().test( primary ) == 0 )
467 if( !
via->FlashLayer( primary ) )
501 if(
via->GetLayerSet().test( primary ) == 0 )
537 color = color.
Mix( it->second, dim_factor_Edge_Cuts );
550 color = color.
Mix( backgroundColor, dim_factor_Edge_Cuts );
566 const BOARD* board =
via->GetBoard();
570 if( (
via->GetLayerSet() & visibleLayers ).none() )
621 if( aActualThickness == 0 )
624 return aActualThickness;
694 switch( item->
Type() )
701 draw(
static_cast<const PCB_ARC*
>( item ), aLayer );
705 draw(
static_cast<const PCB_VIA*
>( item ), aLayer );
709 draw(
static_cast<const PAD*
>( item ), aLayer );
745 draw(
static_cast<const ZONE*
>( item ), aLayer );
787 m_gal->SetIsFill(
false );
788 m_gal->SetIsStroke(
true );
801 m_gal->SetLineWidth( 1 );
828 int track_width = aTrack->
GetWidth();
839 if( netinfo->GetNetChain() ==
m_pcbSettings.m_highlightedNetChain )
844 board->GetNetChainColor(
m_pcbSettings.m_highlightedNetChain );
872 m_gal->SetStrokeColor( color );
873 m_gal->SetFillColor( color );
874 m_gal->SetIsStroke( outline_mode );
875 m_gal->SetIsFill( not outline_mode );
884 m_gal->DrawSegment( start,
end, track_width );
897 m_gal->SetIsFill(
false );
898 m_gal->SetIsStroke(
true );
899 m_gal->SetStrokeColor( color );
906 const wxString& aNetName )
const
917 int num_char = aNetName.size();
920 int seg_minlength = aSeg.
GetWidth() * num_char;
927 double penWidth = textSize / 12.0;
935 if(
end.y == start.
y )
940 else if(
end.x == start.
x )
951 num_names = std::max( num_names,
KiROUND( aSeg.
GetSeg().
Length() / ( M_SQRT2 * min_size ) ) );
954 m_gal->SetIsStroke(
true );
955 m_gal->SetIsFill(
false );
956 m_gal->SetStrokeColor( aColor );
957 m_gal->SetLineWidth( penWidth );
958 m_gal->SetFontBold(
false );
959 m_gal->SetFontItalic(
false );
960 m_gal->SetFontUnderlined(
false );
961 m_gal->SetTextMirrored(
false );
962 m_gal->SetGlyphSize(
VECTOR2D( textSize * 0.55, textSize * 0.55 ) );
966 int divisions = num_names + 1;
968 for(
int ii = 1; ii < divisions; ++ii )
970 VECTOR2I textPosition = start + segV * ( (double) ii / divisions );
972 if( viewport.
Contains( textPosition ) )
973 m_gal->BitmapText( aNetName, textPosition, textOrientation );
997 if( netname.IsEmpty() )
1003 if( arcLen < (
double) width * (
double) netname.size() )
1010 textOrientation = -textOrientation;
1013 double textSize = width;
1014 double penWidth = textSize / 12.0;
1016 m_gal->SetIsStroke(
true );
1017 m_gal->SetIsFill(
false );
1018 m_gal->SetStrokeColor( color );
1019 m_gal->SetLineWidth( penWidth );
1020 m_gal->SetFontBold(
false );
1021 m_gal->SetFontItalic(
false );
1022 m_gal->SetFontUnderlined(
false );
1023 m_gal->SetTextMirrored(
false );
1024 m_gal->SetGlyphSize(
VECTOR2D( textSize * 0.55, textSize * 0.55 ) );
1028 m_gal->BitmapText( netname, midPt, textOrientation );
1037 m_gal->SetStrokeColor( color );
1038 m_gal->SetFillColor( color );
1039 m_gal->SetIsStroke( outline_mode );
1040 m_gal->SetIsFill( not outline_mode );
1070 m_gal->SetIsFill(
false );
1071 m_gal->SetIsStroke(
true );
1072 m_gal->SetStrokeColor( color );
1087 m_gal->SetIsFill(
false );
1088 m_gal->SetIsStroke(
true );
1090 m_gal->DrawPolygon( cornerBuffer );
1097 m_gal->SetIsFill(
false );
1098 m_gal->SetIsStroke(
true );
1111 m_gal->SetIsFill(
false );
1112 m_gal->SetIsStroke(
true );
1113 m_gal->SetStrokeColor(
COLOR4D( 0.3, 0.2, 0.5, 1.0 ) );
1115 for(
int idx = 1; idx < arcSpine.
PointCount(); idx++ )
1137 if( netinfo->GetNetChain() ==
m_pcbSettings.m_highlightedNetChain )
1152 aVia->
LayerPair( &layerTop, &layerBottom );
1158 && ( layerTop !=
F_Cu || layerBottom !=
B_Cu ) );
1170 if( !showNets && !showLayers )
1174 double size = aVia->
GetWidth( currentLayer );
1177 if( size > maxSize )
1181 m_gal->Translate( position );
1184 m_gal->ResetTextAttributes();
1187 m_gal->SetFontBold(
false );
1188 m_gal->SetFontItalic(
false );
1189 m_gal->SetFontUnderlined(
false );
1190 m_gal->SetTextMirrored(
false );
1192 m_gal->SetIsStroke(
true );
1193 m_gal->SetIsFill(
false );
1207 switch( topLayerId )
1209 case F_Cu: topLayer = 1;
break;
1211 default: topLayer = (topLayerId -
B_Cu)/2 + 1;
break;
1214 switch( bottomLayerId )
1216 case F_Cu: bottomLayer = 1;
break;
1218 default: bottomLayer = (bottomLayerId -
B_Cu)/2 + 1;
break;
1222#if wxUSE_UNICODE_WCHAR
1223 layerIds << std::to_wstring( topLayer ) <<
L'-' << std::to_wstring( bottomLayer );
1225 layerIds << std::to_string( topLayer ) <<
'-' << std::to_string( bottomLayer );
1231 int minCharCnt = showLayers ? 6 : 3;
1235 tsize = std::min( tsize, size );
1242 if( showLayers && showNets )
1243 textpos.
y += ( tsize * 1.3 )/ 2;
1245 m_gal->SetGlyphSize( namesize );
1246 m_gal->SetLineWidth( namesize.
x / 10.0 );
1254 textpos.
y -= tsize * 1.3;
1266 m_gal->SetStrokeColor( color );
1267 m_gal->SetFillColor( color );
1268 m_gal->SetIsStroke(
true );
1269 m_gal->SetIsFill(
false );
1279 double maxRadius = aVia->
GetWidth( layerTop ) / 2.0;
1280 double radius = drillRadius + thickness;
1286 thickness =
radius - drillRadius;
1289 if( thickness <= 0 )
1294 m_gal->SetLineWidth( thickness );
1295 radius -= thickness / 2.0;
1299 m_gal->SetIsFill(
true );
1310 if( secDrill.value_or( 0 ) > 0 )
1317 if( terDrill.value_or( 0 ) > 0 )
1329 m_gal->SetIsStroke(
false );
1330 m_gal->SetIsFill(
true );
1334 m_gal->SetIsStroke(
false );
1335 m_gal->SetIsFill(
true );
1356 m_gal->SetIsFill(
true );
1357 m_gal->SetIsStroke(
false );
1359 m_gal->SetLineWidth( margin );
1386 m_gal->SetLineWidth( annular_width );
1387 radius -= annular_width / 2.0;
1415 if( aVia->
FlashLayer( copperLayerForClearance ) )
1421 m_gal->SetIsFill(
false );
1422 m_gal->SetIsStroke(
true );
1423 m_gal->SetStrokeColor( color );
1455 netname = wxT(
"x" );
1457 netname = wxT(
"*" );
1460 if( netname.IsEmpty() && padNumber.IsEmpty() )
1495 for(
const std::shared_ptr<PCB_SHAPE>& primitive : aPad->
GetPrimitives( pcbLayer ) )
1499 position = primitive->GetCenter();
1501 position += aPad->
ShapePos( pcbLayer );
1503 padsize.
x = abs( primitive->GetBotRight().x - primitive->GetTopLeft().x );
1504 padsize.
y = abs( primitive->GetBotRight().y - primitive->GetTopLeft().y );
1518 double limit = std::min( aPad->
GetSize( pcbLayer ).
x,
1519 aPad->
GetSize( pcbLayer ).
y ) * 1.1;
1521 if( padsize.
x > limit && padsize.
y > limit )
1529 double size = padsize.
y;
1532 m_gal->Translate( position );
1535 if( padsize.
x < ( padsize.
y * 0.95 ) )
1539 std::swap( padsize.
x, padsize.
y );
1543 if( size > maxSize )
1547 m_gal->ResetTextAttributes();
1550 m_gal->SetFontBold(
false );
1551 m_gal->SetFontItalic(
false );
1552 m_gal->SetFontUnderlined(
false );
1553 m_gal->SetTextMirrored(
false );
1555 m_gal->SetIsStroke(
true );
1556 m_gal->SetIsFill(
false );
1564 int Y_offset_numpad = 0;
1565 int Y_offset_netname = 0;
1567 if( !netname.IsEmpty() && !padNumber.IsEmpty() )
1571 Y_offset_netname = size / 1.4;
1573 Y_offset_numpad = size / 1.7;
1579 const double Xscale_for_stroked_font = 0.9;
1581 if( !netname.IsEmpty() )
1587 tsize = std::min( tsize, size );
1600 VECTOR2D namesize( tsize*Xscale_for_stroked_font, tsize );
1601 textpos.
y = std::min( tsize * 1.4,
double( Y_offset_netname ) );
1603 m_gal->SetGlyphSize( namesize );
1604 m_gal->SetLineWidth( namesize.
x / 6.0 );
1605 m_gal->SetFontBold(
true );
1609 if( !padNumber.IsEmpty() )
1614 tsize = std::min( tsize, size );
1618 tsize = std::min( tsize, size );
1619 VECTOR2D numsize( tsize*Xscale_for_stroked_font, tsize );
1620 textpos.
y = -Y_offset_numpad;
1622 m_gal->SetGlyphSize( numsize );
1623 m_gal->SetLineWidth( numsize.
x / 6.0 );
1624 m_gal->SetFontBold(
true );
1634 m_gal->SetIsFill(
true );
1635 m_gal->SetIsStroke(
false );
1638 lineWidth = std::min( lineWidth, aPad->
GetSizeX() / 2.0 );
1639 lineWidth = std::min( lineWidth, aPad->
GetSizeY() / 2.0 );
1641 m_gal->SetFillColor( color );
1642 m_gal->SetMinLineWidth( lineWidth );
1646 if( slot->GetSeg().A == slot->GetSeg().B )
1648 double holeRadius = slot->GetWidth() / 2.0;
1649 m_gal->DrawHoleWall( slot->GetSeg().A, holeRadius, lineWidth );
1653 int holeSize = slot->GetWidth() + ( 2 * lineWidth );
1654 m_gal->DrawSegment( slot->GetSeg().A, slot->GetSeg().B, holeSize );
1657 m_gal->SetMinLineWidth( 1.0 );
1663 VECTOR2I holePos = slot->GetSeg().A;
1667 if( secDrill.
x > 0 )
1674 if( terDrill.
x > 0 )
1688 outline_mode =
true;
1690 bool drawShape =
false;
1704 outline_mode =
true;
1709 outline_mode =
false;
1717 m_gal->SetIsFill(
false );
1718 m_gal->SetIsStroke(
true );
1720 m_gal->SetStrokeColor( color );
1725 m_gal->SetIsFill(
true );
1726 m_gal->SetIsStroke(
false );
1727 m_gal->SetFillColor( color );
1740 else if( drawShape )
1763 expansion.
x = expansion.
y = 0;
1777 margin = std::max( margin, getExpansion( layer ) );
1784 margin = getExpansion( pcbLayer );
1787 std::unique_ptr<PAD> dummyPad;
1788 std::shared_ptr<SHAPE_COMPOUND> shapes;
1791 bool simpleShapes = !outline_mode;
1797 simpleShapes =
false;
1803 && ( margin.
x < 0 || margin.
y < 0 ) ) )
1811 if( pad_size.
x + 2 * margin.
x <= 0 || pad_size.
y + 2 * margin.
y <= 0 )
1816 int initial_radius = dummyPad->GetRoundRectCornerRadius( pcbLayer );
1818 dummyPad->SetSize( pcbLayer, pad_size + margin + margin );
1824 int radius_margin = std::max( margin.
x, margin.
y );
1825 dummyPad->SetRoundRectCornerRadius(
1826 pcbLayer, std::max( initial_radius + radius_margin, 0 ) );
1829 shapes = std::dynamic_pointer_cast<SHAPE_COMPOUND>(
1830 dummyPad->GetEffectiveShape( pcbLayer ) );
1831 margin.
x = margin.
y = 0;
1835 shapes = std::dynamic_pointer_cast<SHAPE_COMPOUND>(
1849 simpleShapes =
false;
1852 for(
const SHAPE* shape : shapes->Shapes() )
1857 switch( shape->Type() )
1868 simpleShapes =
false;
1874 const auto drawOneSimpleShape =
1875 [&](
const SHAPE& aShape )
1877 switch( aShape.Type() )
1882 int effectiveWidth = seg.
GetWidth() + 2 * margin.
x;
1884 if( effectiveWidth > 0 )
1893 int effectiveRadius =
circle.GetRadius() + margin.
x;
1895 if( effectiveRadius > 0 )
1896 m_gal->DrawCircle(
circle.GetCenter(), effectiveRadius );
1907 if( effectiveMargin.
x < 0 )
1912 if( effectiveSize.
x > 0 && effectiveSize.
y > 0 )
1913 m_gal->DrawRectangle( pos - effectiveMargin, pos + effectiveSize );
1915 else if( effectiveMargin.
x > 0 )
1921 m_gal->DrawSegment( pos,
1923 effectiveMargin.
x * 2 );
1926 effectiveMargin.
x * 2 );
1929 effectiveMargin.
x * 2 );
1932 effectiveMargin.
x * 2 );
1954 for(
int ii = 0; ii < poly.
PointCount(); ++ii )
1959 m_gal->DrawPolygon( outline );
1972 m_gal->DrawSegment( seg.
A, seg.
B, margin.
x * 2 );
1987 for(
const SHAPE* shape : shapes->Shapes() )
1988 drawOneSimpleShape( *shape );
1995 m_gal->DrawPolygon( polySet );
2016 m_gal->SetIsStroke(
true );
2017 m_gal->SetIsFill(
false );
2018 m_gal->SetStrokeColor( color );
2024 auto shape = std::dynamic_pointer_cast<SHAPE_COMPOUND>( aPad->
GetEffectiveShape( pcbLayer ) );
2026 if( shape && shape->Size() == 1 && shape->Shapes()[0]->Type() ==
SH_SEGMENT )
2032 else if( shape && shape->Size() == 1 && shape->Shapes()[0]->Type() ==
SH_CIRCLE )
2046 m_gal->DrawPolygon( polySet );
2052 m_gal->DrawSegment( slot->GetSeg().A, slot->GetSeg().B,
2064 m_gal->SetIsFill(
false );
2065 m_gal->SetIsStroke(
true );
2080 board->GetNetChainColor(
m_pcbSettings.m_highlightedNetChain );
2083 termColor = chainColor;
2095 m_gal->SetStrokeColor( termColor );
2096 m_gal->SetLineWidth( baseWidth );
2104 int inset = baseWidth * 2;
2106 inner.
Inflate( -inset, -inset );
2140 isHatchedFill =
false;
2158 if( netname.IsEmpty() )
2185 m_gal->SetIsFill(
false );
2186 m_gal->SetIsStroke(
true );
2190 m_gal->SetFillColor( color );
2191 m_gal->SetStrokeColor( color );
2200 std::vector<VECTOR2I> pts;
2202 offset = offset.
Resize( thickness / 2 );
2204 pts.push_back( aShape->
GetStart() + offset );
2205 pts.push_back( aShape->
GetStart() - offset );
2206 pts.push_back( aShape->
GetEnd() - offset );
2207 pts.push_back( aShape->
GetEnd() + offset );
2210 m_gal->DrawLine( pts[0], pts[1] );
2211 m_gal->DrawLine( pts[1], pts[2] );
2212 m_gal->DrawLine( pts[2], pts[3] );
2213 m_gal->DrawLine( pts[3], pts[0] );
2214 m_gal->DrawLine( ( pts[0] + pts[1] ) / 2, ( pts[1] + pts[2] ) / 2 );
2215 m_gal->DrawLine( ( pts[1] + pts[2] ) / 2, ( pts[2] + pts[3] ) / 2 );
2216 m_gal->DrawLine( ( pts[2] + pts[3] ) / 2, ( pts[3] + pts[0] ) / 2 );
2217 m_gal->DrawLine( ( pts[3] + pts[0] ) / 2, ( pts[0] + pts[1] ) / 2 );
2219 else if( outline_mode )
2225 m_gal->SetIsFill(
true );
2226 m_gal->SetIsStroke(
false );
2249 m_gal->DrawPolygon( outline );
2251 else if( outline_mode )
2253 m_gal->DrawSegmentChain( outline, thickness );
2257 m_gal->SetIsFill(
true );
2258 m_gal->SetIsStroke(
false );
2262 m_gal->DrawSegmentChain( outline, thickness );
2271 m_gal->DrawPolygon( deflated_shape );
2275 m_gal->DrawPolygon( outline );
2287 m_gal->DrawLine( pts[0], pts[1] );
2288 m_gal->DrawLine( pts[1], pts[2] );
2289 m_gal->DrawLine( pts[2], pts[3] );
2290 m_gal->DrawLine( pts[3], pts[0] );
2291 m_gal->DrawLine( pts[0], pts[2] );
2292 m_gal->DrawLine( pts[1], pts[3] );
2294 else if( outline_mode )
2296 m_gal->DrawSegment( pts[0], pts[1], thickness );
2297 m_gal->DrawSegment( pts[1], pts[2], thickness );
2298 m_gal->DrawSegment( pts[2], pts[3], thickness );
2299 m_gal->DrawSegment( pts[3], pts[0], thickness );
2303 m_gal->SetIsFill(
true );
2304 m_gal->SetIsStroke(
false );
2308 m_gal->DrawSegment( pts[0], pts[1], thickness );
2309 m_gal->DrawSegment( pts[1], pts[2], thickness );
2310 m_gal->DrawSegment( pts[2], pts[3], thickness );
2311 m_gal->DrawSegment( pts[3], pts[0], thickness );
2326 m_gal->DrawPolygon( poly );
2343 endAngle - startAngle, thickness,
m_maxError );
2347 m_gal->SetIsFill(
true );
2348 m_gal->SetIsStroke(
false );
2351 endAngle - startAngle, thickness,
m_maxError );
2366 m_gal->SetLineWidth( thickness );
2374 else if( isSolidFill )
2397 m_gal->DrawSegmentChain( shape.
Outline( ii ), thickness );
2401 m_gal->SetIsFill(
true );
2402 m_gal->SetIsStroke(
false );
2407 m_gal->DrawSegmentChain( shape.
Outline( ii ), thickness );
2417 m_gal->DrawPolygon( deflated_shape );
2428 m_gal->DrawPolygon( shape );
2439 std::vector<VECTOR2D>
output;
2440 std::vector<VECTOR2D> pointCtrl;
2442 pointCtrl.push_back( aShape->
GetStart() );
2445 pointCtrl.push_back( aShape->
GetEnd() );
2456 m_gal->SetLineWidth( thickness );
2482 m_gal->DrawEllipse(
center, majorR - thickness / 2, minorR - thickness / 2, rot );
2483 m_gal->DrawEllipse(
center, majorR + thickness / 2, minorR + thickness / 2, rot );
2489 m_gal->SetLineWidth( thickness );
2492 m_gal->DrawEllipse(
center, majorR, minorR, rot );
2493 else if( isSolidFill )
2494 m_gal->DrawEllipse(
center, majorR, minorR, rot );
2511 m_gal->DrawEllipseArc(
center, majorR - thickness / 2, minorR - thickness / 2, rot, start,
end );
2512 m_gal->DrawEllipseArc(
center, majorR + thickness / 2, minorR + thickness / 2, rot, start,
end );
2517 m_gal->SetIsFill(
false );
2518 m_gal->SetIsStroke( thickness > 0 );
2519 m_gal->SetLineWidth( thickness );
2520 m_gal->DrawEllipseArc(
center, majorR, minorR, rot, start,
end );
2535 m_gal->SetIsFill(
true );
2536 m_gal->SetIsStroke(
false );
2539 std::vector<SHAPE*> shapes;
2559 for(
SHAPE* shape : shapes )
2565 m_gal->DrawSegment( a, b, thickness );
2569 for(
SHAPE* shape : shapes )
2576 m_gal->SetIsFill(
false );
2577 m_gal->SetIsStroke(
true );
2581 m_gal->DrawLine( seg.A, seg.B );
2613 font->
Draw(
m_gal, aText, pos, aAttrs, aFontMetrics );
2628 if( img_scale != 1.0 )
2636 m_gal->SetIsStroke(
true );
2637 m_gal->SetStrokeColor( color );
2639 m_gal->SetIsFill(
false );
2646 bm_size.
x /= img_scale;
2647 bm_size.
y /= img_scale;
2648 VECTOR2D origin( -bm_size.
x / 2.0, -bm_size.
y / 2.0 );
2651 m_gal->DrawRectangle( origin,
end );
2668 draw(
static_cast<const PCB_TEXT*
>( aField ), aLayer );
2676 if( resolvedText.Length() == 0 )
2683 m_gal->SetIsFill(
true );
2684 m_gal->SetIsStroke(
true );
2685 m_gal->SetFillColor( color );
2686 m_gal->SetStrokeColor( color );
2691 m_gal->DrawPolygon( poly );
2706 m_gal->SetStrokeColor( color );
2707 m_gal->SetFillColor( color );
2714 m_gal->SetIsStroke(
false );
2715 m_gal->SetIsFill(
true );
2716 m_gal->DrawPolygon( finalPoly );
2736 textWidth.
x = -textWidth.
x;
2743 textPos -= textWidth;
2745 textPos += textWidth;
2748 strokeText( resolvedText, textPos, attrs, metrics );
2752 std::vector<std::unique_ptr<KIFONT::GLYPH>>* cache =
nullptr;
2760 m_gal->DrawGlyphs( *cache );
2793 wxString resolvedText( aTextBox->
GetShownText(
true ) );
2800 m_gal->SetIsFill(
true );
2801 m_gal->SetIsStroke(
false );
2802 m_gal->SetFillColor( sh_color );
2803 m_gal->SetStrokeColor( sh_color );
2807 std::vector<VECTOR2I> pts = aTextBox->
GetCorners();
2808 int line_thickness = std::max( thickness*3,
pcbIUScale.mmToIU( 0.2 ) );
2810 std::deque<VECTOR2D> dpts;
2815 dpts.push_back(
VECTOR2D( pts[0] ) );
2817 m_gal->SetIsStroke(
true );
2818 m_gal->SetLineWidth( line_thickness );
2819 m_gal->DrawPolygon( dpts );
2822 m_gal->SetFillColor( color );
2823 m_gal->SetStrokeColor( color );
2824 m_gal->SetIsFill(
true );
2825 m_gal->SetIsStroke(
false );
2833 std::vector<VECTOR2I> pts = aTextBox->
GetCorners();
2835 for(
size_t ii = 0; ii < pts.size(); ++ii )
2836 m_gal->DrawSegment( pts[ii], pts[( ii + 1 ) % pts.size()], thickness );
2843 for(
SHAPE* shape : shapes )
2848 m_gal->DrawSegment( a, b, thickness );
2852 for(
SHAPE* shape : shapes )
2865 m_canvas->SetFillColor( sh_color );
2866 m_canvas->SetStrokeColor( sh_color );
2879 m_gal->SetIsStroke(
false );
2880 m_gal->SetIsFill(
true );
2881 m_gal->DrawPolygon( finalPoly );
2885 if( resolvedText.Length() == 0 )
2901 std::vector<std::unique_ptr<KIFONT::GLYPH>>* cache =
nullptr;
2909 m_gal->DrawGlyphs( *cache );
2925 if( cell->GetColSpan() > 0 || cell->GetRowSpan() > 0 )
2937 m_gal->SetIsFill(
false );
2938 m_gal->SetIsStroke(
true );
2939 m_gal->SetStrokeColor( color );
2940 m_gal->SetLineWidth( lineWidth );
2944 m_gal->DrawLine( ptA, ptB );
2955 m_gal->DrawLine( a+1, b );
2957 m_gal->DrawLine( a, b );
2965 if( aTable->
IsSelected() || cell->IsSelected() )
2967 std::vector<VECTOR2I> corners = cell->GetCorners();
2968 std::deque<VECTOR2D> pts;
2970 pts.insert( pts.end(), corners.begin(), corners.end() );
2973 m_gal->SetIsFill(
true );
2974 m_gal->SetIsStroke(
false );
2975 m_gal->DrawPolygon( pts );
2989 double anchorSize = 5.0 /
m_gal->GetWorldScale();
2990 double anchorThickness = 1.0 /
m_gal->GetWorldScale();
2993 m_gal->SetIsFill(
false );
2994 m_gal->SetIsStroke(
true );
2995 m_gal->SetStrokeColor( color );
2996 m_gal->SetLineWidth( anchorThickness );
3007 m_gal->SetIsFill(
true );
3008 m_gal->SetIsStroke(
false );
3009 m_gal->SetFillColor( color );
3013 m_canvas->DrawPolygon( poly );
3019 m_gal->DrawRectangle( topLeft, botRight );
3036 m_gal->SetIsFill(
true );
3037 m_gal->SetIsStroke(
false );
3038 m_gal->SetFillColor( color );
3041 m_gal->DrawPolygon( frontpoly );
3044 m_gal->DrawPolygon( backpoly );
3070 m_gal->SetStrokeColor( color );
3078 m_gal->DrawLine( topLeft, topLeft + width );
3079 m_gal->DrawLine( topLeft + width, topLeft + width + height );
3080 m_gal->DrawLine( topLeft + width + height, topLeft + height );
3081 m_gal->DrawLine( topLeft + height, topLeft );
3085 if(
name.IsEmpty() )
3089 int scaledSize = abs(
KiROUND(
m_gal->GetScreenWorldMatrix().GetScale().x * ptSize ) );
3090 int unscaledSize =
pcbIUScale.MilsToIU( ptSize );
3093 int textSize = ( scaledSize + ( unscaledSize * 2 ) ) / 3;
3099 m_gal->DrawLine( topLeft, topLeft - titleHeight );
3100 m_gal->DrawLine( topLeft - titleHeight, topLeft + width - titleHeight );
3101 m_gal->DrawLine( topLeft + width - titleHeight, topLeft + width );
3134 m_gal->SetIsFill(
true );
3135 m_gal->SetIsStroke(
false );
3136 m_gal->SetFillColor( color );
3161 std::deque<VECTOR2D> corners;
3176 m_gal->SetStrokeColor( color.
a > 0.0 ? color.
WithAlpha( 1.0 ) : color );
3177 m_gal->SetIsFill(
false );
3178 m_gal->SetIsStroke(
true );
3195 int holes_count = outline->
HoleCount( ii );
3197 for(
int jj = 0; jj < holes_count; ++jj )
3198 m_gal->DrawPolyline( outline->
CHole( ii, jj ) );
3203 m_gal->DrawLine( hatchLine.A, hatchLine.B );
3215 if( polySet->OutlineCount() == 0 )
3218 m_gal->SetStrokeColor( color );
3219 m_gal->SetFillColor( color );
3220 m_gal->SetLineWidth( 0 );
3224 m_gal->SetIsFill(
true );
3225 m_gal->SetIsStroke(
false );
3229 m_gal->SetIsFill(
false );
3230 m_gal->SetIsStroke(
true );
3237 if(
m_gal->IsOpenGlEngine() && !polySet->IsTriangulationUpToDate() )
3238 polySet->CacheTriangulation(
true );
3249 m_gal->SetIsFill(
true );
3250 m_gal->SetIsStroke(
false );
3251 m_gal->SetFillColor( color );
3262 m_gal->DrawPolygon( shape );
3272 m_gal->SetIsFill(
true );
3273 m_gal->SetIsStroke(
true );
3274 m_gal->SetFillColor( color );
3275 m_gal->SetStrokeColor( color );
3278 for(
const std::shared_ptr<SHAPE>& shape : aDimension->
GetShapes() )
3280 switch( shape->Type() )
3302 m_gal->DrawPolygon( poly );
3307 m_gal->SetStrokeColor( color );
3308 m_gal->SetFillColor( color );
3309 m_gal->SetIsFill(
false );
3310 m_gal->SetIsStroke(
true );
3321 for(
const std::shared_ptr<SHAPE>& shape : aDimension->
GetShapes() )
3323 switch( shape->Type() )
3328 m_gal->DrawLine( seg.
A, seg.
B );
3345 wxString resolvedText = aDimension->
GetShownText(
true );
3356 std::vector<std::unique_ptr<KIFONT::GLYPH>>* cache =
nullptr;
3363 for(
const std::unique_ptr<KIFONT::GLYPH>& glyph : *cache )
3364 m_gal->DrawGlyph( *glyph.get() );
3380 m_gal->SetStrokeColor( strokeColor );
3381 m_gal->SetIsFill(
false );
3382 m_gal->SetIsStroke(
true );
3385 m_gal->Translate( position );
3391 size = 2.0 * aTarget->
GetSize() / 3.0;
3397 size = aTarget->
GetSize() / 2.0;
3416 double size = (double)aPoint->
GetSize() / 2;
3436 m_gal->SetLineWidth( thickness );
3437 m_gal->SetStrokeColor( crossColor );
3438 m_gal->SetIsFill(
false );
3439 m_gal->SetIsStroke(
true );
3442 m_gal->Translate( position );
3449 m_gal->SetStrokeColor( ringColor );
3465 aMarker->
SetZoom( 1.0 / sqrt(
m_gal->GetZoomFactor() ) );
3491 m_gal->SetIsStroke(
true );
3496 m_gal->SetFillColor( color );
3497 m_gal->SetIsFill(
true );
3500 m_gal->DrawPolygon( polygon );
3511 if( shape.GetStroke().GetWidth() == 1.0 )
3513 m_gal->SetIsFill(
false );
3514 m_gal->SetIsStroke(
true );
3515 m_gal->SetStrokeColor( color );
3520 m_gal->DrawLine( shape.GetStart(), shape.GetEnd() );
3525 shape.CalcArcAngles( startAngle, endAngle );
3527 m_gal->DrawArc( shape.GetCenter(), shape.GetRadius(), startAngle, shape.GetArcAngle() );
3532 m_gal->SetIsFill(
true );
3533 m_gal->SetIsStroke(
false );
3538 m_gal->DrawSegment( shape.GetStart(), shape.GetEnd(), shape.GetWidth() );
3543 shape.CalcArcAngles( startAngle, endAngle );
3545 m_gal->DrawArcSegment( shape.GetCenter(), shape.GetRadius(), startAngle, shape.GetArcAngle(),
3572 m_gal->SetFillColor( outlineColor );
3573 m_gal->AdvanceDepth();
3574 m_gal->SetLineWidth( 0 );
3575 m_gal->SetIsFill(
true );
3576 m_gal->SetIsStroke(
false );
3587 double backdrillRadius = aDrillSize / 2.0;
3588 double lineWidth = std::max( backdrillRadius / 4.0,
m_pcbSettings.m_outlineWidth * 2.0 );
3591 m_gal->AdvanceDepth();
3592 m_gal->SetIsFill(
false );
3593 m_gal->SetIsStroke(
true );
3594 m_gal->SetLineWidth( lineWidth );
3613 if(
const PAD*
pad =
dynamic_cast<const PAD*
>( aItem ) )
3615 size =
pad->GetPostMachiningKnockout( aLayer );
3619 size =
via->GetPostMachiningKnockout( aLayer );
3626 m_gal->AdvanceDepth();
3628 double pmRadius = size / 2.0;
3630 double lineWidth = std::max( pmRadius / 8.0,
m_pcbSettings.m_outlineWidth * 2.0 );
3634 m_gal->SetIsFill(
false );
3635 m_gal->SetIsStroke(
true );
3636 m_gal->SetStrokeColor( layerColor );
3637 m_gal->SetLineWidth( lineWidth );
3640 constexpr int NUM_DASHES = 12;
3643 for(
int i = 0; i < NUM_DASHES; ++i )
3645 EDA_ANGLE startAngle = dashAngle * ( i * 2 );
3646 m_gal->DrawArc( aCenter, pmRadius, startAngle, dashAngle );
ERROR_LOC
When approximating an arc or circle, should the error be placed on the outside or inside of the curve...
constexpr int ARC_HIGH_DEF
constexpr EDA_IU_SCALE pcbIUScale
KIFACE_BASE & Kiface()
Global KIFACE_BASE "get" accessor.
@ NORMAL
Inactive layers are shown normally (no high-contrast mode)
@ HIDDEN
Inactive layers are hidden.
@ RATSNEST
Net/netclass colors are shown on ratsnest lines only.
@ ALL
Net/netclass colors are shown on all net copper.
constexpr BOX2I KiROUND(const BOX2D &aBoxD)
static const ADVANCED_CFG & GetCfg()
Get the singleton instance's config, which is shared by all consumers.
Bezier curves to polygon converter.
void GetPoly(std::vector< VECTOR2I > &aOutput, int aMaxError=10)
Convert a Bezier curve to a polygon.
A base class derived from BOARD_ITEM for items that can be connected and have a net,...
virtual NETCLASS * GetEffectiveNetClass() const
Return the NETCLASS for this item.
wxString GetNetname() const
NETINFO_ITEM * GetNet() const
Return #NET_INFO object for a given item.
const wxString & GetDisplayNetname() const
virtual int GetOwnClearance(PCB_LAYER_ID aLayer, wxString *aSource=nullptr) const
Return an item's "own" clearance in internal units.
Container for design settings for a BOARD object.
int GetHolePlatingThickness() const
Pad & via drills are finish size.
int m_SolderMaskExpansion
int GetLineThickness(PCB_LAYER_ID aLayer) const
Return the default graphic segment thickness from the layer class for the given layer.
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 BOARD_ITEM * Duplicate(bool addToParentGroup, BOARD_COMMIT *aCommit=nullptr) const
Create a copy of this BOARD_ITEM.
virtual bool IsConnected() const
Returns information if the object is derived from BOARD_CONNECTED_ITEM.
virtual bool IsKnockout() const
virtual const BOARD * GetBoard() const
Return the BOARD in which this BOARD_ITEM resides, or NULL if none.
FOOTPRINT * GetParentFootprint() const
virtual LSET GetLayerSet() const
Return a std::bitset of all layers on which the item physically resides.
virtual void TransformShapeToPolySet(SHAPE_POLY_SET &aBuffer, PCB_LAYER_ID aLayer, int aClearance, int aError, ERROR_LOC aErrorLoc, KIGFX::RENDER_SETTINGS *aRenderSettings=nullptr) const
Convert the item shape to a polyset.
const KIFONT::METRICS & GetFontMetrics() const
BOARD_ITEM_CONTAINER * GetParent() const
bool IsSideSpecific() const
virtual bool IsOnCopperLayer() const
Information pertinent to a Pcbnew printed circuit board.
BOARD_USE GetBoardUse() const
Get what the board use is.
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.
int GetCopperLayerCount() const
KIGFX::COLOR4D GetNetChainColor(const wxString &aChain) const
BOARD_DESIGN_SETTINGS & GetDesignSettings() const
const LSET & GetEnabledLayers() const
A proxy function that calls the corresponding function in m_BoardSettings.
constexpr const Vec & GetPosition() const
constexpr BOX2< Vec > & Inflate(coord_type dx, coord_type dy)
Inflates the rectangle horizontally by dx and vertically by dy.
constexpr const Vec GetEnd() const
constexpr void SetOrigin(const Vec &pos)
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
constexpr void SetEnd(coord_type x, coord_type y)
Color settings are a bit different than most of the settings objects in that there can be more than o...
COLOR4D GetColor(int aLayer) const
virtual const BOX2I GetBoundingBox() const
Return the orthogonal bounding box of this object for display purposes.
KICAD_T Type() const
Returns the type of object.
bool IsBrightened() const
int GetEllipseMinorRadius() const
const VECTOR2I & GetBezierC2() const
const VECTOR2I & GetEllipseCenter() const
virtual VECTOR2I GetTopLeft() const
EDA_ANGLE GetEllipseEndAngle() const
int GetEllipseMajorRadius() const
int GetRectangleWidth() const
virtual std::vector< SHAPE * > MakeEffectiveShapes(bool aEdgeOnly=false) const
Make a set of SHAPE objects representing the EDA_SHAPE.
void CalcArcAngles(EDA_ANGLE &aStartAngle, EDA_ANGLE &aEndAngle) const
Calc arc start and end angles such that aStartAngle < aEndAngle.
EDA_ANGLE GetEllipseRotation() const
virtual VECTOR2I GetBotRight() const
const std::vector< SEG > & GetHatchLines() const
bool IsHatchedFill() const
virtual int GetHatchLineWidth() const
const VECTOR2I & GetEnd() const
Return the ending point of the graphic.
const VECTOR2I & GetStart() const
Return the starting point of the graphic.
std::vector< VECTOR2I > GetRectCorners() const
EDA_ANGLE GetEllipseStartAngle() const
const std::vector< VECTOR2I > & GetBezierPoints() const
const VECTOR2I & GetBezierC1() const
int GetRectangleHeight() const
int GetCornerRadius() const
virtual bool IsVisible() const
KIFONT::FONT * GetFont() const
std::vector< std::unique_ptr< KIFONT::GLYPH > > * GetRenderCache(const KIFONT::FONT *aFont, const wxString &forResolvedText, const VECTOR2I &aOffset={ 0, 0 }) const
BOX2I GetTextBox(const RENDER_SETTINGS *aSettings, int aLine=-1) const
Useful in multiline texts to calculate the full text or a line area (for zones filling,...
GR_TEXT_H_ALIGN_T GetHorizJustify() const
virtual KIFONT::FONT * GetDrawFont(const RENDER_SETTINGS *aSettings) const
const TEXT_ATTRIBUTES & GetAttributes() const
int GetEffectiveTextPenWidth(int aDefaultPenWidth=0) const
The EffectiveTextPenWidth uses the text thickness if > 1 or aDefaultPenWidth.
APP_SETTINGS_BASE * KifaceSettings() const
FONT is an abstract base class for both outline and stroke fonts.
static FONT * GetFont(const wxString &aFontName=wxEmptyString, bool aBold=false, bool aItalic=false, const std::vector< wxString > *aEmbeddedFiles=nullptr, bool aForDrawingSheet=false)
virtual bool IsStroke() const
void Draw(KIGFX::GAL *aGal, const wxString &aText, const VECTOR2I &aPosition, const VECTOR2I &aCursor, const TEXT_ATTRIBUTES &aAttributes, const METRICS &aFontMetrics, std::optional< VECTOR2I > aMousePos=std::nullopt, wxString *aActiveUrl=nullptr) const
Draw a string.
virtual bool IsOutline() const
A color representation with 4 components: red, green, blue, alpha.
COLOR4D WithAlpha(double aAlpha) const
Return a color with the same color, but the given alpha.
static const COLOR4D CLEAR
COLOR4D & Darken(double aFactor)
Makes the color darker by a given factor.
COLOR4D Darkened(double aFactor) const
Return a color that is darker by a given factor, without modifying object.
COLOR4D Inverted() const
Returns an inverted color, alpha remains the same.
COLOR4D & Brighten(double aFactor)
Makes the color brighter by a given factor.
static const COLOR4D WHITE
COLOR4D Brightened(double aFactor) const
Return a color that is brighter by a given factor, without modifying object.
static const COLOR4D UNSPECIFIED
For legacy support; used as a value to indicate color hasn't been set yet.
static const COLOR4D BLACK
COLOR4D Mix(const COLOR4D &aColor, double aFactor) const
Return a color that is mixed with the input by a factor.
Attribute save/restore for GAL attributes.
Abstract interface for drawing on a 2D-surface.
GAL * m_gal
Instance of graphic abstraction layer that gives an interface to call commands used to draw (eg.
PAINTER(GAL *aGal)
Initialize this object for painting on any of the polymorphic GRAPHICS_ABSTRACTION_LAYER* derivatives...
void drawPostMachiningIndicator(const BOARD_ITEM *aItem, const VECTOR2D &aCenter, PCB_LAYER_ID aLayer)
Draw post-machining indicator (dashed circle) at the given center point.
virtual SHAPE_SEGMENT getPadHoleShape(const PAD *aPad) const
Return hole shape for a pad (internal units).
PCB_PAINTER(GAL *aGal, FRAME_T aFrameType)
int getLineThickness(int aActualThickness) const
Get the thickness to draw for a line (e.g.
void renderNetNameForSegment(const SHAPE_SEGMENT &aSeg, const COLOR4D &aColor, const wxString &aNetName) const
PCB_VIEWERS_SETTINGS_BASE * viewer_settings()
void draw(const PCB_TRACK *aTrack, int aLayer)
virtual PAD_DRILL_SHAPE getDrillShape(const PAD *aPad) const
Return drill shape of a pad.
int m_holePlatingThickness
PCB_RENDER_SETTINGS m_pcbSettings
virtual int getViaDrillSize(const PCB_VIA *aVia) const
Return drill diameter for a via (internal units).
void strokeText(const wxString &aText, const VECTOR2I &aPosition, const TEXT_ATTRIBUTES &aAttrs, const KIFONT::METRICS &aFontMetrics)
void drawBackdrillIndicator(const BOARD_ITEM *aItem, const VECTOR2D &aCenter, int aDrillSize, PCB_LAYER_ID aStartLayer, PCB_LAYER_ID aEndLayer)
Draw backdrill indicator (two semi-circles) at the given center point.
virtual bool Draw(const VIEW_ITEM *aItem, int aLayer) override
Takes an instance of VIEW_ITEM and passes it to a function that knows how to draw the item.
double m_zoneOpacity
Opacity override for filled zones.
double m_trackOpacity
Opacity override for all tracks.
double m_imageOpacity
Opacity override for user images.
double m_viaOpacity
Opacity override for all types of via.
ZONE_DISPLAY_MODE m_ZoneDisplayMode
void LoadColors(const COLOR_SETTINGS *aSettings) override
double m_padOpacity
Opacity override for SMD pads and PTHs.
void SetBackgroundColor(const COLOR4D &aColor) override
Set the background color.
COLOR4D GetColor(const VIEW_ITEM *aItem, int aLayer) const override
Returns the color that should be used to draw the specific VIEW_ITEM on the specific layer using curr...
HIGH_CONTRAST_MODE m_ContrastModeDisplay
std::map< int, KIGFX::COLOR4D > m_netColors
Set of net codes that should not have their ratsnest displayed.
NET_COLOR_MODE m_netColorMode
Overrides for specific netclass colors.
static const double MAX_FONT_SIZE
< Maximum font size for netnames (and other dynamically shown strings)
double m_filledShapeOpacity
Opacity override for graphic shapes.
bool m_ForceShowFieldsWhenFPSelected
bool GetShowPageLimits() const override
void LoadDisplayOptions(const PCB_DISPLAY_OPTIONS &aOptions)
Load settings related to display options (high-contrast mode, full or outline modes for vias/pads/tra...
bool m_ForcePadSketchModeOn
COLOR4D m_backgroundColor
PCB_LAYER_ID GetPrimaryHighContrastLayer() const
Return the board layer which is in high-contrast mode.
void SetGapLengthRatio(double aRatio)
PCB_LAYER_ID GetActiveLayer() const
std::map< int, COLOR4D > m_layerColorsHi
virtual void update()
Precalculates extra colors for layers (e.g.
void SetDashLengthRatio(double aRatio)
std::set< int > m_highlightNetcodes
std::map< int, COLOR4D > m_layerColorsDark
std::map< int, COLOR4D > m_layerColorsSel
std::set< int > m_highContrastLayers
std::map< int, COLOR4D > m_layerColors
bool m_hiContrastEnabled
Parameters for display modes.
An abstract base class for deriving all objects that can be added to a VIEW.
bool IsBOARD_ITEM() const
double GetForcedTransparency() const
LSET is a set of PCB_LAYER_IDs.
static const LSET & AllCuMask()
return AllCuMask( MAX_CU_LAYERS );
PCB_LAYER_ID ExtractLayer() const
Find the first set PCB_LAYER_ID.
LSEQ Seq(const LSEQ &aSequence) const
Return an LSEQ from the union of this LSET and a desired sequence.
static LSET AllCuMask(int aCuLayerCount)
Return a mask holding the requested number of Cu PCB_LAYER_IDs.
static const LSET & PhysicalLayersMask()
Return a mask holding all layers which are physically realized.
int MarkerScale() const
The scaling factor to convert polygonal shape coordinates to internal units.
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...
A collection of nets and the parameters used to route or test these nets.
COLOR4D GetPcbColor(bool aIsForSave=false) const
Handle the data for a net.
const wxString & GetNetChain() const
PAD * GetTerminalPad(int aIndex) const
static const int UNCONNECTED
Constant that holds the "unconnected net" number (typically 0) all items "connected" to this net are ...
@ NORMAL
Shape is the same on all layers.
int GetOwnClearance(PCB_LAYER_ID aLayer, wxString *aSource=nullptr) const override
Return the pad's "own" clearance in internal units.
LSET GetLayerSet() const override
Return a std::bitset of all layers on which the item physically resides.
const std::vector< std::shared_ptr< PCB_SHAPE > > & GetPrimitives(PCB_LAYER_ID aLayer) const
Accessor to the basic shape list for custom-shaped pads.
bool FlashLayer(int aLayer, bool aOnlyCheckIfPermitted=false) const
Check to see whether the pad should be flashed on the specific layer.
virtual std::shared_ptr< SHAPE > GetEffectiveShape(PCB_LAYER_ID aLayer, FLASHING flashPTHPads=FLASHING::DEFAULT) const override
Some pad shapes can be complex (rounded/chamfered rectangle), even without considering custom shapes.
const BOX2I GetBoundingBox() const override
The bounding box is cached, so this will be efficient most of the time.
PAD_ATTRIB GetAttribute() const
const wxString & GetPinFunction() const
const wxString & GetNumber() const
VECTOR2I GetPosition() const override
PCB_LAYER_ID GetTertiaryDrillEndLayer() const
VECTOR2I GetOffset(PCB_LAYER_ID aLayer) const
PCB_LAYER_ID GetTertiaryDrillStartLayer() const
bool IsNoConnectPad() const
int GetDrillSizeX() const
PAD_SHAPE GetShape(PCB_LAYER_ID aLayer) const
void TransformShapeToPolygon(SHAPE_POLY_SET &aBuffer, PCB_LAYER_ID aLayer, int aClearance, int aMaxError, ERROR_LOC aErrorLoc=ERROR_INSIDE, bool ignoreLineWidth=false) const override
Convert the pad shape to a closed polygon.
int GetSolderMaskExpansion(PCB_LAYER_ID aLayer) const
VECTOR2I GetSize(PCB_LAYER_ID aLayer) const
const VECTOR2I & GetSecondaryDrillSize() const
EDA_ANGLE GetOrientation() const
Return the rotation angle of the pad.
PAD_DRILL_SHAPE GetDrillShape() const
int GetPostMachiningKnockout(PCB_LAYER_ID aLayer) const
Get the knockout diameter for a layer affected by post-machining.
VECTOR2I GetSolderPasteMargin(PCB_LAYER_ID aLayer) const
Usually < 0 (mask shape smaller than pad)because the margin can be dependent on the pad size,...
PCB_LAYER_ID GetSecondaryDrillStartLayer() const
const VECTOR2I & GetTertiaryDrillSize() const
VECTOR2I ShapePos(PCB_LAYER_ID aLayer) const
std::shared_ptr< SHAPE_SEGMENT > GetEffectiveHoleShape() const override
Return a SHAPE_SEGMENT object representing the pad's hole.
PCB_LAYER_ID GetSecondaryDrillEndLayer() const
DISPLAY_OPTIONS m_Display
EDA_ANGLE GetArcAngleStart() const
const VECTOR2I GetFocusPosition() const override
Similar to GetPosition() but allows items to return their visual center rather than their anchor.
EDA_ANGLE GetAngle() const
const VECTOR2I & GetMid() const
virtual VECTOR2I GetCenter() const override
This defaults to the center of the bounding box if not overridden.
void GetBoundingHull(SHAPE_POLY_SET &aBuffer, PCB_LAYER_ID aLayer, int aClearance, int aMaxError, ERROR_LOC aErrorLoc=ERROR_INSIDE) const
const SHAPE_POLY_SET & GetOutline() const
int GetLineThickness() const
const std::vector< std::shared_ptr< SHAPE > > & GetShapes() const
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.
HIGH_CONTRAST_MODE m_ContrastModeDisplay
How inactive layers are displayed.
NET_COLOR_MODE m_NetColorMode
How to use color overrides on specific nets and netclasses.
ZONE_DISPLAY_MODE m_ZoneDisplayMode
A set of BOARD_ITEMs (i.e., without duplicates).
const BOX2I GetBoundingBox() const override
Return the orthogonal bounding box of this object for display purposes.
void SetZoom(double aZoomFactor) const
std::vector< PCB_SHAPE > GetShapes() const
GAL_LAYER_ID GetColorLayer() const
VECTOR2I GetPosition() const override
PCB_VIEWERS_SETTINGS_BASE * viewer_settings()
A PCB_POINT is a 0-dimensional point that is used to mark a position on a PCB, or more usually a foot...
VECTOR2I GetPosition() const override
Object to handle a bitmap image that can be inserted in a PCB.
REFERENCE_IMAGE & GetReferenceImage()
VECTOR2I GetCenter() const override
This defaults to the center of the bounding box if not overridden.
int GetWidth() const override
bool HasSolderMask() const
int GetSolderMaskExpansion() const
bool IsProxyItem() const override
STROKE_PARAMS GetStroke() const override
void UpdateHatching() const override
PCB_LAYER_ID GetLayer() const override
Return the primary layer this item is on.
std::vector< PCB_TABLECELL * > GetCells() const
void DrawBorders(const std::function< void(const VECTOR2I &aPt1, const VECTOR2I &aPt2, const STROKE_PARAMS &aStroke)> &aCallback) const
VECTOR2I GetPosition() const override
bool IsBorderEnabled() const
Disables the border, this is done by changing the stroke internally.
void TransformTextToPolySet(SHAPE_POLY_SET &aBuffer, int aClearance, int aMaxError, ERROR_LOC aErrorLoc) const
Function TransformTextToPolySet Convert the text to a polygonSet describing the actual character stro...
VECTOR2I GetTextSize() const override
VECTOR2I GetDrawPos() const override
wxString GetShownText(bool aAllowExtraText, int aDepth=0) const override
Return the string actually shown after processing of the base text.
std::vector< VECTOR2I > GetCorners() const override
Return 4 corners for a rectangle or rotated rectangle (stored as a poly).
void TransformShapeToPolygon(SHAPE_POLY_SET &aBuffer, PCB_LAYER_ID aLayer, int aClearance, int aMaxError, ERROR_LOC aErrorLoc, bool aIgnoreLineWidth=false) const override
Convert the item shape to a closed polygon.
const SHAPE_POLY_SET & GetKnockoutCache(const KIFONT::FONT *aFont, const wxString &forResolvedText, int aMaxError) const
wxString GetShownText(bool aAllowExtraText, int aDepth=0) const override
Return the string actually shown after processing of the base text.
VECTOR2I GetTextPos() const override
int GetTextThickness() const override
EDA_ANGLE GetDrawRotation() const override
VECTOR2I GetTextSize() const override
int GetSolderMaskExpansion() const
const VECTOR2I & GetStart() const
const VECTOR2I & GetEnd() const
virtual int GetWidth() const
PCB_LAYER_ID BottomLayer() const
PCB_LAYER_ID GetTertiaryDrillEndLayer() const
std::optional< int > GetTertiaryDrillSize() const
bool FlashLayer(int aLayer) const
Check to see whether the via should have a pad on the specific layer.
std::optional< int > GetSecondaryDrillSize() const
PCB_LAYER_ID GetSecondaryDrillEndLayer() const
int GetWidth() const override
PCB_LAYER_ID GetTertiaryDrillStartLayer() const
bool IsOnLayer(PCB_LAYER_ID aLayer) const override
Test to see if this object is on the given layer.
PCB_LAYER_ID TopLayer() const
int GetDrillValue() const
Calculate the drill value for vias (m_drill if > 0, or default drill value for the board).
VIATYPE GetViaType() const
PCB_LAYER_ID GetSecondaryDrillStartLayer() const
void LayerPair(PCB_LAYER_ID *top_layer, PCB_LAYER_ID *bottom_layer) const
Return the 2 layers used by the via (the via actually uses all layers between these 2 layers)
VIEWERS_DISPLAY_OPTIONS m_ViewersDisplay
virtual COMMON_SETTINGS * GetCommonSettings() const
virtual SETTINGS_MANAGER & GetSettingsManager() const
A REFERENCE_IMAGE is a wrapper around a BITMAP_IMAGE that is displayed in an editor as a reference fo...
VECTOR2I GetPosition() const
const BITMAP_BASE & GetImage() const
Get the underlying image.
double GetImageScale() const
A round rectangle shape, based on a rectangle and a radius.
void TransformToPolygon(SHAPE_POLY_SET &aBuffer, int aMaxError) const
Get the polygonal representation of the roundrect.
VECTOR2I::extended_type ecoord
int Length() const
Return the length (this).
ecoord SquaredLength() const
T * GetAppSettings(const char *aFilename)
Return a handle to the a given settings by type.
VECTOR2I GetEnd() const override
const SHAPE_LINE_CHAIN ConvertToPolyline(int aMaxError=DefaultAccuracyForPCB(), int *aActualError=nullptr) const
Construct a SHAPE_LINE_CHAIN of segments from a given arc.
VECTOR2I GetStart() const override
const VECTOR2I & GetCenter() const
Represent a polyline containing arcs as well as line segments: A chain of connected line and/or arc s...
int PointCount() const
Return the number of points (vertices) in this line chain.
const VECTOR2I & CPoint(int aIndex) const
Return a reference to a given point in the line chain.
Represent a set of closed polygons.
bool IsTriangulationUpToDate() const
void Inflate(int aAmount, CORNER_STRATEGY aCornerStrategy, int aMaxError, bool aSimplify=false)
Perform outline inflation/deflation.
int HoleCount(int aOutline) const
Returns the number of holes in a given outline.
int Append(int x, int y, int aOutline=-1, int aHole=-1, bool aAllowDuplication=false)
Appends a vertex at the end of the given outline/hole (default: the last outline)
virtual void CacheTriangulation(bool aSimplify=false, const TASK_SUBMITTER &aSubmitter={})
Build a polygon triangulation, needed to draw a polygon on OpenGL and in some other calculations.
SHAPE_LINE_CHAIN & Outline(int aIndex)
Return the reference to aIndex-th outline in the set.
int NewOutline()
Creates a new empty polygon in the set and returns its index.
void Deflate(int aAmount, CORNER_STRATEGY aCornerStrategy, int aMaxError)
const SHAPE_LINE_CHAIN & CHole(int aOutline, int aHole) const
int OutlineCount() const
Return the number of outlines in the set.
void Fracture(bool aSimplify=true)
Convert a set of polygons with holes to a single outline with "slits"/"fractures" connecting the oute...
const SHAPE_LINE_CHAIN & COutline(int aIndex) const
int GetWidth() const override
const VECTOR2I & GetPosition() const
const VECTOR2I GetSize() const
const SEG & GetSeg() const
int GetWidth() const override
Represent a simple polygon consisting of a zero-thickness closed chain of connected line segments.
const SHAPE_LINE_CHAIN & Vertices() const
Return the list of vertices defining this simple polygon.
virtual const SEG GetSegment(int aIndex) const override
const VECTOR2I & CPoint(int aIndex) const
Return a const reference to a given point in the polygon.
int PointCount() const
Return the number of points (vertices) in this polygon.
virtual size_t GetSegmentCount() const override
An abstract shape on 2D plane.
Simple container to manage line stroke parameters.
LINE_STYLE GetLineStyle() const
static void Stroke(const SHAPE *aShape, LINE_STYLE aLineStyle, int aWidth, const KIGFX::RENDER_SETTINGS *aRenderSettings, const std::function< void(const VECTOR2I &a, const VECTOR2I &b)> &aStroker)
GR_TEXT_H_ALIGN_T m_Halign
GR_TEXT_V_ALIGN_T m_Valign
VECTOR2< T > Resize(T aNewLength) const
Return a vector of the same direction, but length specified in aNewLength.
Handle a list of polygons defining a copper zone.
bool GetIsRuleArea() const
Accessors to parameters used in Rule Area zones:
std::shared_ptr< SHAPE_POLY_SET > GetFilledPolysList(PCB_LAYER_ID aLayer) const
SHAPE_POLY_SET GetBoardOutline() const
virtual bool IsOnLayer(PCB_LAYER_ID) const override
Test to see if this object is on the given layer.
bool IsTeardropArea() const
ZONE_BORDER_DISPLAY_STYLE GetHatchStyle() const
bool IsConflicting() const
For rule areas which exclude footprints (and therefore participate in courtyard conflicts during move...
std::vector< SEG > GetHatchLines() const
void TransformArcToPolygon(SHAPE_POLY_SET &aBuffer, const VECTOR2I &aStart, const VECTOR2I &aMid, const VECTOR2I &aEnd, int aWidth, int aError, ERROR_LOC aErrorLoc)
Convert arc to multiple straight segments.
@ CHAMFER_ALL_CORNERS
All angles are chamfered.
@ ROUND_ALL_CORNERS
All angles are rounded.
static constexpr EDA_ANGLE ANGLE_90
static constexpr EDA_ANGLE ANGLE_VERTICAL
static constexpr EDA_ANGLE ANGLE_HORIZONTAL
static constexpr EDA_ANGLE ANGLE_360
#define IGNORE_PARENT_GROUP
@ RECTANGLE
Use RECTANGLE instead of RECT to avoid collision in a Windows header.
FRAME_T
The set of EDA_BASE_FRAME derivatives, typically stored in EDA_BASE_FRAME::m_Ident.
@ FRAME_FOOTPRINT_PREVIEW
@ FRAME_FOOTPRINT_CHOOSER
a few functions useful in geometry calculations.
int GetPenSizeForNormal(int aTextSize)
double m_HoleWallPaintingMultiplier
What factor to use when painting via and PTH pad hole walls, so that the painted hole wall can be ove...
bool IsSolderMaskLayer(int aLayer)
@ LAYER_PAD_FR_NETNAMES
Additional netnames layers (not associated with a PCB layer).
@ NETNAMES_LAYER_ID_START
bool IsPcbLayer(int aLayer)
Test whether a layer is a valid layer for Pcbnew.
bool IsPadCopperLayer(int aLayer)
bool IsPointsLayer(int aLayer)
int GetNetnameLayer(int aLayer)
Return a netname layer corresponding to the given layer.
bool IsClearanceLayer(int aLayer)
bool IsCopperLayer(int aLayerId)
Test whether a layer is a copper layer.
@ LAYER_POINTS
PCB reference/manual snap points visibility.
@ LAYER_LOCKED_ITEM_SHADOW
Shadow layer for locked items.
@ LAYER_PAD_COPPER_START
Virtual layers for pad copper on a given copper layer.
@ LAYER_CONFLICTS_SHADOW
Shadow layer for items flagged conflicting.
@ LAYER_NON_PLATEDHOLES
Draw usual through hole vias.
@ LAYER_DRC_EXCLUSION
Layer for DRC markers which have been individually excluded.
@ LAYER_PCB_BACKGROUND
PCB background color.
@ LAYER_DRC_HIGHLIGHTED
Color for highlighted DRC markers.
@ LAYER_DRC_SHAPES
Custom shapes for DRC markers.
@ LAYER_PADS
Meta control for all pads opacity/visibility (color ignored).
@ LAYER_DRC_WARNING
Layer for DRC markers with #SEVERITY_WARNING.
@ LAYER_PAD_PLATEDHOLES
to draw pad holes (plated)
@ LAYER_VIA_COPPER_START
Virtual layers for via copper on a given copper layer.
@ LAYER_CLEARANCE_START
Virtual layers for pad/via/track clearance outlines for a given copper layer.
@ LAYER_ZONE_START
Virtual layers for stacking zones and tracks on a given copper layer.
@ LAYER_ANCHOR
Anchor of items having an anchor point (texts, footprints).
@ LAYER_VIA_BURIED
Draw blind vias.
@ LAYER_MARKER_SHADOWS
Shadows for DRC markers.
@ LAYER_VIA_HOLES
Draw via holes (pad holes do not use this layer).
@ LAYER_VIA_BLIND
Draw micro vias.
@ LAYER_VIA_THROUGH
Draw buried vias.
@ LAYER_DRC_ERROR
Layer for DRC markers with #SEVERITY_ERROR.
bool IsViaCopperLayer(int aLayer)
bool IsNetnameLayer(int aLayer)
Test whether a layer is a netname layer.
bool IsHoleLayer(int aLayer)
bool IsExternalCopperLayer(int aLayerId)
Test whether a layer is an external (F_Cu or B_Cu) copper layer.
PCB_LAYER_ID
A quick note on layer IDs:
bool IsZoneFillLayer(int aLayer)
PCB_LAYER_ID ToLAYER_ID(int aLayer)
MATRIX3x3< double > MATRIX3x3D
The Cairo implementation of the graphics abstraction layer.
bool ZoneOutlineDrawnOnLayer(bool aIsRuleArea, int aLayer)
Decide which GAL draw pass paints a zone's outline.
EDA_ANGLE abs(const EDA_ANGLE &aAngle)
PAD_DRILL_SHAPE
The set of pad drill shapes, used with PAD::{Set,Get}DrillShape()
@ NPTH
like PAD_PTH, but not plated mechanical use only, no connection allowed
@ PTH
Plated through hole pad.
BARCODE class definition.
Class to handle a set of BOARD_ITEMs.
PCBNEW_SETTINGS * pcbconfig()
PGM_BASE & Pgm()
The global program "get" accessor.
PGM_BASE * PgmOrNull()
Return a reference that can be nullptr when running a shared lib from a script, not from a kicad app.
@ SH_RECT
axis-aligned rectangle
@ SH_SIMPLE
simple polygon
wxString UnescapeString(const wxString &aSource)
int PrintableCharCount(const wxString &aString)
Return the number of printable (ie: non-formatting) chars.
LINE_STYLE
Dashed line types.
double hicontrast_dimming_factor
bool m_DisplayPcbTrackFill
bool m_DisplayGraphicsFill
SHAPE_CIRCLE circle(c.m_circle_center, c.m_circle_radius)
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.
@ 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_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
@ 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_BOARD_OUTLINE_T
class PCB_BOARD_OUTLINE_T, a pcb board outline item
@ 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_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
VECTOR2< int32_t > VECTOR2I
VECTOR2< double > VECTOR2D