53 virtual bool Run()
override;
55 virtual const wxString
GetName()
const override
57 return wxT(
"text_dimensions" );
62 return wxT(
"Tests text height and thickness" );
69 const int progressDelta = 250;
76 reportAux( wxT(
"Text dimension violations ignored. Tests not run." ) );
83 reportAux( wxT(
"No text height or text thickness constraints found. Tests not run." ) );
90 auto checkTextHeight =
102 int actualHeight =
text->GetTextSize().y;
107 wxString msg =
formatMsg(
_(
"(%s min height %s; actual %s)" ),
112 drcItem->SetErrorMessage( drcItem->GetErrorText() + wxS(
" " ) + msg );
113 drcItem->SetItems( item );
122 wxString msg =
formatMsg(
_(
"(%s max height %s; actual %s)" ),
127 drcItem->SetErrorMessage( drcItem->GetErrorText() + wxS(
" " ) + msg );
128 drcItem->SetItems( item );
137 auto checkTextThickness =
156 auto* glyphs =
text->GetRenderCache( font,
text->GetShownText(
true ) );
157 bool collapsedStroke =
false;
158 bool collapsedArea =
false;
160 for(
const std::unique_ptr<KIFONT::GLYPH>& glyph : *glyphs )
164 if( !glyph->IsOutline() )
171 if( outlineCount == 0 )
174 for( ii = 0; ii < outlineCount; ++ii )
175 holeCount += outlineGlyph->HoleCount( ii );
179 CORNER_STRATEGY::CHAMFER_ALL_CORNERS,
ARC_LOW_DEF );
183 int resultingHoleCount = 0;
185 for( ii = 0; ii < resultingOutlineCount; ++ii )
186 resultingHoleCount += poly.
HoleCount( ii );
188 if( ( resultingOutlineCount != outlineCount )
189 || ( resultingHoleCount != holeCount ) )
191 collapsedStroke =
true;
195 double glyphArea = outlineGlyph->Area();
201 CORNER_STRATEGY::CHAMFER_ALL_CORNERS,
ARC_LOW_DEF, true );
203 double resultingGlyphArea = poly.
Area();
205 if( (
std::abs( resultingGlyphArea - glyphArea ) / glyphArea ) > 0.1 )
207 collapsedArea =
true;
212 if( collapsedStroke || collapsedArea )
217 msg =
_(
"(TrueType font characters with insufficient stroke weight)" );
219 drcItem->SetErrorMessage( drcItem->GetErrorText() + wxS(
" " ) + msg );
220 drcItem->SetItems( item );
228 int actualThickness =
text->GetEffectiveTextPenWidth();
233 wxString msg =
formatMsg(
_(
"(%s min thickness %s; actual %s)" ),
238 drcItem->SetErrorMessage( drcItem->GetErrorText() + wxS(
" " ) + msg );
239 drcItem->SetItems( item );
248 wxString msg =
formatMsg(
_(
"(%s max thickness %s; actual %s)" ),
253 drcItem->SetErrorMessage( drcItem->GetErrorText() + wxS(
" " ) + msg );
254 drcItem->SetItems( item );
282 switch( item->
Type() )
284 case PCB_FIELD_T: text = static_cast<PCB_FIELD*>( item ); break;
285 case PCB_TEXT_T: text = static_cast<PCB_TEXT*>( item ); break;
286 case PCB_TEXTBOX_T: text = static_cast<PCB_TEXTBOX*>( item ); break;
287 default: UNIMPLEMENTED_FOR( item->GetClass() ); break;
296 checkTextThickness( item,
text );
301 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)
int forEachGeometryItem(const std::vector< KICAD_T > &aTypes, LSET aLayers, const std::function< bool(BOARD_ITEM *)> &aFunc)
virtual void reportViolation(std::shared_ptr< DRC_ITEM > &item, const VECTOR2I &aMarkerPos, int aMarkerLayer, DRC_CUSTOM_MARKER_HANDLER *aCustomHandler=nullptr)
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
KICAD_T Type() const
Returns the type of object.
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