/* * This program source code file is part of KiCad, a free EDA CAD application. * * Copyright (C) 2018 Jean-Pierre Charras, jp.charras at wanadoo.fr * Copyright (C) 2013 Dick Hollenbeck, dick@softplc.com * Copyright (C) 2008-2013 Wayne Stambaugh * Copyright (C) 1992-2023 KiCad Developers, see AUTHORS.txt for contributors. * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License * as published by the Free Software Foundation; either version 2 * of the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, you may find one here: * http://www.gnu.org/licenses/old-licenses/gpl-2.0.html * or you may search the http://www.gnu.org website for the version 2 license, * or you may write to the Free Software Foundation, Inc., * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA */ #ifndef _DIALOG_PAD_PROPERTIES_H_ #define _DIALOG_PAD_PROPERTIES_H_ #include #include #include #include #include #include #include #include #include #include #include /** * DIALOG_PAD_PROPERTIES, derived from DIALOG_PAD_PROPERTIES_BASE, * created by wxFormBuilder */ // The wxWidgets window name. Used to retrieve the dialog by window name #define PAD_PROPERTIES_DLG_NAME wxT( "pad_properties_dlg_name" ) class DIALOG_PAD_PROPERTIES : public DIALOG_PAD_PROPERTIES_BASE { public: DIALOG_PAD_PROPERTIES( PCB_BASE_FRAME* aParent, PAD* aPad ); ~DIALOG_PAD_PROPERTIES(); private: void prepareCanvas(); // Initialize the canvases (legacy or gal) to display the pad void initValues(); bool padValuesOK(); ///< test if all values are acceptable for the pad void redraw(); void updateRoundRectCornerValues(); /** * Updates the CheckBox states in pad layers list, based on the layer_mask (if non-empty) * or the default layers for the current pad type. */ void updatePadLayersList( LSET layer_mask, bool remove_unconnected, bool keep_top_bottom ); /// Copy values from dialog field to aPad's members bool transferDataToPad( PAD* aPad ); bool Show( bool aShow ) override; // event handlers: void OnInitDialog( wxInitDialogEvent& event ) override; void OnResize( wxSizeEvent& event ); void OnCancel( wxCommandEvent& event ) override; void OnUpdateUI( wxUpdateUIEvent& event ) override; void onTeardropsUpdateUi( wxUpdateUIEvent& event ) override; void onTeardropCurvePointsUpdateUi( wxUpdateUIEvent& event ) override; void OnUpdateUINonCopperWarning( wxUpdateUIEvent& event ) override; void OnPadShapeSelection( wxCommandEvent& event ) override; void OnDrillShapeSelected( wxCommandEvent& event ) override; void onChangePadMode( wxCommandEvent& event ) override; void OnOffsetCheckbox( wxCommandEvent& event ) override; void OnPadToDieCheckbox( wxCommandEvent& event ) override; void PadOrientEvent( wxCommandEvent& event ) override; void PadTypeSelected( wxCommandEvent& event ) override; void UpdateLayersDropdown(); void OnSetCopperLayers( wxCommandEvent& event ) override; void OnSetLayers( wxCommandEvent& event ) override; // Called when corner setup value is changed for rounded rect pads void onCornerSizePercentChange( wxCommandEvent& event ) override; void onCornerRadiusChange( wxCommandEvent& event ) override; /// Called when a dimension has changed. /// Update the graphical pad shown in the panel. void OnValuesChanged( wxCommandEvent& event ) override; /// Updates the different parameters for the component being edited. /// Automatically fired from the OK button click. bool TransferDataFromWindow() override; bool TransferDataToWindow() override; /// Return the pad property currently selected PAD_PROP getSelectedProperty(); // Show/hide the hole size Y widgets // Setting the X/Diameter label according to the selected hole type void updateHoleControls(); // Show/hide the pad size Y widgets // Setting the X/Diameter label according to the selected hole type void updatePadSizeControls(); private: PCB_BASE_FRAME* m_parent; PAD* m_currentPad; // pad currently being edited PAD* m_previewPad; // a working copy used to show changes PAD* m_masterPad; // pad used to create new pads in board or FP editor BOARD* m_board; // the main board: this is the board handled by the PCB // editor or the dummy board used by the FP editor bool m_canUpdate; bool m_canEditNetName; // true only if the caller is the board editor bool m_isFpEditor; // true if the caller is the footprint editor std::vector> m_primitives; // the custom shape primitives in // local coords, orient 0 // must define a single copper area COLOR4D m_selectedColor; // color used to draw selected primitives when // editing a custom pad shape std::vector m_highlight; // shapes highlighted in GAL mode PCB_DRAW_PANEL_GAL* m_padPreviewGAL; KIGFX::ORIGIN_VIEWITEM* m_axisOrigin; // origin of the preview canvas static bool m_sketchPreview; // session storage UNIT_BINDER m_posX, m_posY; UNIT_BINDER m_sizeX, m_sizeY; UNIT_BINDER m_offsetX, m_offsetY; UNIT_BINDER m_padToDie; UNIT_BINDER m_trapDelta; UNIT_BINDER m_cornerRadius; UNIT_BINDER m_cornerRatio; UNIT_BINDER m_chamferRatio; UNIT_BINDER m_mixedCornerRatio; UNIT_BINDER m_mixedChamferRatio; UNIT_BINDER m_holeX, m_holeY; UNIT_BINDER m_clearance; UNIT_BINDER m_maskMargin; UNIT_BINDER m_pasteMargin; UNIT_BINDER m_pasteMarginRatio; UNIT_BINDER m_thermalGap; UNIT_BINDER m_spokeWidth; UNIT_BINDER m_spokeAngle; UNIT_BINDER m_pad_orientation; UNIT_BINDER m_teardropMaxLenSetting; UNIT_BINDER m_teardropMaxHeightSetting; }; #endif // #ifndef _DIALOG_PAD_PROPERTIES_H_