diff options
Diffstat (limited to 'eeschema/dialogs/dialog_eeschema_options.h')
-rw-r--r-- | eeschema/dialogs/dialog_eeschema_options.h | 479 |
1 files changed, 479 insertions, 0 deletions
diff --git a/eeschema/dialogs/dialog_eeschema_options.h b/eeschema/dialogs/dialog_eeschema_options.h new file mode 100644 index 0000000..12446b9 --- /dev/null +++ b/eeschema/dialogs/dialog_eeschema_options.h @@ -0,0 +1,479 @@ +/* + * This program source code file is part of KiCad, a free EDA CAD application. + * + * Copyright (C) 2009 Wayne Stambaugh <stambaughw@verizon.net> + * 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 <dialog_eeschema_options_base.h> +#include <template_fieldnames.h> + +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 + * selectedField = -1 when no valid item selected + */ + int selectedField; + + /** @brief return true if aFieldId is a valid field selection + */ + bool fieldSelectionValid( int aFieldId ) + { + return ( aFieldId >= 0 ) && ( aFieldId < int( templateFields.size() ) ); + } + + /** + * Function OnEnterKey (virtual) + * Process the wxWidgets @a event produced when the user presses enter key + * in template fieldname text control or template fieldvalue text control + */ + void OnEnterKey( wxCommandEvent& event ); + + /** + * Function OnVisibleFieldClick (virtual) + * Process the wxWidgets @a event produced when the user click on + * the check box which controls the field visibility + */ + void OnVisibleFieldClick( wxCommandEvent& event ); + + /** + * 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. + * + * <b>NOTE:</b> 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 SetMaxUndoItems + * Sets the maximum number of undo items + * @param aItems the number to set + */ + void SetMaxUndoItems( int aItems ) { m_spinMaxUndoItems->SetValue( aItems ); } + + /** + * Function GetMaxUndoItems + * Return the current maximum number of undo items + */ + int GetMaxUndoItems() const { return m_spinMaxUndoItems->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_checkEnableZoomCenter->SetValue( !enable ); + } + + /** + * Function GetEnableZoomNoCenter + * Returns the current ZoomNoCenter value from the dialog + */ + bool GetEnableZoomNoCenter( void ) + { + return !m_checkEnableZoomCenter->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 SetEnableMousewheelPan + * Sets the MousewheelPan setting in the dialog + * + * @param enable The boolean value to set the AutoPan value in the dialog + */ + void SetEnableMousewheelPan( bool enable ) { m_checkEnableMousewheelPan->SetValue( enable ); } + + /** + * Function GetEnableMousewheelPan + * Return the MousewheelPan setting from the dialog + */ + bool GetEnableMousewheelPan( void ) { return m_checkEnableMousewheelPan->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__ |