66#include <dialogs/dialog_text_properties.h>
67#include <dialogs/dialog_tablecell_properties.h>
68#include <dialogs/dialog_table_properties.h>
74#include <wx/textdlg.h>
104 const int unit = symbol->
GetUnit();
108 for(
int ii = 0; ii < nUnits; ii++ )
112 if( missingUnits.count( ii + 1 ) == 0 )
113 unit_text +=
_(
" (already placed)" );
126 if( !missingUnits.empty() )
130 for(
int unitNumber : missingUnits )
179 wxEmptyString, wxITEM_CHECK );
214 if(
pin->GetAlt().IsEmpty() || (
pin->GetAlt() == libPin->
GetName() ) )
262 if( !
pin && !sheetPin )
290 wxASSERT_MSG( drawingTools,
"eeshema.InteractiveDrawing tool is not available" );
292 auto hasElements = [
this](
const SELECTION& aSel )
294 return !
m_frame->GetScreen()->Items().empty();
297 auto sheetHasUndefinedPins = [](
const SELECTION& aSel )
299 if( aSel.Size() == 1 && aSel.Front()->Type() ==
SCH_SHEET_T )
305 auto attribDNPCond = [](
const SELECTION& aSel )
307 return std::all_of( aSel.Items().begin(), aSel.Items().end(),
310 return !item->IsType( { SCH_SYMBOL_T } )
311 ||
static_cast<const SCH_SYMBOL*
>( item )->GetDNP();
315 auto attribExcludeFromSimCond = [](
const SELECTION& aSel )
317 return std::all_of( aSel.Items().begin(), aSel.Items().end(),
320 return !item->IsType( { SCH_SYMBOL_T } )
321 ||
static_cast<const SCH_SYMBOL*
>( item )->GetExcludedFromSim();
325 auto attribExcludeFromBOMCond = [](
const SELECTION& aSel )
327 return std::all_of( aSel.Items().begin(), aSel.Items().end(),
330 return !item->IsType( { SCH_SYMBOL_T } )
331 ||
static_cast<const SCH_SYMBOL*
>( item )->GetExcludedFromBOM();
336 auto attribExcludeFromBoardCond = [](
const SELECTION& aSel )
338 return std::all_of( aSel.Items().begin(), aSel.Items().end(),
341 return !item->IsType( { SCH_SYMBOL_T } )
342 ||
static_cast<const SCH_SYMBOL*
>( item )->GetExcludedFromBoard();
350 auto haveHighlight = [
this](
const SELECTION& sel )
357 auto anyTextTool = [
this](
const SELECTION& aSel )
366 auto duplicateCondition = [](
const SELECTION& aSel )
374 auto orientCondition = [](
const SELECTION& aSel )
384 auto propertiesCondition = [
this](
const SELECTION& aSel )
386 if( aSel.GetSize() == 0 )
403 if( !firstItem || !eeSelection )
406 switch( firstItem->
Type() )
428 if( std::all_of( aSel.Items().begin(), aSel.Items().end(),
431 return item->Type() == SCH_LINE_T
432 && static_cast<const SCH_LINE*>( item )->IsGraphicLine();
437 else if( std::all_of( aSel.Items().begin(), aSel.Items().end(),
440 return item->Type() == SCH_JUNCTION_T;
445 else if( std::all_of( aSel.Items().begin(), aSel.Items().end(),
448 const SCH_ITEM* schItem = dynamic_cast<const SCH_ITEM*>( item );
450 wxCHECK( schItem, false );
452 return ( schItem->HasLineStroke() && schItem->IsConnectable() )
453 || item->Type() == SCH_JUNCTION_T;
461 default:
return false;
465 auto autoplaceCondition = [](
const SELECTION& aSel )
528 std::shared_ptr<SYMBOL_UNIT_MENU> menu = std::make_shared<SYMBOL_UNIT_MENU>();
529 menu->SetTool( tool );
530 tool->GetToolMenu().RegisterSubMenu( menu );
536 std::shared_ptr<BODY_STYLE_MENU> menu = std::make_shared<BODY_STYLE_MENU>();
537 menu->SetTool( tool );
538 tool->GetToolMenu().RegisterSubMenu( menu );
544 std::shared_ptr<ALT_PIN_FUNCTION_MENU> menu = std::make_shared<ALT_PIN_FUNCTION_MENU>();
545 menu->SetTool( tool );
546 tool->GetToolMenu().RegisterSubMenu( menu );
552 std::shared_ptr<PIN_TRICKS_MENU> menu = std::make_shared<PIN_TRICKS_MENU>();
553 menu->SetTool( tool );
554 tool->GetToolMenu().RegisterSubMenu( menu );
558 auto makeTransformMenu = [&]()
571 auto makeAttributesMenu = [&]()
584 auto makeEditFieldsMenu = [&]()
596 auto makeConvertToMenu = [&]()
635 moveMenu.AddMenu( makeTransformMenu(), orientCondition, 200 );
641 moveMenu.AddSeparator();
662 drawMenu.
AddMenu( makeTransformMenu(), orientCondition, 200 );
686 selToolMenu.
AddMenu( makeTransformMenu(), orientCondition, 200 );
698 selToolMenu.
AddMenu( makeConvertToMenu(), toChangeCondition, 200 );
748 wxLogTrace(
"KICAD_SCH_MOVE",
"SCH_EDIT_TOOL::Rotate: start, clockwise=%d, selection size=%u", clockwise,
755 int principalItemCount = 0;
762 std::map<SCH_SHEET_PIN*, SCH_NO_CONNECT*> noConnects;
765 commit = &localCommit;
767 for(
unsigned ii = 0; ii < selection.
GetSize(); ii++ )
774 principalItemCount++;
783 if( principalItemCount == 1 )
795 switch( head->
Type() )
801 symbol->
Rotate( rotPoint, !clockwise );
803 if(
m_frame->eeconfig()->m_AutoplaceFields.enable )
891 rotPoint =
m_frame->GetNearestHalfGridPosition(
group->GetPosition() );
893 group->Rotate( rotPoint, !clockwise );
895 group->Move( rotPoint -
m_frame->GetNearestHalfGridPosition(
group->GetPosition() ) );
904 rotPoint =
m_frame->GetNearestHalfGridPosition(
table->GetCenter() );
906 table->Rotate( rotPoint, !clockwise );
908 table->Move( rotPoint -
m_frame->GetNearestHalfGridPosition(
table->GetCenter() ) );
914 head->
Rotate( rotPoint, clockwise );
928 sheet->
Rotate( rotPoint, !clockwise );
936 m_frame->UpdateItem( head,
false,
true );
946 for(
EDA_ITEM* edaItem : selection )
962 line->
Rotate( rotPoint, !clockwise );
992 field->
Rotate( rotPoint, !clockwise );
1003 table->Rotate( rotPoint, !clockwise );
1006 table->Move( beforeCenter -
table->GetCenter() );
1014 sheet->
Rotate( rotPoint, !clockwise );
1019 item->
Rotate( rotPoint, !clockwise );
1021 wxLogTrace(
"KICAD_SCH_MOVE",
" SCH_EDIT_TOOL::Rotate: item type=%d rotated, pos (%d,%d) -> (%d,%d)",
1022 item->
Type(), posBefore.
x, posBefore.
y, posAfter.
x, posAfter.
y );
1025 m_frame->UpdateItem( item,
false,
true );
1029 wxLogTrace(
"KICAD_SCH_MOVE",
"SCH_EDIT_TOOL::Rotate: complete, moving=%d", moving );
1033 wxLogTrace(
"KICAD_SCH_MOVE",
"SCH_EDIT_TOOL::Rotate: posting refreshPreview" );
1038 for(
auto& [sheetPin, noConnect] : noConnects )
1040 if( noConnect->GetPosition() != sheetPin->GetTextPos() )
1042 commit->
Modify( noConnect, screen );
1043 noConnect->SetPosition( sheetPin->GetTextPos() );
1057 m_frame->Schematic().CleanUp( commit );
1059 if( !localCommit.
Empty() )
1060 localCommit.
Push(
_(
"Rotate" ) );
1071 if( selection.
GetSize() == 0 )
1076 bool connections =
false;
1082 std::map<SCH_SHEET_PIN*, SCH_NO_CONNECT*> noConnects;
1085 commit = &localCommit;
1087 if( selection.
GetSize() == 1 )
1092 switch( item->
Type() )
1162 noConnects =
static_cast<SCH_SHEET*
>( item )->GetNoConnects();
1185 m_frame->UpdateItem( item,
false,
true );
1187 else if( selection.
GetSize() > 1 )
1191 for(
EDA_ITEM* edaItem : selection )
1193 item =
static_cast<SCH_ITEM*
>( edaItem );
1237 m_frame->UpdateItem( item,
false,
true );
1242 for(
EDA_ITEM* selected : selection )
1251 for(
auto& [sheetPin, noConnect] : noConnects )
1253 if( noConnect->GetPosition() != sheetPin->GetTextPos() )
1255 commit->
Modify( noConnect, screen );
1256 noConnect->SetPosition( sheetPin->GetTextPos() );
1272 m_frame->Schematic().CleanUp( commit );
1275 if( !localCommit.
Empty() )
1276 localCommit.
Push(
_(
"Mirror" ) );
1292 unsigned aFallbackRotationsCCW )
1294 std::set<wxString> handledKeys;
1303 const VECTOR2I bRelPos = bField.GetPosition() - bField.GetParentPosition();
1306 const EDA_ANGLE bTextAngle = bField.GetTextAngle();
1313 bField.SetPosition( bField.GetParentPosition() + aRelPos );
1314 bField.SetHorizJustify( aTextJustifyH );
1315 bField.SetVertJustify( aTextJustifyV );
1316 bField.SetTextAngle( aTextAngle );
1323 auto it = std::find_if( aBFields.begin(), aBFields.end(),
1326 return bField.GetCanonicalName() == name;
1329 if( it != aBFields.end() )
1333 swapFieldTextProps( aField, bField );
1338 for(
unsigned ii = 0; ii < aFallbackRotationsCCW; ii++ )
1345 handledKeys.insert(
name );
1352 const wxString bName = bField.GetCanonicalName();
1353 if( handledKeys.find( bName ) == handledKeys.end() )
1355 for(
unsigned ii = 0; ii < aFallbackRotationsCCW; ii++ )
1357 bField.Rotate( bField.GetParentPosition(),
false );
1369 if( selection.
Size() < 2 )
1389 bool connections =
false;
1395 commit = &localCommit;
1397 for(
size_t i = 0; i < sorted.size() - 1; i++ )
1409 std::swap( aPos, bPos );
1418 std::swap( aSide, bSide );
1446 std::vector<SCH_FIELD>& aFields = aLabelBase.
GetFields();
1447 std::vector<SCH_FIELD>& bFields = bLabelBase.
GetFields();
1449 const unsigned rotationsAtoB = aSpinStyle.
CCWRotationsTo( bSpinStyle );
1459 std::swap( aOrient, bOrient );
1470 m_frame->UpdateItem( a,
false,
true );
1471 m_frame->UpdateItem( b,
false,
true );
1487 if( !localCommit.
Empty() )
1488 localCommit.
Push(
_(
"Swap" ) );
1508 if( !
m_frame->eeconfig()->m_Input.allow_unconstrained_pin_swaps )
1514 if( selection.
Size() < 2 )
1531 std::set<wxString> sharedSheetPaths;
1532 std::set<wxString> sharedProjectNames;
1535 &sharedProjectNames ) )
1539 std::set<wxString> friendlySheets;
1541 if( !sharedSheetPaths.empty() )
1544 if( !sharedProjectNames.empty() )
1548 if( projects.IsEmpty() )
1550 m_frame->ShowInfoBarError(
_(
"Pin swaps are disabled for symbols shared across other projects. "
1551 "Duplicate the sheet to edit pins independently." ) );
1556 wxString::Format(
_(
"Pin swaps are disabled for symbols shared across other projects (%s). "
1557 "Duplicate the sheet to edit pins independently." ),
1561 else if( !friendlySheets.empty() )
1566 wxString::Format(
_(
"Pin swaps are disabled for symbols used by multiple sheet instances (%s). "
1567 "Duplicate the sheet to edit pins independently." ),
1573 _(
"Pin swaps are disabled for shared symbols. Duplicate the sheet to edit pins independently." ) );
1579 bool connections =
false;
1585 commit = &localCommit;
1591 bool swappedLibPins =
false;
1593 for(
size_t i = 0; i < sorted.size() - 1; i++ )
1596 SCH_PIN* bPin =
static_cast<SCH_PIN*
>( sorted[( i + 1 ) % sorted.size()] );
1609 m_frame->UpdateItem( aPin,
false,
true );
1610 m_frame->UpdateItem( bPin,
false,
true );
1613 if( swappedLibPins )
1617 m_frame->UpdateItem( parentSymbol,
false,
true );
1630 m_frame->Schematic().CleanUp( commit );
1637 if( !localCommit.
Empty() )
1638 localCommit.
Push(
_(
"Swap Pins" ) );
1648 if( !aGraph || !aPin )
1656 const std::set<SCH_ITEM*>& items = sg->
GetItems();
1658 size_t pinCount = 0;
1666 switch( item->
Type() )
1674 if( conn && conn->
IsNet() )
1700 if( orderedPins.size() < 2 )
1707 std::vector<SCH_LABEL_BASE*> labels;
1709 for(
EDA_ITEM* item : orderedPins )
1717 _(
"Each selected pin must have exactly one attached net label and no other pin connections." ) );
1721 labels.push_back( label );
1724 if( labels.size() >= 2 )
1731 for(
size_t i = 0; i < labels.size() - 1; ++i )
1735 wxString aText = a->
GetText();
1736 wxString bText = b->
GetText();
1741 commit.
Push(
_(
"Swap Pin Labels" ) );
1753 if( selectedUnits.size() < 2 )
1761 std::vector<std::vector<SCH_LABEL_BASE*>> symbolLabelVectors;
1765 std::vector<std::pair<VECTOR2I, SCH_LABEL_BASE*>> byPos;
1767 for(
SCH_PIN*
pin : symbol->GetPins( &sheetPath ) )
1773 m_frame->ShowInfoBarError(
_(
"Each pin of selected units must have exactly one attached net label and "
1774 "no other pin connections." ) );
1778 byPos.emplace_back(
pin->GetPosition(), label );
1782 std::sort( byPos.begin(), byPos.end(),
1783 [](
const auto& a,
const auto& b )
1785 if( a.first.x != b.first.x )
1786 return a.first.x < b.first.x;
1788 return a.first.y < b.first.y;
1792 std::vector<SCH_LABEL_BASE*> labels;
1794 for(
const auto& pr : byPos )
1795 labels.push_back( pr.second );
1797 symbolLabelVectors.push_back( labels );
1801 const size_t pinCount = symbolLabelVectors.front().size();
1806 for(
size_t pin = 0;
pin < pinCount;
pin++ )
1808 for(
auto& vec : symbolLabelVectors )
1811 wxString carry = symbolLabelVectors.back()[
pin]->GetText();
1813 for(
size_t i = 0; i < symbolLabelVectors.size(); i++ )
1822 if( !commit.
Empty() )
1823 commit.
Push(
_(
"Swap Unit Labels" ) );
1831 const std::vector<std::unique_ptr<SCH_ITEM>>& sourceItems =
m_frame->GetRepeatItems();
1833 if( sourceItems.empty() )
1842 for(
const std::unique_ptr<SCH_ITEM>& item : sourceItems )
1845 bool restore_state =
false;
1856 enteredGroup->AddItem( newItem );
1865 if( !label->IncrementLabel( cfg->m_Drawing.repeat_label_increment ) )
1866 m_frame->ShowInfoBarWarning(
_(
"Label value cannot go below zero" ),
true );
1879 schIUScale.MilsToIU( cfg->m_Drawing.default_repeat_offset_y ) ) );
1888 if(
m_frame->CheckSheetForRecursion( sheet, currentSheet ) )
1891 const wxString originalFileName = sheet->
GetFileName();
1896 restore_state = !
m_frame->EditSheetProperties( sheet, currentSheet );
1909 commit.Added( newItem,
m_frame->GetScreen() );
1918 if(
m_frame->eeconfig()->m_AnnotatePanel.automatic )
1920 static_cast<SCH_SYMBOL*
>( newItem )->ClearAnnotation(
nullptr,
false );
1923 true , annotateStartNum,
false,
false,
false,
1939 newItems.
Add( newItem );
1945 m_frame->Schematic().CleanUp( &commit );
1946 commit.Push(
_(
"Repeat Item" ) );
1950 if( !newItems.
Empty() )
1951 m_frame->SaveCopyForRepeatItem(
static_cast<SCH_ITEM*
>( newItems[0] ) );
1953 for(
size_t ii = 1; ii < newItems.
GetSize(); ++ii )
1954 m_frame->AddCopyForRepeatItem(
static_cast<SCH_ITEM*
>( newItems[ii] ) );
1965 std::vector<VECTOR2I> pts;
1966 bool updateHierarchy =
false;
1987 pts.insert( pts.end(), tmp_pts.begin(), tmp_pts.end() );
2010 static_cast<SCH_FIELD*
>( sch_item )->SetVisible(
false );
2016 static_cast<SCH_TABLECELL*
>( sch_item )->SetText( wxEmptyString );
2053 m_frame->DeleteJunction( &commit, junction );
2056 commit.
Push(
_(
"Delete" ) );
2058 if( updateHierarchy )
2059 m_frame->UpdateHierarchyNavigator();
2083 caption.Printf(
_(
"Edit %s Field" ),
TitleCaps( fieldName ) );
2087 caption.Printf(
_(
"Edit '%s' Field" ), aField->
GetName() );
2107 if( !commit.
Empty() )
2108 commit.
Push( caption );
2116 if( sel.
Size() != 1 )
2119 bool clearSelection = sel.
IsHover();
2135 if( item ==
nullptr )
2167 clearSelection =
true;
2191 if( clearSelection )
2203 bool moving = head && head->
IsMoving();
2205 if( selection.
Empty() )
2208 std::vector<SCH_ITEM*> autoplaceItems;
2210 for(
unsigned ii = 0; ii < selection.
GetSize(); ii++ )
2215 autoplaceItems.push_back( item );
2220 for(
SCH_ITEM* sch_item : autoplaceItems )
2222 if( !moving && !sch_item->IsNew() )
2236 if( !commit.
Empty() )
2237 commit.
Push(
_(
"Autoplace Fields" ) );
2252 if( !selection.
Empty() )
2276 if( selection.
Empty() )
2282 if( !symbol->
IsNew() )
2290 m_frame->SelectBodyStyle( symbol, nextBodyStyle );
2292 if( symbol->
IsNew() )
2295 if( !commit.
Empty() )
2296 commit.
Push(
_(
"Change Body Style" ) );
2308 bool clearSelection = selection.
IsHover();
2310 if( selection.
Empty() )
2335 switch( curr_item->
Type() )
2342 std::deque<SCH_LINE*> lines;
2345 lines.push_back(
static_cast<SCH_LINE*
>( selItem ) );
2353 std::deque<SCH_JUNCTION*> junctions;
2356 junctions.push_back(
static_cast<SCH_JUNCTION*
>( selItem ) );
2365 std::deque<SCH_ITEM*> items;
2368 items.push_back(
static_cast<SCH_ITEM*
>( selItem ) );
2386 if( inspectionTool )
2394 std::vector<SCH_TABLECELL*> cells;
2416 if( selection.
Size() > 1 )
2422 if( clearSelection )
2431 switch( aItem->
Type() )
2452 if(
m_frame->eeconfig()->m_AutoplaceFields.enable )
2468 if( wxWindow* blocking_win =
editor->Kiway().GetBlockingDialog() )
2469 blocking_win->Close(
true );
2475 editor->LoadSymbolFromSchematic( symbol );
2486 if( wxWindow* blocking_win =
editor->Kiway().GetBlockingDialog() )
2487 blocking_win->Close(
true );
2511 bool isUndoable =
false;
2512 bool doClearAnnotation =
false;
2513 bool okPressed =
false;
2514 bool updateHierarchyNavigator =
false;
2524 okPressed =
m_frame->EditSheetProperties( sheet, &
m_frame->GetCurrentSheet(), &isUndoable, &doClearAnnotation,
2525 &updateHierarchyNavigator );
2531 commit.
Push(
_(
"Edit Sheet Properties" ) );
2535 std::vector<SCH_ITEM*> items;
2537 items.emplace_back( sheet );
2538 m_frame->Schematic().OnItemsRemoved( items );
2539 m_frame->Schematic().OnItemsAdded( items );
2541 m_frame->Schematic().RefreshHierarchy();
2542 m_frame->UpdateHierarchyNavigator();
2555 if( doClearAnnotation )
2569 m_frame->GetCanvas()->Refresh();
2571 if( updateHierarchyNavigator )
2572 m_frame->UpdateHierarchyNavigator();
2655 dlg.SetTitle(
_(
"Rule Area Properties" ) );
2670 wxFAIL_MSG( wxString(
"Cannot edit schematic item type " ) + aItem->
GetClass() );
2686 commit = &localCommit;
2688 for(
unsigned int i = 0; i < selection.GetSize(); ++i )
2692 if( item && item->
Type() != convertTo )
2703 wxCHECK2( sourceText,
continue );
2705 switch( item->
Type() )
2725 txt =
_(
"<empty>" );
2736 txt =
text->GetText();
2737 href =
text->GetHyperlink();
2754 int textSize =
text->GetTextSize().y;
2787 position =
m_frame->GetNearestGridPosition( position );
2795 auto getValidNetname = [](
const wxString& aText )
2797 wxString local_txt = aText;
2798 local_txt.Replace(
"\n",
"_" );
2799 local_txt.Replace(
"\r",
"_" );
2800 local_txt.Replace(
"\t",
"_" );
2804 local_txt.Replace(
" ",
"_" );
2809 if( local_txt.IsEmpty() )
2810 return _(
"<empty>" );
2838 newtext = new_label;
2863 newtext = new_label;
2888 newtext = new_label;
2905 new_label->
GetFields().push_back( netclass );
2912 newtext = new_label;
2932 bbox.
Inflate( -label->GetLabelBoxExpansion() );
2963 new_textbox->
SetEnd( botRight );
2966 newtext = new_textbox;
2973 wxCHECK2( newtext,
continue );
2984 wxCHECK2( eda_text && new_eda_text,
continue );
2999 if( label && new_label )
3008 return field.GetId() == FIELD_T::INTERSHEET_REFS
3009 && new_label->Type() != SCH_GLOBAL_LABEL_T;
3031 if( !localCommit.
Empty() )
3032 localCommit.
Push(
_(
"Change To" ) );
3034 if( selection.IsHover() )
3047 if( selection.
GetSize() == 0 )
3056 commit = &localCommit;
3058 auto setJustify = [&](
EDA_TEXT* aTextItem )
3068 for(
EDA_ITEM* edaItem : selection )
3070 item =
static_cast<SCH_ITEM*
>( edaItem );
3077 setJustify(
static_cast<SCH_FIELD*
>( item ) );
3084 setJustify(
static_cast<SCH_TEXT*
>( item ) );
3095 setJustify( label );
3098 m_frame->UpdateItem( item,
false,
true );
3102 for(
EDA_ITEM* selected : selection )
3116 if( !localCommit.
Empty() )
3119 localCommit.
Push(
_(
"Left Justify" ) );
3121 localCommit.
Push(
_(
"Center Justify" ) );
3123 localCommit.
Push(
_(
"Right Justify" ) );
3140 if( !
IsOK(
m_frame,
_(
"Do you wish to delete the unreferenced pins from this sheet?" ) ) )
3149 commit.
Push(
_(
"Cleanup Sheet Pins" ) );
3174 screen =
m_frame->GetScreen();
3183 if( prevInstance.
size() )
3191 screen =
m_frame->GetScreen();
3194 sheet =
m_frame->GetCurrentSheet().Last();
3201 msg.Printf(
_(
"Enter page number for sheet path%s" ),
3202 ( sheetPath.Length() > 20 ) ?
"\n" + sheetPath :
" " + sheetPath );
3204 wxTextEntryDialog dlg(
m_frame, msg,
_(
"Edit Sheet Page Number" ), pageNumber );
3206 dlg.SetTextValidator( wxFILTER_ALPHANUMERIC );
3208 if( dlg.ShowModal() == wxID_CANCEL || dlg.GetValue() == instance.
GetPageNumber() )
3213 commit.
Modify( sheet, screen );
3217 if( instance ==
m_frame->GetCurrentSheet() )
3219 m_frame->GetScreen()->SetPageNumber( dlg.GetValue() );
3220 m_frame->OnPageSettingsChange();
3223 commit.
Push( wxS(
"Change Sheet Page Number" ) );
3240 wxString* filename = aEvent.
Parameter<wxString*>();
3247 if( !
image->GetReferenceImage().ReadImageFile( *filename ) )
3249 wxMessageBox( wxString::Format(
_(
"Could not load image from '%s'." ), *filename ) );
3259 std::set<std::pair<SCH_SYMBOL*, SCH_SCREEN*>>& aCollectedUnits )
3267 aCollectedUnits.insert( { symbol,
m_frame->GetScreen() } );
3273 wxString ref = symbol->
GetRef( &
m_frame->GetCurrentSheet() );
3280 std::vector<SCH_SYMBOL*> otherUnits;
3285 aCollectedUnits.insert( { otherUnit, screen } );
3298 std::set<std::pair<SCH_SYMBOL*, SCH_SCREEN*>> collectedUnits;
3301 bool new_state =
false;
3303 for(
const auto& [symbol,
_] : collectedUnits )
3315 for(
const auto& [symbol, screen] : collectedUnits )
3317 commit.
Modify( symbol, screen );
3320 symbol->SetDNP( new_state );
3323 symbol->SetExcludedFromSim( new_state );
3326 symbol->SetExcludedFromBOM( new_state );
3329 symbol->SetExcludedFromBoard( new_state );
3332 if( !commit.
Empty() )
3333 commit.
Push(
_(
"Toggle Attribute" ) );
3347 return _(
"Edit Symbol Properties..." );
3363 return _(
"Edit Netclasses..." );
3366 return wxEmptyString;
constexpr EDA_IU_SCALE schIUScale
constexpr BOX2I KiROUND(const BOX2D &aBoxD)
static TOOL_ACTION decrementPrimary
static TOOL_ACTION unselectAll
static TOOL_ACTION decrementSecondary
static TOOL_ACTION selectItem
Select an item (specified as the event parameter).
static TOOL_ACTION unselectItem
static TOOL_ACTION showSymbolLibTable
static TOOL_ACTION pasteSpecial
static TOOL_ACTION groupProperties
static TOOL_ACTION rightJustify
static TOOL_ACTION pageSettings
static TOOL_ACTION incrementSecondary
static TOOL_ACTION duplicate
static TOOL_ACTION incrementPrimary
static TOOL_ACTION doDelete
static TOOL_ACTION deleteTool
static TOOL_ACTION increment
static TOOL_ACTION selectionClear
Clear the current selection.
static TOOL_ACTION leftJustify
static TOOL_ACTION copyAsText
static TOOL_ACTION refreshPreview
static TOOL_ACTION selectAll
static TOOL_ACTION centerJustify
Manage TOOL_ACTION objects.
void SetConditions(const TOOL_ACTION &aAction, const ACTION_CONDITIONS &aConditions)
Set the conditions the UI elements for activating a specific tool action should use for determining t...
void update() override
Update menu state stub.
ACTION_MENU * create() const override
Return an instance of this class. It has to be overridden in inheriting classes.
constexpr const Vec & GetPosition() const
constexpr BOX2< Vec > & Inflate(coord_type dx, coord_type dy)
Inflates the rectangle horizontally by dx and vertically by dy.
constexpr const Vec GetEnd() const
constexpr void SetOrigin(const Vec &pos)
constexpr Vec Centre() const
constexpr const Vec GetCenter() const
constexpr coord_type GetLeft() const
constexpr const Vec & GetOrigin() const
constexpr coord_type GetRight() const
constexpr void SetEnd(coord_type x, coord_type y)
constexpr coord_type GetTop() const
constexpr coord_type GetBottom() const
COMMIT & Remove(EDA_ITEM *aItem, BASE_SCREEN *aScreen=nullptr)
Remove a new item from the model.
COMMIT & Added(EDA_ITEM *aItem, BASE_SCREEN *aScreen=nullptr)
Notify observers that aItem has been added.
void Unstage(EDA_ITEM *aItem, BASE_SCREEN *aScreen)
COMMIT & Modify(EDA_ITEM *aItem, BASE_SCREEN *aScreen=nullptr, RECURSE_MODE aRecurse=RECURSE_MODE::NO_RECURSE)
Modify a given item in the model.
COMMIT & Removed(EDA_ITEM *aItem, BASE_SCREEN *aScreen=nullptr)
int GetStatus(EDA_ITEM *aItem, BASE_SCREEN *aScreen=nullptr)
Returns status of an item.
Calculate the connectivity of a schematic and generates netlists.
CONNECTION_SUBGRAPH * GetSubgraphForItem(SCH_ITEM *aItem) const
A subgraph is a set of items that are electrically connected on a single sheet.
const std::set< SCH_ITEM * > & GetItems() const
Provide a read-only reference to the items in the subgraph.
Dialog to update or change schematic library symbols.
This class is setup in expectation of its children possibly using Kiway player so DIALOG_SHIM::ShowQu...
void UpdateField(SCH_FIELD *aField)
Dialog used to edit SCH_SYMBOL objects in a schematic.
@ TABLECELL_PROPS_EDIT_TABLE
enum TABLECELL_PROPS_RETVALUE GetReturnValue()
bool HitTestDrawingSheetItems(KIGFX::VIEW *aView, const VECTOR2I &aPosition)
bool IsHorizontal() const
A set of EDA_ITEMs (i.e., without duplicates).
A base class for most all the KiCad significant classes used in schematics and boards.
virtual VECTOR2I GetPosition() const
virtual void SetPosition(const VECTOR2I &aPos)
virtual const BOX2I GetBoundingBox() const
Return the orthogonal bounding box of this object for display purposes.
EDA_ITEM_FLAGS GetEditFlags() const
void SetFlags(EDA_ITEM_FLAGS aMask)
KICAD_T Type() const
Returns the type of object.
void ClearFlags(EDA_ITEM_FLAGS aMask=EDA_ITEM_ALL_FLAGS)
virtual bool IsType(const std::vector< KICAD_T > &aScanTypes) const
Check whether the item is one of the listed types.
virtual void SetParent(EDA_ITEM *aParent)
EDA_ITEM * GetParent() const
bool HasFlag(EDA_ITEM_FLAGS aFlag) const
void SetEnd(const VECTOR2I &aEnd)
A mix-in class (via multiple inheritance) that handles texts such as labels, parts,...
const EDA_ANGLE & GetTextAngle() const
void SetTextSize(VECTOR2I aNewSize, bool aEnforceMinTextSize=true)
virtual const wxString & GetText() const
Return the string associated with the text object.
virtual bool IsVisible() const
void SetTextPos(const VECTOR2I &aPoint)
KIFONT::FONT * GetFont() const
void SetAttributes(const EDA_TEXT &aSrc, bool aSetPosition=true)
Set the text attributes from another instance.
void SetVertJustify(GR_TEXT_V_ALIGN_T aType)
wxString GetHyperlink() const
GR_TEXT_H_ALIGN_T GetHorizJustify() const
void SetTextThickness(int aWidth)
The TextThickness is that set by the user.
void SetBold(bool aBold)
Set the text to be bold - this will also update the font if needed.
void SetHyperlink(wxString aLink)
GR_TEXT_V_ALIGN_T GetVertJustify() const
virtual void SetText(const wxString &aText)
virtual void SetTextAngle(const EDA_ANGLE &aAngle)
int GetTextThickness() const
void SetItalic(bool aItalic)
Set the text to be italic - this will also update the font if needed.
void SetFont(KIFONT::FONT *aFont)
VECTOR2I GetTextSize() const
void SetHorizJustify(GR_TEXT_H_ALIGN_T aType)
EE_TYPE Overlapping(const BOX2I &aRect) const
VECTOR2D GetCursorPosition() const
Return the current cursor position in world coordinates.
virtual wxString GetClass() const =0
Return the class name.
void RecacheAllItems()
Rebuild GAL display lists.
A wxFrame capable of the OpenProjectFiles function, meaning it can load a portion of a KiCad project.
A logical library item identifier and consists of various portions much like a URI.
int GetUnitCount() const override
static bool ParseBusGroup(const wxString &aGroup, wxString *name, std::vector< wxString > *aMemberList)
Parse a bus group label into the name and a list of components.
A singleton reporter that reports to nowhere.
These are loaded from Eeschema settings but then overwritten by the project settings.
SCHEMATIC_SETTINGS & Settings() const
static TOOL_ACTION rotateCCW
static TOOL_ACTION placeClassLabel
static TOOL_ACTION swapPins
static TOOL_ACTION editValue
static TOOL_ACTION setExcludeFromBOM
static TOOL_ACTION mirrorV
static TOOL_ACTION clearHighlight
static TOOL_ACTION placeGlobalLabel
static TOOL_ACTION changeSymbols
static TOOL_ACTION updateSymbol
static TOOL_ACTION autoplaceFields
static TOOL_ACTION changeSymbol
static TOOL_ACTION ddAddImage
static TOOL_ACTION properties
static TOOL_ACTION editReference
static TOOL_ACTION placeHierLabel
static TOOL_ACTION placeLabel
static TOOL_ACTION toText
static TOOL_ACTION toHLabel
static TOOL_ACTION rotateCW
static TOOL_ACTION importSheet
static TOOL_ACTION toLabel
static TOOL_ACTION setDNP
static TOOL_ACTION swapUnitLabels
static TOOL_ACTION placeImage
static TOOL_ACTION editWithLibEdit
static TOOL_ACTION cleanupSheetPins
static TOOL_ACTION toDLabel
static TOOL_ACTION cycleBodyStyle
static TOOL_ACTION mirrorH
static TOOL_ACTION setExcludeFromSimulation
static TOOL_ACTION ddAppendFile
static TOOL_ACTION placeSchematicText
static TOOL_ACTION toTextBox
static TOOL_ACTION annotate
static TOOL_ACTION updateSymbols
static TOOL_ACTION swapPinLabels
static TOOL_ACTION enterSheet
static TOOL_ACTION editFootprint
static TOOL_ACTION repeatDrawItem
static TOOL_ACTION editTextAndGraphics
static TOOL_ACTION editPageNumber
static TOOL_ACTION toGLabel
static TOOL_ACTION setExcludeFromBoard
Object to handle a bitmap image that can be inserted in a schematic.
static const std::vector< KICAD_T > FieldOwners
static const std::vector< KICAD_T > DeletableItems
virtual void Push(const wxString &aMessage=wxT("A commit"), int aCommitFlags=0) override
Execute the changes.
static SELECTION_CONDITION SingleMultiFunctionPin
static SELECTION_CONDITION SingleSymbol
static SELECTION_CONDITION MultipleSymbolsOrPower
static SELECTION_CONDITION AllPinsOrSheetPins
static SELECTION_CONDITION SingleSymbolOrPower
static SELECTION_CONDITION SingleMultiUnitSymbol
static SELECTION_CONDITION SingleMultiBodyStyleSymbol
Each graphical item can have a SCH_CONNECTION describing its logical connection (to a bus or net).
Schematic editor (Eeschema) main window.
void ShowSchematicSetupDialog(const wxString &aInitialPage=wxEmptyString)
EDA_ITEM * ResolveItem(const KIID &aId, bool aAllowNullptrReturn=false) const override
Fetch an item by KIID.
const wxString & GetHighlightedConnection() const
void Rotate(const VECTOR2I &aCenter, bool aRotateCCW) override
Rotate the item around aCenter 90 degrees in the clockwise direction.
VECTOR2I GetPosition() const override
wxString GetCanonicalName() const
Get a non-language-specific name for a field which can be used for storage, variable look-up,...
wxString GetName(bool aUseDefaultName=true) const
Return the field name (not translated).
void SetPosition(const VECTOR2I &aPosition) override
void SetText(const wxString &aText) override
VECTOR2I GetParentPosition() const
A set of SCH_ITEMs (i.e., without duplicates).
Base class for any item which can be embedded within the SCHEMATIC container class,...
virtual bool IsConnectable() const
virtual void AutoplaceFields(SCH_SCREEN *aScreen, AUTOPLACE_ALGO aAlgo)
virtual void RunOnChildren(const std::function< void(SCH_ITEM *)> &aFunction, RECURSE_MODE aMode)
const SYMBOL * GetParentSymbol() const
SCHEMATIC * Schematic() const
Search the item hierarchy to find a SCHEMATIC.
virtual void MirrorHorizontally(int aCenter)
Mirror item horizontally about aCenter.
virtual void Move(const VECTOR2I &aMoveVector)
Move the item by aMoveVector to a new position.
void SetConnectivityDirty(bool aDirty=true)
void SetFieldsAutoplaced(AUTOPLACE_ALGO aAlgo)
virtual void Rotate(const VECTOR2I &aCenter, bool aRotateCCW)
Rotate the item around aCenter 90 degrees in the clockwise direction.
AUTOPLACE_ALGO GetFieldsAutoplaced() const
Return whether the fields have been automatically placed.
wxString GetClass() const override
Return the class name.
bool IsGroupableType() const
virtual std::vector< VECTOR2I > GetConnectionPoints() const
Add all the connection points for this item to aPoints.
bool IsType(const std::vector< KICAD_T > &aScanTypes) const override
Check whether the item is one of the listed types.
virtual void MirrorVertically(int aCenter)
Mirror item vertically about aCenter.
void AddFields(const std::vector< SCH_FIELD > &aFields)
void MirrorHorizontally(int aCenter) override
Mirror item horizontally about aCenter.
SPIN_STYLE GetSpinStyle() const
void SetShape(LABEL_FLAG_SHAPE aShape)
LABEL_FLAG_SHAPE GetShape() const
void MirrorVertically(int aCenter) override
Mirror item vertically about aCenter.
std::vector< SCH_FIELD > & GetFields()
virtual void SetSpinStyle(SPIN_STYLE aSpinStyle)
Segment description base class to describe items which have 2 end points (track, wire,...
void Rotate(const VECTOR2I &aCenter, bool aRotateCCW) override
Rotate the item around aCenter 90 degrees in the clockwise direction.
VECTOR2I GetEndPoint() const
VECTOR2I GetStartPoint() const
const std::map< wxString, ALT > & GetAlternates() const
bool IsConnectable() const override
const wxString & GetName() const
Container class that holds multiple SCH_SCREEN objects in a hierarchy.
void ClearAnnotationOfNewSheetPaths(SCH_SHEET_LIST &aInitialSheetPathList)
Clear the annotation for the symbols inside new sheetpaths when a complex hierarchy is modified and n...
bool IsExplicitJunction(const VECTOR2I &aPosition) const
Indicate that a junction dot is necessary at the given location.
EE_RTREE & Items()
Get the full RTree, usually for iterating.
const wxString & GetFileName() const
SCH_ITEM * GetItem(const VECTOR2I &aPosition, int aAccuracy=0, KICAD_T aType=SCH_LOCATE_ANY_T) const
Check aPosition within a distance of aAccuracy for items of type aFilter.
void SetFileName(const wxString &aFileName)
Set the file name for this screen to aFileName.
void ClearAnnotation(SCH_SHEET_PATH *aSheetPath, bool aResetPrefix)
Clear the annotation for the symbols in aSheetPath on the screen.
void SetPosition(const VECTOR2I &aPos) override
const BOX2I GetBoundingBox() const override
Return the orthogonal bounding box of this object for display purposes.
A container for handling SCH_SHEET_PATH objects in a flattened hierarchy.
void BuildSheetList(SCH_SHEET *aSheet, bool aCheckIntegrity)
Build the list of sheets and their sheet path from aSheet.
Handle access to a stack of flattened SCH_SHEET objects by way of a path for creating a flattened sch...
wxString PathHumanReadable(bool aUseShortRootName=true, bool aStripTrailingSeparator=false) const
Return the sheet path in a human readable form made from the sheet names.
SCH_SCREEN * LastScreen()
wxString GetPageNumber() const
void SetPageNumber(const wxString &aPageNumber)
Set the sheet instance user definable page number.
void push_back(SCH_SHEET *aSheet)
Forwarded method from std::vector.
size_t size() const
Forwarded method from std::vector.
void pop_back()
Forwarded method from std::vector.
Define a sheet pin (label) used in sheets to create hierarchical schematics.
SHEET_SIDE GetSide() const
void SetSide(SHEET_SIDE aEdge)
Sheet symbol placed in a schematic, and is the entry point for a sub schematic.
void SetFileName(const wxString &aFilename)
wxString GetFileName() const
Return the filename corresponding to this sheet.
std::map< SCH_SHEET_PIN *, SCH_NO_CONNECT * > GetNoConnects() const
VECTOR2I GetRotationCenter() const
Rotating around the boundingBox's center can cause walking when the sheetname or filename is longer t...
void CleanupSheet()
Delete sheet label which do not have a corresponding hierarchical label.
void RemovePin(const SCH_SHEET_PIN *aSheetPin)
Remove aSheetPin from the sheet.
bool HasUndefinedPins() const
Check all sheet labels against schematic for undefined hierarchical labels.
SCH_SCREEN * GetScreen() const
const BOX2I GetBodyBoundingBox() const
Return a bounding box for the sheet body but not the fields.
const BOX2I GetBoundingBox() const override
Return the orthogonal bounding box of this object for display purposes.
void Rotate(const VECTOR2I &aCenter, bool aRotateCCW) override
Rotate the item around aCenter 90 degrees in the clockwise direction.
wxString GetUnitDisplayName(int aUnit, bool aLabel) const override
Return the display name for a given unit aUnit.
bool IsAnnotated(const SCH_SHEET_PATH *aSheet) const
Check if the symbol has a valid annotation (reference) for the given sheet path.
bool IsMultiBodyStyle() const override
void AutoplaceFields(SCH_SCREEN *aScreen, AUTOPLACE_ALGO aAlgo) override
Automatically orient all the fields in the symbol.
wxString GetBodyStyleDescription(int aBodyStyle, bool aLabel) const override
void UpdatePins()
Updates the cache of SCH_PIN objects for each pin.
bool HasDeMorganBodyStyles() const override
int GetBodyStyleCount() const override
Return the number of body styles of the symbol.
void SetOrientation(int aOrientation)
Compute the new transform matrix based on aOrientation for the symbol which is applied to the current...
bool IsMissingLibSymbol() const
Check to see if the library symbol is set to the dummy library symbol.
const LIB_ID & GetLibId() const override
int GetOrientation() const override
Get the display symbol orientation.
std::unique_ptr< LIB_SYMBOL > & GetLibSymbolRef()
const wxString GetRef(const SCH_SHEET_PATH *aSheet, bool aIncludeUnit=false) const override
void Rotate(const VECTOR2I &aCenter, bool aRotateCCW) override
Rotate the item around aCenter 90 degrees in the clockwise direction.
bool IsPower() const override
SCH_FIELD * GetField(FIELD_T aFieldType)
Return a mandatory field in this symbol.
int GetMarginBottom() const
int GetLegacyTextMargin() const
int GetMarginLeft() const
int GetMarginRight() const
virtual void Rotate90(bool aClockwise)
virtual void MirrorSpinStyle(bool aLeftRight)
static SELECTION_CONDITION HasTypes(std::vector< KICAD_T > aTypes)
Create a functor that tests if among the selected items there is at least one of a given types.
static SELECTION_CONDITION HasType(KICAD_T aType)
Create a functor that tests if among the selected items there is at least one of a given type.
static bool NotEmpty(const SELECTION &aSelection)
Test if there are any items selected.
static SELECTION_CONDITION MoreThan(int aNumber)
Create a functor that tests if the number of selected items is greater than the value given as parame...
static bool Idle(const SELECTION &aSelection)
Test if there no items selected or being edited.
static bool IdleSelection(const SELECTION &aSelection)
Test if all selected items are not being edited.
static SELECTION_CONDITION Count(int aNumber)
Create a functor that tests if the number of selected items is equal to the value given as parameter.
static bool ShowAlways(const SELECTION &aSelection)
The default condition function (always returns true).
static SELECTION_CONDITION OnlyTypes(std::vector< KICAD_T > aTypes)
Create a functor that tests if the selected items are only of given types.
virtual void Add(EDA_ITEM *aItem)
virtual KIGFX::VIEW_ITEM * GetItem(unsigned int aIdx) const override
VECTOR2I GetReferencePoint() const
virtual VECTOR2I GetCenter() const
Returns the center point of the selection area bounding box.
virtual unsigned int GetSize() const override
Return the number of stored items.
int Size() const
Returns the number of selected parts.
std::deque< EDA_ITEM * > & Items()
std::vector< EDA_ITEM * > GetItemsSortedBySelectionOrder() const
bool OnlyContains(std::vector< KICAD_T > aList) const
Checks if all items in the selection have a type in aList.
bool Empty() const
Checks if there is anything selected.
bool HasReferencePoint() const
size_t CountType(KICAD_T aType) const
unsigned CCWRotationsTo(const SPIN_STYLE &aOther) const
Get CCW rotation needed to get to the given spin style.
The symbol library editor main window.
bool IsOK(wxWindow *aParent, const wxString &aMessage)
Display a yes/no dialog with aMessage and returns the user response.
This file is part of the common library.
@ SYMBOL_PROPS_EDIT_SCHEMATIC_SYMBOL
@ SYMBOL_PROPS_WANT_EXCHANGE_SYMBOL
@ SYMBOL_PROPS_WANT_UPDATE_SYMBOL
@ SYMBOL_PROPS_EDIT_LIBRARY_SYMBOL
static constexpr EDA_ANGLE ANGLE_90
static constexpr EDA_ANGLE ANGLE_VERTICAL
static constexpr EDA_ANGLE ANGLE_HORIZONTAL
#define IGNORE_PARENT_GROUP
#define IS_NEW
New item, just created.
#define SELECTED_BY_DRAG
Item was algorithmically selected as a dragged item.
#define STRUCT_DELETED
flag indication structures to be erased
#define ENDPOINT
ends. (Used to support dragging.)
#define STARTPOINT
When a line is selected, these flags indicate which.
@ ID_POPUP_SCH_PIN_TRICKS_HIER_LABEL
@ ID_POPUP_SCH_PIN_TRICKS_WIRE
@ ID_POPUP_SCH_ALT_PIN_FUNCTION
@ ID_POPUP_SCH_SELECT_UNIT1
@ ID_POPUP_SCH_SELECT_UNIT
@ ID_POPUP_SCH_SELECT_BODY_STYLE
@ ID_POPUP_SCH_PLACE_UNIT1
@ ID_POPUP_SCH_SELECT_BODY_STYLE1
@ ID_POPUP_SCH_PIN_TRICKS_NET_LABEL
@ ID_POPUP_SCH_PIN_TRICKS_NO_CONNECT
@ ID_POPUP_SCH_SELECT_UNIT_END
@ ID_POPUP_SCH_ALT_PIN_FUNCTION_END
@ ID_POPUP_SCH_PIN_TRICKS_GLOBAL_LABEL
@ ERCE_UNANNOTATED
Symbol has not been annotated.
@ ERCE_DUPLICATE_REFERENCE
More than one symbol with the same reference.
@ ERCE_FOOTPRINT_LINK_ISSUES
The footprint link is invalid, or points to a missing (or inactive) footprint or library.
@ ERCE_UNDEFINED_NETCLASS
A netclass was referenced but not defined.
@ ERCE_SIMULATION_MODEL
An error was found in the simulation model.
@ ERCE_LIB_SYMBOL_MISMATCH
Symbol doesn't match copy in library.
@ ERCE_LIB_SYMBOL_ISSUES
Symbol not found in active libraries.
@ ERCE_FOOTPRINT_FILTERS
The assigned footprint doesn't match the footprint filters.
@ FRAME_SCH_SYMBOL_EDITOR
@ LAYER_SCHEMATIC_DRAWINGSHEET
#define KI_FALLTHROUGH
The KI_FALLTHROUGH macro is to be used when switch statement cases should purposely fallthrough from ...
#define UNIMPLEMENTED_FOR(type)
bool contains(const _Container &__container, _Value __value)
Returns true if the container contains the given value.
void CollectOtherUnits(const wxString &aRef, int aUnit, const LIB_ID &aLibId, SCH_SHEET_PATH &aSheet, std::vector< SCH_SYMBOL * > *otherUnits)
Class to handle a set of SCH_ITEMs.
ANNOTATE_ORDER_T
Schematic annotation order options.
@ ANNOTATE_SELECTION
Annotate the selection.
ANNOTATE_ALGO_T
Schematic annotation type options.
SHEET_SIDE
Define the edge of the sheet that the sheet pin is positioned.
T * GetAppSettings(const char *aFilename)
wxString UnescapeString(const wxString &aSource)
wxString TitleCaps(const wxString &aString)
Capitalize the first letter in each word.
wxString EscapeString(const wxString &aSource, ESCAPE_CONTEXT aContext)
The Escape/Unescape routines use HTML-entity-reference-style encoding to handle characters which are:...
void AccumulateDescriptions(wxString &aDesc, const T &aItemCollection)
Build a comma-separated list from a collection of wxStrings.
Functors that can be used to figure out how the action controls should be displayed in the UI and if ...
wxString GetDefaultFieldName(FIELD_T aFieldId, bool aTranslateForHI)
Return a default symbol field name for a mandatory field type.
@ USER
The field ID hasn't been set yet; field is invalid.
@ FOOTPRINT
Field Name Module PCB, i.e. "16DIP300".
@ REFERENCE
Field Reference of part, i.e. "IC21".
@ VALUE
Field Value of part, i.e. "3.3K".
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.
constexpr GR_TEXT_H_ALIGN_T GetFlippedAlignment(GR_TEXT_H_ALIGN_T aAlign)
Get the reverse alignment: left-right are swapped, others are unchanged.
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.
KICAD_T
The set of class identification values stored in EDA_ITEM::m_structType.
@ SCH_ITEM_LOCATE_GRAPHIC_LINE_T
VECTOR2< int32_t > VECTOR2I
VECTOR2< double > VECTOR2D