KiCad PCB EDA Suite
|
#include <graphics_importer_pcbnew.h>
Public Types | |
enum | POLY_FILL_RULE { PF_NONZERO = 0 , PF_EVEN_ODD } |
Public Member Functions | |
GRAPHICS_IMPORTER_PCBNEW (BOARD_ITEM_CONTAINER *aParent) | |
void | SetLayer (PCB_LAYER_ID aLayer) |
PCB_LAYER_ID | GetLayer () const |
void | AddLine (const VECTOR2D &aStart, const VECTOR2D &aEnd, const IMPORTED_STROKE &aStroke) override |
Create an object representing a line segment. | |
void | AddCircle (const VECTOR2D &aCenter, double aRadius, const IMPORTED_STROKE &aStroke, bool aFilled, const COLOR4D &aFillColor=COLOR4D::UNSPECIFIED) override |
Create an object representing a circle. | |
void | AddArc (const VECTOR2D &aCenter, const VECTOR2D &aStart, const EDA_ANGLE &aAngle, const IMPORTED_STROKE &aStroke) override |
Create an object representing an arc. | |
void | AddPolygon (const std::vector< VECTOR2D > &aVertices, const IMPORTED_STROKE &aStroke, bool aFilled, const COLOR4D &aFillColor=COLOR4D::UNSPECIFIED) override |
Create an object representing a polygon. | |
void | AddText (const VECTOR2D &aOrigin, const wxString &aText, double aHeight, double aWidth, double aThickness, double aOrientation, GR_TEXT_H_ALIGN_T aHJustify, GR_TEXT_V_ALIGN_T aVJustify, const COLOR4D &aColor=COLOR4D::UNSPECIFIED) override |
Create an object representing a text. | |
void | AddSpline (const VECTOR2D &aStart, const VECTOR2D &aBezierControl1, const VECTOR2D &aBezierControl2, const VECTOR2D &aEnd, const IMPORTED_STROKE &aStroke) override |
Create an object representing an arc. | |
VECTOR2I | MapCoordinate (const VECTOR2D &aCoordinate) |
Convert an imported coordinate to a board coordinate, according to the internal units, user scale and offset. | |
int | MapLineWidth (double aLineWidth) |
If aLineWidth < 0, the default line thickness value is returned. | |
STROKE_PARAMS | MapStrokeParams (const IMPORTED_STROKE &aStroke) |
void | SetPlugin (std::unique_ptr< GRAPHICS_IMPORT_PLUGIN > aPlugin) |
Set the import plugin used to obtain shapes from a file. | |
bool | Load (const wxString &aFileName) |
Load file and get its basic data. | |
bool | Import (const VECTOR2D &aScale=VECTOR2D(1.0, 1.0)) |
Import shapes from loaded file. | |
const wxString & | GetMessages () const |
Collect warning and error messages after loading/importing. | |
void | ReportMsg (const wxString &aMessage) |
double | GetImageWidthMM () const |
Get original image Width. | |
double | GetImageHeightMM () const |
Get original image Height. | |
void | SetLineWidthMM (double aWidth) |
Set the line width for the imported outlines (in mm). | |
double | GetLineWidthMM () const |
Return the line width used for importing the outlines (in mm). | |
VECTOR2D | GetScale () const |
const VECTOR2D & | GetImportOffsetMM () const |
void | SetImportOffsetMM (const VECTOR2D &aOffset) |
Set the offset in millimeters to add to coordinates when importing graphic items. | |
void | SetScale (const VECTOR2D &aScale) |
Set the scale factor affecting the imported shapes. | |
double | GetMillimeterToIuFactor () |
VECTOR2D | ImportScalingFactor () const |
std::list< std::unique_ptr< EDA_ITEM > > & | GetItems () |
Return the list of objects representing the imported shapes. | |
void | ClearItems () |
Empties out the imported shapes list. | |
virtual void | NewShape (POLY_FILL_RULE aFillRule=PF_NONZERO) |
Static Public Attributes | |
static constexpr unsigned int | DEFAULT_LINE_WIDTH_DFX = 1 |
Default line thickness (in mm). | |
Protected Member Functions | |
void | addItem (std::unique_ptr< EDA_ITEM > aItem) |
Add an item to the imported shapes list. | |
bool | setupSplineOrLine (EDA_SHAPE &aShape, int aAccuracy) |
Configure a shape as a spline or a line segment if it's degenerate. | |
Protected Attributes | |
PCB_LAYER_ID | m_layer |
< Target layer for the imported shapes. | |
BOARD_ITEM_CONTAINER * | m_parent |
double | m_millimeterToIu |
Factor to convert millimeters to Internal Units. | |
VECTOR2D | m_offsetCoordmm |
Offset (in mm) for imported coordinates. | |
std::vector< POLY_FILL_RULE > | m_shapeFillRules |
Private Attributes | |
std::list< std::unique_ptr< EDA_ITEM > > | m_items |
List of imported items. | |
std::unique_ptr< GRAPHICS_IMPORT_PLUGIN > | m_plugin |
Plugin used to load a file. | |
double | m_originalWidth |
Total image width. | |
double | m_originalHeight |
Total image Height. | |
VECTOR2D | m_scale |
Scale factor applied to the imported graphics. | |
double | m_lineWidth |
Default line thickness for the imported graphics. | |
Definition at line 35 of file graphics_importer_pcbnew.h.
|
inherited |
Enumerator | |
---|---|
PF_NONZERO | |
PF_EVEN_ODD |
Definition at line 79 of file graphics_importer.h.
GRAPHICS_IMPORTER_PCBNEW::GRAPHICS_IMPORTER_PCBNEW | ( | BOARD_ITEM_CONTAINER * | aParent | ) |
Definition at line 36 of file graphics_importer_pcbnew.cpp.
References Dwgs_User, m_layer, GRAPHICS_IMPORTER::m_millimeterToIu, EDA_IU_SCALE::mmToIU(), and pcbIUScale.
|
overridevirtual |
Create an object representing an arc.
aCenter | is the arc center point expressed in mm. |
aStart | is the arc arm end point expressed in mm. Its length is the arc radius. |
aAngle | is the arc angle. |
aStroke | is the shape stroke parameters. |
We need to perform the rotation/conversion here while still using floating point values to avoid rounding errors when operating in integer space in pcbnew
Implements GRAPHICS_IMPORTER.
Definition at line 111 of file graphics_importer_pcbnew.cpp.
References GRAPHICS_IMPORTER::addItem(), AddLine(), GetLayer(), m_parent, MapCoordinate(), MapStrokeParams(), and RotatePoint().
|
overridevirtual |
Create an object representing a circle.
aCenter | is the circle center point expressed in mm. |
aRadius | is the circle radius expressed in mm. |
aStroke | is the shape stroke parameters. |
Implements GRAPHICS_IMPORTER.
Definition at line 95 of file graphics_importer_pcbnew.cpp.
References GRAPHICS_IMPORTER::addItem(), GetLayer(), m_parent, MapCoordinate(), MapStrokeParams(), VECTOR2< T >::x, and VECTOR2< T >::y.
|
protectedinherited |
Add an item to the imported shapes list.
Definition at line 105 of file graphics_importer.cpp.
References GRAPHICS_IMPORTER::m_items.
Referenced by GRAPHICS_IMPORTER_LIB_SYMBOL::AddArc(), GRAPHICS_IMPORTER_SCH::AddArc(), AddArc(), GRAPHICS_IMPORTER_LIB_SYMBOL::AddCircle(), GRAPHICS_IMPORTER_SCH::AddCircle(), AddCircle(), GRAPHICS_IMPORTER_LIB_SYMBOL::AddLine(), GRAPHICS_IMPORTER_SCH::AddLine(), AddLine(), GRAPHICS_IMPORTER_LIB_SYMBOL::AddPolygon(), GRAPHICS_IMPORTER_SCH::AddPolygon(), AddPolygon(), GRAPHICS_IMPORTER_LIB_SYMBOL::AddSpline(), GRAPHICS_IMPORTER_SCH::AddSpline(), AddSpline(), GRAPHICS_IMPORTER_LIB_SYMBOL::AddText(), GRAPHICS_IMPORTER_SCH::AddText(), and AddText().
|
overridevirtual |
Create an object representing a line segment.
aOrigin | is the segment origin point expressed in mm. |
aEnd | is the segment end point expressed in mm. |
aStroke | is the shape stroke parameters. |
Implements GRAPHICS_IMPORTER.
Definition at line 77 of file graphics_importer_pcbnew.cpp.
References GRAPHICS_IMPORTER::addItem(), GetLayer(), m_parent, MapCoordinate(), and MapStrokeParams().
Referenced by AddArc().
|
overridevirtual |
Create an object representing a polygon.
aVertices | is the array of vertices. |
aWidth | is the stroke width. |
aStroke | is the shape stroke parameters. |
aFillColor | is the fill color. |
Implements GRAPHICS_IMPORTER.
Definition at line 150 of file graphics_importer_pcbnew.cpp.
References GRAPHICS_IMPORTER::addItem(), GetLayer(), BOARD_ITEM::GetParentFootprint(), m_parent, MapCoordinate(), and MapStrokeParams().
|
overridevirtual |
Create an object representing an arc.
aStart | is the curve start point expressed in mm. |
aBezierControl1 | is the first Bezier control point expressed in mm. |
aBezierControl2 | is the second Bezier control point expressed in mm. |
aEnd | is the curve end point expressed in mm. |
aStroke | is the shape stroke parameters. |
Implements GRAPHICS_IMPORTER.
Definition at line 199 of file graphics_importer_pcbnew.cpp.
References GRAPHICS_IMPORTER::addItem(), ARC_HIGH_DEF, GetLayer(), m_parent, MapCoordinate(), MapStrokeParams(), and GRAPHICS_IMPORTER::setupSplineOrLine().
|
overridevirtual |
Create an object representing a text.
aOrigin | is the text position. |
aText | is the displayed text. |
aHeight | is the text height expressed in mm. |
aWidth | is the text width expressed in mm. |
aOrientation | is the text orientation angle expressed in degrees. |
aHJustify | is the text horizontal justification. |
aVJustify | is the text vertical justification. |
aWidth | is the segment thickness in mm. Use -1 for default line thickness |
aColor | is the shape color |
Implements GRAPHICS_IMPORTER.
Definition at line 179 of file graphics_importer_pcbnew.cpp.
References GRAPHICS_IMPORTER::addItem(), DEGREES_T, GetLayer(), GRAPHICS_IMPORTER::ImportScalingFactor(), m_parent, MapCoordinate(), and MapLineWidth().
|
inlineinherited |
Empties out the imported shapes list.
Definition at line 231 of file graphics_importer.h.
References GRAPHICS_IMPORTER::m_items.
|
inlineinherited |
Get original image Height.
Definition at line 149 of file graphics_importer.h.
References GRAPHICS_IMPORTER::m_originalHeight.
|
inlineinherited |
Get original image Width.
Definition at line 139 of file graphics_importer.h.
References GRAPHICS_IMPORTER::m_originalWidth.
|
inlineinherited |
Definition at line 181 of file graphics_importer.h.
References GRAPHICS_IMPORTER::m_offsetCoordmm.
Referenced by GRAPHICS_IMPORTER_BUFFER::ImportTo(), GRAPHICS_IMPORTER_LIB_SYMBOL::MapCoordinate(), GRAPHICS_IMPORTER_SCH::MapCoordinate(), and MapCoordinate().
|
inlineinherited |
Return the list of objects representing the imported shapes.
Definition at line 223 of file graphics_importer.h.
References GRAPHICS_IMPORTER::m_items.
Referenced by SCH_EASYEDAPRO_PARSER::ParseSchematic(), SCH_EASYEDA_PARSER::ParseSchematic(), SCH_EASYEDAPRO_PARSER::ParseSymbol(), and SCH_EASYEDA_PARSER::ParseSymbolShapes().
|
inline |
Definition at line 41 of file graphics_importer_pcbnew.h.
References m_layer.
Referenced by AddArc(), AddCircle(), AddLine(), AddPolygon(), AddSpline(), and AddText().
|
inlineinherited |
Return the line width used for importing the outlines (in mm).
Definition at line 165 of file graphics_importer.h.
References GRAPHICS_IMPORTER::m_lineWidth.
Referenced by GRAPHICS_IMPORTER_LIB_SYMBOL::MapLineWidth(), GRAPHICS_IMPORTER_SCH::MapLineWidth(), MapLineWidth(), and DXF_IMPORT_PLUGIN::SetImporter().
|
inlineinherited |
Collect warning and error messages after loading/importing.
Definition at line 124 of file graphics_importer.h.
References GRAPHICS_IMPORTER::m_plugin.
|
inlineinherited |
Definition at line 207 of file graphics_importer.h.
References GRAPHICS_IMPORTER::m_millimeterToIu.
Referenced by GRAPHICS_IMPORTER_BUFFER::ImportTo(), GRAPHICS_IMPORTER_LIB_SYMBOL::MapCoordinate(), GRAPHICS_IMPORTER_SCH::MapCoordinate(), and MapCoordinate().
|
inlineinherited |
Definition at line 173 of file graphics_importer.h.
References GRAPHICS_IMPORTER::m_scale.
Referenced by GRAPHICS_IMPORTER_BUFFER::ImportTo(), GRAPHICS_IMPORTER_LIB_SYMBOL::MapCoordinate(), GRAPHICS_IMPORTER_SCH::MapCoordinate(), and MapCoordinate().
Import shapes from loaded file.
It is important to have the file loaded before importing.
aScale | allow import graphic items with a non 1:1 import ratio VECTOR2D( 1.0, 1.0 ) to import graphics with their actual size. |
Definition at line 70 of file graphics_importer.cpp.
References GRAPHICS_IMPORTER::m_plugin, and GRAPHICS_IMPORTER::SetScale().
|
inlineinherited |
Definition at line 215 of file graphics_importer.h.
References GRAPHICS_IMPORTER::m_millimeterToIu, and GRAPHICS_IMPORTER::m_scale.
Referenced by GRAPHICS_IMPORTER_LIB_SYMBOL::AddText(), GRAPHICS_IMPORTER_SCH::AddText(), AddText(), GRAPHICS_IMPORTER_LIB_SYMBOL::MapLineWidth(), GRAPHICS_IMPORTER_SCH::MapLineWidth(), and MapLineWidth().
|
inherited |
Load file and get its basic data.
Definition at line 46 of file graphics_importer.cpp.
References GRAPHICS_IMPORTER::m_items, GRAPHICS_IMPORTER::m_originalHeight, GRAPHICS_IMPORTER::m_originalWidth, and GRAPHICS_IMPORTER::m_plugin.
Convert an imported coordinate to a board coordinate, according to the internal units, user scale and offset.
aCoordinate | is the imported coordinate in mm. |
Definition at line 44 of file graphics_importer_pcbnew.cpp.
References GRAPHICS_IMPORTER::GetImportOffsetMM(), GRAPHICS_IMPORTER::GetMillimeterToIuFactor(), GRAPHICS_IMPORTER::GetScale(), KiROUND(), VECTOR2< T >::x, and VECTOR2< T >::y.
Referenced by AddArc(), AddCircle(), AddLine(), AddPolygon(), AddSpline(), and AddText().
int GRAPHICS_IMPORTER_PCBNEW::MapLineWidth | ( | double | aLineWidth | ) |
If aLineWidth < 0, the default line thickness value is returned.
aLineWidth | is the line thickness in mm to convert. |
Definition at line 55 of file graphics_importer_pcbnew.cpp.
References GRAPHICS_IMPORTER::GetLineWidthMM(), GRAPHICS_IMPORTER::ImportScalingFactor(), scale, VECTOR2< T >::x, and VECTOR2< T >::y.
Referenced by AddText(), and MapStrokeParams().
STROKE_PARAMS GRAPHICS_IMPORTER_PCBNEW::MapStrokeParams | ( | const IMPORTED_STROKE & | aStroke | ) |
Definition at line 68 of file graphics_importer_pcbnew.cpp.
References IMPORTED_STROKE::GetColor(), IMPORTED_STROKE::GetPlotStyle(), IMPORTED_STROKE::GetWidth(), and MapLineWidth().
Referenced by AddArc(), AddCircle(), AddLine(), AddPolygon(), and AddSpline().
|
virtualinherited |
Definition at line 99 of file graphics_importer.cpp.
References GRAPHICS_IMPORTER::m_shapeFillRules.
Referenced by SVG_IMPORT_PLUGIN::Import().
|
inlineinherited |
Definition at line 129 of file graphics_importer.h.
References GRAPHICS_IMPORTER::m_plugin.
Referenced by GRAPHICS_IMPORTER_BUFFER::ImportTo().
|
inlineinherited |
Set the offset in millimeters to add to coordinates when importing graphic items.
Definition at line 189 of file graphics_importer.h.
References GRAPHICS_IMPORTER::m_offsetCoordmm.
Referenced by ConvertSVGToLibShapes(), GRAPHICS_IMPORTER_BUFFER::ImportTo(), SCH_EASYEDAPRO_PARSER::ParseSchematic(), SCH_EASYEDA_PARSER::ParseSchematic(), SCH_EASYEDAPRO_PARSER::ParseSymbol(), and SCH_EASYEDA_PARSER::ParseSymbolShapes().
|
inline |
Definition at line 40 of file graphics_importer_pcbnew.h.
References m_layer.
|
inlineinherited |
Set the line width for the imported outlines (in mm).
Definition at line 157 of file graphics_importer.h.
References GRAPHICS_IMPORTER::m_lineWidth.
|
inlineinherited |
Set the import plugin used to obtain shapes from a file.
Definition at line 94 of file graphics_importer.h.
References GRAPHICS_IMPORTER::m_plugin.
|
inlineinherited |
Set the scale factor affecting the imported shapes.
This allows conversion between imported shapes units and millimeters.
Definition at line 199 of file graphics_importer.h.
References GRAPHICS_IMPORTER::m_scale.
Referenced by ConvertSVGToLibShapes(), GRAPHICS_IMPORTER::Import(), SCH_EASYEDAPRO_PARSER::ParseSchematic(), SCH_EASYEDA_PARSER::ParseSchematic(), SCH_EASYEDAPRO_PARSER::ParseSymbol(), and SCH_EASYEDA_PARSER::ParseSymbolShapes().
|
protectedinherited |
Configure a shape as a spline or a line segment if it's degenerate.
Definition at line 111 of file graphics_importer.cpp.
References EDA_SHAPE::GetBezierC1(), EDA_SHAPE::GetBezierC2(), EDA_SHAPE::GetBezierPoints(), EDA_SHAPE::GetEnd(), EDA_SHAPE::GetStart(), MIN_SEG_LEN_ACCEPTABLE_NM, EDA_SHAPE::RebuildBezierToSegmentsPointsList(), and EDA_SHAPE::SetShape().
Referenced by GRAPHICS_IMPORTER_SCH::AddSpline(), and AddSpline().
|
staticconstexprinherited |
Default line thickness (in mm).
Definition at line 237 of file graphics_importer.h.
Referenced by GRAPHICS_IMPORTER::GRAPHICS_IMPORTER().
|
privateinherited |
List of imported items.
Definition at line 336 of file graphics_importer.h.
Referenced by GRAPHICS_IMPORTER::addItem(), GRAPHICS_IMPORTER::ClearItems(), GRAPHICS_IMPORTER::GetItems(), and GRAPHICS_IMPORTER::Load().
|
protected |
< Target layer for the imported shapes.
Definition at line 84 of file graphics_importer_pcbnew.h.
Referenced by GetLayer(), GRAPHICS_IMPORTER_PCBNEW(), and SetLayer().
|
privateinherited |
Default line thickness for the imported graphics.
Definition at line 356 of file graphics_importer.h.
Referenced by GRAPHICS_IMPORTER::GetLineWidthMM(), GRAPHICS_IMPORTER::GRAPHICS_IMPORTER(), and GRAPHICS_IMPORTER::SetLineWidthMM().
|
protectedinherited |
Factor to convert millimeters to Internal Units.
Definition at line 327 of file graphics_importer.h.
Referenced by GRAPHICS_IMPORTER::GetMillimeterToIuFactor(), GRAPHICS_IMPORTER::GRAPHICS_IMPORTER(), GRAPHICS_IMPORTER_LIB_SYMBOL::GRAPHICS_IMPORTER_LIB_SYMBOL(), GRAPHICS_IMPORTER_PCBNEW(), GRAPHICS_IMPORTER_SCH::GRAPHICS_IMPORTER_SCH(), and GRAPHICS_IMPORTER::ImportScalingFactor().
|
protectedinherited |
Offset (in mm) for imported coordinates.
Definition at line 330 of file graphics_importer.h.
Referenced by GRAPHICS_IMPORTER::GetImportOffsetMM(), and GRAPHICS_IMPORTER::SetImportOffsetMM().
|
privateinherited |
Total image Height.
Definition at line 345 of file graphics_importer.h.
Referenced by GRAPHICS_IMPORTER::GetImageHeightMM(), GRAPHICS_IMPORTER::GRAPHICS_IMPORTER(), and GRAPHICS_IMPORTER::Load().
|
privateinherited |
Total image width.
Definition at line 342 of file graphics_importer.h.
Referenced by GRAPHICS_IMPORTER::GetImageWidthMM(), GRAPHICS_IMPORTER::GRAPHICS_IMPORTER(), and GRAPHICS_IMPORTER::Load().
|
protected |
Definition at line 85 of file graphics_importer_pcbnew.h.
Referenced by AddArc(), AddCircle(), AddLine(), AddPolygon(), AddSpline(), and AddText().
|
privateinherited |
Plugin used to load a file.
Definition at line 339 of file graphics_importer.h.
Referenced by GRAPHICS_IMPORTER::GetMessages(), GRAPHICS_IMPORTER::Import(), GRAPHICS_IMPORTER::Load(), GRAPHICS_IMPORTER::ReportMsg(), and GRAPHICS_IMPORTER::SetPlugin().
|
privateinherited |
Scale factor applied to the imported graphics.
1.0 does not change the size of imported items scale < 1.0 reduce the size of imported items
Definition at line 353 of file graphics_importer.h.
Referenced by GRAPHICS_IMPORTER::GetScale(), GRAPHICS_IMPORTER::GRAPHICS_IMPORTER(), GRAPHICS_IMPORTER::ImportScalingFactor(), and GRAPHICS_IMPORTER::SetScale().
|
protectedinherited |
Definition at line 332 of file graphics_importer.h.
Referenced by GRAPHICS_IMPORTER_BUFFER::AddPolygon(), GRAPHICS_IMPORTER::NewShape(), and GRAPHICS_IMPORTER_BUFFER::PostprocessNestedPolygons().