502 lines
16 KiB
C++
502 lines
16 KiB
C++
/*
|
|
* 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 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
|
|
* Set the AutoplaceFields setting in the dialog
|
|
*/
|
|
void SetAutoplaceFields( bool enable ) { m_checkAutoplaceFields->SetValue( enable ); }
|
|
|
|
/**
|
|
* Function
|
|
* Return the current AutoplaceFields setting from the dialog
|
|
*/
|
|
bool GetAutoplaceFields() { return m_checkAutoplaceFields->GetValue(); }
|
|
|
|
/**
|
|
* Function
|
|
* Set the AutoplaceJustify setting in the dialog
|
|
*/
|
|
void SetAutoplaceJustify( bool enable ) { m_checkAutoplaceJustify->SetValue( enable ); }
|
|
|
|
/**
|
|
* Function
|
|
* Return the current AutoplaceJustify setting from the dialog
|
|
*/
|
|
bool GetAutoplaceJustify() { return m_checkAutoplaceJustify->GetValue(); }
|
|
|
|
/**
|
|
* Function
|
|
* Set the AutoplaceAlign setting in the dialog
|
|
*/
|
|
void SetAutoplaceAlign( bool enable ) { m_checkAutoplaceAlign->SetValue( enable ); }
|
|
|
|
/**
|
|
* Function
|
|
* Return the current AutoplaceAlign setting from the dialog
|
|
*/
|
|
bool GetAutoplaceAlign() { return m_checkAutoplaceAlign->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__
|