458 lines
16 KiB
C++
458 lines
16 KiB
C++
/*
|
|
* This program source code file is part of KiCad, a free EDA CAD application.
|
|
*
|
|
* Copyright (C) 2018 Jean-Pierre Charras, jp.charras at wanadoo.fr
|
|
* Copyright (C) 2008-2016 Wayne Stambaugh <stambaughw@verizon.net>
|
|
* Copyright (C) 1992-2018 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 pcb_base_frame.h
|
|
* @brief Classes used in Pcbnew, CvPcb and GerbView.
|
|
*/
|
|
|
|
#ifndef PCB_BASE_FRAME_H
|
|
#define PCB_BASE_FRAME_H
|
|
|
|
|
|
#include <vector>
|
|
#include <boost/interprocess/exceptions.hpp>
|
|
|
|
#include <draw_frame.h>
|
|
#include <base_struct.h>
|
|
#include <eda_text.h> // EDA_DRAW_MODE_T
|
|
#include <richio.h>
|
|
#include <pcb_screen.h>
|
|
#include <pcb_display_options.h>
|
|
#include <pcb_general_settings.h>
|
|
#include <lib_id.h>
|
|
|
|
/* Forward declarations of classes. */
|
|
class BOARD;
|
|
class BOARD_CONNECTED_ITEM;
|
|
class MODULE;
|
|
class TRACK;
|
|
class D_PAD;
|
|
class TEXTE_MODULE;
|
|
class EDA_3D_VIEWER;
|
|
class GENERAL_COLLECTOR;
|
|
class GENERAL_COLLECTORS_GUIDE;
|
|
class BOARD_DESIGN_SETTINGS;
|
|
class ZONE_SETTINGS;
|
|
class PCB_PLOT_PARAMS;
|
|
class FP_LIB_TABLE;
|
|
class PCB_GENERAL_SETTINGS ;
|
|
|
|
/**
|
|
* class PCB_BASE_FRAME
|
|
* basic PCB main window class for Pcbnew, Gerbview, and CvPcb footprint viewer.
|
|
*/
|
|
class PCB_BASE_FRAME : public EDA_DRAW_FRAME
|
|
{
|
|
public:
|
|
PCB_DISPLAY_OPTIONS m_DisplayOptions;
|
|
wxPoint m_UserGridSize;
|
|
|
|
int m_FastGrid1; // 1st fast grid setting (index in EDA_DRAW_FRAME::m_gridSelectBox)
|
|
int m_FastGrid2; // 2nd fast grid setting (index in EDA_DRAW_FRAME::m_gridSelectBox)
|
|
|
|
protected:
|
|
BOARD* m_Pcb;
|
|
|
|
PCB_GENERAL_SETTINGS m_configSettings;
|
|
|
|
void updateZoomSelectBox();
|
|
virtual void unitsChangeRefresh() override;
|
|
|
|
/**
|
|
* Function loadFootprint
|
|
* attempts to load \a aFootprintId from the footprint library table.
|
|
*
|
|
* @param aFootprintId is the #LIB_ID of component footprint to load.
|
|
* @return the #MODULE if found or NULL if \a aFootprintId not found in any of the
|
|
* libraries in the table returned from #Prj().PcbFootprintLibs().
|
|
* @throw IO_ERROR if an I/O error occurs or a #PARSE_ERROR if a file parsing error
|
|
* occurs while reading footprint library files.
|
|
*/
|
|
MODULE* loadFootprint( const LIB_ID& aFootprintId );
|
|
|
|
public:
|
|
PCB_BASE_FRAME( KIWAY* aKiway, wxWindow* aParent, FRAME_T aFrameType,
|
|
const wxString& aTitle, const wxPoint& aPos, const wxSize& aSize,
|
|
long aStyle, const wxString& aFrameName );
|
|
|
|
~PCB_BASE_FRAME();
|
|
|
|
/**
|
|
* @return a reference to the 3D viewer frame, when exists, or NULL
|
|
*/
|
|
EDA_3D_VIEWER* Get3DViewerFrame();
|
|
|
|
/**
|
|
* Update the 3D view, if the viewer is opened by this frame
|
|
* @param aTitle = the new title of the 3D frame, or nullptr
|
|
* to do not change the frame title
|
|
* @return false if the 3D view cannot be updated (because the
|
|
* owner of the viewer is not this frame)
|
|
*/
|
|
virtual void Update3DView( bool aForceReload, const wxString* aTitle = nullptr );
|
|
|
|
/**
|
|
* Function LoadFootprint
|
|
* attempts to load \a aFootprintId from the footprint library table.
|
|
*
|
|
* @param aFootprintId is the #LIB_ID of component footprint to load.
|
|
* @return the #MODULE if found or NULL if \a aFootprintId not found in any of the
|
|
* libraries in table returned from #Prj().PcbFootprintLibs().
|
|
*/
|
|
MODULE* LoadFootprint( const LIB_ID& aFootprintId );
|
|
|
|
/**
|
|
* Function GetBoardBoundingBox
|
|
* calculates the bounding box containing all board items (or board edge segments).
|
|
* @param aBoardEdgesOnly is true if we are interested in board edge segments only.
|
|
* @return EDA_RECT - the board's bounding box
|
|
*/
|
|
EDA_RECT GetBoardBoundingBox( bool aBoardEdgesOnly = false ) const;
|
|
|
|
const BOX2I GetDocumentExtents() const override
|
|
{
|
|
return GetBoardBoundingBox( false );
|
|
}
|
|
|
|
virtual void SetPageSettings( const PAGE_INFO& aPageSettings ) override;
|
|
const PAGE_INFO& GetPageSettings() const override;
|
|
const wxSize GetPageSizeIU() const override;
|
|
|
|
const wxPoint& GetAuxOrigin() const override;
|
|
void SetAuxOrigin( const wxPoint& aPoint ) override;
|
|
|
|
const wxPoint& GetGridOrigin() const override;
|
|
void SetGridOrigin( const wxPoint& aPoint ) override;
|
|
|
|
const TITLE_BLOCK& GetTitleBlock() const override;
|
|
void SetTitleBlock( const TITLE_BLOCK& aTitleBlock ) override;
|
|
|
|
/**
|
|
* Function GetDesignSettings
|
|
* returns the BOARD_DESIGN_SETTINGS for the BOARD owned by this frame.
|
|
* Overloaded in FOOTPRINT_EDIT_FRAME.
|
|
*/
|
|
virtual BOARD_DESIGN_SETTINGS& GetDesignSettings() const;
|
|
virtual void SetDesignSettings( const BOARD_DESIGN_SETTINGS& aSettings );
|
|
|
|
void SetDrawBgColor( COLOR4D aColor ) override;
|
|
|
|
/**
|
|
* Function GetDisplayOptions
|
|
* returns the display options current in use
|
|
* Display options are relative to the way tracks, vias, outlines
|
|
* and other things are shown (for instance solid or sketch mode)
|
|
* Must be overloaded in frames which have display options
|
|
* (board editor and footprint editor)
|
|
*/
|
|
void* GetDisplayOptions() override { return &m_DisplayOptions; }
|
|
|
|
const ZONE_SETTINGS& GetZoneSettings() const;
|
|
void SetZoneSettings( const ZONE_SETTINGS& aSettings );
|
|
|
|
/**
|
|
* Function GetPlotSettings
|
|
* returns the PCB_PLOT_PARAMS for the BOARD owned by this frame.
|
|
* Overloaded in FOOTPRINT_EDIT_FRAME.
|
|
*/
|
|
virtual const PCB_PLOT_PARAMS& GetPlotSettings() const;
|
|
virtual void SetPlotSettings( const PCB_PLOT_PARAMS& aSettings );
|
|
|
|
/**
|
|
* Function SetBoard
|
|
* sets the m_Pcb member in such as way as to ensure deleting any previous
|
|
* BOARD.
|
|
* @param aBoard The BOARD to put into the frame.
|
|
*/
|
|
virtual void SetBoard( BOARD* aBoard );
|
|
|
|
BOARD* GetBoard() const
|
|
{
|
|
wxASSERT( m_Pcb );
|
|
return m_Pcb;
|
|
}
|
|
|
|
// General
|
|
virtual void OnCloseWindow( wxCloseEvent& Event ) = 0;
|
|
virtual void ReCreateOptToolbar() { }
|
|
virtual void ShowChangedLanguage() override;
|
|
virtual void ReCreateMenuBar() override;
|
|
virtual void SetToolID( int aId, int aCursor, const wxString& aToolMsg ) override;
|
|
virtual void UpdateStatusBar() override;
|
|
|
|
PCB_SCREEN* GetScreen() const override { return (PCB_SCREEN*) EDA_DRAW_FRAME::GetScreen(); }
|
|
|
|
void UpdateGridSelectBox();
|
|
|
|
/**
|
|
* Function BestZoom
|
|
* @return the "best" zoom to show the entire board or footprint on the screen.
|
|
*/
|
|
virtual double BestZoom() override;
|
|
|
|
/**
|
|
* Function GetZoomLevelIndicator
|
|
* returns a human readable value which can be displayed as zoom
|
|
* level indicator in dialogs.
|
|
* Virtual from the base class
|
|
*/
|
|
const wxString GetZoomLevelIndicator() const override;
|
|
|
|
/**
|
|
* Shows the 3D view frame.
|
|
* If it does not exist, it is created.
|
|
* If it exists, it is bring to the foreground
|
|
*/
|
|
EDA_3D_VIEWER* CreateAndShow3D_Frame();
|
|
|
|
/**
|
|
* Function GetCollectorsGuide
|
|
* @return GENERAL_COLLECTORS_GUIDE - that considers the global
|
|
*configuration options.
|
|
*/
|
|
GENERAL_COLLECTORS_GUIDE GetCollectorsGuide();
|
|
|
|
/**
|
|
* Function SelectLibrary
|
|
* puts up a dialog and allows the user to pick a library, for unspecified use.
|
|
*
|
|
* @param aNicknameExisting is the current choice to highlight
|
|
* @return wxString - the library or wxEmptyString on abort.
|
|
*/
|
|
wxString SelectLibrary( const wxString& aNicknameExisting );
|
|
|
|
/**
|
|
* Function GetFootprintFromBoardByReference
|
|
* @return a reference to the footprint found by its refence
|
|
* on the curent board. the reference is entered by the user from
|
|
* a dialog (by awxTextCtlr, or a list of available references)
|
|
*/
|
|
MODULE* GetFootprintFromBoardByReference();
|
|
|
|
/**
|
|
* Function OnModify
|
|
* Virtual
|
|
* Must be called after a change
|
|
* in order to set the "modify" flag of the current screen
|
|
* and update the date in frame reference
|
|
* do not forget to call this basic OnModify function to update info
|
|
* in derived OnModify functions
|
|
*/
|
|
virtual void OnModify();
|
|
|
|
// Modules (footprints)
|
|
|
|
/**
|
|
* Function CreateNewModule
|
|
* Creates a new module or footprint, at position 0,0
|
|
* The new module contains only 2 texts: a reference and a value:
|
|
* Reference = REF**
|
|
* Value = "VAL**" or Footprint name in lib
|
|
* Note: they are dummy texts, which will be replaced by the actual texts
|
|
* when the fooprint is placed on a board and a netlist is read
|
|
* @param aModuleName = name of the new footprint in library
|
|
* @return a reference to the new module
|
|
*/
|
|
MODULE* CreateNewModule( const wxString& aModuleName );
|
|
|
|
void Edit_Module( MODULE* module, wxDC* DC );
|
|
|
|
/**
|
|
* Function PlaceModule
|
|
* places \a aModule at the current cursor position and updates module coordinates
|
|
* with the new position.
|
|
*
|
|
* @param aModule A MODULE object point of the module to be placed.
|
|
* @param aRecreateRatsnest A bool true redraws the module rats nest.
|
|
*/
|
|
void PlaceModule( MODULE* aModule, bool aRecreateRatsnest = true );
|
|
|
|
void InstallPadOptionsFrame( D_PAD* pad );
|
|
|
|
void AddPad( MODULE* Module, bool draw );
|
|
|
|
/**
|
|
* Function DeletePad
|
|
* Delete the pad aPad.
|
|
* Refresh the modified screen area
|
|
* Refresh modified parameters of the parent module (bounding box, last date)
|
|
* @param aPad = the pad to delete
|
|
* @param aQuery = true to prompt for confirmation, false to delete silently
|
|
*/
|
|
void DeletePad( D_PAD* aPad, bool aQuery = true );
|
|
|
|
void PlacePad( D_PAD* Pad, wxDC* DC );
|
|
void Export_Pad_Settings( D_PAD* aPad );
|
|
void Import_Pad_Settings( D_PAD* aPad, bool aDraw );
|
|
|
|
/**
|
|
* Function SelectFootprintFromLibTree
|
|
* opens a dialog to select a footprint.
|
|
*
|
|
* @param aPreslect = if valid, the LIB_ID to select (otherwise the global history is
|
|
* used)
|
|
* @param aAllowBroswer = allow selection via the footprint viewer (false when already
|
|
* called from footprint viewer)
|
|
*/
|
|
MODULE* SelectFootprintFromLibTree( LIB_ID aPreselect = LIB_ID(), bool aAllowBroswer = true );
|
|
|
|
/**
|
|
* Adds the given module to the board.
|
|
* @param module
|
|
* @param aDC (can be NULL ) = the current Device Context, to draw the new footprint
|
|
*/
|
|
virtual void AddModuleToBoard( MODULE* module );
|
|
|
|
/**
|
|
* Function SelectFootprintFromLibBrowser
|
|
* launches the footprint viewer to select the name of a footprint to load.
|
|
*
|
|
* @return the selected footprint name or an empty string if no selection was made.
|
|
*/
|
|
wxString SelectFootprintFromLibBrowser();
|
|
|
|
// ratsnest functions
|
|
/**
|
|
* Function Compile_Ratsnest
|
|
* Create the entire board ratsnest.
|
|
* Must be called after a board change (changes for
|
|
* pads, footprints or a read netlist ).
|
|
* @param aDC = the current device context (can be NULL)
|
|
* @param aDisplayStatus : if true, display the computation results
|
|
*/
|
|
void Compile_Ratsnest( bool aDisplayStatus );
|
|
|
|
/* Functions relative to Undo/redo commands: */
|
|
|
|
/**
|
|
* Function SaveCopyInUndoList (virtual pure)
|
|
* Creates a new entry in undo list of commands.
|
|
* add a picker to handle aItemToCopy
|
|
* @param aItemToCopy = the board item modified by the command to undo
|
|
* @param aTypeCommand = command type (see enum UNDO_REDO_T)
|
|
* @param aTransformPoint = the reference point of the transformation, for
|
|
* commands like move
|
|
*/
|
|
virtual void SaveCopyInUndoList( BOARD_ITEM* aItemToCopy,
|
|
UNDO_REDO_T aTypeCommand,
|
|
const wxPoint& aTransformPoint = wxPoint( 0, 0 ) ) = 0;
|
|
|
|
/**
|
|
* Function SaveCopyInUndoList (virtual pure, overloaded).
|
|
* Creates a new entry in undo list of commands.
|
|
* add a list of pickers to handle a list of items
|
|
* @param aItemsList = the list of items modified by the command to undo
|
|
* @param aTypeCommand = command type (see enum UNDO_REDO_T)
|
|
* @param aTransformPoint = the reference point of the transformation,
|
|
* for commands like move
|
|
*/
|
|
virtual void SaveCopyInUndoList( const PICKED_ITEMS_LIST& aItemsList,
|
|
UNDO_REDO_T aTypeCommand,
|
|
const wxPoint& aTransformPoint = wxPoint( 0, 0 ) ) = 0;
|
|
|
|
|
|
/** Install the dialog box for layer selection
|
|
* @param aDefaultLayer = Preselection (NB_PCB_LAYERS for "(Deselect)" layer)
|
|
* @param aNotAllowedLayersMask = a layer mask for not allowed layers
|
|
* (= 0 to show all layers in use)
|
|
* @param aDlgPosition = position of dialog ( defualt = centered)
|
|
* @return the selected layer id
|
|
*/
|
|
PCB_LAYER_ID SelectLayer( PCB_LAYER_ID aDefaultLayer,
|
|
LSET aNotAllowedLayersMask = LSET(),
|
|
wxPoint aDlgPosition = wxDefaultPosition );
|
|
|
|
/* Display a list of two copper layers to choose a pair of copper layers
|
|
* the layer pair is used to fast switch between copper layers when placing vias
|
|
*/
|
|
void SelectCopperLayerPair();
|
|
|
|
virtual void SwitchLayer( wxDC* DC, PCB_LAYER_ID layer );
|
|
|
|
/**
|
|
* Function SetActiveLayer
|
|
* will change the currently active layer to \a aLayer.
|
|
*/
|
|
virtual void SetActiveLayer( PCB_LAYER_ID aLayer )
|
|
{
|
|
GetScreen()->m_Active_Layer = aLayer;
|
|
}
|
|
|
|
/**
|
|
* Function GetActiveLayer
|
|
* returns the active layer
|
|
*/
|
|
virtual PCB_LAYER_ID GetActiveLayer() const
|
|
{
|
|
return GetScreen()->m_Active_Layer;
|
|
}
|
|
|
|
void LoadSettings( wxConfigBase* aCfg ) override;
|
|
void SaveSettings( wxConfigBase* aCfg ) override;
|
|
|
|
void CommonSettingsChanged() override;
|
|
|
|
void OnTogglePadDrawMode( wxCommandEvent& aEvent );
|
|
void OnToggleGraphicDrawMode( wxCommandEvent& aEvent );
|
|
void OnToggleEdgeDrawMode( wxCommandEvent& aEvent );
|
|
void OnToggleTextDrawMode( wxCommandEvent& aEvent );
|
|
|
|
// User interface update event handlers.
|
|
void OnUpdateSelectZoom( wxUpdateUIEvent& aEvent );
|
|
|
|
virtual void OnUpdateLayerAlpha( wxUpdateUIEvent& aEvent ) {}
|
|
|
|
/**
|
|
* Function SetFastGrid1()
|
|
*
|
|
* Switches grid settings to the 1st "fast" setting predefined by user.
|
|
*/
|
|
void SetFastGrid1();
|
|
|
|
/**
|
|
* Function SetFastGrid2()
|
|
*
|
|
* Switches grid settings to the 1st "fast" setting predefined by user.
|
|
*/
|
|
void SetFastGrid2();
|
|
|
|
///> @copydoc EDA_DRAW_FRAME::UseGalCanvas
|
|
virtual void ActivateGalCanvas() override;
|
|
|
|
PCB_GENERAL_SETTINGS& Settings()
|
|
{
|
|
return m_configSettings;
|
|
}
|
|
|
|
///> Key in KifaceSettings to store the canvas type.
|
|
static const wxChar AUTO_ZOOM_KEY[];
|
|
static const wxChar ZOOM_KEY[];
|
|
|
|
DECLARE_EVENT_TABLE()
|
|
};
|
|
|
|
#endif // PCB_BASE_FRAME_H
|