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 );
1450 std::vector<SCH_FIELD>& aFields = aLabelBase.
GetFields();
1451 std::vector<SCH_FIELD>& bFields = bLabelBase.
GetFields();
1453 const unsigned rotationsAtoB = aSpinStyle.
CCWRotationsTo( bSpinStyle );
1464 if( !aText || !bText )
1490 std::swap( aOrient, bOrient );
1503 m_frame->UpdateItem( a,
false,
true );
1504 m_frame->UpdateItem( b,
false,
true );
1520 if( !localCommit.
Empty() )
1521 localCommit.
Push(
_(
"Swap" ) );
1541 if( !
m_frame->eeconfig()->m_Input.allow_unconstrained_pin_swaps )
1547 if( selection.
Size() < 2 )
1564 std::set<wxString> sharedSheetPaths;
1565 std::set<wxString> sharedProjectNames;
1568 &sharedProjectNames ) )
1572 std::set<wxString> friendlySheets;
1574 if( !sharedSheetPaths.empty() )
1577 if( !sharedProjectNames.empty() )
1581 if( projects.IsEmpty() )
1583 m_frame->ShowInfoBarError(
_(
"Pin swaps are disabled for symbols shared across other projects. "
1584 "Duplicate the sheet to edit pins independently." ) );
1589 wxString::Format(
_(
"Pin swaps are disabled for symbols shared across other projects (%s). "
1590 "Duplicate the sheet to edit pins independently." ),
1594 else if( !friendlySheets.empty() )
1599 wxString::Format(
_(
"Pin swaps are disabled for symbols used by multiple sheet instances (%s). "
1600 "Duplicate the sheet to edit pins independently." ),
1606 _(
"Pin swaps are disabled for shared symbols. Duplicate the sheet to edit pins independently." ) );
1612 bool connections =
false;
1618 commit = &localCommit;
1624 bool swappedLibPins =
false;
1626 for(
size_t i = 0; i < sorted.size() - 1; i++ )
1629 SCH_PIN* bPin =
static_cast<SCH_PIN*
>( sorted[( i + 1 ) % sorted.size()] );
1642 m_frame->UpdateItem( aPin,
false,
true );
1643 m_frame->UpdateItem( bPin,
false,
true );
1646 if( swappedLibPins )
1650 m_frame->UpdateItem( parentSymbol,
false,
true );
1663 m_frame->Schematic().CleanUp( commit );
1670 if( !localCommit.
Empty() )
1671 localCommit.
Push(
_(
"Swap Pins" ) );
1681 if( !aGraph || !aPin )
1689 const std::set<SCH_ITEM*>& items = sg->
GetItems();
1691 size_t pinCount = 0;
1699 switch( item->
Type() )
1707 if( conn && conn->
IsNet() )
1733 if( orderedPins.size() < 2 )
1740 std::vector<SCH_LABEL_BASE*> labels;
1742 for(
EDA_ITEM* item : orderedPins )
1750 _(
"Each selected pin must have exactly one attached net label and no other pin connections." ) );
1754 labels.push_back( label );
1757 if( labels.size() >= 2 )
1764 for(
size_t i = 0; i < labels.size() - 1; ++i )
1768 wxString aText = a->
GetText();
1769 wxString bText = b->
GetText();
1774 commit.
Push(
_(
"Swap Pin Labels" ) );
1786 if( selectedUnits.size() < 2 )
1794 std::vector<std::vector<SCH_LABEL_BASE*>> symbolLabelVectors;
1798 std::vector<std::pair<VECTOR2I, SCH_LABEL_BASE*>> byPos;
1800 for(
SCH_PIN*
pin : symbol->GetPins( &sheetPath ) )
1806 m_frame->ShowInfoBarError(
_(
"Each pin of selected units must have exactly one attached net label and "
1807 "no other pin connections." ) );
1811 byPos.emplace_back(
pin->GetPosition(), label );
1815 std::sort( byPos.begin(), byPos.end(),
1816 [](
const auto& a,
const auto& b )
1818 if( a.first.x != b.first.x )
1819 return a.first.x < b.first.x;
1821 return a.first.y < b.first.y;
1825 std::vector<SCH_LABEL_BASE*> labels;
1827 for(
const auto& pr : byPos )
1828 labels.push_back( pr.second );
1830 symbolLabelVectors.push_back( labels );
1834 const size_t pinCount = symbolLabelVectors.front().size();
1839 for(
size_t pin = 0;
pin < pinCount;
pin++ )
1841 for(
auto& vec : symbolLabelVectors )
1844 wxString carry = symbolLabelVectors.back()[
pin]->GetText();
1846 for(
size_t i = 0; i < symbolLabelVectors.size(); i++ )
1855 if( !commit.
Empty() )
1856 commit.
Push(
_(
"Swap Unit Labels" ) );
1864 const std::vector<std::unique_ptr<SCH_ITEM>>& sourceItems =
m_frame->GetRepeatItems();
1866 if( sourceItems.empty() )
1875 for(
const std::unique_ptr<SCH_ITEM>& item : sourceItems )
1878 bool restore_state =
false;
1889 enteredGroup->AddItem( newItem );
1898 if( !label->IncrementLabel( cfg->m_Drawing.repeat_label_increment ) )
1899 m_frame->ShowInfoBarWarning(
_(
"Label value cannot go below zero" ),
true );
1912 schIUScale.MilsToIU( cfg->m_Drawing.default_repeat_offset_y ) ) );
1921 if(
m_frame->CheckSheetForRecursion( sheet, currentSheet ) )
1924 const wxString originalFileName = sheet->
GetFileName();
1929 restore_state = !
m_frame->EditSheetProperties( sheet, currentSheet );
1942 commit.Added( newItem,
m_frame->GetScreen() );
1951 if(
m_frame->eeconfig()->m_AnnotatePanel.automatic )
1953 static_cast<SCH_SYMBOL*
>( newItem )->ClearAnnotation(
nullptr,
false );
1956 true , annotateStartNum,
false,
false,
false,
1972 newItems.
Add( newItem );
1978 m_frame->Schematic().CleanUp( &commit );
1979 commit.Push(
_(
"Repeat Item" ) );
1983 if( !newItems.
Empty() )
1984 m_frame->SaveCopyForRepeatItem(
static_cast<SCH_ITEM*
>( newItems[0] ) );
1986 for(
size_t ii = 1; ii < newItems.
GetSize(); ++ii )
1987 m_frame->AddCopyForRepeatItem(
static_cast<SCH_ITEM*
>( newItems[ii] ) );
1998 std::vector<VECTOR2I> pts;
1999 bool updateHierarchy =
false;
2020 pts.insert( pts.end(), tmp_pts.begin(), tmp_pts.end() );
2043 static_cast<SCH_FIELD*
>( sch_item )->SetVisible(
false );
2049 static_cast<SCH_TABLECELL*
>( sch_item )->SetText( wxEmptyString );
2086 m_frame->DeleteJunction( &commit, junction );
2089 commit.
Push(
_(
"Delete" ) );
2091 if( updateHierarchy )
2092 m_frame->UpdateHierarchyNavigator();
2116 caption.Printf(
_(
"Edit %s Field" ),
TitleCaps( fieldName ) );
2120 caption.Printf(
_(
"Edit '%s' Field" ), aField->
GetName() );
2140 if( !commit.
Empty() )
2141 commit.
Push( caption );
2149 if( sel.
Size() != 1 )
2152 bool clearSelection = sel.
IsHover();
2168 if( item ==
nullptr )
2200 clearSelection =
true;
2224 if( clearSelection )
2236 bool moving = head && head->
IsMoving();
2238 if( selection.
Empty() )
2241 std::vector<SCH_ITEM*> autoplaceItems;
2243 for(
unsigned ii = 0; ii < selection.
GetSize(); ii++ )
2248 autoplaceItems.push_back( item );
2253 for(
SCH_ITEM* sch_item : autoplaceItems )
2255 if( !moving && !sch_item->IsNew() )
2269 if( !commit.
Empty() )
2270 commit.
Push(
_(
"Autoplace Fields" ) );
2285 if( !selection.
Empty() )
2309 if( selection.
Empty() )
2315 if( !symbol->
IsNew() )
2323 m_frame->SelectBodyStyle( symbol, nextBodyStyle );
2325 if( symbol->
IsNew() )
2328 if( !commit.
Empty() )
2329 commit.
Push(
_(
"Change Body Style" ) );
2341 bool clearSelection = selection.
IsHover();
2343 if( selection.
Empty() )
2368 switch( curr_item->
Type() )
2375 std::deque<SCH_LINE*> lines;
2378 lines.push_back(
static_cast<SCH_LINE*
>( selItem ) );
2386 std::deque<SCH_JUNCTION*> junctions;
2389 junctions.push_back(
static_cast<SCH_JUNCTION*
>( selItem ) );
2398 std::deque<SCH_ITEM*> items;
2401 items.push_back(
static_cast<SCH_ITEM*
>( selItem ) );
2419 if( inspectionTool )
2427 std::vector<SCH_TABLECELL*> cells;
2449 if( selection.
Size() > 1 )
2455 if( clearSelection )
2464 switch( aItem->
Type() )
2485 if(
m_frame->eeconfig()->m_AutoplaceFields.enable )
2501 if( wxWindow* blocking_win =
editor->Kiway().GetBlockingDialog() )
2502 blocking_win->Close(
true );
2508 editor->LoadSymbolFromSchematic( symbol );
2519 if( wxWindow* blocking_win =
editor->Kiway().GetBlockingDialog() )
2520 blocking_win->Close(
true );
2544 bool isUndoable =
false;
2545 bool doClearAnnotation =
false;
2546 bool okPressed =
false;
2547 bool updateHierarchyNavigator =
false;
2557 okPressed =
m_frame->EditSheetProperties( sheet, &
m_frame->GetCurrentSheet(), &isUndoable, &doClearAnnotation,
2558 &updateHierarchyNavigator );
2564 commit.
Push(
_(
"Edit Sheet Properties" ) );
2568 std::vector<SCH_ITEM*> items;
2570 items.emplace_back( sheet );
2571 m_frame->Schematic().OnItemsRemoved( items );
2572 m_frame->Schematic().OnItemsAdded( items );
2574 m_frame->Schematic().RefreshHierarchy();
2575 m_frame->UpdateHierarchyNavigator();
2588 if( doClearAnnotation )
2602 m_frame->GetCanvas()->Refresh();
2604 if( updateHierarchyNavigator )
2605 m_frame->UpdateHierarchyNavigator();
2688 dlg.SetTitle(
_(
"Rule Area Properties" ) );
2703 wxFAIL_MSG( wxString(
"Cannot edit schematic item type " ) + aItem->
GetClass() );
2719 commit = &localCommit;
2721 for(
unsigned int i = 0; i < selection.GetSize(); ++i )
2725 if( item && item->
Type() != convertTo )
2736 wxCHECK2( sourceText,
continue );
2738 switch( item->
Type() )
2758 txt =
_(
"<empty>" );
2769 txt =
text->GetText();
2770 href =
text->GetHyperlink();
2787 int textSize =
text->GetTextSize().y;
2820 position =
m_frame->GetNearestGridPosition( position );
2828 auto getValidNetname = [](
const wxString& aText )
2830 wxString local_txt = aText;
2831 local_txt.Replace(
"\n",
"_" );
2832 local_txt.Replace(
"\r",
"_" );
2833 local_txt.Replace(
"\t",
"_" );
2837 local_txt.Replace(
" ",
"_" );
2842 if( local_txt.IsEmpty() )
2843 return _(
"<empty>" );
2871 newtext = new_label;
2896 newtext = new_label;
2921 newtext = new_label;
2938 new_label->
GetFields().push_back( netclass );
2945 newtext = new_label;
2965 bbox.
Inflate( -label->GetLabelBoxExpansion() );
2996 new_textbox->
SetEnd( botRight );
2999 newtext = new_textbox;
3006 wxCHECK2( newtext,
continue );
3017 wxCHECK2( eda_text && new_eda_text,
continue );
3032 if( label && new_label )
3041 return field.GetId() == FIELD_T::INTERSHEET_REFS
3042 && new_label->Type() != SCH_GLOBAL_LABEL_T;
3064 if( !localCommit.
Empty() )
3065 localCommit.
Push(
_(
"Change To" ) );
3067 if( selection.IsHover() )
3080 if( selection.
GetSize() == 0 )
3089 commit = &localCommit;
3091 auto setJustify = [&](
EDA_TEXT* aTextItem )
3101 for(
EDA_ITEM* edaItem : selection )
3103 item =
static_cast<SCH_ITEM*
>( edaItem );
3110 setJustify(
static_cast<SCH_FIELD*
>( item ) );
3117 setJustify(
static_cast<SCH_TEXT*
>( item ) );
3128 setJustify( label );
3131 m_frame->UpdateItem( item,
false,
true );
3135 for(
EDA_ITEM* selected : selection )
3149 if( !localCommit.
Empty() )
3152 localCommit.
Push(
_(
"Left Justify" ) );
3154 localCommit.
Push(
_(
"Center Justify" ) );
3156 localCommit.
Push(
_(
"Right Justify" ) );
3173 if( !
IsOK(
m_frame,
_(
"Do you wish to delete the unreferenced pins from this sheet?" ) ) )
3182 commit.
Push(
_(
"Cleanup Sheet Pins" ) );
3207 screen =
m_frame->GetScreen();
3216 if( prevInstance.
size() )
3224 screen =
m_frame->GetScreen();
3227 sheet =
m_frame->GetCurrentSheet().Last();
3234 msg.Printf(
_(
"Enter page number for sheet path%s" ),
3235 ( sheetPath.Length() > 20 ) ?
"\n" + sheetPath :
" " + sheetPath );
3237 wxTextEntryDialog dlg(
m_frame, msg,
_(
"Edit Sheet Page Number" ), pageNumber );
3239 dlg.SetTextValidator( wxFILTER_ALPHANUMERIC );
3241 if( dlg.ShowModal() == wxID_CANCEL || dlg.GetValue() == instance.
GetPageNumber() )
3246 commit.
Modify( sheet, screen );
3250 if( instance ==
m_frame->GetCurrentSheet() )
3252 m_frame->GetScreen()->SetPageNumber( dlg.GetValue() );
3253 m_frame->OnPageSettingsChange();
3256 commit.
Push( wxS(
"Change Sheet Page Number" ) );
3273 wxString* filename = aEvent.
Parameter<wxString*>();
3280 if( !
image->GetReferenceImage().ReadImageFile( *filename ) )
3282 wxMessageBox( wxString::Format(
_(
"Could not load image from '%s'." ), *filename ) );
3292 std::set<std::pair<SCH_SYMBOL*, SCH_SCREEN*>>& aCollectedUnits )
3300 aCollectedUnits.insert( { symbol,
m_frame->GetScreen() } );
3306 wxString ref = symbol->
GetRef( &
m_frame->GetCurrentSheet() );
3313 std::vector<SCH_SYMBOL*> otherUnits;
3318 aCollectedUnits.insert( { otherUnit, screen } );
3331 wxString variant =
m_frame->Schematic().GetCurrentVariant();
3333 std::set<std::pair<SCH_SYMBOL*, SCH_SCREEN*>> collectedUnits;
3336 bool new_state =
false;
3338 for(
const auto& [symbol,
_] : collectedUnits )
3350 for(
const auto& [symbol, screen] : collectedUnits )
3352 commit.
Modify( symbol, screen );
3355 symbol->SetDNP( new_state );
3358 symbol->SetExcludedFromSim( new_state );
3361 symbol->SetExcludedFromBOM( new_state );
3364 symbol->SetExcludedFromBoard( new_state );
3367 if( !commit.
Empty() )
3368 commit.
Push(
_(
"Toggle Attribute" ) );
3382 return _(
"Edit Symbol Properties..." );
3398 return _(
"Edit Netclasses..." );
3401 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...
SCH_SCREEN * LastScreen()
wxString GetPageNumber() const
wxString PathHumanReadable(bool aUseShortRootName=true, bool aStripTrailingSeparator=false, bool aEscapeSheetNames=false) const
Return the sheet path in a human readable form made from the sheet names.
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