/* * This program source code file is part of KiCad, a free EDA CAD application. * * Copyright (C) 2009 Wayne Stambaugh * Copyright (C) 1992-2011 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 */ /** * @file dialog_eeschema_options.h * * Subclass of DIALOG_EESCHEMA_OPTIONS_BASE, which is generated by wxFormBuilder. */ #ifndef __dialog_eeschema_options__ #define __dialog_eeschema_options__ #include #include class DIALOG_EESCHEMA_OPTIONS : public DIALOG_EESCHEMA_OPTIONS_BASE { protected: /** @brief The template fieldnames for this dialog */ TEMPLATE_FIELDNAMES templateFields; /** @brief The current row selected in the template fieldname wxListCtrl which is also in the edit panel */ size_t selectedField; /** @brief The selectedField value is only valid when this bool is set to true */ bool selectionValid; /** @brief Set to true internally when OnTemplateFieldSelected() an event needs to be ignored */ bool ignoreSelection; /** * Function OnAddButtonClick * Process the wxWidgets @a event produced when the user presses the Add buton for the * template fieldnames control * * @param event The wxWidgets produced event information * * Adds a new template fieldname (with default values) to the template fieldnames data */ void OnAddButtonClick( wxCommandEvent& event ); /** * Function OnDeleteButtonClick * Process the wxWidgets @a event produced when the user presses the Delete button for the * template fieldnames control * * @param event The wxWidgets produced event information * * Deletes the selected template fieldname from the template fieldnames data */ void OnDeleteButtonClick( wxCommandEvent& event ); /** * Function OnEditControlKillFocus * This Focus Event Handler should be connected to any controls in the template field edit box * so that any loss of focus results in the data being saved to the currently selected template * field * * @param event The wxWidgets produced event information * * Copies data from the edit box to the selected field template */ void OnEditControlKillFocus( wxFocusEvent& event ); /** * Function copyPanelToSelected * Copies the data from the edit panel to the selected template fieldname */ void copyPanelToSelected( void ); /** * Function copySelectedToPanel * Copies the data from the selected template fieldname and fills in the edit panel */ void copySelectedToPanel( void ); /** * Function OnTemplateFieldSelected * Event handler for the wxListCtrl containing the template fieldnames * * @param event The event information provided by wxWidgets * * Processes data exchange between the edit panel and the selected template fieldname */ void OnTemplateFieldSelected( wxListEvent& event ); /** * Function RefreshTemplateFieldView * Refresh the template fieldname wxListCtrl * * Deletes all data from the wxListCtrl and then re-polpulates the control with the data in * the template fieldnames. * * Use any time the template field data has changed */ void RefreshTemplateFieldView( void ); /** * Function SelectTemplateField * Selects @a aItem from the wxListCtrl populated with the template fieldnames * * @param aItem The item index of the row to be selected * * When RefreshTemplateFieldView() is used the selection is lost because all of the items are * removed from the wxListCtrl and then the control is re-populated. This function can be used * to re-select an item that was previously selected so that the selection is not lost. * * NOTE: This function first sets the ignoreSelection flag before making the selection. * This means the class can select something in the wxListCtrl without causing further * selection events. */ void SelectTemplateField( int aItem ); public: /** * Public constructor * * @param parent The dialog's parent */ DIALOG_EESCHEMA_OPTIONS( wxWindow* parent ); /** * Function GetUnitsSelection * Returns the currently selected grid size in the dialog */ int GetUnitsSelection( void ) { return m_choiceUnits->GetSelection(); } /** * Function SetUnits * Set the unit options * * @param units The array of strings representing the unit options * @param select The unit to select from the unit options * * Appends the @a units options to the list of unit options and selects the @a aSelect option */ void SetUnits( const wxArrayString& units, int aSelect = 0 ); /** * Function GetGridSelection * Returns the curent grid size selected in the dialog */ int GetGridSelection( void ) { return m_choiceGridSize->GetSelection(); } /** * Function SetGridSizes * Sets the available grid size choices @a aGridSizes and selectd the current option @a aGridId * * @param aGridSizes The grid sizes that are able to be chosen from * @param aGridId The grid size to select from the grid size options */ void SetGridSizes( const GRIDS& aGridSizes, int aGridId ); /** * Function GetBusWidth * Get the current bus width setting from the dialog */ int GetBusWidth( void ) { return m_spinBusWidth->GetValue(); } /** * Function SetBusWidth * Sets the bus width setting in the dialog * * @param aWidth The bus width to set the dialog edit spinbox with */ void SetBusWidth( int aWidth ) { m_spinBusWidth->SetValue( aWidth ); } /** * Function SetLineWidth * Sets the current LineWidth value in the dialog * @param aWidth The line width to set in the dialog */ void SetLineWidth( int aWidth ) { m_spinLineWidth->SetValue( aWidth ); } /** * Function GetLineWidth * Returns the current LineWidth value from the dialog */ int GetLineWidth( void ) { return m_spinLineWidth->GetValue(); } /** * Function SetTextSize * Sets the current default TextSize value in the dialog * @param text_size The text size to set in the dialog */ void SetTextSize( int text_size ) { m_spinTextSize->SetValue( text_size ); } /** * Function GetTextSize * Returns the current default TextSize value from the dialog */ int GetTextSize( void ) { return m_spinTextSize->GetValue(); } /** * Function SetRepeatHorizontal * Sets the current RepeatHorizontal displacement value in the dialog * @param displacement The displacement to set in the dialog */ void SetRepeatHorizontal( int displacement ) { m_spinRepeatHorizontal->SetValue( displacement ); } /** * Function GetRepeatHorizontal * Returns the current RepeatHorizontal displacement value from the dialog */ int GetRepeatHorizontal( void ) { return m_spinRepeatHorizontal->GetValue(); } /** * Function SetRepeatVertical * Sets the current RepeatVertical displacement value in the dialog * @param displacement The displacement to set in the dialog */ void SetRepeatVertical( int displacement ) { m_spinRepeatVertical->SetValue( displacement ); } /** * Function GetRepeatVertical * Returns the current RepeatVertical displacement value from the dialog */ int GetRepeatVertical( void ) { return m_spinRepeatVertical->GetValue(); } /** * Function SetRepeatLabel * Sets the current RepeatLabel increment value in the dialog * @param increment The increment to set in the dialog */ void SetRepeatLabel( int increment ) { m_spinRepeatLabel->SetValue( increment ); } /** * Function GetRepeatLabel * Returns the current RepeatLabel increment value from the dialog */ int GetRepeatLabel( void ) { return m_spinRepeatLabel->GetValue(); } /** * Function SetAutoSaveInterval * Sets the current AutoSaveInterval value in the dialog * @param aInterval The interval to set in the dialog */ void SetAutoSaveInterval( int aInterval ) { m_spinAutoSaveInterval->SetValue( aInterval ); } /** * Function GetAutoSaveInterval * Returns the current AutoSaveInterval value from the dialog */ int GetAutoSaveInterval() const { return m_spinAutoSaveInterval->GetValue(); } /** * Function SetRefIdSeparator * Sets the current RefIdSeparator value in the dialog * @param aSep The seperator to use between the reference and the part ID * @param aFirstId The first part ID, currently either 'A' or '1' */ void SetRefIdSeparator( wxChar aSep, wxChar aFirstId); /** * Function GetRefIdSeparator * Returns the current RefIdSeparator value from the dialog * @param aSep The OUTPUT seperator value * @param aFirstId The OUTPUT reference first ID */ void GetRefIdSeparator( int& aSep, int& aFirstId); /** * Function SetShowGrid * Sets the current ShowGrid value in the dialog * @param show The ShowGrid value to set in the dialog */ void SetShowGrid( bool show ) { m_checkShowGrid->SetValue( show ); } /** * Function GetShowGrid * Returns the current ShowGrid value from the dialog */ bool GetShowGrid( void ) { return m_checkShowGrid->GetValue(); } /** * Function SetShowHiddenPins * Sets the current ShowHiddenPins value in the dialog * @param show The ShowHiddenPins value to set in the dialog */ void SetShowHiddenPins( bool show ) { m_checkShowHiddenPins->SetValue( show ); } /** * Function GetShowHiddenPins * Returns the current ShowHiddenPins value from the dialog */ bool GetShowHiddenPins( void ) { return m_checkShowHiddenPins->GetValue(); } /** * Function SetEnableZoomNoCenter * Sets the current ZoomNoCenter value in the dialog * @param enable The ZoomNoCenter value to set in the dialog */ void SetEnableZoomNoCenter( bool enable ) { m_checkEnableZoomNoCenter->SetValue( enable ); } /** * Function GetEnableZoomNoCenter * Returns the current ZoomNoCenter value from the dialog */ bool GetEnableZoomNoCenter( void ) { return m_checkEnableZoomNoCenter->GetValue(); } /** * Function SetEnableMiddleButtonPan * Sets the current MiddleButtonPan value in the dialog * * @param enable The boolean value to set the MiddleButtonPan value in the dialog */ void SetEnableMiddleButtonPan( bool enable ) { m_checkEnableMiddleButtonPan->SetValue( enable ); m_checkMiddleButtonPanLimited->Enable( enable ); } /** * Function GetEnableMiddleButtonPan * Returns the current MiddleButtonPan setting from the dialog */ bool GetEnableMiddleButtonPan( void ) { return m_checkEnableMiddleButtonPan->GetValue(); } /** * Function SetMiddleButtonPanLimited * Sets the MiddleButtonPanLimited value in the dialog * * @param enable The boolean value to set the MiddleButtonPanLimted value in the dialog */ void SetMiddleButtonPanLimited( bool enable ) { m_checkMiddleButtonPanLimited->SetValue( enable ); } /** * Function GetMiddleButtonPanLimited * Returns the MiddleButtonPanLimited setting from the dialog */ bool GetMiddleButtonPanLimited( void ) { return m_checkMiddleButtonPanLimited->GetValue(); } /** * Function SetEnableAutoPan * Sets the AutoPan setting in the dialog * * @param enable The boolean value to set the AutoPan value in the dialog */ void SetEnableAutoPan( bool enable ) { m_checkAutoPan->SetValue( enable ); } /** * Function GetEnableAutoPan * Return the AutoPan setting from the dialog */ bool GetEnableAutoPan( void ) { return m_checkAutoPan->GetValue(); } /** * Function SetEnableHVBusOrientation * Set the HVBusOrientation setting in the dialog * * @param enable The boolean value to set the HVBusOrientation value in the dialog */ void SetEnableHVBusOrientation( bool enable ) { m_checkHVOrientation->SetValue( enable ); } /** * Function GetEnableHVBusOrientation * Get the HVBusOrientation setting from the dialog */ bool GetEnableHVBusOrientation( void ) { return m_checkHVOrientation->GetValue(); } /** * Function * Set the ShowPageLimits setting in the dialog */ void SetShowPageLimits( bool show ) { m_checkPageLimits->SetValue( show ); } /** * Function * Return the current ShowPageLimits setting from the dialog */ bool GetShowPageLimits( void ) { return m_checkPageLimits->GetValue(); } /** * Function SetTemplateFields * Set the template field data in the dialog * * @param aFields The template fieldnames that the dialog should start with before any editing */ void SetTemplateFields( const TEMPLATE_FIELDNAMES& aFields ); /** * Function GetTemplateFields * Get the dialog's template field data * */ TEMPLATE_FIELDNAMES GetTemplateFields( void ); private: void OnMiddleBtnPanEnbl( wxCommandEvent& event ) { m_checkMiddleButtonPanLimited->Enable( GetEnableMiddleButtonPan() ); } }; #endif // __dialog_eeschema_options__