30#ifndef GEOMETRY_UTILS_H
31#define GEOMETRY_UTILS_H
113 if( !only45 && absVec.x > ext_type( absVec.y ) * 2 )
118 else if( !only45 && absVec.y > ext_type( absVec.x ) * 2 )
123 else if( absVec.x > absVec.y )
126 newVec.y = std::copysign( aVec.
x, aVec.
y );
131 newVec.x = std::copysign( aVec.
y, aVec.
x );
150template <
typename in_type,
typename ret_type = in_type,
typename pad_type =
unsigned int,
151 typename =
typename std::enable_if<std::is_unsigned<pad_type>::value>::type>
154 typedef std::numeric_limits<int32_t> coord_limits;
156 in_type x = aCoords.
x;
157 in_type y = aCoords.
y;
159 if constexpr( !std::is_floating_point_v<in_type> )
161 int64_t max =
static_cast<int64_t
>( coord_limits::max() ) - aPadding;
163 x = std::clamp<int64_t>(
static_cast<int64_t
>( x ), min, max );
164 y = std::clamp<int64_t>(
static_cast<int64_t
>( y ), min, max );
168 double max =
static_cast<double>( coord_limits::max() ) - aPadding;
170 x = std::clamp<double>(
static_cast<double>( x ), min, max );
171 y = std::clamp<double>(
static_cast<double>( y ), min, max );
174 if constexpr( !std::is_integral_v<in_type> && std::is_integral_v<ret_type> )
177 KiROUND<in_type, ret_type>( y,
true ) );
197bool ClipLine(
const BOX2I *aClipBox,
int &x1,
int &y1,
int &x2,
int &y2 );
When creating polygons to create a clearance polygonal area, the polygon must be same or bigger than ...
~DISABLE_ARC_RADIUS_CORRECTION()
DISABLE_ARC_RADIUS_CORRECTION()
Define a general 2D-vector/point.
VECTOR2_TRAITS< T >::extended_type extended_type
int GetCircleToPolyCorrection(int aMaxError)
int CircleToEndSegmentDeltaRadius(int aInnerCircleRadius, int aSegCount)
ERROR_LOC
When approximating an arc or circle, should the error be placed on the outside or inside of the curve...
VECTOR2< T > GetVectorSnapped45(const VECTOR2< T > &aVec, bool only45=false)
Snap a vector onto the nearest 0, 45 or 90 degree line.
bool ClipLine(const BOX2I *aClipBox, int &x1, int &y1, int &x2, int &y2)
Test if any part of a line falls within the bounds of a rectangle.
int GetArcToSegmentCount(int aRadius, int aErrorMax, const EDA_ANGLE &aArcAngle)
VECTOR2< ret_type > GetClampedCoords(const VECTOR2< in_type > &aCoords, pad_type aPadding=1u)
Clamps a vector to values that can be negated, respecting numeric limits of coordinates data type wit...
EDA_ANGLE abs(const EDA_ANGLE &aAngle)