52 bool aPlotFPText,
bool aPlotReferences,
bool aPlotValues );
70 LSET layers = { aLayer };
84 itemplotter.
PlotZone( &zone, aLayer, *aPolySet );
99 PlotLayer( aBoard, aPlotter, aLayerMask, aPlotOpt );
109 PlotPolySet( aBoard, aPlotter, aPlotOpt, &solderMask, layer );
126 PlotPolySet( aBoard, aPlotter, aPlotOpt, &silkscreen, silkLayer );
133 if( !aBoard || !aPlotter || aLayers.empty() )
161 std::vector<wxString> properties;
163 properties.emplace_back( wxString::Format( wxT(
"!%s = %s" ),
164 _(
"Reference designator" ),
165 fp->Reference().GetShownText(
false ) ) );
167 properties.emplace_back( wxString::Format( wxT(
"!%s = %s" ),
169 fp->Value().GetShownText(
false ) ) );
171 properties.emplace_back( wxString::Format( wxT(
"!%s = %s" ),
173 fp->GetFPID().GetUniStringLibItemName() ) );
175 for(
const PCB_FIELD* field : fp->GetFields() )
177 wxCHECK2( field,
continue );
179 if( field->IsReference() || field->IsValue() )
182 if( field->GetText().IsEmpty() )
185 properties.emplace_back( wxString::Format( wxT(
"!%s = %s" ),
187 field->GetText() ) );
192 properties.emplace_back( wxString::Format( wxT(
"!%s = %s" ),
_(
"Library Description" ),
193 fp->GetLibDescription() ) );
195 properties.emplace_back( wxString::Format( wxT(
"!%s = %s" ),
_(
"Keywords" ),
196 fp->GetKeywords() ) );
203 BOX2I bbox = fp->GetBoundingBox(
false );
210 bbox = fp->GetBoundingBox(
true );
213 aPlotter->
Bookmark( bbox, fp->GetReference(),
_(
"Footprints" ) );
229 LSET layer_mask( { aLayer } );
240 PlotLayer( aBoard, aPlotter, layer_mask, plotOpt );
266 PlotLayer( aBoard, aPlotter, layer_mask, plotOpt );
304 PlotLayer( aBoard, aPlotter, layer_mask, plotOpt );
318 PlotLayer( aBoard, aPlotter, layer_mask, plotOpt );
339 bool onFrontFab = (
LSET( {
F_Fab } ) & aLayerMask ).any();
340 bool onBackFab = (
LSET( {
B_Fab } ) & aLayerMask ).any();
359 const bool dnp = footprint->GetDNPForVariant( variantName );
363 for(
PAD*
pad : footprint->Pads() )
365 bool doSketchPads =
false;
367 if( !(
pad->GetLayerSet() & aLayerMask ).any() )
369 if( sketchPads && ( ( onFrontFab &&
pad->GetLayerSet().Contains(
F_Cu ) )
370 || ( onBackFab &&
pad->GetLayerSet().Contains(
B_Cu ) ) ) )
380 if( onCopperLayer && !
pad->IsOnCopperLayer() )
384 if( onCopperLayer && !
pad->FlashLayer( aLayerMask ) )
392 if( aLayerMask.count() == 1 )
398 if( (
pad->GetLayerSet() & aLayerMask )[
B_Cu] )
401 if( (
pad->GetLayerSet() & aLayerMask )[
F_Cu] )
404 if( sketchPads && aLayerMask[
F_Fab] )
406 else if( sketchPads && aLayerMask[
B_Fab] )
410 if( sketchPads && ( ( onFrontFab &&
pad->GetLayerSet().Contains(
F_Cu ) )
411 || ( onBackFab &&
pad->GetLayerSet().Contains(
B_Cu ) ) ) )
426 if( onSolderMaskLayer )
427 margin.
x = margin.
y =
pad->GetSolderMaskExpansion( aLayer );
429 if( onSolderPasteLayer )
430 margin =
pad->GetSolderPasteMargin( aLayer );
436 int mask_clearance = margin.
x;
438 bool sameXYClearance = margin.
x == margin.
y;
441 VECTOR2I padPlotsSize =
pad->GetSize( aLayer ) + margin * 2 +
VECTOR2I( width_adj, width_adj );
449 double padCornerRadiusRatio =
pad->GetRoundRectRadiusRatio( aLayer );
454 && ( padPlotsSize.
x <= 0 || padPlotsSize.
y <= 0 ) )
463 pad->SetSize( aLayer, padPlotsSize );
467 (
pad->GetSize(aLayer ) ==
pad->GetDrillSize() ) &&
473 itemplotter.
PlotPad(
pad, aLayer, color, doSketchPads );
477 pad->SetSize( aLayer, padPlotsSize );
479 if( mask_clearance > 0 )
482 pad->SetRoundRectCornerRadius( aLayer, mask_clearance );
485 itemplotter.
PlotPad(
pad, aLayer, color, doSketchPads );
494 if( mask_clearance == 0 )
496 itemplotter.
PlotPad(
pad, aLayer, color, doSketchPads );
505 int dx = padSize.
x / 2;
506 int dy = padSize.
y / 2;
507 int ddx = padDelta.
x / 2;
508 int ddy = padDelta.
y / 2;
510 outline.
Append( -dx - ddy, dy + ddx );
511 outline.
Append( dx + ddy, dy - ddx );
512 outline.
Append( dx - ddy, -dy + ddx );
513 outline.
Append( -dx + ddy, -dy - ddx );
519 dummy.DeletePrimitivesList();
520 dummy.AddPrimitivePoly( aLayer, outline, 0,
true );
527 itemplotter.
PlotPad( &
dummy, aLayer, color, doSketchPads );
537 double radius_ratio =
pad->GetRoundRectRadiusRatio( aLayer );
538 pad->SetSize( aLayer, padPlotsSize );
539 pad->SetRoundRectRadiusRatio( aLayer, radius_ratio );
541 itemplotter.
PlotPad(
pad, aLayer, color, doSketchPads );
548 if( mask_clearance <= 0 )
551 pad->SetSize( aLayer, padPlotsSize );
552 itemplotter.
PlotPad(
pad, aLayer, color, doSketchPads );
568 if( !sameXYClearance )
569 dummy.SetSize( aLayer, padPlotsSize );
575 if( sameXYClearance )
582 dummy.DeletePrimitivesList();
583 dummy.AddPrimitivePoly( aLayer, outline, 0,
true );
590 dummy.SetPosition(
pad->GetPosition() );
591 dummy.SetOffset( aLayer,
pad->GetOffset( aLayer ) );
592 dummy.SetOrientation(
pad->GetOrientation() );
594 itemplotter.
PlotPad( &
dummy, aLayer, color, doSketchPads );
604 dummy.SetParentGroup(
nullptr );
607 pad->MergePrimitivesAsPolygon( aLayer, &shape );
613 dummy.DeletePrimitivesList();
614 dummy.AddPrimitivePoly( aLayer, shape, 0,
true );
619 if( mask_clearance < 0 )
622 std::max( 0, padPlotsSize.
y ) ) );
625 itemplotter.
PlotPad( &
dummy, aLayer, color, doSketchPads );
631 pad->SetSize( aLayer, padSize );
632 pad->SetDelta( aLayer, padDelta );
633 pad->SetShape( aLayer, padShape );
634 pad->SetRoundRectRadiusRatio( aLayer, padCornerRadiusRatio );
638 plotPadLayer( layer );
644 && ( ( onFrontFab && footprint->GetLayer() ==
F_Cu )
645 || ( onBackFab && footprint->GetLayer() ==
B_Cu ) ) )
647 const SHAPE_POLY_SET& courtyard = footprint->GetCourtyard( footprint->GetLayer() );
649 EDA_ANGLE orient = footprint->GetOrientation();
658 std::shared_ptr<SHAPE> shape = footprint->GetEffectiveShape();
659 shape->Rotate( -orient,
center );
660 localRect = shape->BBox();
666 localRect = temp.
BBox();
685 aPlotter->
SetColor( dnpMarkerColor );
689 aPlotter->
ThickSegment( corner1, corner3, width,
nullptr );
690 aPlotter->
ThickSegment( corner2, corner4, width,
nullptr );
710 return (
void*) &gbr_metadata;
712 return (
void*) &aPlotOpt;
714 return (
void*)
nullptr;
727 LSET via_mask_layer =
via->GetLayerSet();
729 if( !( via_mask_layer & aLayerMask ).
any() )
733 double width_adj = 0;
736 if( onSolderMaskLayer )
737 via_margin =
via->GetSolderMaskExpansion();
743 if( onCopperLayer && !
via->FlashLayer( aLayerMask ) )
749 diameter = std::max( diameter,
via->GetWidth( layer ) );
751 diameter += 2 * via_margin + width_adj;
766 if( aLayerMask.count() == 1 )
801 if( !( aLayerMask & track->GetLayerSet() ).any() )
808 gbr_metadata.
SetNetName( track->GetNetname() );
812 if( onSolderMaskLayer )
813 margin = track->GetSolderMaskExpansion();
815 int width = track->GetWidth() + 2 * margin + itemplotter.
getFineWidthAdj();
849 for(
const ZONE* zone : aBoard->
Zones() )
851 if( zone->GetIsRuleArea() )
856 if( !aLayerMask[layer] )
864 if( zone->IsIsland( layer, i ) )
871 itemplotter.
PlotZone( zone, layer, mainArea );
876 dummy.SetNet( &nonet );
907 std::vector<VECTOR2I> cornerList;
912 for(
int kk = 0; kk <= outlines.
HoleCount(ii); kk++ )
916 : outlines.
CHole( ii, kk - 1 );
927 for(
PAD*
pad : footprint->Pads() )
931 if(
pad->GetDrillSizeX() ==
pad->GetDrillSizeY() )
933 int drill =
pad->GetDrillSizeX();
936 drill = std::min( smallDrill, drill );
962 if(
via->GetLayerSet().Contains( layer ) )
976 bool aPlotFPText,
bool aPlotReferences,
bool aPlotValues )
999 auto handleFPTextItem =
1005 if( aText.GetText() == wxT(
"${REFERENCE}" ) && !aPlotReferences )
1008 if( aText.GetText() == wxT(
"${VALUE}" ) && !aPlotValues )
1012 aText.TransformTextToPolySet( exactPolys, 0, maxError,
ERROR_OUTSIDE );
1014 aText.TransformTextToPolySet( *aResult, inflate, maxError,
ERROR_OUTSIDE );
1025 footprint->TransformPadsToPolySet( exactPolys, aLayer, 0, maxError,
ERROR_OUTSIDE );
1027 footprint->TransformPadsToPolySet( *aResult, aLayer, inflate, maxError,
ERROR_OUTSIDE );
1029 for(
const PCB_FIELD* field : footprint->GetFields() )
1031 wxCHECK2( field,
continue );
1033 if( field->IsReference() && !aPlotReferences )
1036 if( field->IsValue() && !aPlotValues )
1039 if( field->IsVisible() && field->IsOnLayer( aLayer ) )
1040 handleFPTextItem(
static_cast<const PCB_TEXT&
>( *field ) );
1043 for(
const BOARD_ITEM* item : footprint->GraphicalItems() )
1045 if( item->IsOnLayer( aLayer ) )
1049 handleFPTextItem(
static_cast<const PCB_TEXT&
>( *item ) );
1054 item->TransformShapeToPolySet( exactPolys, aLayer, 0, maxError,
ERROR_OUTSIDE );
1056 item->TransformShapeToPolySet( *aResult, aLayer, inflate, maxError,
ERROR_OUTSIDE );
1066 if( !track->IsOnLayer( aLayer ) )
1069 int clearance = track->GetSolderMaskExpansion();
1079 if( item->IsOnLayer( aLayer ) )
1093 item->TransformShapeToPolySet( exactPolys, aLayer, 0, maxError,
ERROR_OUTSIDE,
1096 item->TransformShapeToPolySet( *aResult, aLayer, inflate, maxError,
1105 if( zone->GetIsRuleArea() )
1108 if( !zone->IsOnLayer( aLayer ) )
1119 exactPolys.
Append( area );
1154 bool autocenter =
false;
1163 sheet_info = &pageA4;
1165 paperscale = (double) paperSizeIU.
x / pageSizeIU.
x;
1170 sheet_info = &pageInfo;
1171 paperSizeIU = pageSizeIU;
1182 double compound_scale;
1186 if( aPlotOpts->
GetAutoScale() && boardSize.
x > 0 && boardSize.
y > 0 )
1188 double xscale = (paperSizeIU.
x * 0.8) / boardSize.
x;
1189 double yscale = (paperSizeIU.
y * 0.8) / boardSize.
y;
1191 compound_scale = std::min( xscale, yscale ) * paperscale;
1195 compound_scale = aPlotOpts->
GetScale() * paperscale;
1204 offset.
x =
KiROUND( boardCenter.
x - ( paperSizeIU.
x / 2.0 ) / compound_scale );
1205 offset.
y =
KiROUND( boardCenter.
y - ( paperSizeIU.
y / 2.0 ) / compound_scale );
1238 BOX2I area = aBbbox;
1272 const wxString& aLayerName,
const wxString& aFullFileName,
1273 const wxString& aSheetName,
const wxString& aSheetPath,
1274 const wxString& aPageName,
const wxString& aPageNumber,
1275 const int aPageCount )
1277 wxCHECK( aBoard && aPlotOpts,
nullptr );
1289 plotter = DXF_plotter;
1300 plotter = PS_plotter;
1308 wxLogError(
_(
"HPGL plotting is no longer supported as of KiCad 10.0" ) );
1316 wxLogError( wxString::Format(
"Invalid board layer %d, cannot build a valid Gerber file header",
1334 double iuPerInch =
pcbIUScale.IU_PER_MILS * 1000.0;
1337 KiROUND( sizeIU.
y * dpi / iuPerInch ) );
1340 plotter = pngPlotter;
1373 if( plotter->
OpenFile( aFullFileName ) )
1391 bool startPlotSuccess =
false;
1395 startPlotSuccess =
static_cast<PDF_PLOTTER*
>( plotter )->StartPlot( aPageNumber, aPageName );
1397 startPlotSuccess = plotter->
StartPlot( aPageName );
1401 startPlotSuccess =
false;
1405 if( startPlotSuccess )
1417 &aBoard->
GetProperties(), aPageNumber, aPageCount, aSheetName, aSheetPath,
1419 variantName, variantDesc );
1445 const wxString& aLayerName,
const wxString& aSheetName,
1446 const wxString& aSheetPath,
const wxString& aPageNumber,
1457 bool revertOps =
false;
1458 bool oldMirror = aPlotOpts->
GetMirror();
1460 double oldScale = aPlotOpts->
GetScale();
1462 if( oldMirror || oldAutoScale || oldScale != 1.0 )
1475 &aBoard->
GetProperties(), aPageNumber, aPageCount, aSheetName, aSheetPath,
1477 variantName, variantDesc );
constexpr EDA_IU_SCALE pcbIUScale
constexpr BOX2I KiROUND(const BOX2D &aBoxD)
static const ADVANCED_CFG & GetCfg()
Get the singleton instance's config, which is shared by all consumers.
const VECTOR2I & GetAuxOrigin() const
int m_LineThickness[LAYER_CLASS_COUNT]
A base class for any item which can be embedded within the BOARD container class, and therefore insta...
Information pertinent to a Pcbnew printed circuit board.
void ConvertBrdLayerToPolygonalContours(PCB_LAYER_ID aLayer, SHAPE_POLY_SET &aOutlines, KIGFX::RENDER_SETTINGS *aRenderSettings=nullptr) const
Build a set of polygons which are the outlines of copper items (pads, tracks, vias,...
const PAGE_INFO & GetPageSettings() const
const ZONES & Zones() const
TITLE_BLOCK & GetTitleBlock()
const std::map< wxString, wxString > & GetProperties() const
const FOOTPRINTS & Footprints() const
const TRACKS & Tracks() const
const wxString & GetFileName() const
wxString GetVariantDescription(const wxString &aVariantName) const
wxString GetCurrentVariant() const
PROJECT * GetProject() const
BOARD_DESIGN_SETTINGS & GetDesignSettings() const
BOX2I ComputeBoundingBox(bool aBoardEdgesOnly=false, bool aPhysicalLayersOnly=false) const
Calculate the bounding box containing all board items (or board edge segments).
const DRAWINGS & Drawings() 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 size_type GetWidth() const
constexpr Vec Centre() const
constexpr size_type GetHeight() const
constexpr coord_type GetLeft() const
constexpr void Move(const Vec &aMoveVector)
Move the rectangle by the aMoveVector.
constexpr const Vec & GetOrigin() const
constexpr coord_type GetRight() const
constexpr const SizeVec & GetSize() const
constexpr coord_type GetTop() const
constexpr coord_type GetBottom() const
void SetLayerSet(const LSET &aLayerMask)
void PlotDrillMarks()
Draw a drill mark for pads and vias.
void PlotZone(const ZONE *aZone, PCB_LAYER_ID aLayer, const SHAPE_POLY_SET &aPolysList)
void PlotPadNumber(const PAD *aPad, const COLOR4D &aColor)
void PlotBoardGraphicItem(const BOARD_ITEM *item)
Plot items like text and graphics but not tracks and footprints.
void PlotPad(const PAD *aPad, PCB_LAYER_ID aLayer, const COLOR4D &aColor, bool aSketchMode)
Plot a pad.
COLOR4D getColor(int aLayer) const
White color is special because it cannot be seen on a white paper in B&W mode.
void PlotFootprintTextItems(const FOOTPRINT *aFootprint)
int getFineWidthAdj() const
void PlotFootprintGraphicItems(const FOOTPRINT *aFootprint)
static const COLOR4D UNSPECIFIED
For legacy support; used as a value to indicate color hasn't been set yet.
static const COLOR4D BLACK
COLOR4D GetColor(int aLayer) const
When creating polygons to create a clearance polygonal area, the polygon must be same or bigger than ...
void SetUnits(DXF_UNITS aUnit)
Set the units to use for plotting the DXF file.
void UseX2format(bool aEnable)
void UseX2NetAttributes(bool aEnable)
void DisableApertMacros(bool aDisable)
Disable Aperture Macro (AM) command, only for broken Gerber Readers.
A color representation with 4 components: red, green, blue, alpha.
COLOR4D LegacyMix(const COLOR4D &aColor) const
Mix this COLOR4D with an input COLOR4D using the OR-mixing of legacy canvas.
PCB specific render settings.
void LoadColors(const COLOR_SETTINGS *aSettings) override
void SetDefaultPenWidth(int aWidth)
const COLOR4D & GetLayerColor(int aLayer) const
Return the color used to draw a layer.
void SetLayerName(const wxString &aLayerName)
LSEQ is a sequence (and therefore also a set) of PCB_LAYER_IDs.
LSET is a set of PCB_LAYER_IDs.
static const LSET & AllCuMask()
return AllCuMask( MAX_CU_LAYERS );
LSEQ SeqStackupForPlotting() const
Return the sequence that is typical for a bottom-to-top stack-up.
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.
Handle the data for a net.
Describe the page size and margins of a paper page on which to eventually print or plot.
int GetHeightIU(double aIUScale) const
Gets the page height in IU.
const VECTOR2D GetSizeIU(double aIUScale) const
Gets the page size in internal units.
int GetWidthIU(double aIUScale) const
Gets the page width in IU.
bool IsDegenerated(int aThreshold=5) const
EDA_ANGLE GetArcAngleStart() const
EDA_ANGLE GetAngle() const
virtual VECTOR2I GetCenter() const override
This defaults to the center of the bounding box if not overridden.
Parameters and options when plotting/printing a board.
PLOT_FORMAT GetFormat() const
bool GetSkipPlotNPTH_Pads() const
bool GetPngAntialias() const
void SetDrillMarksType(DRILL_MARKS aVal)
bool GetUseAuxOrigin() const
bool GetHideDNPFPsOnFabLayers() const
void SetSkipPlotNPTH_Pads(bool aSkip)
DXF_UNITS GetDXFPlotUnits() const
bool GetAutoScale() const
bool GetCrossoutDNPFPsOnFabLayers() const
void SetDXFPlotPolygonMode(bool aFlag)
void SetAutoScale(bool aFlag)
unsigned GetSvgPrecision() const
PLOT_TEXT_MODE GetTextMode() const override
bool GetDXFPlotPolygonMode() const
bool GetPlotReference() const
bool m_PDFFrontFPPropertyPopups
Generate PDF property popup menus for footprints.
void SetScale(double aVal)
void SetMirror(bool aFlag)
bool GetSketchPadsOnFabLayers() const
bool GetSubtractMaskFromSilk() const
int GetGerberPrecision() const
double GetFineScaleAdjustY() const
bool GetPlotPadNumbers() const
DRILL_MARKS GetDrillMarksType() const
bool GetUseGerberX2format() const
bool GetPlotValue() const
bool GetIncludeGerberNetlistInfo() const
double GetFineScaleAdjustX() const
bool GetBlackAndWhite() const
bool m_PDFBackFPPropertyPopups
on front and/or back of board
bool GetPlotFPText() const
bool GetPlotFrameRef() const
COLOR4D GetPDFBackgroundColor() const
bool GetDisableGerberMacros() const
std::vector< std::pair< PCB_LAYER_ID, wxString > > GetLayersToExport() const
COLOR_SETTINGS * ColorSettings() const
Base plotter engine class.
virtual void Circle(const VECTOR2I &pos, int diametre, FILL_T fill, int width)=0
virtual bool OpenFile(const wxString &aFullFilename)
Open or create the plot file aFullFilename.
virtual void SetNegative(bool aNegative)
virtual void SetSvgCoordinatesFormat(unsigned aPrecision)
Set the number of digits for mantissa in coordinates in mm for SVG plotter.
virtual void SetPageSettings(const PAGE_INFO &aPageSettings)
void SetRenderSettings(RENDER_SETTINGS *aSettings)
static const int USE_DEFAULT_LINE_WIDTH
virtual void ThickOval(const VECTOR2I &aPos, const VECTOR2I &aSize, const EDA_ANGLE &aOrient, int aWidth, void *aData)
virtual bool StartPlot(const wxString &aPageNumber)=0
void SetLayersToExport(const std::vector< std::pair< PCB_LAYER_ID, wxString > > &aLayersToExport)
Sets the list of layers to export to the specified vector.
RENDER_SETTINGS * RenderSettings()
virtual void SetGerberCoordinatesFormat(int aResolution, bool aUseInches=false)
virtual void Bookmark(const BOX2I &aBox, const wxString &aName, const wxString &aGroupName=wxEmptyString)
Create a bookmark to a symbol.
virtual PLOT_FORMAT GetPlotterType() const =0
Return the effective plot engine in use.
virtual void ThickArc(const EDA_SHAPE &aArcShape, void *aData, int aWidth)
virtual void SetTextMode(PLOT_TEXT_MODE mode)
Change the current text mode.
virtual void Rect(const VECTOR2I &p1, const VECTOR2I &p2, FILL_T fill, int width, int aCornerRadius=0)=0
virtual void SetCreator(const wxString &aCreator)
VECTOR2I GetPlotOffsetUserUnits()
void ClearHeaderLinesList()
Remove all lines from the list of free lines to print at the beginning of the file.
bool GetColorMode() const
PAGE_INFO & PageSettings()
virtual void SetViewport(const VECTOR2I &aOffset, double aIusPerDecimil, double aScale, bool aMirror)=0
Set the plot offset and scaling for the current plot.
virtual void SetColorMode(bool aColorMode)
Plot in B/W or color.
virtual void StartBlock(void *aData)
calling this function allows one to define the beginning of a group of drawing items,...
virtual void ThickSegment(const VECTOR2I &start, const VECTOR2I &end, int width, void *aData)
virtual void PlotPoly(const std::vector< VECTOR2I > &aCornerList, FILL_T aFill, int aWidth, void *aData)=0
Draw a polygon ( filled or not ).
virtual void FlashPadCircle(const VECTOR2I &aPadPos, int aDiameter, void *aData)=0
virtual void HyperlinkMenu(const BOX2I &aBox, const std::vector< wxString > &aDestURLs)
Create a clickable hyperlink menu with a rectangular click area.
virtual void SetLayerPolarity(bool aPositive)
Set the current Gerber layer polarity to positive or negative by writing %LPD*% or %LPC*% to the Gerb...
virtual void ThickCircle(const VECTOR2I &pos, int diametre, int width, void *aData)
virtual void SetColor(const COLOR4D &color)=0
virtual void EndBlock(void *aData)
calling this function allows one to define the end of a group of drawing items for instance in SVG or...
PNG rasterization plotter using Cairo graphics library.
void SetPixelSize(int aWidth, int aHeight)
Set the output image dimensions in pixels.
void SetResolution(int aDPI)
Set the output resolution in dots per inch.
void SetAntialias(bool aEnable)
Enable or disable anti-aliasing.
void SetScaleAdjust(double scaleX, double scaleY)
Set the 'fine' scaling for the postscript engine.
Represent a polyline containing arcs as well as line segments: A chain of connected line and/or arc s...
Represent a set of closed polygons.
void Rotate(const EDA_ANGLE &aAngle, const VECTOR2I &aCenter={ 0, 0 }) override
Rotate all vertices by a given angle.
void RemoveAllContours()
Remove all outlines & holes (clears) the polygon set.
void BooleanAdd(const SHAPE_POLY_SET &b)
Perform boolean polyset union.
int AddOutline(const SHAPE_LINE_CHAIN &aOutline)
Adds a new outline to the set and returns its index.
void DeletePolygon(int aIdx)
Delete aIdx-th polygon from the set.
bool IsEmpty() const
Return true if the set is empty (no polygons at all)
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)
void Simplify()
Simplify the polyset (merges overlapping polys, eliminates degeneracy/self-intersections)
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 InflateWithLinkedHoles(int aFactor, CORNER_STRATEGY aCornerStrategy, int aMaxError)
Perform outline inflation/deflation, using round corners.
void Fracture(bool aSimplify=true)
Convert a set of polygons with holes to a single outline with "slits"/"fractures" connecting the oute...
SHAPE_POLY_SET CloneDropTriangulation() const
void BooleanSubtract(const SHAPE_POLY_SET &b)
Perform boolean polyset difference.
const POLYGON & CPolygon(int aIndex) const
const SHAPE_LINE_CHAIN & COutline(int aIndex) const
const BOX2I BBox(int aClearance=0) const override
Compute a bounding box of the shape, with a margin of aClearance a collision.
Handle a list of polygons defining a copper zone.
void SetMinThickness(int aMinThickness)
virtual void SetLayer(PCB_LAYER_ID aLayer) override
Set the layer this item is on.
A type-safe container of any type.
constexpr any() noexcept
Default constructor, creates an empty object.
void PlotDrawingSheet(PLOTTER *plotter, const PROJECT *aProject, const TITLE_BLOCK &aTitleBlock, const PAGE_INFO &aPageInfo, const std::map< wxString, wxString > *aProperties, const wxString &aSheetNumber, int aSheetCount, const wxString &aSheetName, const wxString &aSheetPath, const wxString &aFilename, COLOR4D aColor, bool aIsFirstPage, const wxString &aVariantName, const wxString &aVariantDesc)
@ CHAMFER_ALL_CORNERS
All angles are chamfered.
@ ROUND_ALL_CORNERS
All angles are rounded.
static constexpr EDA_ANGLE ANGLE_0
@ FILLED_SHAPE
Fill with object color.
a few functions useful in geometry calculations.
bool IsCopperLayer(int aLayerId)
Test whether a layer is a copper layer.
@ LAYER_DRAWINGSHEET
Sheet frame and title block.
@ LAYER_VIAS
Meta control for all vias opacity/visibility.
PCB_LAYER_ID
A quick note on layer IDs:
@ NPTH
like PAD_PTH, but not plated mechanical use only, no connection allowed
PAD_SHAPE
The set of pad shapes, used with PAD::{Set,Get}Shape()
void AddGerberX2Attribute(PLOTTER *aPlotter, const BOARD *aBoard, int aLayer, bool aUseX1CompatibilityMode)
Calculate some X2 attributes as defined in the Gerber file format specification and add them to the g...
void GenerateLayerPoly(SHAPE_POLY_SET *aResult, BOARD *aBoard, PLOTTER *aPlotter, PCB_LAYER_ID aLayer, bool aPlotFPText, bool aPlotReferences, bool aPlotValues)
Generates a SHAPE_POLY_SET representing the plotted items on a layer.
static void FillNegativeKnockout(PLOTTER *aPlotter, const BOX2I &aBbbox)
Prefill in black an area a little bigger than the board to prepare for the negative plot.
void PlotClippedSilkLayer(BOARD *aBoard, PLOTTER *aPlotter, const LSET &aLayerMask, const PCB_PLOT_PARAMS &aPlotOpt)
void PlotBoardLayers(BOARD *aBoard, PLOTTER *aPlotter, const LSEQ &aLayers, const PCB_PLOT_PARAMS &aPlotOptions)
Plot a sequence of board layer IDs.
void PlotStandardLayer(BOARD *aBoard, PLOTTER *aPlotter, const LSET &aLayerMask, const PCB_PLOT_PARAMS &aPlotOpt)
Plot any layer EXCEPT a solder-mask with an enforced minimum width.
PLOTTER * StartPlotBoard(BOARD *aBoard, const PCB_PLOT_PARAMS *aPlotOpts, int aLayer, const wxString &aLayerName, const wxString &aFullFileName, const wxString &aSheetName, const wxString &aSheetPath, const wxString &aPageName, const wxString &aPageNumber, const int aPageCount)
Open a new plotfile using the options (and especially the format) specified in the options and prepar...
void PlotPolySet(BOARD *aBoard, PLOTTER *aPlotter, const PCB_PLOT_PARAMS &aPlotOpt, SHAPE_POLY_SET *aPolySet, PCB_LAYER_ID aLayer)
void setupPlotterNewPDFPage(PLOTTER *aPlotter, BOARD *aBoard, PCB_PLOT_PARAMS *aPlotOpts, const wxString &aLayerName, const wxString &aSheetName, const wxString &aSheetPath, const wxString &aPageNumber, int aPageCount)
void PlotSolderMaskLayer(BOARD *aBoard, PLOTTER *aPlotter, const LSET &aLayerMask, const PCB_PLOT_PARAMS &aPlotOpt)
Plot a solder mask layer.
static void initializePlotter(PLOTTER *aPlotter, const BOARD *aBoard, const PCB_PLOT_PARAMS *aPlotOpts)
Set up most plot options for plotting a board (especially the viewport) Important thing: page size is...
void PlotInteractiveLayer(BOARD *aBoard, PLOTTER *aPlotter, const PCB_PLOT_PARAMS &aPlotOpt)
Plot interactive items (hypertext links, properties, etc.).
void PlotOneBoardLayer(BOARD *aBoard, PLOTTER *aPlotter, PCB_LAYER_ID aLayer, const PCB_PLOT_PARAMS &aPlotOpt, bool isPrimaryLayer)
Plot one copper or technical layer.
void PlotLayer(BOARD *aBoard, PLOTTER *aPlotter, const LSET &layerMask, const PCB_PLOT_PARAMS &plotOpts)
void PlotLayerOutlines(BOARD *aBoard, PLOTTER *aPlotter, const LSET &aLayerMask, const PCB_PLOT_PARAMS &aPlotOpt)
Plot outlines.
static void plotPdfBackground(BOARD *aBoard, const PCB_PLOT_PARAMS *aPlotOpts, PLOTTER *aPlotter)
Plotting engines similar to ps (PostScript, Gerber, svg)
std::vector< FAB_LAYER_COLOR > dummy
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_VIA_T
class PCB_VIA, a via (like a track segment on a copper layer)
@ PCB_TEXT_T
class PCB_TEXT, text on a layer
@ PCB_ARC_T
class PCB_ARC, an arc track segment on a copper layer
VECTOR2< int32_t > VECTOR2I
VECTOR2< double > VECTOR2D