2011-10-13 19:56:32 +00:00
|
|
|
/*
|
|
|
|
* This program source code file is part of KiCad, a free EDA CAD application.
|
|
|
|
*
|
|
|
|
* Copyright (C) 2009 Jean-Pierre Charras, jaen-pierre.charras@gipsa-lab.inpg.com
|
|
|
|
* Copyright (C) 2011 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
|
|
|
|
*/
|
|
|
|
|
2011-09-01 12:54:34 +00:00
|
|
|
/**
|
|
|
|
* @file wxstruct.h
|
|
|
|
* @brief Base window classes and related definitions.
|
|
|
|
*/
|
2007-06-05 12:10:51 +00:00
|
|
|
|
|
|
|
#ifndef WXSTRUCT_H
|
|
|
|
#define WXSTRUCT_H
|
|
|
|
|
|
|
|
|
2009-01-29 14:26:20 +00:00
|
|
|
#include <vector>
|
|
|
|
|
2007-06-05 12:10:51 +00:00
|
|
|
#include <wx/socket.h>
|
|
|
|
#include "wx/log.h"
|
|
|
|
#include "wx/config.h"
|
|
|
|
#include <wx/wxhtml.h>
|
|
|
|
#include <wx/laywin.h>
|
2009-11-02 22:24:55 +00:00
|
|
|
#include <wx/aui/aui.h>
|
2011-03-17 19:14:45 +00:00
|
|
|
#include <wx/docview.h>
|
2009-11-02 22:24:55 +00:00
|
|
|
|
2011-09-01 12:54:34 +00:00
|
|
|
#include "bitmaps.h"
|
2010-02-01 21:23:27 +00:00
|
|
|
#include "colors.h"
|
2010-07-12 14:07:09 +00:00
|
|
|
#include "common.h"
|
2007-10-10 18:01:14 +00:00
|
|
|
|
2011-09-01 12:54:34 +00:00
|
|
|
// C++ guarantees that operator delete checks its argument for null-ness
|
2008-02-12 21:12:46 +00:00
|
|
|
#ifndef SAFE_DELETE
|
2009-04-07 11:53:58 +00:00
|
|
|
#define SAFE_DELETE( p ) delete (p); (p) = NULL;
|
2008-02-12 21:12:46 +00:00
|
|
|
#endif
|
2007-06-05 12:10:51 +00:00
|
|
|
|
|
|
|
#ifndef EESCHEMA_INTERNAL_UNIT
|
2009-04-07 11:53:58 +00:00
|
|
|
#define EESCHEMA_INTERNAL_UNIT 1000
|
2007-06-05 12:10:51 +00:00
|
|
|
#endif
|
|
|
|
|
2011-09-01 12:54:34 +00:00
|
|
|
// Option for dialog boxes
|
2011-04-13 19:30:27 +00:00
|
|
|
#define DIALOG_STYLE wxDEFAULT_DIALOG_STYLE | wxFRAME_FLOAT_ON_PARENT | MAYBE_RESIZE_BORDER
|
2007-06-05 12:10:51 +00:00
|
|
|
|
2009-01-29 14:26:20 +00:00
|
|
|
#define KICAD_DEFAULT_DRAWFRAME_STYLE wxDEFAULT_FRAME_STYLE | wxWANTS_CHARS
|
2007-06-05 12:10:51 +00:00
|
|
|
|
2010-12-08 20:12:46 +00:00
|
|
|
class EDA_ITEM;
|
2011-03-29 19:33:07 +00:00
|
|
|
class EDA_RECT;
|
2011-01-21 19:30:59 +00:00
|
|
|
class EDA_DRAW_PANEL;
|
2011-04-12 14:19:59 +00:00
|
|
|
class EDA_MSG_PANEL;
|
2007-06-05 12:10:51 +00:00
|
|
|
class BASE_SCREEN;
|
2011-04-13 19:30:27 +00:00
|
|
|
class EDA_TOOLBAR;
|
2007-06-05 12:10:51 +00:00
|
|
|
class PARAM_CFG_BASE;
|
|
|
|
class Ki_PageDescr;
|
2009-08-29 10:20:48 +00:00
|
|
|
class PLOTTER;
|
2007-06-05 12:10:51 +00:00
|
|
|
|
2007-08-04 04:42:49 +00:00
|
|
|
enum id_librarytype {
|
|
|
|
LIBRARY_TYPE_EESCHEMA,
|
|
|
|
LIBRARY_TYPE_PCBNEW,
|
2009-08-27 11:41:56 +00:00
|
|
|
LIBRARY_TYPE_DOC,
|
|
|
|
LIBRARY_TYPE_SYMBOL
|
2007-06-05 12:10:51 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
enum id_drawframe {
|
2007-08-04 04:42:49 +00:00
|
|
|
NOT_INIT_FRAME = 0,
|
|
|
|
SCHEMATIC_FRAME,
|
|
|
|
LIBEDITOR_FRAME,
|
|
|
|
VIEWER_FRAME,
|
|
|
|
PCB_FRAME,
|
|
|
|
MODULE_EDITOR_FRAME,
|
|
|
|
CVPCB_FRAME,
|
|
|
|
CVPCB_DISPLAY_FRAME,
|
|
|
|
GERBER_FRAME,
|
|
|
|
TEXT_EDITOR_FRAME,
|
|
|
|
DISPLAY3D_FRAME,
|
|
|
|
KICAD_MAIN_FRAME
|
2007-06-05 12:10:51 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
enum id_toolbar {
|
2007-10-16 19:05:33 +00:00
|
|
|
TOOLBAR_MAIN = 1, // Main horizontal Toolbar
|
2009-05-01 18:06:03 +00:00
|
|
|
TOOLBAR_TOOL, // Right vertical Toolbar (list of tools)
|
2007-10-16 19:05:33 +00:00
|
|
|
TOOLBAR_OPTION, // Left vertical Toolbar (option toolbar
|
2009-04-07 11:53:58 +00:00
|
|
|
TOOLBAR_AUX // Secondary horizontal Toolbar
|
2007-06-05 12:10:51 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2011-09-01 12:54:34 +00:00
|
|
|
/**
|
|
|
|
* Class EDA_BASE_FRAME
|
2011-09-30 18:15:37 +00:00
|
|
|
* is the base frame for deriving all KiCad main window classes. This class is not
|
2011-09-01 12:54:34 +00:00
|
|
|
* intended to be used directly.
|
|
|
|
*/
|
2011-01-21 19:30:59 +00:00
|
|
|
class EDA_BASE_FRAME : public wxFrame
|
2007-06-05 12:10:51 +00:00
|
|
|
{
|
2011-10-13 19:56:32 +00:00
|
|
|
protected:
|
2011-04-13 19:30:27 +00:00
|
|
|
int m_Ident; // Id Type (pcb, schematic, library..)
|
|
|
|
wxPoint m_FramePos;
|
|
|
|
wxSize m_FrameSize;
|
|
|
|
int m_MsgFrameHeight;
|
|
|
|
|
|
|
|
EDA_TOOLBAR* m_HToolBar; // Standard horizontal Toolbar
|
|
|
|
bool m_FrameIsActive;
|
|
|
|
wxString m_FrameName; // name used for writing and reading setup
|
2011-09-01 12:54:34 +00:00
|
|
|
// It is "SchematicFrame", "PcbFrame" ....
|
2011-04-13 19:30:27 +00:00
|
|
|
wxString m_AboutTitle; // Name of program displayed in About.
|
2007-06-05 12:10:51 +00:00
|
|
|
|
2011-04-13 19:30:27 +00:00
|
|
|
wxAuiManager m_auimgr;
|
2009-11-02 22:24:55 +00:00
|
|
|
|
2011-10-13 19:56:32 +00:00
|
|
|
/// Flag to indicate if this frame supports auto save.
|
|
|
|
bool m_hasAutoSave;
|
|
|
|
|
|
|
|
/// Flag to indicate the last auto save state.
|
|
|
|
bool m_autoSaveState;
|
|
|
|
|
|
|
|
/// The auto save interval time in seconds.
|
|
|
|
int m_autoSaveInterval;
|
|
|
|
|
|
|
|
/// The timer used to implement the auto save feature;
|
|
|
|
wxTimer* m_autoSaveTimer;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function onAutoSaveTimer
|
|
|
|
* handles the auto save timer event.
|
|
|
|
*/
|
|
|
|
void onAutoSaveTimer( wxTimerEvent& aEvent );
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function isModified
|
|
|
|
* returns the modification status of the application. Override this function if
|
|
|
|
* your derived frame supports automatic file saving.
|
|
|
|
*/
|
|
|
|
virtual bool isModified() const { return false; }
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function doAutoSave
|
|
|
|
* should be overridden by the derived class to handle the auto save feature.
|
|
|
|
*
|
|
|
|
* @return true if the auto save was successful otherwise false.
|
|
|
|
*/
|
|
|
|
virtual bool doAutoSave();
|
|
|
|
|
2007-06-05 12:10:51 +00:00
|
|
|
public:
|
2011-09-01 12:54:34 +00:00
|
|
|
EDA_BASE_FRAME( wxWindow* father, int idtype, const wxString& title,
|
2011-01-21 19:30:59 +00:00
|
|
|
const wxPoint& pos, const wxSize& size,
|
|
|
|
long style = KICAD_DEFAULT_DRAWFRAME_STYLE );
|
2011-10-13 19:56:32 +00:00
|
|
|
|
2011-01-21 19:30:59 +00:00
|
|
|
~EDA_BASE_FRAME();
|
2007-10-01 15:37:42 +00:00
|
|
|
|
2011-10-13 19:56:32 +00:00
|
|
|
/**
|
|
|
|
* Function ProcessEvent
|
|
|
|
* overrides the default process event handler to implement the auto save feature.
|
|
|
|
*
|
|
|
|
* @warning If you override this function in a derived class, make sure you call
|
|
|
|
* down to this or the auto save feature will be disabled.
|
|
|
|
*/
|
|
|
|
virtual bool ProcessEvent( wxEvent& aEvent );
|
|
|
|
|
|
|
|
void SetAutoSaveInterval( int aInterval ) { m_autoSaveInterval = aInterval; }
|
|
|
|
|
|
|
|
int GetAutoSaveInterval() const { return m_autoSaveInterval; }
|
|
|
|
|
|
|
|
wxString GetName() const { return m_FrameName; }
|
|
|
|
|
|
|
|
bool IsActive() const { return m_FrameIsActive; }
|
|
|
|
|
|
|
|
bool IsType( int aType ) const { return m_Ident == aType; }
|
|
|
|
|
2011-09-01 12:54:34 +00:00
|
|
|
void GetKicadHelp( wxCommandEvent& event );
|
2011-10-13 19:56:32 +00:00
|
|
|
|
2011-09-01 12:54:34 +00:00
|
|
|
void GetKicadAbout( wxCommandEvent& event );
|
2010-08-24 17:26:51 +00:00
|
|
|
|
|
|
|
/**
|
2011-09-01 12:54:34 +00:00
|
|
|
* Function CopyVersionInfoToClipboard
|
|
|
|
* copies the version information to the clipboard for bug reporting purposes.
|
2010-08-24 17:26:51 +00:00
|
|
|
*/
|
2011-09-01 12:54:34 +00:00
|
|
|
void CopyVersionInfoToClipboard( wxCommandEvent& event );
|
|
|
|
|
|
|
|
void PrintMsg( const wxString& text );
|
2009-04-07 11:53:58 +00:00
|
|
|
|
2010-08-24 17:26:51 +00:00
|
|
|
/**
|
|
|
|
* Append the copy version information to clipboard help menu entry to \a aMenu.
|
|
|
|
*
|
|
|
|
* @param aMenu - The menu to append.
|
|
|
|
*/
|
2011-09-01 12:54:34 +00:00
|
|
|
void AddHelpVersionInfoMenuEntry( wxMenu* aMenu );
|
2010-08-24 17:26:51 +00:00
|
|
|
|
2011-10-13 19:56:32 +00:00
|
|
|
/**
|
|
|
|
* Load common frame parameters from configuration.
|
|
|
|
*
|
|
|
|
* The method is virtual so you can override it to load frame specific
|
|
|
|
* parameters. Don't forget to call the base method or your frames won't
|
|
|
|
* remember their positions and sizes.
|
|
|
|
*/
|
2009-04-07 11:53:58 +00:00
|
|
|
virtual void LoadSettings();
|
2011-10-13 19:56:32 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Save common frame parameters from configuration.
|
|
|
|
*
|
|
|
|
* The method is virtual so you can override it to save frame specific
|
|
|
|
* parameters. Don't forget to call the base method or your frames won't
|
|
|
|
* remember their positions and sizes.
|
|
|
|
*/
|
2009-04-07 11:53:58 +00:00
|
|
|
virtual void SaveSettings();
|
|
|
|
|
2011-03-13 18:03:43 +00:00
|
|
|
/**
|
|
|
|
* Function OnSelectPreferredEditor
|
2011-09-30 18:15:37 +00:00
|
|
|
* Open a dialog to select the editor that will used in KiCad
|
2011-03-13 18:03:43 +00:00
|
|
|
* to edit or display files (reports ... )
|
|
|
|
* The full filename editor is saved in configuration (global params)
|
|
|
|
*/
|
|
|
|
virtual void OnSelectPreferredEditor( wxCommandEvent& event );
|
|
|
|
|
2010-08-28 18:02:24 +00:00
|
|
|
// Read/Save and Import/export hotkeys config
|
|
|
|
|
2010-11-12 15:17:10 +00:00
|
|
|
/**
|
|
|
|
* Function ReadHotkeyConfig
|
2010-08-28 18:02:24 +00:00
|
|
|
* Read configuration data and fill the current hotkey list with hotkeys
|
2011-09-01 12:54:34 +00:00
|
|
|
* @param aDescList = current hotkey list descr. to initialize.
|
2010-08-28 18:02:24 +00:00
|
|
|
*/
|
2011-09-29 16:49:40 +00:00
|
|
|
int ReadHotkeyConfig( struct EDA_HOTKEY_CONFIG* aDescList );
|
2010-08-28 18:02:24 +00:00
|
|
|
|
2010-11-12 15:17:10 +00:00
|
|
|
/**
|
|
|
|
* Function WriteHotkeyConfig
|
2010-08-28 18:02:24 +00:00
|
|
|
* Store the current hotkey list
|
|
|
|
* It is stored using the standard wxConfig mechanism or a file.
|
|
|
|
*
|
|
|
|
* @param aDescList = pointer to the current hotkey list.
|
2011-09-01 12:54:34 +00:00
|
|
|
* @param aFullFileName = a wxString pointer to a full file name.
|
2010-08-28 18:02:24 +00:00
|
|
|
* if NULL, use the standard wxConfig mechanism (default)
|
|
|
|
* the output format is: shortcut "key" "function"
|
|
|
|
* lines starting with # are comments
|
|
|
|
*/
|
2011-09-29 16:49:40 +00:00
|
|
|
int WriteHotkeyConfig( struct EDA_HOTKEY_CONFIG* aDescList, wxString* aFullFileName = NULL);
|
2010-08-28 18:02:24 +00:00
|
|
|
|
2010-11-12 15:17:10 +00:00
|
|
|
/**
|
|
|
|
* Function ReadHotkeyConfigFile
|
2010-12-14 15:56:30 +00:00
|
|
|
* Read an old configuration file (<file>.key) and fill the current hotkey list
|
2010-08-28 18:02:24 +00:00
|
|
|
* with hotkeys
|
|
|
|
* @param aFilename = file name to read.
|
2011-09-01 12:54:34 +00:00
|
|
|
* @param aDescList = current hotkey list descr. to initialize.
|
2010-08-28 18:02:24 +00:00
|
|
|
*/
|
2011-09-29 16:49:40 +00:00
|
|
|
int ReadHotkeyConfigFile( const wxString& aFilename, struct EDA_HOTKEY_CONFIG* aDescList );
|
2010-08-28 18:02:24 +00:00
|
|
|
|
2010-11-12 15:17:10 +00:00
|
|
|
/**
|
|
|
|
* Function ImportHotkeyConfigFromFile
|
2010-08-28 18:02:24 +00:00
|
|
|
* Prompt the user for an old hotkey file to read, and read it.
|
2011-09-01 12:54:34 +00:00
|
|
|
* @param aDescList = current hotkey list descr. to initialize.
|
2010-08-28 18:02:24 +00:00
|
|
|
*/
|
2011-09-29 16:49:40 +00:00
|
|
|
void ImportHotkeyConfigFromFile( struct EDA_HOTKEY_CONFIG* aDescList );
|
2010-08-28 18:02:24 +00:00
|
|
|
|
2010-11-12 15:17:10 +00:00
|
|
|
/**
|
|
|
|
* Function ExportHotkeyConfigToFile
|
2010-08-28 18:02:24 +00:00
|
|
|
* Prompt the user for an old hotkey file to read, and read it.
|
2011-09-01 12:54:34 +00:00
|
|
|
* @param aDescList = current hotkey list descr. to initialize.
|
2010-08-28 18:02:24 +00:00
|
|
|
*/
|
2011-09-29 16:49:40 +00:00
|
|
|
void ExportHotkeyConfigToFile( struct EDA_HOTKEY_CONFIG* aDescList );
|
2010-08-28 18:02:24 +00:00
|
|
|
|
2010-11-12 15:17:10 +00:00
|
|
|
/**
|
|
|
|
* Function SetLanguage
|
2010-02-26 15:39:10 +00:00
|
|
|
* called on a language menu selection
|
|
|
|
* when using a derived function, do not forget to call this one
|
|
|
|
*/
|
|
|
|
virtual void SetLanguage( wxCommandEvent& event );
|
2009-04-07 11:53:58 +00:00
|
|
|
|
2011-03-17 19:14:45 +00:00
|
|
|
/**
|
2011-03-25 19:16:05 +00:00
|
|
|
* Function GetFileFromHistory
|
|
|
|
* fetches the file name from the file history list.
|
2011-04-17 13:54:17 +00:00
|
|
|
* and removes the selected file, if this file does not exists
|
|
|
|
* Note also the menu is updated, if wxFileHistory::UseMenu
|
|
|
|
* was called at init time
|
2011-03-25 19:16:05 +00:00
|
|
|
* @param cmdId The command ID associated with the \a aFileHistory object.
|
|
|
|
* @param type Please document me!
|
|
|
|
* @param aFileHistory The wxFileHistory in use. If null, the main application file
|
|
|
|
* history is used
|
2011-03-17 19:14:45 +00:00
|
|
|
* @return a wxString containing the selected filename
|
|
|
|
*/
|
2011-09-01 12:54:34 +00:00
|
|
|
wxString GetFileFromHistory( int cmdId, const wxString& type,
|
|
|
|
wxFileHistory* aFileHistory = NULL );
|
2011-03-17 19:14:45 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Function UpdateFileHistory
|
2011-04-17 13:54:17 +00:00
|
|
|
* Updates the list of recently opened files.
|
|
|
|
* Note also the menu is updated, if wxFileHistory::UseMenu
|
|
|
|
* was called at init time
|
2011-03-25 19:16:05 +00:00
|
|
|
* @param FullFileName The full file name including the path.
|
2011-04-17 13:54:17 +00:00
|
|
|
* @param aFileHistory The wxFileHistory in use.
|
|
|
|
* If NULL, the main application file history is used.
|
2011-03-17 19:14:45 +00:00
|
|
|
*/
|
2011-09-01 12:54:34 +00:00
|
|
|
void UpdateFileHistory( const wxString& FullFileName, wxFileHistory * aFileHistory = NULL );
|
2011-03-17 19:14:45 +00:00
|
|
|
|
2011-10-13 19:56:32 +00:00
|
|
|
/*
|
|
|
|
* Display a bargraph (0 to 50 point length) for a PerCent value from 0 to 100
|
|
|
|
*/
|
2011-09-01 12:54:34 +00:00
|
|
|
void DisplayActivity( int PerCent, const wxString& Text );
|
2011-04-17 13:54:17 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Function ReCreateMenuBar
|
|
|
|
* Creates recreates the menu bar.
|
|
|
|
* Needed when the language is changed
|
|
|
|
*/
|
2009-04-07 11:53:58 +00:00
|
|
|
virtual void ReCreateMenuBar();
|
2011-08-18 19:25:12 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Function IsWritable
|
|
|
|
* checks if \a aFileName can be written.
|
|
|
|
* <p>
|
|
|
|
* The function performs a number of tests on \a aFileName to verify that it can
|
|
|
|
* be saved. The file name is tested for validity and if the user has write
|
|
|
|
* permissions.
|
|
|
|
* </p>
|
|
|
|
*
|
|
|
|
* @param aFileName The full path and/or file name of the file to test.
|
|
|
|
* @return False if \a aFileName cannot be written.
|
|
|
|
*/
|
|
|
|
bool IsWritable( const wxFileName& aFileName );
|
2007-06-05 12:10:51 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2011-09-01 12:54:34 +00:00
|
|
|
/**
|
|
|
|
* Class EDA_DRAW_FRAME
|
2011-09-30 18:15:37 +00:00
|
|
|
* is the base class for create windows for drawing purpose. The Eeschema, Pcbnew and
|
|
|
|
* GerbView main windows are just a few examples of classes derived from EDA_DRAW_FRAME.
|
2011-09-01 12:54:34 +00:00
|
|
|
*/
|
2011-01-21 19:30:59 +00:00
|
|
|
class EDA_DRAW_FRAME : public EDA_BASE_FRAME
|
2007-06-05 12:10:51 +00:00
|
|
|
{
|
2011-09-01 12:54:34 +00:00
|
|
|
int m_toolId; ///< Id of active button on the vertical toolbar.
|
2011-02-24 20:22:12 +00:00
|
|
|
|
2007-06-05 12:10:51 +00:00
|
|
|
public:
|
2011-01-21 19:30:59 +00:00
|
|
|
EDA_DRAW_PANEL* DrawPanel; // Draw area
|
2011-04-12 14:19:59 +00:00
|
|
|
EDA_MSG_PANEL* MsgPanel; // Panel used to display some
|
2009-11-23 20:18:47 +00:00
|
|
|
// info (bottom of the screen)
|
2011-04-13 19:30:27 +00:00
|
|
|
EDA_TOOLBAR* m_VToolBar; // Vertical (right side) Toolbar
|
|
|
|
EDA_TOOLBAR* m_AuxVToolBar; // Auxiliary Vertical (right side)
|
2009-11-23 20:18:47 +00:00
|
|
|
// Toolbar
|
2011-04-13 19:30:27 +00:00
|
|
|
EDA_TOOLBAR* m_OptionsToolBar; // Options Toolbar (left side)
|
2011-09-30 18:15:37 +00:00
|
|
|
EDA_TOOLBAR* m_AuxiliaryToolBar; // Auxiliary Toolbar used in Pcbnew
|
2009-11-23 20:18:47 +00:00
|
|
|
|
2011-04-19 19:19:41 +00:00
|
|
|
wxComboBox* m_SelGridBox; // Choice box to choose the grid size
|
|
|
|
wxComboBox* m_SelZoomBox; // Choice box to choose the zoom value
|
2009-11-23 20:18:47 +00:00
|
|
|
|
|
|
|
int m_CursorShape; // shape for cursor (0 = default
|
|
|
|
// cursor)
|
|
|
|
int m_ID_last_state; // Id of previous active button
|
|
|
|
// on the vertical toolbar
|
|
|
|
int m_HTOOL_current_state; // Id of active button on
|
|
|
|
// horizontal toolbar
|
2007-08-04 04:42:49 +00:00
|
|
|
|
2009-04-07 11:53:58 +00:00
|
|
|
int m_InternalUnits; // Internal units count in 1 inch
|
2011-09-30 18:15:37 +00:00
|
|
|
// = 1000 for Eeschema, = 10000
|
|
|
|
// for Pcbnew and GerbView
|
2007-10-01 15:37:42 +00:00
|
|
|
|
2009-04-07 11:53:58 +00:00
|
|
|
bool m_Draw_Axis; // TRUE to show X and Y axis
|
2011-09-01 12:54:34 +00:00
|
|
|
bool m_Draw_Grid_Axis; // TRUE to show grid axis.
|
2009-04-07 11:53:58 +00:00
|
|
|
bool m_Draw_Sheet_Ref; // TRUE to show frame references
|
2007-08-04 04:42:49 +00:00
|
|
|
|
2009-04-07 11:53:58 +00:00
|
|
|
bool m_Print_Sheet_Ref; // TRUE to print frame references
|
2009-11-23 20:18:47 +00:00
|
|
|
bool m_Draw_Auxiliary_Axis; /* TRUE to show auxiliary axis.
|
2011-09-30 18:15:37 +00:00
|
|
|
* Used in Pcbnew: the auxiliary
|
2009-11-23 20:18:47 +00:00
|
|
|
* axis is the origin of
|
|
|
|
* coordinates for drill, gerber
|
|
|
|
* and component position files
|
2009-04-07 11:53:58 +00:00
|
|
|
*/
|
2011-09-01 12:54:34 +00:00
|
|
|
wxPoint m_Auxiliary_Axis_Position; // position of the auxiliary axis
|
2007-08-04 04:42:49 +00:00
|
|
|
|
2009-10-14 19:43:31 +00:00
|
|
|
protected:
|
2011-09-29 16:49:40 +00:00
|
|
|
EDA_HOTKEY_CONFIG* m_HotkeysZoomAndGridList;
|
2009-10-14 19:43:31 +00:00
|
|
|
int m_LastGridSizeId;
|
2010-02-01 21:23:27 +00:00
|
|
|
bool m_DrawGrid; // hide/Show grid
|
|
|
|
int m_GridColor; // Grid color
|
2009-10-14 19:43:31 +00:00
|
|
|
|
2008-04-17 16:25:29 +00:00
|
|
|
private:
|
2011-02-05 02:21:11 +00:00
|
|
|
BASE_SCREEN* m_currentScreen; ///< current used SCREEN
|
2011-02-03 19:27:28 +00:00
|
|
|
bool m_snapToGrid; ///< Indicates if cursor should be snapped to grid.
|
2008-04-17 16:25:29 +00:00
|
|
|
|
|
|
|
protected:
|
2011-02-05 02:21:11 +00:00
|
|
|
void SetScreen( BASE_SCREEN* aScreen )
|
2009-11-23 20:18:47 +00:00
|
|
|
{
|
2011-02-05 02:21:11 +00:00
|
|
|
m_currentScreen = aScreen;
|
2009-11-23 20:18:47 +00:00
|
|
|
}
|
2008-04-17 16:25:29 +00:00
|
|
|
|
2011-03-01 19:26:17 +00:00
|
|
|
/**
|
|
|
|
* Function unitsChangeRefresh
|
|
|
|
* is called when when the units setting has changed to allow for any derived classes
|
|
|
|
* to handle refreshing and controls that have units based measurements in them. The
|
|
|
|
* default version only updates the status bar. Don't forget to call the default
|
|
|
|
* in your derived class or the status bar will not get updated properly.
|
|
|
|
*/
|
2011-03-11 15:53:28 +00:00
|
|
|
virtual void unitsChangeRefresh();
|
2011-03-01 19:26:17 +00:00
|
|
|
|
2007-06-05 12:10:51 +00:00
|
|
|
public:
|
2011-09-01 12:54:34 +00:00
|
|
|
EDA_DRAW_FRAME( wxWindow* father, int idtype, const wxString& title,
|
2011-01-21 19:30:59 +00:00
|
|
|
const wxPoint& pos, const wxSize& size,
|
|
|
|
long style = KICAD_DEFAULT_DRAWFRAME_STYLE );
|
2007-08-04 04:42:49 +00:00
|
|
|
|
2011-01-21 19:30:59 +00:00
|
|
|
~EDA_DRAW_FRAME();
|
2007-10-01 15:37:42 +00:00
|
|
|
|
2009-04-07 11:53:58 +00:00
|
|
|
virtual wxString GetScreenDesc();
|
2007-08-04 04:42:49 +00:00
|
|
|
|
2008-04-17 16:25:29 +00:00
|
|
|
/**
|
|
|
|
* Function GetBaseScreen
|
2009-05-01 18:06:03 +00:00
|
|
|
* is virtual and returns a pointer to a BASE_SCREEN or one of its
|
|
|
|
* derivatives. It may be overloaded by derived classes.
|
2008-04-17 16:25:29 +00:00
|
|
|
*/
|
2011-02-05 02:21:11 +00:00
|
|
|
virtual BASE_SCREEN* GetScreen() const { return m_currentScreen; }
|
2009-04-07 11:53:58 +00:00
|
|
|
|
2011-09-01 12:54:34 +00:00
|
|
|
void OnMenuOpen( wxMenuEvent& event );
|
|
|
|
void OnMouseEvent( wxMouseEvent& event );
|
|
|
|
virtual void OnHotKey( wxDC* aDC, int aHotKey, const wxPoint& aPosition,
|
|
|
|
EDA_ITEM* aItem = NULL );
|
2009-04-07 11:53:58 +00:00
|
|
|
|
2010-11-12 15:17:10 +00:00
|
|
|
/**
|
|
|
|
* Function AddMenuZoomAndGrid (virtual)
|
2010-02-14 18:14:33 +00:00
|
|
|
* Add standard zoom commands and submenu zoom and grid selection to a popup menu
|
|
|
|
* uses zoom hotkeys info base to add hotkeys info to menu commands
|
|
|
|
* @param aMasterMenu = the menu to populate.
|
|
|
|
*/
|
2011-09-01 12:54:34 +00:00
|
|
|
virtual void AddMenuZoomAndGrid( wxMenu* aMasterMenu );
|
2010-02-14 18:14:33 +00:00
|
|
|
|
2011-09-01 12:54:34 +00:00
|
|
|
void EraseMsgBox();
|
|
|
|
void Process_PageSettings( wxCommandEvent& event );
|
2011-02-03 19:27:28 +00:00
|
|
|
|
2010-11-12 15:17:10 +00:00
|
|
|
/**
|
|
|
|
* Function SetLanguage
|
2010-02-26 15:39:10 +00:00
|
|
|
* called on a language menu selection
|
|
|
|
* when using a derived function, do not forget to call this one
|
|
|
|
*/
|
2011-09-01 12:54:34 +00:00
|
|
|
virtual void SetLanguage( wxCommandEvent& event );
|
2010-02-26 15:39:10 +00:00
|
|
|
|
2011-09-01 12:54:34 +00:00
|
|
|
virtual void ReCreateHToolbar() = 0;
|
|
|
|
virtual void ReCreateVToolbar() = 0;
|
|
|
|
virtual void ReCreateMenuBar();
|
|
|
|
virtual void ReCreateAuxiliaryToolbar();
|
2011-02-11 20:48:13 +00:00
|
|
|
|
2010-11-12 15:17:10 +00:00
|
|
|
/**
|
|
|
|
* Function SetToolID
|
2011-02-24 20:22:12 +00:00
|
|
|
* sets the tool command ID to \a aId and sets the cursor to \a aCursor. The
|
|
|
|
* command ID must be greater or equal ::ID_NO_TOOL_SELECTED. If the command
|
|
|
|
* ID is less than ::ID_NO_TOOL_SELECTED, the tool command ID is set to
|
|
|
|
* ::ID_NO_TOOL_SELECTED. On debug builds, an assertion will be raised when
|
|
|
|
* \a aId is invalid.
|
|
|
|
* @param aId New tool command ID if greater than or equal to ::ID_NO_TOOL_SELECTED.
|
|
|
|
If less than zero, the current tool command ID is retained.
|
|
|
|
* @param aCursor Sets the cursor shape if greater than or equal to zero.
|
|
|
|
* @param aToolMsg The tool message to set in the status bar.
|
2010-07-27 16:49:38 +00:00
|
|
|
*/
|
2011-02-24 20:22:12 +00:00
|
|
|
virtual void SetToolID( int aId, int aCursor, const wxString& aToolMsg );
|
|
|
|
|
|
|
|
int GetToolId() const { return m_toolId; }
|
2009-04-07 11:53:58 +00:00
|
|
|
|
2010-08-24 17:26:51 +00:00
|
|
|
/* These 4 functions provide a basic way to show/hide grid
|
2010-02-01 21:23:27 +00:00
|
|
|
* and /get/set grid color.
|
2011-09-30 18:15:37 +00:00
|
|
|
* These parameters are saved in KiCad config for each main frame
|
2010-02-01 21:23:27 +00:00
|
|
|
*/
|
2010-11-12 15:17:10 +00:00
|
|
|
/**
|
|
|
|
* Function IsGridVisible() , virtual
|
2010-02-01 21:23:27 +00:00
|
|
|
* @return true if the grid must be shown
|
|
|
|
*/
|
2011-09-01 12:54:34 +00:00
|
|
|
virtual bool IsGridVisible()
|
2010-02-01 21:23:27 +00:00
|
|
|
{
|
|
|
|
return m_DrawGrid;
|
|
|
|
}
|
|
|
|
|
2010-11-12 15:17:10 +00:00
|
|
|
/**
|
|
|
|
* Function SetGridVisibility() , virtual
|
2010-02-01 21:23:27 +00:00
|
|
|
* It may be overloaded by derived classes
|
|
|
|
* @param aVisible = true if the grid must be shown
|
|
|
|
*/
|
2011-09-01 12:54:34 +00:00
|
|
|
virtual void SetGridVisibility( bool aVisible )
|
2010-02-01 21:23:27 +00:00
|
|
|
{
|
|
|
|
m_DrawGrid = aVisible;
|
|
|
|
}
|
|
|
|
|
2010-11-12 15:17:10 +00:00
|
|
|
/**
|
|
|
|
* Function GetGridColor() , virtual
|
2010-02-01 21:23:27 +00:00
|
|
|
* @return the color of the grid
|
|
|
|
*/
|
2011-09-01 12:54:34 +00:00
|
|
|
virtual int GetGridColor()
|
2010-02-01 21:23:27 +00:00
|
|
|
{
|
|
|
|
return m_GridColor;
|
|
|
|
}
|
|
|
|
|
2010-11-12 15:17:10 +00:00
|
|
|
/**
|
|
|
|
* Function SetGridColor() , virtual
|
2010-02-01 21:23:27 +00:00
|
|
|
* @param aColor = the new color of the grid
|
|
|
|
*/
|
2011-09-01 12:54:34 +00:00
|
|
|
virtual void SetGridColor( int aColor )
|
2010-02-01 21:23:27 +00:00
|
|
|
{
|
|
|
|
m_GridColor = aColor;
|
|
|
|
}
|
|
|
|
|
2011-02-03 19:27:28 +00:00
|
|
|
/**
|
|
|
|
* Function GetGridPosition
|
|
|
|
* returns the nearest grid position to \a aPosition if a screen is defined and snap to
|
2011-09-01 12:54:34 +00:00
|
|
|
* grid is enabled. Otherwise, the original positions is returned.
|
2011-02-03 19:27:28 +00:00
|
|
|
* @see m_snapToGrid and m_BaseScreen members.
|
|
|
|
* @param aPosition The position to test.
|
|
|
|
* @return The wxPoint of the appropriate cursor position.
|
|
|
|
*/
|
|
|
|
wxPoint GetGridPosition( const wxPoint& aPosition );
|
2010-02-01 21:23:27 +00:00
|
|
|
|
2009-10-14 19:43:31 +00:00
|
|
|
/**
|
|
|
|
* Command event handler for selecting grid sizes.
|
|
|
|
*
|
|
|
|
* All commands that set the grid size should eventually end up here.
|
|
|
|
* This is where the application setting is saved. If you override
|
|
|
|
* this method, make sure you call down to the base class.
|
|
|
|
*
|
|
|
|
* @param event - Command event passed by selecting grid size from the
|
|
|
|
* grid size combobox on the toolbar.
|
|
|
|
*/
|
2011-09-01 12:54:34 +00:00
|
|
|
virtual void OnSelectGrid( wxCommandEvent& event );
|
|
|
|
virtual void OnSelectZoom( wxCommandEvent& event );
|
2009-04-07 11:53:58 +00:00
|
|
|
|
2011-02-21 13:54:29 +00:00
|
|
|
// Command event handlers shared by all applications derived from EDA_DRAW_FRAME.
|
|
|
|
void OnToggleGridState( wxCommandEvent& aEvent );
|
|
|
|
void OnSelectUnits( wxCommandEvent& aEvent );
|
|
|
|
void OnToggleCrossHairStyle( wxCommandEvent& aEvent );
|
|
|
|
|
|
|
|
// Update user interface event handlers shared by all applications derived from
|
|
|
|
// EDA_DRAW_FRAME.
|
|
|
|
void OnUpdateUndo( wxUpdateUIEvent& aEvent );
|
|
|
|
void OnUpdateRedo( wxUpdateUIEvent& aEvent );
|
|
|
|
void OnUpdateGrid( wxUpdateUIEvent& aEvent );
|
|
|
|
void OnUpdateUnits( wxUpdateUIEvent& aEvent );
|
|
|
|
void OnUpdateCrossHairStyle( wxUpdateUIEvent& aEvent );
|
|
|
|
|
2011-02-01 15:46:25 +00:00
|
|
|
/**
|
2011-02-22 16:43:03 +00:00
|
|
|
* Function GeneralControl
|
2011-02-01 15:46:25 +00:00
|
|
|
* performs application specific control using \a aDC at \a aPosition in logical units.
|
|
|
|
* <p>
|
|
|
|
* Override this function for application specific control. This function gets
|
|
|
|
* called on every mouse and key event.
|
|
|
|
*</p>
|
|
|
|
* @param aDC A device context.
|
2011-02-02 19:01:21 +00:00
|
|
|
* @param aPosition The current cursor position in logical (drawing) units.
|
2011-09-01 12:54:34 +00:00
|
|
|
* @param aHotKey A key event used for application specific control if not zero.
|
2011-02-01 15:46:25 +00:00
|
|
|
*/
|
2011-09-01 12:54:34 +00:00
|
|
|
virtual void GeneralControl( wxDC* aDC, const wxPoint& aPosition, int aHotKey = 0 ) { }
|
2011-02-01 15:46:25 +00:00
|
|
|
|
2011-09-01 12:54:34 +00:00
|
|
|
virtual void OnSize( wxSizeEvent& event );
|
|
|
|
void OnEraseBackground( wxEraseEvent& SizeEvent );
|
2007-08-04 04:42:49 +00:00
|
|
|
|
2011-09-01 12:54:34 +00:00
|
|
|
virtual void OnZoom( wxCommandEvent& event );
|
|
|
|
void OnGrid( int grid_type );
|
2011-01-30 22:22:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Function RedrawScreen
|
|
|
|
* redraws the entire screen area by updating the scroll bars and mouse pointer in
|
2011-02-11 20:48:13 +00:00
|
|
|
* order to have \a aCenterPoint at the center of the screen.
|
|
|
|
* @param aCenterPoint The position in logical units to center the scroll bars.
|
|
|
|
* @param aWarpPointer Moves the mouse cursor to \a aCenterPoint if true.
|
2010-09-23 14:04:08 +00:00
|
|
|
*/
|
2011-09-01 12:54:34 +00:00
|
|
|
void RedrawScreen( const wxPoint& aCenterPoint, bool aWarpPointer );
|
2010-11-12 15:17:10 +00:00
|
|
|
|
2011-09-01 12:54:34 +00:00
|
|
|
void Zoom_Automatique( bool aWarpPointer );
|
2007-08-04 04:42:49 +00:00
|
|
|
|
2007-10-16 19:05:33 +00:00
|
|
|
/* Set the zoom level to show the area Rect */
|
2011-09-01 12:54:34 +00:00
|
|
|
void Window_Zoom( EDA_RECT& Rect );
|
2007-08-04 04:42:49 +00:00
|
|
|
|
2007-10-16 19:05:33 +00:00
|
|
|
/* Return the zoom level which displays the full page on screen */
|
2011-09-01 12:54:34 +00:00
|
|
|
virtual double BestZoom() = 0;
|
2007-08-04 04:42:49 +00:00
|
|
|
|
2007-10-26 06:08:19 +00:00
|
|
|
/* Return the current zoom level */
|
2011-09-01 12:54:34 +00:00
|
|
|
double GetZoom( void );
|
2007-10-26 06:08:19 +00:00
|
|
|
|
2011-09-01 12:54:34 +00:00
|
|
|
void TraceWorkSheet( wxDC* DC, BASE_SCREEN* screen, int line_width );
|
|
|
|
void PlotWorkSheet( PLOTTER *plotter, BASE_SCREEN* screen );
|
2009-01-29 14:26:20 +00:00
|
|
|
|
2010-11-12 15:17:10 +00:00
|
|
|
/**
|
|
|
|
* Function GetXYSheetReferences
|
2008-07-31 15:30:57 +00:00
|
|
|
* Return the X,Y sheet references where the point position is located
|
|
|
|
* @param aScreen = screen to use
|
|
|
|
* @param aPosition = position to identify by YX ref
|
2009-11-23 20:18:47 +00:00
|
|
|
* @return a wxString containing the message locator like A3 or B6
|
|
|
|
* (or ?? if out of page limits)
|
2008-07-31 15:30:57 +00:00
|
|
|
*/
|
2011-09-01 12:54:34 +00:00
|
|
|
wxString GetXYSheetReferences( BASE_SCREEN* aScreen, const wxPoint& aPosition );
|
2009-04-07 11:53:58 +00:00
|
|
|
|
2011-09-01 12:54:34 +00:00
|
|
|
void DisplayToolMsg( const wxString& msg );
|
|
|
|
virtual void RedrawActiveWindow( wxDC* DC, bool EraseBg ) = 0;
|
|
|
|
virtual void OnLeftClick( wxDC* DC, const wxPoint& MousePos ) = 0;
|
|
|
|
virtual void OnLeftDClick( wxDC* DC, const wxPoint& MousePos );
|
|
|
|
virtual bool OnRightClick( const wxPoint& MousePos, wxMenu* PopMenu ) = 0;
|
|
|
|
virtual void ToolOnRightClick( wxCommandEvent& event );
|
|
|
|
void AdjustScrollBars( const wxPoint& aCenterPosition );
|
2009-04-09 17:34:51 +00:00
|
|
|
|
2010-07-23 14:12:37 +00:00
|
|
|
/**
|
|
|
|
* Function OnActivate (virtual)
|
|
|
|
* is called when activating the frame.
|
|
|
|
* In derived classes with a overriding OnActivate function,
|
2011-01-21 19:30:59 +00:00
|
|
|
* do not forget to call this EDA_DRAW_FRAME::OnActivate( event ) basic function.
|
2009-12-22 20:08:56 +00:00
|
|
|
*/
|
2011-09-01 12:54:34 +00:00
|
|
|
virtual void OnActivate( wxActivateEvent& event );
|
2010-07-23 14:12:37 +00:00
|
|
|
|
2009-04-09 17:34:51 +00:00
|
|
|
/**
|
|
|
|
* Function UpdateStatusBar
|
|
|
|
* updates the status bar information.
|
|
|
|
*
|
|
|
|
* The base method updates the absolute and relative coordinates and the
|
|
|
|
* zoom information. If you override this virtual method, make sure to call
|
|
|
|
* this subclassed method. The status bar can draw itself. This is not
|
|
|
|
* a drawing function per se, but rather updates lines of text held by
|
|
|
|
* the components within the status bar which is owned by the wxFrame.
|
|
|
|
* <p>
|
2009-11-23 20:18:47 +00:00
|
|
|
* On a MAC, be careful about calling this function when there is an
|
|
|
|
* existing wxDC in existence on a sibling window.
|
2009-04-09 17:34:51 +00:00
|
|
|
*/
|
2011-09-01 12:54:34 +00:00
|
|
|
virtual void UpdateStatusBar();
|
2009-04-09 17:34:51 +00:00
|
|
|
|
2011-09-01 12:54:34 +00:00
|
|
|
void DisplayUnitsMsg();
|
2007-08-04 04:42:49 +00:00
|
|
|
|
2007-10-16 19:05:33 +00:00
|
|
|
/* Handlers for block commands */
|
2011-09-01 12:54:34 +00:00
|
|
|
virtual void InitBlockPasteInfos();
|
|
|
|
virtual bool HandleBlockBegin( wxDC* DC, int cmd_type,const wxPoint& startpos );
|
2010-11-13 11:02:24 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Function ReturnBlockCommand
|
|
|
|
* Returns the block command internat code (BLOCK_MOVE, BLOCK_COPY...)
|
|
|
|
* corresponding to the keys pressed (ALT, SHIFT, SHIFT ALT ..) when
|
|
|
|
* block command is started by dragging the mouse.
|
|
|
|
* @param aKey = the key modifiers (Alt, Shift ...)
|
|
|
|
* @return the block command id (BLOCK_MOVE, BLOCK_COPY...)
|
|
|
|
*/
|
2011-09-01 12:54:34 +00:00
|
|
|
virtual int ReturnBlockCommand( int aKey );
|
2010-11-13 11:02:24 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Function HandleBlockPlace( )
|
|
|
|
* Called after HandleBlockEnd, when a block command needs to be
|
|
|
|
* executed after the block is moved to its new place
|
|
|
|
* (bloc move, drag, copy .. )
|
|
|
|
* Parameters must be initialized in GetScreen()->m_BlockLocate
|
|
|
|
*/
|
|
|
|
virtual void HandleBlockPlace( wxDC* DC );
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function HandleBlockEnd( )
|
|
|
|
* Handle the "end" of a block command,
|
|
|
|
* i.e. is called at the end of the definition of the area of a block.
|
|
|
|
* depending on the current block command, this command is executed
|
|
|
|
* or parameters are initialized to prepare a call to HandleBlockPlace
|
|
|
|
* in GetScreen()->m_BlockLocate
|
|
|
|
* @return false if no item selected, or command finished,
|
|
|
|
* true if some items found and HandleBlockPlace must be called later
|
|
|
|
*/
|
|
|
|
virtual bool HandleBlockEnd( wxDC* DC );
|
2007-08-04 04:42:49 +00:00
|
|
|
|
2011-09-01 12:54:34 +00:00
|
|
|
void CopyToClipboard( wxCommandEvent& event );
|
2007-08-04 04:42:49 +00:00
|
|
|
|
|
|
|
/* interprocess communication */
|
2011-09-01 12:54:34 +00:00
|
|
|
void OnSockRequest( wxSocketEvent& evt );
|
|
|
|
void OnSockRequestServer( wxSocketEvent& evt );
|
2007-06-05 12:10:51 +00:00
|
|
|
|
2011-09-01 12:54:34 +00:00
|
|
|
virtual void LoadSettings();
|
|
|
|
virtual void SaveSettings();
|
2009-04-05 20:49:15 +00:00
|
|
|
|
2009-10-14 19:43:31 +00:00
|
|
|
/**
|
|
|
|
* Append a message to the message panel.
|
|
|
|
*
|
|
|
|
* This helper method checks to make sure the message panel exists in
|
|
|
|
* the frame and appends a message to it using the message panel
|
|
|
|
* AppendMessage() method.
|
|
|
|
*
|
|
|
|
* @param textUpper - The message upper text.
|
|
|
|
* @param textLower - The message lower text.
|
2011-09-30 18:15:37 +00:00
|
|
|
* @param color - A color ID from the KiCad color list (see colors.h).
|
2009-10-14 19:43:31 +00:00
|
|
|
* @param pad - Number of spaces to pad between messages (default = 4).
|
|
|
|
*/
|
|
|
|
void AppendMsgPanel( const wxString& textUpper, const wxString& textLower,
|
|
|
|
int color, int pad = 6 );
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Clear all messages from the message panel.
|
|
|
|
*/
|
|
|
|
void ClearMsgPanel( void );
|
|
|
|
|
2011-09-01 12:54:34 +00:00
|
|
|
/**
|
|
|
|
* Function PrintPage
|
2010-03-18 20:35:29 +00:00
|
|
|
* used to print a page
|
2011-02-01 15:46:25 +00:00
|
|
|
* Print the page pointed by current screen, set by the calling print function
|
2010-03-18 20:35:29 +00:00
|
|
|
* @param aDC = wxDC given by the calling print function
|
|
|
|
* @param aPrintMask = not used here
|
|
|
|
* @param aPrintMirrorMode = not used here (Set when printing in mirror mode)
|
|
|
|
* @param aData = a pointer on an auxiliary data (not always used, NULL if not used)
|
|
|
|
*/
|
2011-02-11 20:48:13 +00:00
|
|
|
virtual void PrintPage( wxDC* aDC, int aPrintMask, bool aPrintMirrorMode, void* aData = NULL );
|
2010-03-18 20:35:29 +00:00
|
|
|
|
2011-03-11 15:53:28 +00:00
|
|
|
/**
|
|
|
|
* Function CoordinateToString
|
|
|
|
* is a helper to convert the integer coordinate \a aValue to a string in inches or mm
|
|
|
|
* according to the current user units setting.
|
|
|
|
* @param aValue The coordinate to convert.
|
|
|
|
* @param aConvertToMils Convert inch values to mils if true. This setting has no effect if
|
|
|
|
* the current user unit is millimeters.
|
|
|
|
* @return The converted string for display in user interface elements.
|
|
|
|
*/
|
|
|
|
wxString CoordinateToString( int aValue, bool aConvertToMils = false );
|
|
|
|
|
2010-10-04 12:58:07 +00:00
|
|
|
DECLARE_EVENT_TABLE()
|
2009-01-07 15:59:49 +00:00
|
|
|
};
|
2007-06-05 12:10:51 +00:00
|
|
|
|
|
|
|
|
2007-10-10 18:01:14 +00:00
|
|
|
/**
|
2011-09-01 12:54:34 +00:00
|
|
|
* Struct EDA_MSG_ITEM
|
|
|
|
* is used privately by EDA_MSG_PANEL as the item type for displaying messages.
|
2007-10-10 18:01:14 +00:00
|
|
|
*/
|
2011-09-01 12:54:34 +00:00
|
|
|
struct EDA_MSG_ITEM
|
2007-10-10 18:01:14 +00:00
|
|
|
{
|
2009-04-07 11:53:58 +00:00
|
|
|
int m_X;
|
|
|
|
int m_UpperY;
|
|
|
|
int m_LowerY;
|
|
|
|
wxString m_UpperText;
|
|
|
|
wxString m_LowerText;
|
|
|
|
int m_Color;
|
2007-10-10 18:01:14 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Function operator=
|
|
|
|
* overload the assignment operator so that the wxStrings get copied
|
2011-09-01 12:54:34 +00:00
|
|
|
* properly when copying a EDA_MSG_ITEM.
|
2007-10-10 18:01:14 +00:00
|
|
|
* No, actually I'm not sure this needed, C++ compiler may auto-generate it.
|
|
|
|
*/
|
2011-09-01 12:54:34 +00:00
|
|
|
EDA_MSG_ITEM& operator=( const EDA_MSG_ITEM& rv )
|
2007-10-10 18:01:14 +00:00
|
|
|
{
|
2011-09-01 12:54:34 +00:00
|
|
|
m_X = rv.m_X;
|
2007-10-10 18:01:14 +00:00
|
|
|
m_UpperY = rv.m_UpperY;
|
|
|
|
m_LowerY = rv.m_LowerY;
|
|
|
|
m_UpperText = rv.m_UpperText; // overloaded operator=()
|
|
|
|
m_LowerText = rv.m_LowerText; // overloaded operator=()
|
|
|
|
m_Color = rv.m_Color;
|
2009-04-07 11:53:58 +00:00
|
|
|
|
|
|
|
return * this;
|
2007-10-10 18:01:14 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2011-09-01 12:54:34 +00:00
|
|
|
/**
|
|
|
|
* class EDA_MSG_PANEL
|
|
|
|
* is a panel to display various information messages.
|
|
|
|
*/
|
2011-04-12 14:19:59 +00:00
|
|
|
class EDA_MSG_PANEL : public wxPanel
|
2007-06-05 12:10:51 +00:00
|
|
|
{
|
2007-10-10 18:01:14 +00:00
|
|
|
protected:
|
2011-09-01 12:54:34 +00:00
|
|
|
std::vector<EDA_MSG_ITEM> m_Items;
|
|
|
|
int m_last_x; ///< the last used x coordinate
|
|
|
|
wxSize m_fontSize;
|
2008-03-31 13:46:00 +00:00
|
|
|
|
2011-09-01 12:54:34 +00:00
|
|
|
void showItem( wxDC& dc, const EDA_MSG_ITEM& aItem );
|
2007-10-10 18:01:14 +00:00
|
|
|
|
2009-04-07 11:53:58 +00:00
|
|
|
void erase( wxDC* DC );
|
2008-03-20 01:50:21 +00:00
|
|
|
|
2009-08-07 04:44:42 +00:00
|
|
|
/**
|
|
|
|
* Function getFontSize
|
|
|
|
* computes the height and width of a 'W' in the system font.
|
|
|
|
*/
|
|
|
|
static wxSize computeFontSize();
|
|
|
|
|
2009-09-18 14:56:05 +00:00
|
|
|
/**
|
|
|
|
* Calculate the width and height of a text string using the system UI font.
|
|
|
|
*/
|
|
|
|
wxSize computeTextSize( const wxString& text );
|
2009-08-07 04:44:42 +00:00
|
|
|
|
2007-06-05 12:10:51 +00:00
|
|
|
public:
|
2011-01-21 19:30:59 +00:00
|
|
|
EDA_DRAW_FRAME* m_Parent;
|
2009-11-23 20:18:47 +00:00
|
|
|
int m_BgColor;
|
2007-06-05 12:10:51 +00:00
|
|
|
|
|
|
|
public:
|
2011-04-12 14:19:59 +00:00
|
|
|
EDA_MSG_PANEL( EDA_DRAW_FRAME* parent, int id, const wxPoint& pos, const wxSize& size );
|
|
|
|
~EDA_MSG_PANEL();
|
2007-08-04 04:42:49 +00:00
|
|
|
|
2009-08-07 04:44:42 +00:00
|
|
|
/**
|
|
|
|
* Function GetRequiredHeight
|
2011-04-12 14:19:59 +00:00
|
|
|
* returns the required height (in pixels) of a EDA_MSG_PANEL. This takes
|
2009-08-07 04:44:42 +00:00
|
|
|
* into consideration the system gui font, wxSYS_DEFAULT_GUI_FONT.
|
|
|
|
*/
|
|
|
|
static int GetRequiredHeight();
|
|
|
|
|
2009-04-07 11:53:58 +00:00
|
|
|
void OnPaint( wxPaintEvent& event );
|
|
|
|
void EraseMsgBox();
|
2011-04-12 14:19:59 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Function SetMessage
|
|
|
|
* sets a message at \a aXPosition to \a aUpperText and \a aLowerText in the message panel.
|
|
|
|
*
|
|
|
|
* @param aXPosition The horizontal position to display the message or less than zero
|
|
|
|
* to set the message using the last message position.
|
|
|
|
* @param aUpperText The text to be displayed in top line.
|
|
|
|
* @param aLowerText The text to be displayed in bottom line.
|
|
|
|
* @param aColor Color of the text to display.
|
|
|
|
*/
|
|
|
|
void SetMessage( int aXPosition, const wxString& aUpperText,
|
|
|
|
const wxString& aLowerText, int aColor );
|
2007-06-05 12:10:51 +00:00
|
|
|
|
2009-09-18 14:56:05 +00:00
|
|
|
/**
|
|
|
|
* Append a message to the message panel.
|
|
|
|
*
|
|
|
|
* This method automatically adjusts for the width of the text string.
|
2010-08-24 17:26:51 +00:00
|
|
|
* Making consecutive calls to AppendMessage will append each message
|
2009-09-18 14:56:05 +00:00
|
|
|
* to the right of the last message. This message is not compatible
|
|
|
|
* with Affiche_1_Parametre.
|
|
|
|
*
|
|
|
|
* @param textUpper - The message upper text.
|
|
|
|
* @param textLower - The message lower text.
|
2011-09-30 18:15:37 +00:00
|
|
|
* @param color - A color ID from the KiCad color list (see colors.h).
|
2009-09-18 14:56:05 +00:00
|
|
|
* @param pad - Number of spaces to pad between messages (default = 4).
|
|
|
|
*/
|
|
|
|
void AppendMessage( const wxString& textUpper, const wxString& textLower,
|
2009-10-14 19:43:31 +00:00
|
|
|
int color, int pad = 6 );
|
2007-06-05 12:10:51 +00:00
|
|
|
|
2007-08-04 04:42:49 +00:00
|
|
|
DECLARE_EVENT_TABLE()
|
2007-06-05 12:10:51 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2011-09-01 12:54:34 +00:00
|
|
|
/**
|
|
|
|
* Class EDA_TOOLBAR
|
2011-09-30 18:15:37 +00:00
|
|
|
* is the base class for deriving KiCad tool bars.
|
2011-09-01 12:54:34 +00:00
|
|
|
*/
|
2011-04-13 19:30:27 +00:00
|
|
|
class EDA_TOOLBAR : public wxAuiToolBar
|
2007-06-05 12:10:51 +00:00
|
|
|
{
|
|
|
|
public:
|
2007-08-04 04:42:49 +00:00
|
|
|
wxWindow* m_Parent;
|
|
|
|
id_toolbar m_Ident;
|
2010-08-24 17:26:51 +00:00
|
|
|
bool m_Horizontal; // some auxiliary TB are horizontal, others vertical
|
2007-06-05 12:10:51 +00:00
|
|
|
|
|
|
|
public:
|
2011-04-13 19:30:27 +00:00
|
|
|
EDA_TOOLBAR( id_toolbar type, wxWindow* parent, wxWindowID id, bool horizontal );
|
2009-11-02 22:24:55 +00:00
|
|
|
|
2009-11-05 08:52:41 +00:00
|
|
|
bool GetToolState( int toolId ) { return GetToolToggled(toolId); };
|
2009-11-02 22:24:55 +00:00
|
|
|
|
2009-11-23 20:18:47 +00:00
|
|
|
void AddRadioTool( int toolid,
|
|
|
|
const wxString& label,
|
|
|
|
const wxBitmap& bitmap,
|
|
|
|
const wxBitmap& bmpDisabled = wxNullBitmap,
|
|
|
|
const wxString& shortHelp = wxEmptyString,
|
|
|
|
const wxString& longHelp = wxEmptyString,
|
|
|
|
wxObject* data = NULL )
|
2009-11-05 08:52:41 +00:00
|
|
|
{
|
2009-11-23 20:18:47 +00:00
|
|
|
AddTool( toolid, label, bitmap, bmpDisabled, wxITEM_CHECK,
|
|
|
|
shortHelp, longHelp, data );
|
2009-11-02 22:24:55 +00:00
|
|
|
};
|
|
|
|
|
2009-11-05 08:52:41 +00:00
|
|
|
void SetToolNormalBitmap( int id, const wxBitmap& bitmap ) {};
|
|
|
|
void SetRows( int nRows ) {};
|
2010-02-01 21:23:27 +00:00
|
|
|
|
2010-11-12 15:17:10 +00:00
|
|
|
/**
|
|
|
|
* Function GetDimension
|
2010-01-14 20:20:59 +00:00
|
|
|
* @return the dimension of this toolbar (Height if horizontal, Width if vertical.
|
|
|
|
*/
|
2011-09-01 12:54:34 +00:00
|
|
|
int GetDimension();
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function AddMenuItem
|
|
|
|
* is an inline helper function to create and insert a menu item with an image
|
|
|
|
* into \a aMenu
|
|
|
|
*
|
|
|
|
* @param aMenu is the menu to add the new item.
|
|
|
|
* @param aId is the command ID for the new menu item.
|
|
|
|
* @param aText is the string for the new menu item.
|
|
|
|
* @param aImage is the image to add to the new menu item.
|
|
|
|
*/
|
|
|
|
static inline void AddMenuItem( wxMenu* aMenu,
|
|
|
|
int aId,
|
|
|
|
const wxString& aText,
|
|
|
|
const wxBitmap& aImage )
|
|
|
|
{
|
|
|
|
wxMenuItem* item;
|
|
|
|
|
|
|
|
item = new wxMenuItem( aMenu, aId, aText );
|
|
|
|
|
|
|
|
#if defined( USE_IMAGES_IN_MENUS )
|
|
|
|
item->SetBitmap( aImage );
|
|
|
|
#endif
|
|
|
|
|
|
|
|
aMenu->Append( item );
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function AddMenuItem
|
|
|
|
* is an inline helper function to create and insert a menu item with an image
|
|
|
|
* and a help message string into \a aMenu
|
|
|
|
*
|
|
|
|
* @param aMenu is the menu to add the new item.
|
|
|
|
* @param aId is the command ID for the new menu item.
|
|
|
|
* @param aText is the string for the new menu item.
|
|
|
|
* @param aHelpText is the help message string for the new menu item.
|
|
|
|
* @param aImage is the image to add to the new menu item.
|
|
|
|
*/
|
|
|
|
static inline void AddMenuItem( wxMenu* aMenu,
|
|
|
|
int aId,
|
|
|
|
const wxString& aText,
|
|
|
|
const wxString& aHelpText,
|
|
|
|
const wxBitmap& aImage )
|
|
|
|
{
|
|
|
|
wxMenuItem* item;
|
|
|
|
|
|
|
|
item = new wxMenuItem( aMenu, aId, aText, aHelpText );
|
|
|
|
|
|
|
|
#if defined( USE_IMAGES_IN_MENUS )
|
|
|
|
item->SetBitmap( aImage );
|
|
|
|
#endif
|
|
|
|
|
|
|
|
aMenu->Append( item );
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function AddMenuItem
|
|
|
|
* is an inline helper function to create and insert a menu item with an image
|
|
|
|
* into \a aSubMenu in \a aMenu
|
|
|
|
*
|
|
|
|
* @param aMenu is the menu to add the new submenu item.
|
|
|
|
* @param aSubMenu is the submenu to add the new menu.
|
|
|
|
* @param aId is the command ID for the new menu item.
|
|
|
|
* @param aText is the string for the new menu item.
|
|
|
|
* @param aImage is the image to add to the new menu item.
|
|
|
|
*/
|
|
|
|
static inline void AddMenuItem( wxMenu* aMenu,
|
|
|
|
wxMenu* aSubMenu,
|
|
|
|
int aId,
|
|
|
|
const wxString& aText,
|
|
|
|
const wxBitmap& aImage )
|
|
|
|
{
|
|
|
|
wxMenuItem* item;
|
|
|
|
|
|
|
|
item = new wxMenuItem( aMenu, aId, aText );
|
|
|
|
item->SetSubMenu( aSubMenu );
|
|
|
|
|
|
|
|
#if defined( USE_IMAGES_IN_MENUS )
|
|
|
|
item->SetBitmap( aImage );
|
|
|
|
#endif
|
|
|
|
|
|
|
|
aMenu->Append( item );
|
2007-06-05 12:10:51 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2011-09-01 12:54:34 +00:00
|
|
|
/**
|
|
|
|
* Function AddMenuItem
|
|
|
|
* is an inline helper function to create and insert a menu item with an image
|
|
|
|
* and a help message string into \a aSubMenu in \a aMenu
|
|
|
|
*
|
|
|
|
* @param aMenu is the menu to add the new submenu item.
|
|
|
|
* @param aSubMenu is the submenu to add the new menu.
|
|
|
|
* @param aId is the command ID for the new menu item.
|
|
|
|
* @param aText is the string for the new menu item.
|
|
|
|
* @param aHelpText is the help message string for the new menu item.
|
|
|
|
* @param aImage is the image to add to the new menu item.
|
|
|
|
*/
|
|
|
|
static inline void AddMenuItem( wxMenu* aMenu,
|
|
|
|
wxMenu* aSubMenu,
|
|
|
|
int aId,
|
|
|
|
const wxString& aText,
|
|
|
|
const wxString& aHelpText,
|
|
|
|
const wxBitmap& aImage )
|
|
|
|
{
|
|
|
|
wxMenuItem* item;
|
|
|
|
|
|
|
|
item = new wxMenuItem( aMenu, aId, aText, aHelpText );
|
|
|
|
item->SetSubMenu( aSubMenu );
|
|
|
|
|
|
|
|
#if defined( USE_IMAGES_IN_MENUS )
|
|
|
|
item->SetBitmap( aImage );
|
|
|
|
#endif
|
|
|
|
|
|
|
|
aMenu->Append( item );
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Definition SETBITMAPS
|
|
|
|
* is a macro use to add a bitmaps to check menu item.
|
|
|
|
* @note Do not use with normal menu items or any platform other than Windows.
|
|
|
|
* @param aImage is the image to add the menu item.
|
|
|
|
*/
|
|
|
|
#if defined( USE_IMAGES_IN_MENUS ) && defined( __WINDOWS__ )
|
|
|
|
# define SETBITMAPS( aImage ) item->SetBitmaps( KiBitmap( apply_xpm ), KiBitmap( aImage ) )
|
|
|
|
#else
|
|
|
|
# define SETBITMAPS( aImage )
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Definition SETBITMAP
|
|
|
|
* is a macro use to add a bitmap to a menu items.
|
|
|
|
* @note Do not use with checked menu items.
|
|
|
|
* @param aImage is the image to add the menu item.
|
|
|
|
*/
|
|
|
|
#if !defined( USE_IMAGES_IN_MENUS )
|
|
|
|
# define SET_BITMAP( aImage )
|
|
|
|
#else
|
|
|
|
# define SET_BITMAP( aImage ) item->SetBitmap( aImage )
|
|
|
|
#endif
|
|
|
|
|
2011-09-15 18:25:44 +00:00
|
|
|
|
|
|
|
/**
|
2011-09-30 18:15:37 +00:00
|
|
|
* Specialization of the wxAuiPaneInfo class for KiCad panels.
|
2011-09-15 18:25:44 +00:00
|
|
|
*
|
|
|
|
* Documentation for wxAui is poor at this time. The following notes spring from errors made in
|
2011-09-30 18:15:37 +00:00
|
|
|
* previous KiCad implementations:
|
2011-09-15 18:25:44 +00:00
|
|
|
*
|
|
|
|
* wxAuiPaneInfo.ToolbarPane() and .Defaults() are used to clear and then prepare the objects so
|
|
|
|
* only use them once at the beginning of configuration..
|
|
|
|
*
|
|
|
|
* Panels are organized in layers, from 0 (close to the center) and increasing outward. Note
|
|
|
|
* that for ToolbarPanes, layer 0 considered a special default value, and ToolbarPanes on
|
|
|
|
* layer 0 are pushed to layer 10 automatically. Use Layer 1 for the inner layer as a work-
|
|
|
|
* around.
|
|
|
|
*
|
|
|
|
* Each panel has rows, starting at 0. Each row has positions starting at 0. Each item in a panel
|
|
|
|
* can have it's row and position set.
|
|
|
|
*
|
|
|
|
* Eventually panels will be moveable. Each initialization function sets up the panel for this,
|
|
|
|
* then after a //==// break has additional calls to anchor toolbars in a way that matches
|
|
|
|
* present functionality.
|
|
|
|
*/
|
|
|
|
|
|
|
|
class EDA_PANEINFO : public wxAuiPaneInfo
|
|
|
|
{
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function HorizontalToolbarPane
|
2011-09-30 18:15:37 +00:00
|
|
|
* Change *this to a horizontal toolbar for KiCad.
|
2011-09-15 18:25:44 +00:00
|
|
|
*/
|
|
|
|
EDA_PANEINFO& HorizontalToolbarPane()
|
|
|
|
{
|
|
|
|
ToolbarPane();
|
|
|
|
CloseButton( false );
|
|
|
|
LeftDockable( false );
|
|
|
|
RightDockable( false );
|
|
|
|
//==================== Remove calls below here for moveable toolbars //
|
|
|
|
Gripper( false );
|
|
|
|
DockFixed( true );
|
|
|
|
Movable( false );
|
|
|
|
Resizable( true );
|
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function VerticalToolbarPane
|
2011-09-30 18:15:37 +00:00
|
|
|
* Change *this to a vertical toolbar for KiCad.
|
2011-09-15 18:25:44 +00:00
|
|
|
*/
|
|
|
|
EDA_PANEINFO& VerticalToolbarPane()
|
|
|
|
{
|
|
|
|
ToolbarPane();
|
|
|
|
CloseButton( false );
|
|
|
|
TopDockable( false );
|
|
|
|
BottomDockable( false );
|
|
|
|
//==================== Remove calls below here for moveable toolbars //
|
|
|
|
Gripper( false );
|
|
|
|
DockFixed( true );
|
|
|
|
Movable( false );
|
|
|
|
Resizable( true );
|
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function MessageToolbarPane
|
2011-09-30 18:15:37 +00:00
|
|
|
* Change *this to a message pane for KiCad.
|
2011-09-15 18:25:44 +00:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
EDA_PANEINFO& MessageToolbarPane()
|
|
|
|
{
|
|
|
|
Gripper( false );
|
|
|
|
DockFixed( true );
|
|
|
|
Movable( false );
|
|
|
|
Floatable( false );
|
|
|
|
CloseButton( false );
|
|
|
|
CaptionVisible( false );
|
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function LayersToolbarPane
|
2011-09-30 18:15:37 +00:00
|
|
|
* Change *this to a layers toolbar for KiCad.
|
2011-09-15 18:25:44 +00:00
|
|
|
*/
|
|
|
|
EDA_PANEINFO& LayersToolbarPane()
|
|
|
|
{
|
|
|
|
CloseButton( false );
|
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function InfoToolbarPane
|
2011-09-30 18:15:37 +00:00
|
|
|
* Change *this to a information panel for for KiCad.
|
2011-09-15 18:25:44 +00:00
|
|
|
*
|
|
|
|
* Info panes are used for vertical display of information next to the center pane.
|
2011-09-30 18:15:37 +00:00
|
|
|
* Used in CvPcb and the library viewer primarily.
|
2011-09-15 18:25:44 +00:00
|
|
|
*/
|
|
|
|
EDA_PANEINFO& InfoToolbarPane()
|
|
|
|
{
|
|
|
|
Gripper( false );
|
|
|
|
CloseButton( false );
|
|
|
|
CaptionVisible( false );
|
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
|
|
|
|
};
|
|
|
|
|
2007-06-05 12:10:51 +00:00
|
|
|
#endif /* WXSTRUCT_H */
|