44#define PIN_TEXT_MARGIN 4
52 static const wxChar* msgPinElectricType[] =
56 wxT(
"bidirectional" ),
63 wxT(
"open_collector" ),
64 wxT(
"open_emitter" ),
68 return msgPinElectricType[
static_cast<int>( aType )];
103 m_position( { 0, 0 } ),
111 m_isDangling(
true ),
112 m_layoutCache( std::make_unique<PIN_LAYOUT_CACHE>( *
this ) )
127 int aNameTextSize,
int aNumTextSize,
int aBodyStyle,
const VECTOR2I& aPos,
133 m_orientation( aOrientation ),
137 m_numTextSize( aNumTextSize ),
138 m_nameTextSize( aNameTextSize ),
139 m_isDangling( true ),
155 m_isDangling( true ),
158 wxASSERT( aParentSymbol );
169 const KIID& aUuid ) :
177 m_isDangling( true ),
180 wxASSERT( aParentSymbol );
189 m_libPin( aPin.m_libPin ),
190 m_alternates( aPin.m_alternates ),
191 m_position( aPin.m_position ),
192 m_length( aPin.m_length ),
193 m_orientation( aPin.m_orientation ),
194 m_shape( aPin.m_shape ),
195 m_type( aPin.m_type ),
196 m_hidden( aPin.m_hidden ),
197 m_numTextSize( aPin.m_numTextSize ),
198 m_nameTextSize( aPin.m_nameTextSize ),
200 m_isDangling( aPin.m_isDangling ),
241 return symbol->GetTransform().TransformCoordinate(
m_position ) + symbol->GetPosition();
251 return PIN_ORIENTATION::PIN_RIGHT;
262 if( !
m_alt.IsEmpty() )
265 return GRAPHIC_PINSHAPE::LINE;
269 else if(
m_shape == GRAPHIC_PINSHAPE::INHERIT )
272 return GRAPHIC_PINSHAPE::LINE;
297 if( !
m_alt.IsEmpty() )
300 return ELECTRICAL_PINTYPE::PT_UNSPECIFIED;
304 else if(
m_type == ELECTRICAL_PINTYPE::PT_INHERIT )
307 return ELECTRICAL_PINTYPE::PT_UNSPECIFIED;
327 if(
m_type == ELECTRICAL_PINTYPE::PT_INHERIT )
341 if(
m_type == ELECTRICAL_PINTYPE::PT_INHERIT )
355 return GetType() == ELECTRICAL_PINTYPE::PT_POWER_IN
362 return GetType() == ELECTRICAL_PINTYPE::PT_POWER_IN
389 if( !
m_alt.IsEmpty() )
413 m_name.Replace( wxT(
" " ), wxT(
"_" ) );
428 m_alt = wxEmptyString;
433 wxString::Format( wxS(
"Pin '%s' does not have an alterate '%s'" ),
m_number, aAlt ) );
440 if(
GetType() == ELECTRICAL_PINTYPE::PT_NC ||
GetType() == ELECTRICAL_PINTYPE::PT_NIC )
455 bool isConnectableType_a =
GetType() == ELECTRICAL_PINTYPE::PT_PASSIVE
456 ||
GetType() == ELECTRICAL_PINTYPE::PT_NIC;
457 bool isConnectableType_b = aPin->
GetType() == ELECTRICAL_PINTYPE::PT_PASSIVE
458 || aPin->
GetType() == ELECTRICAL_PINTYPE::PT_NIC;
463 && (
GetType() == aPin->
GetType() || isConnectableType_a || isConnectableType_b );
496 bool isReplaced =
false;
512 aAccuracy = std::max( aAccuracy,
Schematic()->Settings().m_PinSymbolSize / 4 );
539 if( !
m_alt.IsEmpty() )
561 m_number.Replace( wxT(
" " ), wxT(
"_" ) );
619 const TRANSFORM& t = symbol->GetTransform();
641 int MapX1, MapY1, x1, y1;
648 if( bg == COLOR4D::UNSPECIFIED || !aPlotter->
GetColorMode() )
661 x1 = aPosition.
x; y1 = aPosition.
y;
663 switch( aOrientation )
665 case PIN_ORIENTATION::PIN_UP: y1 = aPosition.
y - pinLength; MapY1 = 1;
break;
666 case PIN_ORIENTATION::PIN_DOWN: y1 = aPosition.
y + pinLength; MapY1 = -1;
break;
667 case PIN_ORIENTATION::PIN_LEFT: x1 = aPosition.
x - pinLength; MapX1 = 1;
break;
668 case PIN_ORIENTATION::PIN_RIGHT: x1 = aPosition.
x + pinLength; MapX1 = -1;
break;
669 case PIN_ORIENTATION::INHERIT: wxFAIL_MSG( wxS(
"aOrientation must be resolved!" ) );
break;
672 if(
m_shape == GRAPHIC_PINSHAPE::INVERTED ||
m_shape == GRAPHIC_PINSHAPE::INVERTED_CLOCK )
676 FILL_T::NO_FILL, penWidth );
681 else if(
m_shape == GRAPHIC_PINSHAPE::FALLING_EDGE_CLOCK )
697 aPlotter->
MoveTo(
VECTOR2I( MapX1 * deco_size * 2 + x1, MapY1 * deco_size * 2 + y1 ) );
706 if(
m_shape == GRAPHIC_PINSHAPE::CLOCK
707 ||
m_shape == GRAPHIC_PINSHAPE::INVERTED_CLOCK
708 ||
m_shape == GRAPHIC_PINSHAPE::CLOCK_LOW )
725 if(
m_shape == GRAPHIC_PINSHAPE::INPUT_LOW
726 ||
m_shape == GRAPHIC_PINSHAPE::CLOCK_LOW )
733 aPlotter->
LineTo(
VECTOR2I( x1 + MapX1 * deco_size * 2, y1 - deco_size * 2 ) );
739 aPlotter->
LineTo(
VECTOR2I( x1 - deco_size * 2, y1 + MapY1 * deco_size * 2 ) );
744 if(
m_shape == GRAPHIC_PINSHAPE::OUTPUT_LOW )
759 else if(
m_shape == GRAPHIC_PINSHAPE::NONLOGIC )
763 y1 - ( MapY1 - MapX1 ) * deco_size ) );
765 y1 + ( MapY1 - MapX1 ) * deco_size ) );
767 y1 - ( MapY1 + MapX1 ) * deco_size ) );
769 y1 + ( MapY1 + MapX1 ) * deco_size ) );
772 if(
m_type == ELECTRICAL_PINTYPE::PT_NC )
775 const int ex1 = aPosition.
x;
776 const int ey1 = aPosition.
y;
786 int aTextInside,
bool aDrawPinNum,
bool aDrawPinName,
795 aDrawPinName =
false;
800 if( !aDrawPinNum && !aDrawPinName )
813 if( bg == COLOR4D::UNSPECIFIED || !aPlotter->
GetColorMode() )
820 nameColor = nameColor.
Mix( bg, 0.5f );
821 numColor = numColor.
Mix( bg, 0.5f );
829 case PIN_ORIENTATION::PIN_UP: y1 -=
GetLength();
break;
830 case PIN_ORIENTATION::PIN_DOWN: y1 +=
GetLength();
break;
831 case PIN_ORIENTATION::PIN_LEFT: x1 -=
GetLength();
break;
832 case PIN_ORIENTATION::PIN_RIGHT: x1 +=
GetLength();
break;
833 case PIN_ORIENTATION::INHERIT: wxFAIL_MSG( wxS(
"aPinOrient must be resolved!" ) );
break;
871 if( ( aPinOrient == PIN_ORIENTATION::PIN_LEFT )
872 || ( aPinOrient == PIN_ORIENTATION::PIN_RIGHT ) )
876 if( aPinOrient == PIN_ORIENTATION::PIN_RIGHT )
896 if( aPinOrient == PIN_ORIENTATION::PIN_DOWN )
928 if( ( aPinOrient == PIN_ORIENTATION::PIN_LEFT )
929 || ( aPinOrient == PIN_ORIENTATION::PIN_RIGHT ) )
932 if( aDrawPinName && aDrawPinNum )
940 else if( aDrawPinName )
945 else if( aDrawPinNum )
954 if( aDrawPinName && aDrawPinNum )
962 else if( aDrawPinName )
967 else if( aDrawPinNum )
985 case PIN_ORIENTATION::PIN_RIGHT:
end.
x = 1;
break;
986 case PIN_ORIENTATION::PIN_UP:
end.
y = -1;
break;
987 case PIN_ORIENTATION::PIN_DOWN:
end.
y = 1;
break;
988 case PIN_ORIENTATION::PIN_LEFT:
end.
x = -1;
break;
993 orient = PIN_ORIENTATION::PIN_UP;
998 orient = PIN_ORIENTATION::PIN_DOWN;
1002 orient = PIN_ORIENTATION::PIN_RIGHT;
1005 orient = PIN_ORIENTATION::PIN_LEFT;
1023 int lengthChange =
GetLength() - aLength;
1030 case PIN_ORIENTATION::PIN_RIGHT:
1031 offsetX = lengthChange;
1033 case PIN_ORIENTATION::PIN_LEFT:
1034 offsetX = -1 * lengthChange;
1036 case PIN_ORIENTATION::PIN_UP:
1037 offsetY = -1 * lengthChange;
1039 case PIN_ORIENTATION::PIN_DOWN:
1040 offsetY = lengthChange;
1104 case PIN_ORIENTATION::PIN_RIGHT:
m_orientation = PIN_ORIENTATION::PIN_UP;
break;
1105 case PIN_ORIENTATION::PIN_UP:
m_orientation = PIN_ORIENTATION::PIN_LEFT;
break;
1106 case PIN_ORIENTATION::PIN_LEFT:
m_orientation = PIN_ORIENTATION::PIN_DOWN;
break;
1107 case PIN_ORIENTATION::PIN_DOWN:
m_orientation = PIN_ORIENTATION::PIN_RIGHT;
break;
1117 case PIN_ORIENTATION::PIN_RIGHT:
m_orientation = PIN_ORIENTATION::PIN_DOWN;
break;
1118 case PIN_ORIENTATION::PIN_UP:
m_orientation = PIN_ORIENTATION::PIN_RIGHT;
break;
1119 case PIN_ORIENTATION::PIN_LEFT:
m_orientation = PIN_ORIENTATION::PIN_UP;
break;
1120 case PIN_ORIENTATION::PIN_DOWN:
m_orientation = PIN_ORIENTATION::PIN_LEFT;
break;
1134 int aUnit,
int aBodyStyle,
const VECTOR2I& aOffset,
bool aDimmed )
1165 aList.emplace_back(
_(
"Type" ),
_(
"Pin" ) );
1170 wxString(
"Undefined library pin." );
1171 aList.emplace_back(
_(
"Unit" ), msg );
1177 wxString(
"Undefined library pin." );
1178 aList.emplace_back(
_(
"Body Style" ), msg );
1187 aList.emplace_back(
_(
"Visible" ),
IsVisible() ?
_(
"Yes" ) :
_(
"No" ) );
1205 aList.emplace_back( symbol->
GetRef( currentSheet ),
1206 UnescapeString( schsymbol->GetField( FIELD_T::VALUE )->GetText() ) );
1260 if( it->second.second == aForceNoConnect )
1261 return it->second.first;
1264 wxString
name =
"Net-(";
1265 bool unconnected =
false;
1267 if( aForceNoConnect ||
GetType() == ELECTRICAL_PINTYPE::PT_NC )
1270 name = (
"unconnected-(" );
1273 bool annotated =
true;
1275 std::vector<SCH_PIN*> pins = symbol->
GetPins( &aPath );
1276 bool has_multiple =
false;
1282 && unconnected == (
pin->GetType() == ELECTRICAL_PINTYPE::PT_NC ) )
1284 has_multiple =
true;
1293 if( symbol->
GetRef( &aPath,
false ).Last() ==
'?' )
1298 name <<
"-Pad" << libPinNumber <<
")";
1301 else if( !libPinShownName.IsEmpty() && ( libPinShownName != libPinShownNumber ) )
1308 if( unconnected || has_multiple )
1343 if( aCache->
m_Font == aFont
1362 bool aIncludeElectricalType )
const
1365 return m_layoutCache->GetPinBoundingBox( aIncludeLabelsOnInvisiblePins, aIncludeNameAndNumber,
1366 aIncludeElectricalType );
1380 wxCHECK(
pin,
false );
1424 if( !
m_alt.IsEmpty() )
1427 alt = &localStorage;
1431 : wxString( wxS(
"Undefined library pin." ) );
1435 return wxString::Format(
"Symbol %s %s",
1452 if ( !
name.IsEmpty() )
1454 return wxString::Format(
_(
"Pin %s [%s, %s, %s]" ),
1462 return wxString::Format(
_(
"Pin %s [%s, %s]" ),
1470 if( !
name.IsEmpty() )
1472 return wxString::Format(
_(
"Hidden pin %s [%s, %s, %s]" ),
1480 return wxString::Format(
_(
"Hidden pin %s [%s, %s]" ),
1535 return static_cast<int>(
m_shape ) -
static_cast<int>( tmp->
m_shape );
1538 return static_cast<int>(
m_type ) -
static_cast<int>( tmp->
m_type );
1557 const ALT& lhsAlt = lhsItem->second;
1558 const ALT& rhsAlt = rhsItem->second;
1566 return static_cast<int>( lhsAlt.
m_Type ) -
static_cast<int>( rhsAlt.
m_Type );
1569 return static_cast<int>( lhsAlt.
m_Shape ) -
static_cast<int>( rhsAlt.
m_Shape );
1642 aStream <<
"SCH_PIN:" << std::endl
1643 <<
" Name: \"" <<
m_name <<
"\"" << std::endl
1644 <<
" Number: \"" <<
m_number <<
"\"" << std::endl
1646 <<
" Length: " <<
GetLength() << std::endl
1659void SCH_PIN::Show(
int nestLevel, std::ostream& os )
const
1661 NestedSpace( nestLevel, os ) <<
'<' <<
GetClass().Lower().mb_str()
1682 if( pinTypeEnum.Choices().GetCount() == 0 )
1684 pinTypeEnum.Map( ELECTRICAL_PINTYPE::PT_INPUT,
_HKI(
"Input" ) )
1685 .Map( ELECTRICAL_PINTYPE::PT_OUTPUT,
_HKI(
"Output" ) )
1686 .Map( ELECTRICAL_PINTYPE::PT_BIDI,
_HKI(
"Bidirectional" ) )
1687 .Map( ELECTRICAL_PINTYPE::PT_TRISTATE,
_HKI(
"Tri-state" ) )
1688 .Map( ELECTRICAL_PINTYPE::PT_PASSIVE,
_HKI(
"Passive" ) )
1689 .Map( ELECTRICAL_PINTYPE::PT_NIC,
_HKI(
"Free" ) )
1690 .Map( ELECTRICAL_PINTYPE::PT_UNSPECIFIED,
_HKI(
"Unspecified" ) )
1691 .Map( ELECTRICAL_PINTYPE::PT_POWER_IN,
_HKI(
"Power input" ) )
1692 .Map( ELECTRICAL_PINTYPE::PT_POWER_OUT,
_HKI(
"Power output" ) )
1693 .Map( ELECTRICAL_PINTYPE::PT_OPENCOLLECTOR,
_HKI(
"Open collector" ) )
1694 .Map( ELECTRICAL_PINTYPE::PT_OPENEMITTER,
_HKI(
"Open emitter" ) )
1695 .Map( ELECTRICAL_PINTYPE::PT_NC,
_HKI(
"Unconnected" ) );
1700 if( pinShapeEnum.Choices().GetCount() == 0 )
1702 pinShapeEnum.Map( GRAPHIC_PINSHAPE::LINE,
_HKI(
"Line" ) )
1703 .Map( GRAPHIC_PINSHAPE::INVERTED,
_HKI(
"Inverted" ) )
1704 .Map( GRAPHIC_PINSHAPE::CLOCK,
_HKI(
"Clock" ) )
1705 .Map( GRAPHIC_PINSHAPE::INVERTED_CLOCK,
_HKI(
"Inverted clock" ) )
1706 .Map( GRAPHIC_PINSHAPE::INPUT_LOW,
_HKI(
"Input low" ) )
1707 .Map( GRAPHIC_PINSHAPE::CLOCK_LOW,
_HKI(
"Clock low" ) )
1708 .Map( GRAPHIC_PINSHAPE::OUTPUT_LOW,
_HKI(
"Output low" ) )
1709 .Map( GRAPHIC_PINSHAPE::FALLING_EDGE_CLOCK,
_HKI(
"Falling edge clock" ) )
1710 .Map( GRAPHIC_PINSHAPE::NONLOGIC,
_HKI(
"NonLogic" ) );
1715 if( orientationEnum.Choices().GetCount() == 0 )
1717 orientationEnum.Map( PIN_ORIENTATION::PIN_RIGHT,
_(
"Right" ) )
1718 .Map( PIN_ORIENTATION::PIN_LEFT,
_(
"Left" ) )
1719 .Map( PIN_ORIENTATION::PIN_UP,
_(
"Up" ) )
1720 .Map( PIN_ORIENTATION::PIN_DOWN,
_(
"Down" ) );
1723 auto isSymbolEditor =
1727 return dynamic_cast<LIB_SYMBOL*
>(
pin->GetParentSymbol() ) !=
nullptr;
1746 _HKI(
"Electrical Type" ),
1751 _HKI(
"Graphic Style" ),
1769 PROPERTY_DISPLAY::PT_SIZE ) )
1774 PROPERTY_DISPLAY::PT_SIZE ) )
1779 PROPERTY_DISPLAY::PT_SIZE ) )
constexpr EDA_IU_SCALE schIUScale
BITMAPS
A list of all bitmap identifiers.
constexpr BOX2< Vec > & Inflate(coord_type dx, coord_type dy)
Inflates the rectangle horizontally by dx and vertically by dy.
constexpr bool Contains(const Vec &aPoint) const
constexpr bool Intersects(const BOX2< Vec > &aRect) const
The base class for create windows for drawing purpose.
A base class for most all the KiCad significant classes used in schematics and boards.
KICAD_T Type() const
Returns the type of object.
virtual bool Matches(const EDA_SEARCH_DATA &aSearchData, void *aAuxData) const
Compare the item against the search criteria in aSearchData.
EDA_ITEM * GetParent() const
EDA_ITEM * m_parent
Owner.
virtual const wxString & GetText() const
Return the string associated with the text object.
static ENUM_MAP< T > & Instance()
Class that other classes need to inherit from, in order to be inspectable.
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)
VECTOR2I StringBoundaryLimits(const wxString &aText, const VECTOR2I &aSize, int aThickness, bool aBold, bool aItalic, const METRICS &aFontMetrics) const
Compute the boundary limits of aText (the bounding box of all shapes).
A color representation with 4 components: red, green, blue, alpha.
COLOR4D & Desaturate()
Removes color (in HSL model)
COLOR4D Mix(const COLOR4D &aColor, double aFactor) const
Return a color that is mixed with the input by a factor.
Container for all the knowledge about how graphical objects are drawn on any output surface/device.
int GetDefaultPenWidth() const
const wxString & GetDefaultFont() const
const COLOR4D & GetLayerColor(int aLayer) const
Return the color used to draw a layer.
virtual const COLOR4D & GetBackgroundColor() const =0
Return current background color settings.
wxString AsString() const
Define a library symbol object.
A pin layout helper is a class that manages the layout of the parts of a pin on a schematic symbol:
Base plotter engine class.
virtual void Circle(const VECTOR2I &pos, int diametre, FILL_T fill, int width)=0
void MoveTo(const VECTOR2I &pos)
void FinishTo(const VECTOR2I &pos)
RENDER_SETTINGS * RenderSettings()
bool GetColorMode() const
virtual void SetCurrentLineWidth(int width, void *aData=nullptr)=0
Set the line width for the next drawing.
void LineTo(const VECTOR2I &pos)
virtual void PlotText(const VECTOR2I &aPos, const COLOR4D &aColor, const wxString &aText, const TEXT_ATTRIBUTES &aAttributes, KIFONT::FONT *aFont=nullptr, const KIFONT::METRICS &aFontMetrics=KIFONT::METRICS::Default(), void *aData=nullptr)
virtual void SetColor(const COLOR4D &color)=0
PROPERTY_BASE & SetAvailableFunc(std::function< bool(INSPECTABLE *)> aFunc)
Set a callback function to determine whether an object provides this property.
PROPERTY_BASE & SetWriteableFunc(std::function< bool(INSPECTABLE *)> aFunc)
Provide class metadata.Helper macro to map type hashes to names.
void InheritsAfter(TYPE_ID aDerived, TYPE_ID aBase)
Declare an inheritance relationship between types.
static PROPERTY_MANAGER & Instance()
PROPERTY_BASE & AddProperty(PROPERTY_BASE *aProperty, const wxString &aGroup=wxEmptyString)
Register a property.
void AddTypeCast(TYPE_CAST_BASE *aCast)
Register a type converter.
Each graphical item can have a SCH_CONNECTION describing its logical connection (to a bus or net).
wxString GetNetName() const
void AppendInfoToMsgPanel(std::vector< MSG_PANEL_ITEM > &aList) const
Adds information about the connection object to aList.
Schematic editor (Eeschema) main window.
SCH_SHEET_PATH & GetCurrentSheet() const
Base class for any item which can be embedded within the SCHEMATIC container class,...
SCH_ITEM & operator=(const SCH_ITEM &aPin)
SCH_RENDER_SETTINGS * getRenderSettings(PLOTTER *aPlotter) const
const SYMBOL * GetParentSymbol() const
SCHEMATIC * Schematic() const
Search the item hierarchy to find a SCHEMATIC.
static wxString GetUnitDescription(int aUnit)
virtual int compare(const SCH_ITEM &aOther, int aCompareFlags=0) const
Provide the draw object specific comparison called by the == and < operators.
bool IsConnectivityDirty() const
static wxString GetBodyStyleDescription(int aBodyStyle)
SCH_CONNECTION * Connection(const SCH_SHEET_PATH *aSheet=nullptr) const
Retrieve the connection associated with this object in the given sheet.
const KIFONT::METRICS & GetFontMetrics() const
int GetEffectivePenWidth(const SCH_RENDER_SETTINGS *aSettings) const
double SimilarityBase(const SCH_ITEM &aItem) const
Calculate the boilerplate similarity for all LIB_ITEMs without preventing the use above of a pure vir...
void getSymbolEditorMsgPanelInfo(EDA_DRAW_FRAME *aFrame, std::vector< MSG_PANEL_ITEM > &aList)
void Rotate(const VECTOR2I &aCenter, bool aRotateCCW=true) override
Rotate the item around aCenter 90 degrees in the clockwise direction.
std::ostream & operator<<(std::ostream &aStream)
void SetAlt(const wxString &aAlt)
Set the name of the alternate pin.
void PlotPinTexts(PLOTTER *aPlotter, const VECTOR2I &aPinPos, PIN_ORIENTATION aPinOrient, int aTextInside, bool aDrawPinNum, bool aDrawPinName, bool aDimmed) const
Plot the pin name and number.
int GetNumberTextSize() const
std::optional< bool > m_hidden
bool Matches(const EDA_SEARCH_DATA &aSearchData, void *aAuxData) const override
Compare the item against the search criteria in aSearchData.
void GetMsgPanelInfo(EDA_DRAW_FRAME *aFrame, std::vector< MSG_PANEL_ITEM > &aList) override
Populate aList of MSG_PANEL_ITEM objects with it's internal state for display purposes.
std::unique_ptr< PIN_LAYOUT_CACHE > m_layoutCache
The layout cache for this pin.
void MirrorVerticallyPin(int aCenter)
void validateExtentsCache(KIFONT::FONT *aFont, int aSize, const wxString &aText, EXTENTS_CACHE *aCache) const
const BOX2I ViewBBox() const override
Return the bounding box of the item covering all its layers.
std::vector< int > ViewGetLayers() const override
Return the layers the item is drawn on (which may be more than its "home" layer)
const std::map< wxString, ALT > & GetAlternates() const
void CalcEdit(const VECTOR2I &aPosition) override
Calculate the attributes of an item at aPosition when it is being edited.
void SetNumber(const wxString &aNumber)
std::optional< int > m_nameTextSize
PIN_ORIENTATION PinDrawOrient(const TRANSFORM &aTransform) const
Return the pin real orientation (PIN_UP, PIN_DOWN, PIN_RIGHT, PIN_LEFT), according to its orientation...
void SetVisible(bool aVisible)
void ChangeLength(int aLength)
Change the length of a pin and adjust its position based on orientation.
ALT GetAlt(const wxString &aAlt)
bool HasConnectivityChanges(const SCH_ITEM *aItem, const SCH_SHEET_PATH *aInstance=nullptr) const override
Check if aItem has connectivity changes against this object.
SCH_PIN & operator=(const SCH_PIN &aPin)
wxString GetShownNumber() const
void Move(const VECTOR2I &aOffset) override
Move the item by aMoveVector to a new position.
std::map< const SCH_SHEET_PATH, std::pair< wxString, bool > > m_net_name_map
PIN_ORIENTATION m_orientation
void SetOrientation(PIN_ORIENTATION aOrientation)
void SetName(const wxString &aName)
bool IsGlobalPower() const
Return whether this pin forms a global power connection: i.e., is part of a power symbol and of type ...
wxString getItemDescription(ALT *aAlt) const
bool ConnectionPropagatesTo(const EDA_ITEM *aItem) const override
Return true if this item should propagate connection info to aItem.
std::optional< int > m_numTextSize
VECTOR2I GetPinRoot() const
bool IsLocalPower() const
Local power pin is the same except that it is sheet-local and it does not support the legacy hidden p...
ELECTRICAL_PINTYPE m_type
void MirrorVertically(int aCenter) override
Mirror item vertically about aCenter.
SCH_PIN * GetLibPin() const
void SetPosition(const VECTOR2I &aPos) override
double Similarity(const SCH_ITEM &aOther) const override
Return a measure of how likely the other object is to represent the same object.
void SetIsDangling(bool aIsDangling)
wxString GetElectricalTypeName() const
std::map< wxString, ALT > m_alternates
const wxString & GetName() const
bool IsDangling() const override
void Plot(PLOTTER *aPlotter, bool aBackground, const SCH_PLOT_OPTS &aPlotOpts, int aUnit, int aBodyStyle, const VECTOR2I &aOffset, bool aDimmed) override
Plot the item to aPlotter.
void MirrorHorizontally(int aCenter) override
These transforms have effect only if the pin has a LIB_SYMBOL as parent.
std::recursive_mutex m_netmap_mutex
The name that this pin connection will drive onto a net.
PIN_ORIENTATION GetOrientation() const
wxString GetClass() const override
Return the class name.
void SetNumberTextSize(int aSize)
void SetShape(GRAPHIC_PINSHAPE aShape)
void RotatePin(const VECTOR2I &aCenter, bool aRotateCCW=true)
VECTOR2I GetPosition() const override
wxString GetCanonicalElectricalTypeName() const
bool Replace(const EDA_SEARCH_DATA &aSearchData, void *aAuxData) override
Perform a text replace using the find and replace criteria in aSearchData on items that support text ...
int GetNameTextSize() const
wxString GetItemDescription(UNITS_PROVIDER *aUnitsProvider, bool aFull) const override
Return a user-visible description string of this item.
int compare(const SCH_ITEM &aOther, int aCompareFlags=0) const override
The pin specific sort order is as follows:
wxString GetShownName() const
void MirrorHorizontallyPin(int aCenter)
These transforms have always effects.
bool HitTest(const VECTOR2I &aPosition, int aAccuracy=0) const override
Test if aPosition is inside or on the boundary of this item.
void SetType(ELECTRICAL_PINTYPE aType)
const wxString & GetBaseName() const
Get the name without any alternates.
void ClearDefaultNetName(const SCH_SHEET_PATH *aPath)
SCH_PIN(LIB_SYMBOL *aParentSymbol)
bool IsStacked(const SCH_PIN *aPin) const
const wxString & GetNumber() const
EDA_ITEM * Clone() const override
Create a duplicate of this item with linked list members set to NULL.
const BOX2I GetBoundingBox() const override
Return the orthogonal bounding box of this object for display purposes.
wxString GetDefaultNetName(const SCH_SHEET_PATH &aPath, bool aForceNoConnect=false)
std::optional< int > m_length
GRAPHIC_PINSHAPE GetShape() const
void PlotPinType(PLOTTER *aPlotter, const VECTOR2I &aPosition, PIN_ORIENTATION aOrientation, bool aDimmed) const
bool IsPower() const
Check if the pin is either a global or local power pin.
ELECTRICAL_PINTYPE GetType() const
BITMAPS GetMenuImage() const override
Return a pointer to an image to be used in menus.
void SetNameTextSize(int aSize)
VECTOR2I TransformCoordinate(const VECTOR2I &aPoint) const
const KIGFX::COLOR4D & GetBackgroundColor() const override
Return current background color settings.
Handle access to a stack of flattened SCH_SHEET objects by way of a path for creating a flattened sch...
const wxString GetValue(bool aResolve, const SCH_SHEET_PATH *aPath, bool aAllowExtraText) const override
std::vector< SCH_PIN * > GetPins(const SCH_SHEET_PATH *aSheet) const
Retrieve a list of the SCH_PINs for the given sheet path.
const wxString GetRef(const SCH_SHEET_PATH *aSheet, bool aIncludeUnit=false) const override
SCH_FIELD * GetField(FIELD_T aFieldType)
Return a mandatory field in this symbol.
A base class for LIB_SYMBOL and SCH_SYMBOL.
virtual bool IsGlobalPower() const =0
virtual int GetUnitCount() const =0
virtual bool IsLocalPower() const =0
virtual const wxString GetRef(const SCH_SHEET_PATH *aSheet, bool aIncludeUnit=false) const =0
int GetPinNameOffset() const
virtual bool GetShowPinNames() const
virtual bool GetShowPinNumbers() const
virtual bool HasAlternateBodyStyle() const =0
Test if symbol has more than one body conversion type (DeMorgan).
GR_TEXT_H_ALIGN_T m_Halign
GR_TEXT_V_ALIGN_T m_Valign
wxString MessageTextFromValue(double aValue, bool aAddUnitLabel=true, EDA_DATA_TYPE aType=EDA_DATA_TYPE::DISTANCE) const
A lower-precision version of StringFromValue().
#define DEFAULT_PINNUM_SIZE
The default pin name size when creating pins(can be changed in preference menu)
#define DEFAULT_PINNAME_SIZE
The default selection highlight thickness (can be changed in preference menu)
#define DEFAULT_PIN_LENGTH
The default pin number size when creating pins(can be changed in preference menu)
static constexpr EDA_ANGLE ANGLE_90
static constexpr EDA_ANGLE ANGLE_VERTICAL
static constexpr EDA_ANGLE ANGLE_HORIZONTAL
#define STRUCT_DELETED
flag indication structures to be erased
#define SKIP_STRUCT
flag indicating that the structure should be ignored
#define SHOW_ELEC_TYPE
Show pin electrical type.
int GetPenSizeForNormal(int aTextSize)
@ LAYER_SELECTION_SHADOWS
wxString ElectricalPinTypeGetText(ELECTRICAL_PINTYPE aType)
BITMAPS ElectricalPinTypeGetBitmap(ELECTRICAL_PINTYPE aType)
wxString PinShapeGetText(GRAPHIC_PINSHAPE aShape)
wxString PinOrientationName(PIN_ORIENTATION aOrientation)
ELECTRICAL_PINTYPE
The symbol library pin object electrical types used in ERC tests.
@ PT_UNSPECIFIED
unknown electrical properties: creates always a warning when connected
PIN_ORIENTATION
The symbol library pin object orientations.
@ PIN_RIGHT
The pin extends rightwards from the connection point.
#define ENUM_TO_WXANY(type)
Macro to define read-only fields (no setter method available)
static int externalPinDecoSize(const RENDER_SETTINGS *aSettings, const SCH_PIN &aPin)
Utility for getting the size of the 'external' pin decorators (as a radius) i.e.
static int internalPinDecoSize(const RENDER_SETTINGS *aSettings, const SCH_PIN &aPin)
Utility for getting the size of the 'internal' pin decorators (as a radius) i.e.
static struct SCH_PIN_DESC _SCH_PIN_DESC
#define TARGET_PIN_RADIUS
wxString UnescapeString(const wxString &aSource)
wxString EscapeString(const wxString &aSource, ESCAPE_CONTEXT aContext)
The Escape/Unescape routines use HTML-entity-reference-style encoding to handle characters which are:...
constexpr int MilsToIU(int mils) const
ELECTRICAL_PINTYPE m_Type
GR_TEXT_H_ALIGN_T
This is API surface mapped to common.types.HorizontalAlignment.
GR_TEXT_V_ALIGN_T
This is API surface mapped to common.types.VertialAlignment.
void RotatePoint(int *pX, int *pY, const EDA_ANGLE &aAngle)
Calculate the new point of coord coord pX, pY, for a rotation center 0, 0.
VECTOR2< int32_t > VECTOR2I