38#include <magic_enum.hpp>
135 bool hasLocked =
false;
136 bool hasUnlocked =
false;
142 int selection_first_layer = -1;
143 int selection_last_layer = -1;
146 int track_selection_layer = -1;
148 auto getAnnularRingSelection = [](
const PCB_VIA*
via ) ->
int
150 switch(
via->Padstack().UnconnectedLayerMode() )
160 for(
auto& preset : magic_enum::enum_values<IPC4761_PRESET>() )
167 wxString
name =
_(
"Unknown choice" );
170 name = name_it->second;
175 auto getProtectionSurface = [](
const std::optional<bool>& front,
180 if( !front.has_value() )
182 else if( front.value() )
187 if( !back.has_value() )
192 else if( back.value() )
210 auto getProtectionDrill = [](
const std::optional<bool>& drill ) ->
IPC4761_DRILL
212 if( !drill.has_value() )
223 config.tent = getProtectionSurface(
via->Padstack().FrontOuterLayers().has_solder_mask,
224 via->Padstack().BackOuterLayers().has_solder_mask );
226 config.cover = getProtectionSurface(
via->Padstack().FrontOuterLayers().has_covering,
227 via->Padstack().BackOuterLayers().has_covering );
229 config.plug = getProtectionSurface(
via->Padstack().FrontOuterLayers().has_plugging,
230 via->Padstack().BackOuterLayers().has_plugging );
232 config.cap = getProtectionDrill(
via->Padstack().Drill().is_capped );
234 config.fill = getProtectionDrill(
via->Padstack().Drill().is_filled );
238 if( configuration ==
config )
258 switch( item->Type() )
272 track_selection_layer = t->
GetLayer();
299 if( track_selection_layer != t->
GetLayer() )
333 selection_first_layer = v->
TopLayer();
377 if( selection_first_layer != v->
TopLayer() )
413 if(
static_cast<int>( getViaConfiguration( v ) )
494 int viaSelection = wxNOT_FOUND;
497 for(
unsigned ii = 1; ii <
m_frame->GetDesignSettings().m_ViasDimensionsList.size(); ii++ )
505 if( viaSelection == wxNOT_FOUND
509 viaSelection = ii - 1;
543 int widthSelection = wxNOT_FOUND;
546 for(
unsigned ii = 1; ii <
m_frame->GetDesignSettings().m_TrackWidthList.size(); ii++ )
548 int width =
m_frame->GetDesignSettings().m_TrackWidthList[ii];
549 wxString msg =
m_frame->StringFromValue( width );
552 if( widthSelection == wxNOT_FOUND &&
m_trackWidth.GetValue() == width )
553 widthSelection = ii - 1;
559 wxCommandEvent event;
567 if( hasLocked && hasUnlocked )
597 for(
unsigned ii = 1; ii <
m_frame->GetDesignSettings().m_ViasDimensionsList.size(); ii++ )
617 for(
unsigned ii = 1; ii <
m_frame->GetDesignSettings().m_TrackWidthList.size(); ii++ )
619 int width =
m_frame->GetDesignSettings().m_TrackWidthList[ii];
620 wxString msg =
m_frame->StringFromValue( width );
636 if( shortingNets.size() == 1 )
638 msg.Printf(
_(
"Applying these changes will short net %s with %s." ),
640 m_frame->GetBoard()->FindNet( *shortingNets.begin() )->GetNetname() );
644 msg.Printf(
_(
"Applying these changes will short net %s with other nets." ),
648 KIDIALOG dlg(
this, msg,
_(
"Confirmation" ), wxOK | wxCANCEL | wxICON_WARNING );
660 if( changingPads.size() == 1 )
662 PAD*
pad = *changingPads.begin();
663 msg.Printf(
_(
"Changing the net will also update %s pad %s to %s." ),
664 pad->GetParentFootprint()->GetReference(),
668 else if( changingPads.size() == 2 )
670 PAD* pad1 = *changingPads.begin();
671 PAD* pad2 = *( ++changingPads.begin() );
672 msg.Printf(
_(
"Changing the net will also update %s pad %s and %s pad %s to %s." ),
681 msg.Printf(
_(
"Changing the net will also update %lu connected pads to %s." ),
682 static_cast<unsigned long>( changingPads.size() ),
686 KIDIALOG dlg(
this, msg,
_(
"Confirmation" ), wxOK | wxCANCEL | wxICON_WARNING );
696 std::shared_ptr<CONNECTIVITY_DATA> connectivity =
m_frame->GetBoard()->GetConnectivity();
697 std::vector<PCB_TRACK*> selected_tracks;
698 std::set<PCB_TRACK*> connected_tracks;
703 selected_tracks.push_back( track );
706 for(
PCB_TRACK* selected_track : selected_tracks )
711 connected_tracks.insert( track );
731 DisplayError( GetParent(),
_(
"Via hole size must be smaller than via diameter" ) );
740 DisplayError( GetParent(),
_(
"Via start layer and end layer cannot be the same" ) );
763 bool changeLock =
m_lockedCbox->Get3StateValue() != wxCHK_UNDETERMINED;
764 bool setLock =
m_lockedCbox->Get3StateValue() == wxCHK_CHECKED;
766 for(
PCB_TRACK* track : selected_tracks )
770 switch( track->Type() )
803 track->SetLocalSolderMaskMargin( {} );
809 track->SetLocked( setLock );
819 if( !
m_viaX.IsIndeterminate() )
822 if( !
m_viaY.IsIndeterminate() )
825 if(
m_viaNotFree->Get3StateValue() != wxCHK_UNDETERMINED )
845 via->SetTopLayer( startLayer );
851 via->SetBottomLayer( endLayer );
854 via->SanitizeLayers();
859 via->Padstack().SetUnconnectedLayerMode(
863 via->Padstack().SetUnconnectedLayerMode(
867 via->Padstack().SetUnconnectedLayerMode(
871 via->Padstack().SetUnconnectedLayerMode(
910 via->SetLocked( setLock );
912 auto setSurfaceProtection =
913 [&]( std::optional<bool>& aFront, std::optional<bool>& aBack,
IPC4761_SURFACE aProtection )
915 switch( aProtection )
941 auto setDrillProtection =
942 [&]( std::optional<bool>& aDrill,
IPC4761_DRILL aProtection )
944 switch( aProtection )
958 setSurfaceProtection(
via->Padstack().FrontOuterLayers().has_solder_mask,
959 via->Padstack().BackOuterLayers().has_solder_mask,
962 setSurfaceProtection(
via->Padstack().FrontOuterLayers().has_plugging,
963 via->Padstack().BackOuterLayers().has_plugging,
966 setSurfaceProtection(
via->Padstack().FrontOuterLayers().has_covering,
967 via->Padstack().BackOuterLayers().has_covering,
970 setDrillProtection(
via->Padstack().Drill().is_filled,
config.fill );
972 setDrillProtection(
via->Padstack().Drill().is_capped,
config.cap );
984 std::set<int> shortingNets;
986 std::set<PAD*> changingPads;
1003 for(
PCB_TRACK* track : connected_tracks )
1007 if( other->GetNetCode() == track->GetNetCode() || other->GetNetCode() == newNetCode )
1011 shortingNets.insert( other->GetNetCode() );
1016 for(
PAD*
pad : footprint->Pads() )
1018 if(
pad->GetNetCode() == newNetCode )
1023 if(
pad->GetNetCode() == track->GetNetCode() )
1024 changingPads.insert(
pad );
1026 shortingNets.insert(
pad->GetNetCode() );
1042 for(
PCB_TRACK* track : selected_tracks )
1043 track->SetNetCode( newNetCode );
1045 for(
PAD*
pad : changingPads )
1048 pad->SetNetCode( newNetCode );
1053 commit.
Push(
_(
"Edit Track/Via Properties" ) );
1098 wxCHECK_MSG(
m_viaStack, ,
"Expected valid via stack in onPadstackModeChanged" );
1114 wxCHECK_MSG(
m_viaStack, ,
"Expected valid via stack in onEditLayerChanged" );
1163 wxCHECK_MSG(
m_viaStack, ,
"Expected valid via stack in afterPadstackModeChanged" );
1183 std::vector choices = {
1185 _(
"Inner Layers" ),
1235 return m_frame->GetBoard()->GetCopperLayerCount() - 1;
1240 if( startLayer < 0 || endLayer < 0 )
1241 return m_frame->GetBoard()->GetCopperLayerCount() - 1;
1292 event.Enable( !
m_frame->GetBoard()->LegacyTeardrops() );
wxBitmapBundle KiBitmapBundle(BITMAPS aBitmap, int aMinHeight)
virtual void Push(const wxString &aMessage=wxEmptyString, int aCommitFlags=0) override
Execute the changes.
virtual void Revert() override
Revert the commit by restoring the modified items state.
A base class derived from BOARD_ITEM for items that can be connected and have a net,...
TEARDROP_PARAMETERS & GetTeardropParams()
virtual PCB_LAYER_ID GetLayer() const
Return the primary layer this item is on.
bool IsLocked() const override
virtual std::shared_ptr< SHAPE > GetEffectiveShape(PCB_LAYER_ID aLayer=UNDEFINED_LAYER, FLASHING aFlash=FLASHING::DEFAULT) const
Some pad shapes can be complex (rounded/chamfered rectangle), even without considering custom shapes.
FOOTPRINT * GetParentFootprint() const
virtual LSET GetLayerSet() const
Return a std::bitset of all layers on which the item physically resides.
Information pertinent to a Pcbnew printed circuit board.
const wxString GetLayerName(PCB_LAYER_ID aLayer) const
Return the name of a aLayer.
const LSET & GetEnabledLayers() const
A proxy function that calls the corresponding function in m_BoardSettings.
COMMIT & Modify(EDA_ITEM *aItem, BASE_SCREEN *aScreen=nullptr, RECURSE_MODE aRecurse=RECURSE_MODE::NO_RECURSE)
Modify a given item in the model.
void SetInitialFocus(wxWindow *aWindow)
Sets the window (usually a wxTextCtrl) that should be focused when the dialog is shown.
void SetupStandardButtons(std::map< int, wxString > aLabels={})
void finishDialogSettings()
In all dialogs, we must call the same functions to fix minimal dlg size, the default position and per...
wxStaticText * m_annularRingsLabel
wxChoice * m_protectionFeatures
wxBoxSizer * m_legacyTeardropsWarning
wxStaticText * m_stMaxWidthLabel
wxStaticText * m_TrackEndYLabel
wxStaticText * m_ViaYLabel
PCB_LAYER_BOX_SELECTOR * m_ViaStartLayer
wxCheckBox * m_lockedCbox
wxCheckBox * m_curvedEdges
wxStaticText * m_trackMaskMarginUnit
wxStaticText * m_TrackStartYUnit
wxStaticText * m_TrackEndXLabel
wxTextCtrl * m_TrackStartXCtrl
wxStaticText * m_predefinedTrackWidthsUnits
wxStaticText * m_TrackWidthLabel
DIALOG_TRACK_VIA_PROPERTIES_BASE(wxWindow *parent, wxWindowID id=wxID_ANY, const wxString &title=_("Track & Via Properties"), const wxPoint &pos=wxDefaultPosition, const wxSize &size=wxSize(-1,-1), long style=wxDEFAULT_DIALOG_STYLE|wxRESIZE_BORDER|wxSYSTEM_MENU)
wxStaticText * m_stMaxLenUnits
PCB_LAYER_BOX_SELECTOR * m_ViaEndLayer
wxChoice * m_predefinedTrackWidthsCtrl
wxStaticText * m_trackMaskMarginLabel
wxStaticBoxSizer * m_sbTrackSizer
wxChoice * m_annularRingsCtrl
wxStaticBoxSizer * m_sbViaSizer
wxStaticText * m_ViaDrillUnit
wxStaticText * m_TrackStartXLabel
wxStaticText * m_stWidthPercentLabel
wxCheckBox * m_trackHasSolderMask
PCB_LAYER_BOX_SELECTOR * m_TrackLayerCtrl
wxStaticText * m_TrackStartYLabel
wxStaticText * m_stMaxLen
wxStaticText * m_ViaDiameterUnit
wxTextCtrl * m_TrackEndXCtrl
wxCheckBox * m_cbTeardrops
wxTextCtrl * m_tcLenPercent
wxStaticText * m_minTrackWidthHint
wxStaticText * m_ViaDrillLabel
wxStaticText * m_ViaYUnit
wxStaticText * m_stLenPercentLabel
wxChoice * m_cbPadstackMode
wxCheckBox * m_viaNotFree
wxStaticText * m_TrackWidthUnit
wxTextCtrl * m_tcWidthPercent
wxChoice * m_ViaTypeChoice
wxStaticText * m_stHDRatio
wxTextCtrl * m_ViaDiameterCtrl
wxChoice * m_predefinedViaSizesCtrl
wxStaticText * m_ViaXLabel
wxTextCtrl * m_trackMaskMarginCtrl
wxTextCtrl * m_ViaDrillCtrl
wxStaticText * m_TrackEndYUnit
wxStaticText * m_stMaxWidthUnits
wxStaticText * m_netSelectorLabel
wxStaticBitmap * m_bitmapTeardrop
wxTextCtrl * m_TrackEndYCtrl
wxStaticText * m_techLayersLabel
wxTextCtrl * m_tcTdMaxLen
wxTextCtrl * m_TrackStartYCtrl
wxStaticText * m_ViaDiameterLabel
wxStaticText * m_stHDRatioUnits
wxStaticBitmap * m_legacyTeardropsIcon
wxTextCtrl * m_TrackWidthCtrl
wxStaticText * m_predefinedViaSizesUnits
wxCheckBox * m_cbTeardropsUseNextTrack
wxTextCtrl * m_tcMaxWidth
NET_SELECTOR * m_netSelector
void onWidthEdit(wxCommandEvent &aEvent) override
const PCB_SELECTION & m_items
bool TransferDataFromWindow() override
void onUnitsChanged(wxCommandEvent &aEvent)
UNIT_BINDER m_viaDiameter
void onNetSelector(wxCommandEvent &aEvent)
UNIT_BINDER m_trackMaskMargin
void afterPadstackModeChanged()
Get data from the PCB board and display it to dialog.
void onWidthSelect(wxCommandEvent &aEvent) override
UNIT_BINDER m_teardropWidthPercent
bool confirmShortingNets(int aNet, const std::set< int > &shortingNets)
UNIT_BINDER m_teardropLenPercent
UNIT_BINDER m_teardropMaxWidth
const std::map< IPC4761_PRESET, IPC4761_CONFIGURATION > m_IPC4761Presets
const std::map< IPC4761_PRESET, wxString > m_IPC4761Names
void onTeardropsUpdateUi(wxUpdateUIEvent &event) override
void onPadstackModeChanged(wxCommandEvent &aEvent) override
void onViaEdit(wxCommandEvent &aEvent) override
std::map< int, PCB_LAYER_ID > m_editLayerCtrlMap
PCB_LAYER_ID m_editLayer
The currently-shown copper layer of the edited via(s)
UNIT_BINDER m_trackStartY
void onViaSelect(wxCommandEvent &aEvent) override
bool TransferDataToWindow() override
void onEditLayerChanged(wxCommandEvent &aEvent) override
PCB_BASE_EDIT_FRAME * m_frame
void onViaNotFreeClicked(wxCommandEvent &aEvent) override
DIALOG_TRACK_VIA_PROPERTIES(PCB_BASE_EDIT_FRAME *aParent, const PCB_SELECTION &aItems)
std::unique_ptr< PADSTACK > m_viaStack
Temporary padstack of the edited via(s)
UNIT_BINDER m_teardropMaxLen
UNIT_BINDER m_trackStartX
UNIT_BINDER m_teardropHDPercent
bool confirmPadChange(const std::set< PAD * > &connectedPads)
~DIALOG_TRACK_VIA_PROPERTIES()
void onTrackEdit(wxCommandEvent &aEvent) override
A base class for most all the KiCad significant classes used in schematics and boards.
Helper class to create more flexible dialogs, including 'do not show again' checkbox handling.
void DoNotShowCheckbox(wxString file, int line)
Shows the 'do not show again' checkbox.
bool SetOKCancelLabels(const ButtonLabel &ok, const ButtonLabel &cancel) override
LSET is a set of PCB_LAYER_IDs.
LSEQ UIOrder() const
Return the copper, technical and user layers in the order shown in layer widget.
static LSET AllNonCuMask()
Return a mask holding all layer minus CU layers.
static LSET AllCuMask()
return AllCuMask( MAX_CU_LAYERS );
A PADSTACK defines the characteristics of a single or multi-layer pad, in the IPC sense of the word.
@ NORMAL
Shape is the same on all layers.
@ CUSTOM
Shapes can be defined on arbitrary layers.
@ FRONT_INNER_BACK
Up to three shapes can be defined (F_Cu, inner copper layers, B_Cu)
@ REMOVE_EXCEPT_START_AND_END
static constexpr PCB_LAYER_ID ALL_LAYERS
! Temporary layer identifier to identify code that is not padstack-aware
static constexpr PCB_LAYER_ID INNER_LAYERS
! The layer identifier to use for "inner layers" on top/inner/bottom padstacks
const wxString & GetNumber() const
Common, abstract interface for edit frames.
bool HasSolderMask() const
std::optional< int > GetLocalSolderMaskMargin() const
virtual int GetWidth() const
bool GetIsFree() const
Check if the via is a free via (as opposed to one created on a track by the router).
PCB_LAYER_ID BottomLayer() const
VECTOR2I GetPosition() const override
const PADSTACK & Padstack() const
int GetWidth() const override
PCB_LAYER_ID TopLayer() const
int GetDrillValue() const
Calculate the drill value for vias (m_drill if > 0, or default drill value for the board).
VIATYPE GetViaType() const
virtual bool Collide(const VECTOR2I &aP, int aClearance=0, int *aActual=nullptr, VECTOR2I *aLocation=nullptr) const
Check if the boundary of shape (this) lies closer to the point aP than aClearance,...
TEARDROP_PARAMETARS is a helper class to handle parameters needed to build teardrops for a board thes...
double m_BestWidthRatio
The height of a teardrop as ratio between height and size of pad/via.
int m_TdMaxLen
max allowed length for teardrops in IU. <= 0 to disable
bool m_AllowUseTwoTracks
True to create teardrops using 2 track segments if the first in too small.
int m_TdMaxWidth
max allowed height for teardrops in IU. <= 0 to disable
double m_BestLengthRatio
The length of a teardrop as ratio between length and size of pad/via.
double m_WidthtoSizeFilterRatio
The ratio (H/D) between the via/pad size and the track width max value to create a teardrop 1....
bool m_Enabled
Flag to enable teardrops.
bool m_CurvedEdges
True if the teardrop should be curved.
void DisplayError(wxWindow *aParent, const wxString &aText)
Display an error or warning message box with aMessage.
This file is part of the common library.
PCB_LAYER_ID
A quick note on layer IDs:
PCB_LAYER_ID ToLAYER_ID(int aLayer)
This file contains miscellaneous commonly used macros and functions.
#define UNIMPLEMENTED_FOR(type)
KICOMMON_API wxString GetLabel(EDA_UNITS aUnits, EDA_DATA_TYPE aType=EDA_DATA_TYPE::DISTANCE)
Get the units string for a given units type.
KICOMMON_API wxFont GetInfoFont(wxWindow *aWindow)
KICOMMON_API wxFont GetSmallInfoFont(wxWindow *aWindow)
#define GEOMETRY_MIN_SIZE
bool collide(T aObject, U aAnotherObject, int aLayer, int aMinDistance)
Used by SHAPE_INDEX to implement Query().
bool operator==(const IPC4761_CONFIGURATION &other) const
Container to handle a stock of specific vias each with unique diameter and drill sizes in the BOARD c...
@ PCB_VIA_T
class PCB_VIA, a via (like a track segment on a copper layer)
@ PCB_ARC_T
class PCB_ARC, an arc track segment on a copper layer
@ PCB_TRACE_T
class PCB_TRACK, a track segment (segment on a copper layer)
#define INDETERMINATE_ACTION
#define INDETERMINATE_STATE
Used for holding indeterminate values, such as with multiple selections holding different values or c...
VECTOR2< int32_t > VECTOR2I