|
KiCad PCB EDA Suite
|
#include <shape_ellipse.h>
Public Member Functions | |
| SHAPE_ELLIPSE () | |
| SHAPE_ELLIPSE (const VECTOR2I &aCenter, int aMajorRadius, int aMinorRadius, const EDA_ANGLE &aRotation) | |
| SHAPE_ELLIPSE (const VECTOR2I &aCenter, int aMajorRadius, int aMinorRadius, const EDA_ANGLE &aRotation, const EDA_ANGLE &aStartAngle, const EDA_ANGLE &aEndAngle) | |
| SHAPE_ELLIPSE (const VECTOR2I &aCenter, const VECTOR2I &aMajorEndpoint, double aRatio) | |
| SHAPE_ELLIPSE (const VECTOR2I &aCenter, const VECTOR2I &aMajorEndpoint, double aRatio, const EDA_ANGLE &aStartAngle, const EDA_ANGLE &aEndAngle) | |
| SHAPE_ELLIPSE (const SHAPE_ELLIPSE &aOther)=default | |
| SHAPE_ELLIPSE & | operator= (const SHAPE_ELLIPSE &)=default |
| ~SHAPE_ELLIPSE () override=default | |
| SHAPE * | Clone () const override |
| Return a dynamically allocated copy of the shape. | |
| const VECTOR2I & | GetCenter () const |
| int | GetMajorRadius () const |
| int | GetMinorRadius () const |
| const EDA_ANGLE & | GetRotation () const |
| const EDA_ANGLE & | GetStartAngle () const |
| const EDA_ANGLE & | GetEndAngle () const |
| bool | IsArc () const |
| void | SetCenter (const VECTOR2I &aCenter) |
| void | SetMajorRadius (int aRadius) |
| void | SetMinorRadius (int aRadius) |
| void | SetRotation (const EDA_ANGLE &aAngle) |
| void | SetStartAngle (const EDA_ANGLE &aAngle) |
| void | SetEndAngle (const EDA_ANGLE &aAngle) |
| const BOX2I | BBox (int aClearance=0) const override |
| Compute a bounding box of the shape, with a margin of aClearance a collision. | |
| bool | Collide (const SEG &aSeg, int aClearance=0, int *aActual=nullptr, VECTOR2I *aLocation=nullptr) const override |
| Check if the boundary of shape (this) lies closer to the segment aSeg than aClearance, indicating a collision. | |
| bool | Collide (const SHAPE *aShape, int aClearance=0, int *aActual=nullptr, VECTOR2I *aLocation=nullptr) const override |
| void | TransformToPolygon (SHAPE_POLY_SET &aBuffer, int aError, ERROR_LOC aErrorLoc) const override |
| Fills a SHAPE_POLY_SET with a polygon representation of this shape. | |
| void | Rotate (const EDA_ANGLE &aAngle, const VECTOR2I &aCenter={ 0, 0 }) override |
| void | Move (const VECTOR2I &aVector) override |
| bool | IsSolid () const override |
| void | Mirror (const VECTOR2I &aRef, FLIP_DIRECTION aFlipDirection) |
| Mirror the ellipse across a horizontal or vertical axis passing through aRef. | |
| const std::string | Format (bool aCplusPlus=true) const override |
| Serialize the ellipse. | |
| double | GetLength () const |
| SHAPE_LINE_CHAIN | ConvertToPolyline (int aMaxError) const |
| Build a polyline approximation of the ellipse or arc. | |
| bool | PointInside (const VECTOR2I &aPt, int aAccuracy=0, bool aUseBBoxCache=false) const override |
| Check if point aP lies inside a closed shape. | |
| SEG::ecoord | SquaredDistance (const VECTOR2I &aP, bool aOutlineOnly=false) const override |
| int | GetClearance (const SHAPE *aOther) const |
| Return the actual minimum distance between two shapes. | |
| bool | IsNull () const |
| Return true if the shape is a null shape. | |
| virtual bool | Collide (const VECTOR2I &aP, int aClearance=0, int *aActual=nullptr, VECTOR2I *aLocation=nullptr) const |
| Check if the boundary of shape (this) lies closer to the point aP than aClearance, indicating a collision. | |
| virtual bool | Collide (const SHAPE *aShape, int aClearance, VECTOR2I *aMTV) const |
| Check if the boundary of shape (this) lies closer to the shape aShape than aClearance, indicating a collision. | |
| virtual VECTOR2I | Centre () const |
| Compute a center-of-mass of the shape. | |
| virtual int | Distance (const VECTOR2I &aP) const |
| Returns the minimum distance from a given point to this shape. | |
| bool | NearestPoints (const SHAPE *aOther, VECTOR2I &aPtThis, VECTOR2I &aPtOther) const |
| Return the two points that mark the closest distance between this shape and aOther. | |
| virtual VECTOR2I | GetStart () const |
| virtual VECTOR2I | GetEnd () const |
| virtual int | GetWidth () const |
| virtual void | SetWidth (int aWidth) |
| virtual bool | Parse (std::stringstream &aStream) |
| FACET * | NewFacet () |
| SGNODE * | CalcShape (SGNODE *aParent, SGNODE *aColor, WRL1_ORDER aVertexOrder, float aCreaseLimit=0.74317, bool isVRML2=false) |
| SHAPE_TYPE | Type () const |
| Return the type of the shape. | |
| wxString | TypeName () const |
| virtual bool | HasIndexableSubshapes () const |
| virtual size_t | GetIndexableSubshapeCount () const |
| virtual void | GetIndexableSubshapes (std::vector< const SHAPE * > &aSubshapes) const |
Static Public Attributes | |
| static const int | MIN_PRECISION_IU = 4 |
| This is the minimum precision for all the points in a shape. | |
Protected Types | |
| typedef VECTOR2I::extended_type | ecoord |
Protected Attributes | |
| SHAPE_TYPE | m_type |
| < type of our shape | |
Private Member Functions | |
| void | normalize () |
| If major < minor, swap them and add 90 degrees to rotation. | |
| void | updateCache () |
| Recompute cached sin/cos and inverse-radius-squared values. | |
| bool | isAngleInSweep (double aAngleRad) const |
| Return true if aAngleRad falls between StartAngle and EndAngle (counter-clockwise sweep). | |
| void | sweepRange (double &aStart, double &aEnd) const |
| Canonical CCW sweep in radians; aEnd >= aStart. Used by all sweep-aware paths. | |
Private Attributes | |
| ELLIPSE< int > | m_ellipse |
| Wrapped geometric data (from geometry/ellipse.h) | |
| bool | m_isArc |
| true if open elliptical arc, false if closed ellipse | |
| double | m_sinRot |
| sin(Rotation) | |
| double | m_cosRot |
| cos(Rotation) | |
| double | m_invMajorRSq |
| 1 / MajorRadius ^ 2 | |
| double | m_invMinorRSq |
| 1 / MinorRadius ^ 2 | |
| std::list< FACET * > | facets |
Definition at line 35 of file shape_ellipse.h.
|
protectedinherited |
| SHAPE_ELLIPSE::SHAPE_ELLIPSE | ( | ) |
Definition at line 119 of file shape_ellipse.cpp.
References m_cosRot, m_ellipse, m_invMajorRSq, m_invMinorRSq, m_isArc, m_sinRot, SH_ELLIPSE, and SHAPE::SHAPE().
Referenced by Clone(), operator=(), and SHAPE_ELLIPSE().
| SHAPE_ELLIPSE::SHAPE_ELLIPSE | ( | const VECTOR2I & | aCenter, |
| int | aMajorRadius, | ||
| int | aMinorRadius, | ||
| const EDA_ANGLE & | aRotation ) |
Definition at line 131 of file shape_ellipse.cpp.
References m_ellipse, m_isArc, normalize(), SH_ELLIPSE, and SHAPE::SHAPE().
| SHAPE_ELLIPSE::SHAPE_ELLIPSE | ( | const VECTOR2I & | aCenter, |
| int | aMajorRadius, | ||
| int | aMinorRadius, | ||
| const EDA_ANGLE & | aRotation, | ||
| const EDA_ANGLE & | aStartAngle, | ||
| const EDA_ANGLE & | aEndAngle ) |
Definition at line 141 of file shape_ellipse.cpp.
References m_ellipse, m_isArc, normalize(), SH_ELLIPSE, and SHAPE::SHAPE().
| SHAPE_ELLIPSE::SHAPE_ELLIPSE | ( | const VECTOR2I & | aCenter, |
| const VECTOR2I & | aMajorEndpoint, | ||
| double | aRatio ) |
Definition at line 151 of file shape_ellipse.cpp.
References m_ellipse, m_isArc, normalize(), SH_ELLIPSE, and SHAPE::SHAPE().
| SHAPE_ELLIPSE::SHAPE_ELLIPSE | ( | const VECTOR2I & | aCenter, |
| const VECTOR2I & | aMajorEndpoint, | ||
| double | aRatio, | ||
| const EDA_ANGLE & | aStartAngle, | ||
| const EDA_ANGLE & | aEndAngle ) |
Definition at line 160 of file shape_ellipse.cpp.
References m_ellipse, m_isArc, normalize(), SH_ELLIPSE, and SHAPE::SHAPE().
|
default |
References SHAPE_ELLIPSE().
|
overridedefault |
|
overridevirtual |
Compute a bounding box of the shape, with a margin of aClearance a collision.
| aClearance | how much the bounding box is expanded wrs to the minimum enclosing rectangle for the shape. |
Implements SHAPE.
Definition at line 230 of file shape_ellipse.cpp.
References isAngleInSweep(), m_cosRot, m_ellipse, m_isArc, M_PI, m_sinRot, VECTOR2< T >::x, and VECTOR2< T >::y.
Referenced by BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), PNS::BuildHullForPrimitiveShape(), and EDA_SHAPE::getBoundingBox().
|
inherited |
Definition at line 703 of file wrlfacet.cpp.
References IFSG_NODE::AddChildNode(), IFSG_INDEX::AddIndex(), IFSG_NODE::AddRefNode(), facets, IFSG_NODE::GetRawPtr(), S3D::GetSGNodeParent(), IFSG_FACESET::NewNode(), IFSG_SHAPE::NewNode(), IFSG_COLORS::SetColorList(), IFSG_COORDS::SetCoordsList(), IFSG_NORMALS::SetNormalList(), SGPOINT::x, SGPOINT::y, and SGPOINT::z.
Referenced by WRL1FACESET::TranslateToSG(), WRL2FACESET::TranslateToSG(), and X3DIFACESET::TranslateToSG().
|
inlinevirtualinherited |
Compute a center-of-mass of the shape.
Definition at line 234 of file shape.h.
References BBox(), and BOX2< Vec >::Centre().
Referenced by PCB_CONTROL::ApplyDesignBlockLayout(), PNS::TOPOLOGY::AssembleDiffPair(), Collide(), pickSegment(), and DRC_TEST_PROVIDER_EDGE_CLEARANCE::resolveSilkDisposition().
|
inlineoverridevirtual |
Return a dynamically allocated copy of the shape.
| copy | of the shape |
Reimplemented from SHAPE.
Definition at line 54 of file shape_ellipse.h.
References SHAPE::SHAPE(), and SHAPE_ELLIPSE().
|
virtualinherited |
Check if the boundary of shape (this) lies closer to the shape aShape than aClearance, indicating a collision.
| aShape | shape to check collision against |
| aClearance | minimum clearance |
| aMTV | [out] minimum translation vector |
| aActual | [out] an optional pointer to an int to store the actual distance in the event of a collision. |
| aLocation | [out] an option pointer to a point to store a nearby location in the event of a collision. |
Reimplemented in SHAPE_COMPOUND, SHAPE_RECT, and SHAPE_SEGMENT.
Definition at line 1436 of file shape_collisions.cpp.
References collideShapes(), and SHAPE().
|
inlinevirtualinherited |
Check if the boundary of shape (this) lies closer to the point aP than aClearance, indicating a collision.
| aActual | [out] an optional pointer to an int to store the actual distance in the event of a collision. |
| aLocation | [out] an option pointer to a point to store a nearby location in the event of a collision. |
Reimplemented in SHAPE_ARC, SHAPE_LINE_CHAIN, SHAPE_LINE_CHAIN_BASE, SHAPE_POLY_SET, and SHAPE_SEGMENT.
Definition at line 183 of file shape.h.
References Collide().
Referenced by BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), DRC_RTREE::CheckColliding(), FOOTPRINT::CheckShortingPads(), CN_ZONE_LAYER::Collide(), Collide(), SHAPE_ARC::Collide(), SHAPE_COMPOUND::Collide(), SHAPE_COMPOUND::Collide(), SHAPE_ELLIPSE::Collide(), SHAPE_POLY_SET::Collide(), SHAPE_RECT::Collide(), SHAPE_RECT::Collide(), SHAPE_SEGMENT::Collide(), SHAPE_SEGMENT::Collide(), collide(), PNS::ITEM::collideSimple(), PNS::TOPOLOGY::findLinesFromVia(), PCB_SELECTION_TOOL::hitTestDistance(), PNS::SHOVE::onCollidingVia(), PNS::SHOVE::onReverseCollidingVia(), CN_VISITOR::operator()(), PNS::HIT_VISITOR::operator()(), PNS::VIA::PushoutForce(), DRC_RTREE::QueryColliding(), DRC_RTREE::QueryColliding(), DRC_TEST_PROVIDER_DISALLOW::Run(), DRC_TEST_PROVIDER_SILK_CLEARANCE::Run(), KIGEOM::ShapeHitTest(), PNS::OPTIMIZER::smartPadsSingle(), DRC_TEST_PROVIDER_EDGE_CLEARANCE::testAgainstEdge(), DRC_TEST_PROVIDER_PHYSICAL_CLEARANCE::testItemAgainstItem(), DRC_TEST_PROVIDER_COPPER_CLEARANCE::testPadAgainstItem(), DRC_TEST_PROVIDER_COPPER_CLEARANCE::testSingleLayerItemAgainstItem(), DRC_TEST_PROVIDER_COPPER_CLEARANCE::testTrackClearances(), and DIALOG_TRACK_VIA_PROPERTIES::TransferDataFromWindow().
|
overridevirtual |
Check if the boundary of shape (this) lies closer to the segment aSeg than aClearance, indicating a collision.
| aActual | [out] an optional pointer to an int to be updated with the actual distance int the event of a collision. |
| aLocation | [out] an option pointer to a point to store a nearby location in the event of a collision. |
Implements SHAPE.
Definition at line 319 of file shape_ellipse.cpp.
References SEG::A, SEG::B, D, isAngleInSweep(), m_cosRot, m_ellipse, m_isArc, M_PI, m_sinRot, SquaredDistance(), VECTOR2< T >::x, and VECTOR2< T >::y.
Referenced by BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), Collide(), and collideEllipseVsSegments().
|
inlineoverridevirtual |
Reimplemented from SHAPE.
Definition at line 77 of file shape_ellipse.h.
References SHAPE::Collide(), and SHAPE::SHAPE().
| SHAPE_LINE_CHAIN SHAPE_ELLIPSE::ConvertToPolyline | ( | int | aMaxError | ) | const |
Build a polyline approximation of the ellipse or arc.
Stay within aMaxError IU of the true curve.
| aMaxError | maximum error in IU |
Definition at line 750 of file shape_ellipse.cpp.
References SHAPE_LINE_CHAIN::Append(), SHAPE_LINE_CHAIN::CPoint(), m_cosRot, m_ellipse, m_isArc, m_sinRot, SHAPE_LINE_CHAIN::PointCount(), SHAPE_LINE_CHAIN::Remove(), SHAPE_LINE_CHAIN::SetClosed(), and sweepRange().
Referenced by FEATURES_MANAGER::AddShape(), PCB_IO_IPC2581::addShape(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), Collide(), CONVERT_TOOL::CreateLines(), BOARD_ADAPTER::createPadWithMargin(), KIGFX::GAL::DrawEllipse(), KIGFX::GAL::DrawEllipseArc(), EDA_SHAPE::hitTest(), EDA_SHAPE::makeEffectiveShapes(), SCH_SHAPE::Plot(), BRDITEMS_PLOTTER::PlotShape(), processClosedShape(), processShapeSegment(), EDA_SHAPE::TransformShapeToPolygon(), TransformToPolygon(), and EDA_SHAPE::UpdateHatching().
|
virtualinherited |
Returns the minimum distance from a given point to this shape.
Always returns zero if the point is inside a closed shape and aOutlineOnly is false.
| aP | is the point to test |
Reimplemented in SHAPE_COMPOUND, and SHAPE_LINE_CHAIN.
Definition at line 109 of file shape.cpp.
References SquaredDistance().
|
overridevirtual |
Serialize the ellipse.
Reimplemented from SHAPE.
Definition at line 541 of file shape_ellipse.cpp.
References SHAPE::Format(), m_ellipse, and m_isArc.
Referenced by BOOST_AUTO_TEST_CASE().
|
inline |
Definition at line 56 of file shape_ellipse.h.
References m_ellipse.
Referenced by BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), Collide(), Collide(), collideEllipseVsSegments(), ROUTER_PREVIEW_ITEM::drawShape(), and STROKE_PARAMS::Stroke().
|
inherited |
Return the actual minimum distance between two shapes.
| distance | in IU |
POLY_SETs contain a bunch of polygons that are triangulated. But there are way more triangles than necessary for collision detection. Triangles check three vertices each but for the outline, we only need one. These are also fractured, so we don't need to worry about holes
Definition at line 55 of file shape.cpp.
References SHAPE_POLY_SET::COutline(), SHAPE_BASE::GetIndexableSubshapeCount(), SHAPE_BASE::GetIndexableSubshapes(), SHAPE_POLY_SET::OutlineCount(), SH_POLY_SET, SHAPE(), and SHAPE_BASE::Type().
|
inlinevirtualinherited |
Reimplemented in SHAPE_ARC, and SHAPE_SEGMENT.
|
inline |
Definition at line 61 of file shape_ellipse.h.
References m_ellipse.
Referenced by BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), ROUTER_PREVIEW_ITEM::drawShape(), and STROKE_PARAMS::Stroke().
|
inlinevirtualinherited |
Reimplemented in SHAPE_COMPOUND, and SHAPE_POLY_SET.
Definition at line 115 of file shape.h.
Referenced by SHAPE::GetClearance().
|
inlinevirtualinherited |
Reimplemented in SHAPE_COMPOUND, and SHAPE_POLY_SET.
Definition at line 117 of file shape.h.
Referenced by SHAPE_COMPOUND::AddShape(), and SHAPE::GetClearance().
| double SHAPE_ELLIPSE::GetLength | ( | ) | const |
Definition at line 291 of file shape_ellipse.cpp.
References m_ellipse, m_isArc, M_PI, and sweepRange().
Referenced by BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), and EDA_SHAPE::GetLength().
|
inline |
Definition at line 57 of file shape_ellipse.h.
References m_ellipse.
Referenced by BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), ROUTER_PREVIEW_ITEM::drawShape(), and STROKE_PARAMS::Stroke().
|
inline |
Definition at line 58 of file shape_ellipse.h.
References m_ellipse.
Referenced by BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), ROUTER_PREVIEW_ITEM::drawShape(), and STROKE_PARAMS::Stroke().
|
inline |
Definition at line 59 of file shape_ellipse.h.
References m_ellipse.
Referenced by BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), ROUTER_PREVIEW_ITEM::drawShape(), and STROKE_PARAMS::Stroke().
|
inlinevirtualinherited |
Reimplemented in SHAPE_ARC, and SHAPE_SEGMENT.
Definition at line 288 of file shape.h.
Referenced by CADSTAR_PCB_ARCHIVE_LOADER::loadCoppers().
|
inline |
Definition at line 60 of file shape_ellipse.h.
References m_ellipse.
Referenced by BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), ROUTER_PREVIEW_ITEM::drawShape(), and STROKE_PARAMS::Stroke().
|
inlinevirtualinherited |
Reimplemented in SHAPE_ARC, SHAPE_RECT, and SHAPE_SEGMENT.
Definition at line 291 of file shape.h.
Referenced by BOARD_ADAPTER::createPadWithMargin(), ROUTER_PREVIEW_ITEM::drawShape(), and SHAPE_LINE_CHAIN::SHAPE_LINE_CHAIN().
|
inlinevirtualinherited |
Reimplemented in SHAPE_COMPOUND, and SHAPE_POLY_SET.
|
private |
Return true if aAngleRad falls between StartAngle and EndAngle (counter-clockwise sweep).
Only valid for arcs.
Definition at line 820 of file shape_ellipse.cpp.
References M_PI, and sweepRange().
Referenced by BBox(), Collide(), and SquaredDistance().
|
inline |
Definition at line 63 of file shape_ellipse.h.
References m_isArc.
Referenced by BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), Collide(), ROUTER_PREVIEW_ITEM::drawShape(), and STROKE_PARAMS::Stroke().
|
inlineinherited |
Return true if the shape is a null shape.
| true | if null :-) |
Definition at line 168 of file shape.h.
References SHAPE_BASE::m_type, and SH_NULL.
|
inlineoverridevirtual |
| void SHAPE_ELLIPSE::Mirror | ( | const VECTOR2I & | aRef, |
| FLIP_DIRECTION | aFlipDirection ) |
Mirror the ellipse across a horizontal or vertical axis passing through aRef.
Definition at line 534 of file shape_ellipse.cpp.
References m_ellipse, and updateCache().
Referenced by BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), and BOOST_AUTO_TEST_CASE().
|
overridevirtual |
|
inherited |
Return the two points that mark the closest distance between this shape and aOther.
Public interface for finding nearest points between two shapes.
If the shapes are overlapping, the points will be the same.
| aOther | the other shape to compare with |
| aPtThis | [out] the point on this shape closest to aOther |
| aPtOther | [out] the point on aOther closest to this shape |
| aA | first shape |
| aB | second shape |
| aPtA | [out] nearest point on first shape |
| aPtB | [out] nearest point on second shape |
Definition at line 938 of file shape_nearest_points.cpp.
References nearestPoints(), and SHAPE().
Referenced by BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), SHAPE_ARC::NearestPoints(), DRC_TEST_PROVIDER::reportTwoShapeGeometry(), and DRC_TEST_PROVIDER_ANNULAR_WIDTH::Run().
|
inherited |
Definition at line 695 of file wrlfacet.cpp.
References facets.
Referenced by WRL1FACESET::TranslateToSG(), WRL2FACESET::TranslateToSG(), and X3DIFACESET::TranslateToSG().
|
private |
If major < minor, swap them and add 90 degrees to rotation.
Clamps non positive radii to 1.
Definition at line 170 of file shape_ellipse.cpp.
References ANGLE_90, m_ellipse, m_isArc, and updateCache().
Referenced by SetMajorRadius(), SetMinorRadius(), SHAPE_ELLIPSE(), SHAPE_ELLIPSE(), SHAPE_ELLIPSE(), and SHAPE_ELLIPSE().
|
default |
References SHAPE_ELLIPSE().
|
virtualinherited |
Reimplemented in SHAPE_LINE_CHAIN, and SHAPE_POLY_SET.
|
overridevirtual |
Check if point aP lies inside a closed shape.
Always returns false if this shape is not closed.
| aPt | point to check |
| aUseBBoxCache | gives better performance if the bounding box caches have been generated. |
Reimplemented from SHAPE.
Definition at line 594 of file shape_ellipse.cpp.
References m_cosRot, m_ellipse, m_invMajorRSq, m_invMinorRSq, m_isArc, m_sinRot, VECTOR2< T >::x, and VECTOR2< T >::y.
Referenced by BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), and Collide().
|
overridevirtual |
| aCenter | is the rotation center. |
| aAngle | rotation angle. |
Implements SHAPE.
Definition at line 526 of file shape_ellipse.cpp.
References m_ellipse, RotatePoint(), and updateCache().
Referenced by BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), and BOOST_AUTO_TEST_CASE().
| void SHAPE_ELLIPSE::SetCenter | ( | const VECTOR2I & | aCenter | ) |
Definition at line 191 of file shape_ellipse.cpp.
References m_ellipse.
| void SHAPE_ELLIPSE::SetEndAngle | ( | const EDA_ANGLE & | aAngle | ) |
Definition at line 224 of file shape_ellipse.cpp.
References m_ellipse.
| void SHAPE_ELLIPSE::SetMajorRadius | ( | int | aRadius | ) |
Definition at line 197 of file shape_ellipse.cpp.
References m_ellipse, and normalize().
Referenced by BOOST_AUTO_TEST_CASE().
| void SHAPE_ELLIPSE::SetMinorRadius | ( | int | aRadius | ) |
Definition at line 204 of file shape_ellipse.cpp.
References m_ellipse, and normalize().
| void SHAPE_ELLIPSE::SetRotation | ( | const EDA_ANGLE & | aAngle | ) |
Definition at line 211 of file shape_ellipse.cpp.
References m_ellipse, and updateCache().
Referenced by BOOST_AUTO_TEST_CASE(), and BOOST_AUTO_TEST_CASE().
| void SHAPE_ELLIPSE::SetStartAngle | ( | const EDA_ANGLE & | aAngle | ) |
Definition at line 218 of file shape_ellipse.cpp.
References m_ellipse.
|
inlinevirtualinherited |
Reimplemented in SHAPE_ARC, SHAPE_LINE_CHAIN, and SHAPE_SEGMENT.
|
overridevirtual |
Reimplemented from SHAPE.
Definition at line 617 of file shape_ellipse.cpp.
References std::abs(), isAngleInSweep(), m_cosRot, m_ellipse, m_invMajorRSq, m_invMinorRSq, m_isArc, m_sinRot, VECTOR2< T >::x, and VECTOR2< T >::y.
Referenced by BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), BOOST_AUTO_TEST_CASE(), Collide(), Collide(), and EDA_SHAPE::hitTest().
|
private |
Canonical CCW sweep in radians; aEnd >= aStart. Used by all sweep-aware paths.
Definition at line 797 of file shape_ellipse.cpp.
References m_ellipse, m_isArc, and M_PI.
Referenced by ConvertToPolyline(), GetLength(), and isAngleInSweep().
|
overridevirtual |
Fills a SHAPE_POLY_SET with a polygon representation of this shape.
| aBuffer | [out] will be filled with the polygonal representation of this shape. |
| aError | controls the maximum allowed deviation when converting rounded shapes to segments |
| aErrorLoc | controls where the error is placed when approximating rounded shapes |
Implements SHAPE.
Definition at line 515 of file shape_ellipse.cpp.
References SHAPE_POLY_SET::AddOutline(), chain, ConvertToPolyline(), and m_isArc.
|
inlineinherited |
Return the type of the shape.
| the | type |
Definition at line 100 of file shape.h.
References m_type.
Referenced by CREEPAGE_GRAPH::Addshape(), PNS::DP_GATEWAYS::BuildFromPrimitivePair(), PNS::BuildHullForPrimitiveShape(), PNS_LOG_VIEWER_FRAME::buildListTree(), Collide(), SHAPE_POLY_SET::Collide(), collideShapes(), collideSingleShapes(), PNS::OPTIMIZER::computeBreakouts(), ROUTER_PREVIEW_ITEM::drawShape(), PNS_LOG_VIEWER_FRAME::drawSimpleShape(), EDA_SHAPE::EDA_SHAPE(), PNS::LOGGER::formatShapeAsJSON(), SHAPE::GetClearance(), nearestPoints(), nearestPointsSingleShapes(), DRC_RTREE::QueryColliding(), DRC_TEST_PROVIDER_EDGE_CLEARANCE::resolveSilkDisposition(), STROKE_PARAMS::Stroke(), and SHAPE_FILE_IO::Write().
|
inlineinherited |
|
private |
Recompute cached sin/cos and inverse-radius-squared values.
Definition at line 581 of file shape_ellipse.cpp.
References m_cosRot, m_ellipse, m_invMajorRSq, m_invMinorRSq, and m_sinRot.
Referenced by Mirror(), normalize(), Rotate(), and SetRotation().
|
privateinherited |
Definition at line 143 of file wrlfacet.h.
Referenced by CalcShape(), and NewFacet().
|
private |
cos(Rotation)
Definition at line 137 of file shape_ellipse.h.
Referenced by BBox(), Collide(), ConvertToPolyline(), PointInside(), SHAPE_ELLIPSE(), SquaredDistance(), and updateCache().
|
private |
Wrapped geometric data (from geometry/ellipse.h)
Definition at line 133 of file shape_ellipse.h.
Referenced by BBox(), Collide(), ConvertToPolyline(), Format(), GetCenter(), GetEndAngle(), GetLength(), GetMajorRadius(), GetMinorRadius(), GetRotation(), GetStartAngle(), Mirror(), Move(), normalize(), PointInside(), Rotate(), SetCenter(), SetEndAngle(), SetMajorRadius(), SetMinorRadius(), SetRotation(), SetStartAngle(), SHAPE_ELLIPSE(), SHAPE_ELLIPSE(), SHAPE_ELLIPSE(), SHAPE_ELLIPSE(), SHAPE_ELLIPSE(), SquaredDistance(), sweepRange(), and updateCache().
|
private |
1 / MajorRadius ^ 2
Definition at line 138 of file shape_ellipse.h.
Referenced by PointInside(), SHAPE_ELLIPSE(), SquaredDistance(), and updateCache().
|
private |
1 / MinorRadius ^ 2
Definition at line 139 of file shape_ellipse.h.
Referenced by PointInside(), SHAPE_ELLIPSE(), SquaredDistance(), and updateCache().
|
private |
true if open elliptical arc, false if closed ellipse
Definition at line 134 of file shape_ellipse.h.
Referenced by BBox(), Collide(), ConvertToPolyline(), Format(), GetLength(), IsArc(), IsSolid(), normalize(), PointInside(), SHAPE_ELLIPSE(), SHAPE_ELLIPSE(), SHAPE_ELLIPSE(), SHAPE_ELLIPSE(), SHAPE_ELLIPSE(), SquaredDistance(), sweepRange(), and TransformToPolygon().
|
private |
sin(Rotation)
Definition at line 136 of file shape_ellipse.h.
Referenced by BBox(), Collide(), ConvertToPolyline(), PointInside(), SHAPE_ELLIPSE(), SquaredDistance(), and updateCache().
|
protectedinherited |
< type of our shape
Definition at line 121 of file shape.h.
Referenced by SHAPE::Format(), SHAPE::IsNull(), SHAPE_BASE(), Type(), and TypeName().
|
staticinherited |
This is the minimum precision for all the points in a shape.
Definition at line 133 of file shape.h.
Referenced by DIRECTION_45::BuildInitialTrace(), CompareLength(), CIRCLE::Contains(), EDIT_TOOL::FilletTracks(), CIRCLE::IntersectLine(), and LINE_FILLET_ROUTINE::ProcessLinePair().