54 virtual bool Run()
override;
56 virtual const wxString
GetName()
const override
58 return wxT(
"text_dimensions" );
63 return wxT(
"Tests text height and thickness" );
70 const int progressDelta = 250;
77 reportAux( wxT(
"Text dimension violations ignored. Tests not run." ) );
84 reportAux( wxT(
"No text height or text thickness constraints found. Tests not run." ) );
91 auto checkTextHeight =
103 int actualHeight =
text->GetTextSize().y;
108 wxString msg =
formatMsg(
_(
"(%s min height %s; actual %s)" ),
113 drcItem->SetErrorMessage( drcItem->GetErrorText() + wxS(
" " ) + msg );
114 drcItem->SetItems( item );
123 wxString msg =
formatMsg(
_(
"(%s max height %s; actual %s)" ),
128 drcItem->SetErrorMessage( drcItem->GetErrorText() + wxS(
" " ) + msg );
129 drcItem->SetItems( item );
138 auto checkTextThickness =
157 auto* glyphs =
text->GetRenderCache( font,
text->GetShownText(
true ) );
158 bool collapsedStroke =
false;
159 bool collapsedArea =
false;
161 for(
const std::unique_ptr<KIFONT::GLYPH>& glyph : *glyphs )
165 if( !glyph->IsOutline() )
172 if( outlineCount == 0 )
175 for( ii = 0; ii < outlineCount; ++ii )
176 holeCount += outlineGlyph->HoleCount( ii );
180 CORNER_STRATEGY::CHAMFER_ALL_CORNERS,
ARC_LOW_DEF );
184 int resultingHoleCount = 0;
186 for( ii = 0; ii < resultingOutlineCount; ++ii )
187 resultingHoleCount += poly.
HoleCount( ii );
189 if( ( resultingOutlineCount != outlineCount )
190 || ( resultingHoleCount != holeCount ) )
192 collapsedStroke =
true;
196 double glyphArea = outlineGlyph->Area();
202 CORNER_STRATEGY::CHAMFER_ALL_CORNERS,
ARC_LOW_DEF, true );
204 double resultingGlyphArea = poly.
Area();
206 if( (
std::abs( resultingGlyphArea - glyphArea ) / glyphArea ) > 0.1 )
208 collapsedArea =
true;
213 if( collapsedStroke || collapsedArea )
218 msg =
_(
"(TrueType font characters with insufficient stroke weight)" );
220 drcItem->SetErrorMessage( drcItem->GetErrorText() + wxS(
" " ) + msg );
221 drcItem->SetItems( item );
229 int actualThickness =
text->GetEffectiveTextPenWidth();
234 wxString msg =
formatMsg(
_(
"(%s min thickness %s; actual %s)" ),
239 drcItem->SetErrorMessage( drcItem->GetErrorText() + wxS(
" " ) + msg );
240 drcItem->SetItems( item );
249 wxString msg =
formatMsg(
_(
"(%s max thickness %s; actual %s)" ),
254 drcItem->SetErrorMessage( drcItem->GetErrorText() + wxS(
" " ) + msg );
255 drcItem->SetItems( item );
265 static const std::vector<KICAD_T> itemTypes = {
288 if( !
text->IsVisible() )
294 checkTextThickness( item,
text );
299 checkTextHeight( item,
text );
constexpr int ARC_LOW_DEF
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.
SEVERITY GetSeverity() const
MINOPTMAX< int > & Value()
DRC_RULE * GetParentRule() const
bool HasRulesForConstraintType(DRC_CONSTRAINT_T constraintID)
bool IsErrorLimitExceeded(int error_code)
DRC_CONSTRAINT EvalRules(DRC_CONSTRAINT_T aConstraintType, const BOARD_ITEM *a, const BOARD_ITEM *b, PCB_LAYER_ID aLayer, REPORTER *aReporter=nullptr)
static std::shared_ptr< DRC_ITEM > Create(int aErrorCode)
Constructs a DRC_ITEM for the given error code.
DRC_TEST_PROVIDER_TEXT_DIMS()
virtual ~DRC_TEST_PROVIDER_TEXT_DIMS()
virtual bool Run() override
Run this provider against the given PCB with configured options (if any).
virtual const wxString GetName() const override
virtual const wxString GetDescription() const override
Represent a DRC "provider" which runs some DRC functions over a BOARD and spits out DRC_ITEM and posi...
wxString formatMsg(const wxString &aFormatString, const wxString &aSource, double aConstraint, double aActual)
virtual bool reportPhase(const wxString &aStageName)
virtual void reportViolation(std::shared_ptr< DRC_ITEM > &item, const VECTOR2I &aMarkerPos, int aMarkerLayer, DRC_CUSTOM_MARKER_HANDLER *aCustomHandler=nullptr)
int forEachGeometryItem(const std::vector< KICAD_T > &aTypes, const LSET &aLayers, const std::function< bool(BOARD_ITEM *)> &aFunc)
void reportAux(const wxString &aMsg)
virtual void reportRuleStatistics()
virtual bool reportProgress(size_t aCount, size_t aSize, size_t aDelta=1)
virtual VECTOR2I GetPosition() const
A mix-in class (via multiple inheritance) that handles texts such as labels, parts,...
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 IsOutline() const
static LSET AllLayersMask()
Represent a set of closed polygons.
double Area()
Return the area of this poly set.
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.
void Simplify()
Simplify the polyset (merges overlapping polys, eliminates degeneracy/self-intersections)
void Deflate(int aAmount, CORNER_STRATEGY aCornerStrategy, int aMaxError)
int OutlineCount() const
Return the number of outlines in the set.
SHAPE_POLY_SET CloneDropTriangulation() const
@ TEXT_THICKNESS_CONSTRAINT
This file contains miscellaneous commonly used macros and functions.
static DRC_REGISTER_TEST_PROVIDER< DRC_TEST_PROVIDER_ANNULAR_WIDTH > dummy
EDA_ANGLE abs(const EDA_ANGLE &aAngle)
@ PCB_TEXTBOX_T
class PCB_TEXTBOX, wrapped text on a layer
@ PCB_TEXT_T
class PCB_TEXT, text on a layer
@ PCB_FIELD_T
class PCB_FIELD, text associated with a footprint property
@ PCB_TABLECELL_T
class PCB_TABLECELL, PCB_TEXTBOX for use in tables
@ PCB_DIMENSION_T
class PCB_DIMENSION_BASE: abstract dimension meta-type