summaryrefslogtreecommitdiff
path: root/pcbnew/tool_pcb.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'pcbnew/tool_pcb.cpp')
-rw-r--r--pcbnew/tool_pcb.cpp814
1 files changed, 814 insertions, 0 deletions
diff --git a/pcbnew/tool_pcb.cpp b/pcbnew/tool_pcb.cpp
new file mode 100644
index 0000000..ee27942
--- /dev/null
+++ b/pcbnew/tool_pcb.cpp
@@ -0,0 +1,814 @@
+/*
+ * This program source code file is part of KiCad, a free EDA CAD application.
+ *
+ * Copyright (C) 2012 Jean-Pierre Charras, jean-pierre.charras@ujf-grenoble.fr
+ * Copyright (C) 2012 SoftPLC Corporation, Dick Hollenbeck <dick@softplc.com>
+ * Copyright (C) 2012=2015 Wayne Stambaugh <stambaughw@verizon.net>
+ * Copyright (C) 1992-2015 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 tool_pcb.cpp
+ * @brief PCB editor tool bars
+ */
+
+#include <fctsys.h>
+#include <kiface_i.h>
+#include <help_common_strings.h>
+#include <dialog_helpers.h>
+#include <class_layer_box_selector.h>
+#include <colors_selection.h>
+#include <wxPcbStruct.h>
+#include <class_drawpanel.h>
+#include <confirm.h>
+
+#include <class_board.h>
+
+#include <pcbnew.h>
+#include <pcbnew_id.h>
+#include <hotkeys.h>
+#include <class_pcb_layer_box_selector.h>
+
+#include <wx/wupdlock.h>
+
+extern bool IsWxPythonLoaded();
+
+#define SEL_LAYER_HELP _( \
+ "Show active layer selections\nand select layer pair for route and place via" )
+
+
+/* Data to build the layer pair indicator button */
+static wxBitmap* LayerPairBitmap = NULL;
+
+#define BM_LAYERICON_SIZE 24
+static const char s_BitmapLayerIcon[BM_LAYERICON_SIZE][BM_LAYERICON_SIZE] =
+{
+ // 0 = draw pixel with active layer color
+ // 1 = draw pixel with top layer color (top/bottom layer used inautoroute and place via)
+ // 2 = draw pixel with bottom layer color
+ // 3 = draw pixel with via color
+ { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0 },
+ { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0 },
+ { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0 },
+ { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0 },
+ { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0 },
+ { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 3, 3, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0 },
+ { 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 3, 3, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0 },
+ { 0, 0, 0, 0, 0, 0, 0, 0, 3, 3, 3, 0, 1, 1, 1, 1, 3, 0, 0, 0, 0, 0, 0, 0 },
+ { 2, 2, 2, 2, 2, 2, 2, 2, 3, 3, 0, 1, 1, 1, 1, 3, 3, 2, 2, 2, 2, 2, 2, 2 },
+ { 2, 2, 2, 2, 2, 2, 2, 2, 3, 3, 1, 1, 1, 1, 0, 3, 3, 2, 2, 2, 2, 2, 2, 2 },
+ { 2, 2, 2, 2, 2, 2, 2, 2, 3, 3, 1, 1, 1, 1, 0, 3, 3, 2, 2, 2, 2, 2, 2, 2 },
+ { 0, 0, 0, 0, 0, 0, 0, 0, 3, 3, 1, 1, 1, 0, 3, 3, 0, 0, 0, 0, 0, 0, 0, 0 },
+ { 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 3, 3, 3, 3, 3, 0, 0, 0, 0, 0, 0, 0, 0, 0 },
+ { 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 3, 3, 3, 3, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 },
+ { 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 },
+ { 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 },
+ { 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 },
+ { 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 },
+ { 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 },
+ { 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 },
+ { 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 },
+ { 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }
+};
+
+
+void PCB_EDIT_FRAME::PrepareLayerIndicator()
+{
+ int ii, jj;
+ EDA_COLOR_T active_layer_color, Route_Layer_TOP_color,
+ Route_Layer_BOTTOM_color, via_color;
+ bool change = false;
+ bool first_call = LayerPairBitmap == NULL;
+
+ static int previous_active_layer_color, previous_Route_Layer_TOP_color,
+ previous_Route_Layer_BOTTOM_color, previous_via_color;
+
+ /* get colors, and redraw bitmap button only on changes */
+ active_layer_color = GetBoard()->GetLayerColor(GetActiveLayer());
+
+ if( previous_active_layer_color != active_layer_color )
+ {
+ previous_active_layer_color = active_layer_color;
+ change = true;
+ }
+
+ Route_Layer_TOP_color =
+ g_ColorsSettings.GetLayerColor( GetScreen()->m_Route_Layer_TOP );
+
+ if( previous_Route_Layer_TOP_color != Route_Layer_TOP_color )
+ {
+ previous_Route_Layer_TOP_color = Route_Layer_TOP_color;
+ change = true;
+ }
+
+ Route_Layer_BOTTOM_color =
+ g_ColorsSettings.GetLayerColor( GetScreen()->m_Route_Layer_BOTTOM );
+
+ if( previous_Route_Layer_BOTTOM_color != Route_Layer_BOTTOM_color )
+ {
+ previous_Route_Layer_BOTTOM_color = Route_Layer_BOTTOM_color;
+ change = true;
+ }
+
+ int via_type = GetDesignSettings().m_CurrentViaType;
+ via_color = GetBoard()->GetVisibleElementColor(VIAS_VISIBLE+via_type);
+
+ if( previous_via_color != via_color )
+ {
+ previous_via_color = via_color;
+ change = true;
+ }
+
+ if( !change && (LayerPairBitmap != NULL) )
+ return;
+
+ /* Create the bitmap and its Memory DC, if not already made */
+ if( LayerPairBitmap == NULL )
+ {
+ LayerPairBitmap = new wxBitmap( 24, 24 );
+ }
+
+ /* Draw the icon, with colors according to the active layer and layer
+ * pairs for via command (change layer)
+ */
+ wxMemoryDC iconDC;
+ iconDC.SelectObject( *LayerPairBitmap );
+ wxPen pen;
+ int buttonColor = -1;
+
+ for( ii = 0; ii < BM_LAYERICON_SIZE; ii++ )
+ {
+ for( jj = 0; jj < BM_LAYERICON_SIZE; jj++ )
+ {
+ if( s_BitmapLayerIcon[ii][jj] != buttonColor )
+ {
+ switch( s_BitmapLayerIcon[ii][jj] )
+ {
+ default:
+ case 0:
+ pen.SetColour( MakeColour( active_layer_color ) );
+ break;
+
+ case 1:
+ pen.SetColour( MakeColour( Route_Layer_TOP_color) );
+ break;
+
+ case 2:
+ pen.SetColour( MakeColour( Route_Layer_BOTTOM_color ) );
+ break;
+
+ case 3:
+ pen.SetColour( MakeColour( via_color ) );
+ break;
+ }
+
+ buttonColor = s_BitmapLayerIcon[ii][jj];
+ iconDC.SetPen( pen );
+ }
+
+ iconDC.DrawPoint( jj, ii );
+ }
+ }
+
+ /* Deselect the Tool Bitmap from DC,
+ * in order to delete the MemoryDC safely without deleting the bitmap */
+ iconDC.SelectObject( wxNullBitmap );
+
+ if( m_mainToolBar && ! first_call )
+ {
+ m_mainToolBar->SetToolBitmap( ID_AUX_TOOLBAR_PCB_SELECT_LAYER_PAIR, *LayerPairBitmap );
+ m_mainToolBar->Refresh();
+ }
+}
+
+
+void PCB_EDIT_FRAME::ReCreateHToolbar()
+{
+ wxString msg;
+
+ if( m_mainToolBar )
+ return;
+
+ wxWindowUpdateLocker dummy( this );
+
+ m_mainToolBar = new wxAuiToolBar( this, ID_H_TOOLBAR, wxDefaultPosition, wxDefaultSize,
+ wxAUI_TB_DEFAULT_STYLE | wxAUI_TB_HORZ_LAYOUT );
+
+ // Set up toolbar
+ if( Kiface().IsSingle() )
+ {
+ m_mainToolBar->AddTool( ID_NEW_BOARD, wxEmptyString, KiBitmap( new_pcb_xpm ),
+ _( "New board" ) );
+ m_mainToolBar->AddTool( ID_LOAD_FILE, wxEmptyString, KiBitmap( open_brd_file_xpm ),
+ _( "Open existing board" ) );
+ }
+
+ m_mainToolBar->AddTool( ID_SAVE_BOARD, wxEmptyString, KiBitmap( save_xpm ),
+ _( "Save board" ) );
+
+ m_mainToolBar->AddSeparator();
+ m_mainToolBar->AddTool( ID_SHEET_SET, wxEmptyString, KiBitmap( sheetset_xpm ),
+ _( "Page settings for paper size and texts" ) );
+
+ m_mainToolBar->AddSeparator();
+ m_mainToolBar->AddTool( ID_OPEN_MODULE_EDITOR, wxEmptyString,
+ KiBitmap( module_editor_xpm ),
+ _( "Open footprint editor" ) );
+
+ m_mainToolBar->AddTool( ID_OPEN_MODULE_VIEWER, wxEmptyString,
+ KiBitmap( modview_icon_xpm ),
+ _( "Open footprint viewer" ) );
+
+ m_mainToolBar->AddSeparator();
+ msg = AddHotkeyName( HELP_UNDO, g_Board_Editor_Hokeys_Descr, HK_UNDO, IS_COMMENT );
+ m_mainToolBar->AddTool( wxID_UNDO, wxEmptyString, KiBitmap( undo_xpm ), msg );
+ msg = AddHotkeyName( HELP_REDO, g_Board_Editor_Hokeys_Descr, HK_REDO, IS_COMMENT );
+ m_mainToolBar->AddTool( wxID_REDO, wxEmptyString, KiBitmap( redo_xpm ), msg );
+
+ m_mainToolBar->AddSeparator();
+ m_mainToolBar->AddTool( wxID_PRINT, wxEmptyString, KiBitmap( print_button_xpm ),
+ _( "Print board" ) );
+ m_mainToolBar->AddTool( ID_GEN_PLOT, wxEmptyString, KiBitmap( plot_xpm ),
+ _( "Plot (HPGL, PostScript, or GERBER format)" ) );
+
+ m_mainToolBar->AddSeparator();
+ msg = AddHotkeyName( HELP_ZOOM_IN, g_Board_Editor_Hokeys_Descr, HK_ZOOM_IN, IS_COMMENT );
+ m_mainToolBar->AddTool( ID_ZOOM_IN, wxEmptyString, KiBitmap( zoom_in_xpm ), msg );
+
+ msg = AddHotkeyName( HELP_ZOOM_OUT, g_Board_Editor_Hokeys_Descr, HK_ZOOM_OUT, IS_COMMENT );
+ m_mainToolBar->AddTool( ID_ZOOM_OUT, wxEmptyString, KiBitmap( zoom_out_xpm ), msg );
+
+ msg = AddHotkeyName( HELP_ZOOM_REDRAW, g_Board_Editor_Hokeys_Descr, HK_ZOOM_REDRAW,
+ IS_COMMENT );
+ m_mainToolBar->AddTool( ID_ZOOM_REDRAW, wxEmptyString, KiBitmap( zoom_redraw_xpm ), msg );
+
+ msg = AddHotkeyName( HELP_ZOOM_FIT, g_Board_Editor_Hokeys_Descr, HK_ZOOM_AUTO, IS_COMMENT );
+ m_mainToolBar->AddTool( ID_ZOOM_PAGE, wxEmptyString, KiBitmap( zoom_fit_in_page_xpm ), msg );
+
+ m_mainToolBar->AddSeparator();
+ msg = AddHotkeyName( HELP_FIND, g_Board_Editor_Hokeys_Descr, HK_FIND_ITEM, IS_COMMENT );
+ m_mainToolBar->AddTool( ID_FIND_ITEMS, wxEmptyString, KiBitmap( find_xpm ), msg );
+
+ m_mainToolBar->AddSeparator();
+ m_mainToolBar->AddTool( ID_GET_NETLIST, wxEmptyString, KiBitmap( netlist_xpm ),
+ _( "Read netlist" ) );
+ m_mainToolBar->AddTool( ID_DRC_CONTROL, wxEmptyString, KiBitmap( erc_xpm ),
+ _( "Perform design rules check" ) );
+
+ m_mainToolBar->AddSeparator();
+
+ if( m_SelLayerBox == NULL )
+ {
+ m_SelLayerBox = new PCB_LAYER_BOX_SELECTOR( m_mainToolBar, ID_TOOLBARH_PCB_SELECT_LAYER );
+ m_SelLayerBox->SetBoardFrame( this );
+ }
+
+ ReCreateLayerBox( false );
+ m_mainToolBar->AddControl( m_SelLayerBox );
+
+ PrepareLayerIndicator(); // Initialize the bitmap with current
+ // active layer colors for the next tool
+ m_mainToolBar->AddTool( ID_AUX_TOOLBAR_PCB_SELECT_LAYER_PAIR, wxEmptyString,
+ *LayerPairBitmap, SEL_LAYER_HELP );
+
+ m_mainToolBar->AddSeparator();
+ m_mainToolBar->AddTool( ID_TOOLBARH_PCB_MODE_MODULE, wxEmptyString, KiBitmap( mode_module_xpm ),
+ _( "Mode footprint: manual and automatic movement and placement" ),
+ wxITEM_CHECK );
+ m_mainToolBar->AddTool( ID_TOOLBARH_PCB_MODE_TRACKS, wxEmptyString, KiBitmap( mode_track_xpm ),
+ _( "Mode track: autorouting" ), wxITEM_CHECK );
+
+ // Fast call to FreeROUTE Web Bases router
+ m_mainToolBar->AddSeparator();
+ m_mainToolBar->AddTool( ID_TOOLBARH_PCB_FREEROUTE_ACCESS, wxEmptyString,
+ KiBitmap( web_support_xpm ),
+ _( "Fast access to the FreeROUTE external advanced router" ) );
+
+ // Access to the scripting console
+#if defined(KICAD_SCRIPTING_WXPYTHON)
+ if( IsWxPythonLoaded() )
+ {
+ m_mainToolBar->AddSeparator();
+
+ m_mainToolBar->AddTool( ID_TOOLBARH_PCB_SCRIPTING_CONSOLE, wxEmptyString,
+ KiBitmap( py_script_xpm ),
+ _( "Show/Hide the Python Scripting console" ),
+ wxITEM_CHECK );
+ }
+#endif
+
+ // after adding the buttons to the toolbar, must call Realize() to reflect the changes
+ m_mainToolBar->Realize();
+}
+
+
+void PCB_EDIT_FRAME::ReCreateOptToolbar()
+{
+ if( m_optionsToolBar )
+ return;
+
+ wxWindowUpdateLocker dummy( this );
+
+ m_optionsToolBar = new wxAuiToolBar( this, ID_OPT_TOOLBAR, wxDefaultPosition, wxDefaultSize,
+ wxAUI_TB_DEFAULT_STYLE | wxAUI_TB_VERTICAL );
+
+ m_optionsToolBar->AddTool( ID_TB_OPTIONS_DRC_OFF, wxEmptyString, KiBitmap( drc_off_xpm ),
+ _( "Enable design rule checking" ), wxITEM_CHECK );
+ m_optionsToolBar->AddTool( ID_TB_OPTIONS_SHOW_GRID, wxEmptyString, KiBitmap( grid_xpm ),
+ _( "Hide grid" ), wxITEM_CHECK );
+ m_optionsToolBar->AddTool( ID_TB_OPTIONS_SHOW_POLAR_COORD, wxEmptyString,
+ KiBitmap( polar_coord_xpm ),
+ _( "Display polar coordinates" ), wxITEM_CHECK );
+ m_optionsToolBar->AddTool( ID_TB_OPTIONS_SELECT_UNIT_INCH, wxEmptyString,
+ KiBitmap( unit_inch_xpm ),
+ _( "Units in inches" ), wxITEM_CHECK );
+ m_optionsToolBar->AddTool( ID_TB_OPTIONS_SELECT_UNIT_MM, wxEmptyString,
+ KiBitmap( unit_mm_xpm ),
+ _( "Units in millimeters" ), wxITEM_CHECK );
+ m_optionsToolBar->AddTool( ID_TB_OPTIONS_SELECT_CURSOR, wxEmptyString,
+ KiBitmap( cursor_shape_xpm ),
+ _( "Change cursor shape" ), wxITEM_CHECK );
+
+ m_optionsToolBar->AddSeparator();
+ m_optionsToolBar->AddTool( ID_TB_OPTIONS_SHOW_RATSNEST, wxEmptyString,
+ KiBitmap( general_ratsnest_xpm ),
+ _( "Show board ratsnest" ), wxITEM_CHECK );
+ m_optionsToolBar->AddTool( ID_TB_OPTIONS_SHOW_MODULE_RATSNEST, wxEmptyString,
+ KiBitmap( local_ratsnest_xpm ),
+ _( "Show footprint ratsnest when moving" ),
+ wxITEM_CHECK );
+
+ m_optionsToolBar->AddSeparator();
+ m_optionsToolBar->AddTool( ID_TB_OPTIONS_AUTO_DEL_TRACK, wxEmptyString,
+ KiBitmap( auto_delete_track_xpm ),
+ _( "Enable automatic track deletion" ),
+ wxITEM_CHECK );
+
+ m_optionsToolBar->AddSeparator();
+ m_optionsToolBar->AddTool( ID_TB_OPTIONS_SHOW_ZONES, wxEmptyString, KiBitmap( show_zone_xpm ),
+ _( "Show filled areas in zones" ), wxITEM_CHECK );
+ m_optionsToolBar->AddTool( ID_TB_OPTIONS_SHOW_ZONES_DISABLE, wxEmptyString,
+ KiBitmap( show_zone_disable_xpm ),
+ _( "Do not show filled areas in zones" ) , wxITEM_CHECK );
+ m_optionsToolBar->AddTool( ID_TB_OPTIONS_SHOW_ZONES_OUTLINES_ONLY, wxEmptyString,
+ KiBitmap( show_zone_outline_only_xpm ),
+ _( "Show outlines of filled areas only in zones" ), wxITEM_CHECK );
+
+ m_optionsToolBar->AddSeparator();
+ m_optionsToolBar->AddTool( ID_TB_OPTIONS_SHOW_PADS_SKETCH, wxEmptyString,
+ KiBitmap( pad_sketch_xpm ),
+ _( "Show pads in outline mode" ), wxITEM_CHECK );
+
+ m_optionsToolBar->AddTool( ID_TB_OPTIONS_SHOW_VIAS_SKETCH, wxEmptyString,
+ KiBitmap( via_sketch_xpm ),
+ _( "Show vias in outline mode" ), wxITEM_CHECK );
+
+ m_optionsToolBar->AddTool( ID_TB_OPTIONS_SHOW_TRACKS_SKETCH, wxEmptyString,
+ KiBitmap( showtrack_xpm ),
+ _( "Show tracks in outline mode" ),
+ wxITEM_CHECK );
+
+ m_optionsToolBar->AddTool( ID_TB_OPTIONS_SHOW_HIGH_CONTRAST_MODE, wxEmptyString,
+ KiBitmap( contrast_mode_xpm ),
+ _( "Enable high contrast display mode" ),
+ wxITEM_CHECK );
+
+ // Tools to show/hide toolbars:
+ m_optionsToolBar->AddSeparator();
+ m_optionsToolBar->AddTool( ID_TB_OPTIONS_SHOW_MANAGE_LAYERS_VERTICAL_TOOLBAR,
+ wxEmptyString,
+ KiBitmap( layers_manager_xpm ),
+ HELP_SHOW_HIDE_LAYERMANAGER,
+ wxITEM_CHECK );
+ m_optionsToolBar->AddTool( ID_TB_OPTIONS_SHOW_EXTRA_VERTICAL_TOOLBAR_MICROWAVE,
+ wxEmptyString,
+ KiBitmap( mw_toolbar_xpm ),
+ HELP_SHOW_HIDE_MICROWAVE_TOOLS,
+ wxITEM_CHECK );
+
+
+ m_optionsToolBar->AddSeparator();
+ m_optionsToolBar->Realize();
+}
+
+
+void PCB_EDIT_FRAME::ReCreateVToolbar()
+{
+ if( m_drawToolBar )
+ return;
+
+ wxWindowUpdateLocker dummy( this );
+
+ m_drawToolBar = new wxAuiToolBar( this, ID_V_TOOLBAR, wxDefaultPosition, wxDefaultSize,
+ wxAUI_TB_DEFAULT_STYLE | wxAUI_TB_VERTICAL );
+
+ // Set up toolbar
+ m_drawToolBar->AddTool( ID_NO_TOOL_SELECTED, wxEmptyString, KiBitmap( cursor_xpm ),
+ wxEmptyString, wxITEM_CHECK );
+ m_drawToolBar->AddSeparator();
+
+ m_drawToolBar->AddTool( ID_PCB_HIGHLIGHT_BUTT, wxEmptyString, KiBitmap( net_highlight_xpm ),
+ _( "Highlight net" ), wxITEM_CHECK );
+
+ m_drawToolBar->AddTool( ID_PCB_SHOW_1_RATSNEST_BUTT, wxEmptyString,
+ KiBitmap( tool_ratsnest_xpm ),
+ _( "Display local ratsnest" ), wxITEM_CHECK );
+
+ m_drawToolBar->AddSeparator();
+ m_drawToolBar->AddTool( ID_PCB_MODULE_BUTT, wxEmptyString, KiBitmap( module_xpm ),
+ _( "Add footprints" ), wxITEM_CHECK );
+
+ m_drawToolBar->AddTool( ID_TRACK_BUTT, wxEmptyString, KiBitmap( add_tracks_xpm ),
+ _( "Add tracks and vias" ), wxITEM_CHECK );
+
+ m_drawToolBar->AddTool( ID_PCB_ZONES_BUTT, wxEmptyString, KiBitmap( add_zone_xpm ),
+ _( "Add filled zones" ), wxITEM_CHECK );
+
+ m_drawToolBar->AddTool( ID_PCB_KEEPOUT_AREA_BUTT, wxEmptyString,
+ KiBitmap( add_keepout_area_xpm ),
+ _( "Add keepout areas" ), wxITEM_CHECK );
+
+ m_drawToolBar->AddSeparator();
+ m_drawToolBar->AddTool( ID_PCB_ADD_LINE_BUTT, wxEmptyString, KiBitmap( add_dashed_line_xpm ),
+ _( "Add graphic line or polygon" ), wxITEM_CHECK );
+
+ m_drawToolBar->AddTool( ID_PCB_CIRCLE_BUTT, wxEmptyString, KiBitmap( add_circle_xpm ),
+ _( "Add graphic circle" ), wxITEM_CHECK );
+
+ m_drawToolBar->AddTool( ID_PCB_ARC_BUTT, wxEmptyString, KiBitmap( add_arc_xpm ),
+ _( "Add graphic arc" ), wxITEM_CHECK );
+
+ m_drawToolBar->AddTool( ID_PCB_ADD_TEXT_BUTT, wxEmptyString, KiBitmap( add_text_xpm ),
+ _( "Add text on copper layers or graphic text" ), wxITEM_CHECK );
+
+ m_drawToolBar->AddSeparator();
+ m_drawToolBar->AddTool( ID_PCB_DIMENSION_BUTT, wxEmptyString, KiBitmap( add_dimension_xpm ),
+ _( "Add dimension" ), wxITEM_CHECK );
+
+ m_drawToolBar->AddTool( ID_PCB_MIRE_BUTT, wxEmptyString, KiBitmap( add_mires_xpm ),
+ _( "Add layer alignment target" ), wxITEM_CHECK );
+
+ m_drawToolBar->AddSeparator();
+ m_drawToolBar->AddTool( ID_PCB_DELETE_ITEM_BUTT, wxEmptyString, KiBitmap( delete_xpm ),
+ _( "Delete items" ), wxITEM_CHECK );
+
+ m_drawToolBar->AddSeparator();
+ m_drawToolBar->AddTool( ID_PCB_PLACE_OFFSET_COORD_BUTT, wxEmptyString,
+ KiBitmap( pcb_offset_xpm ),
+ _( "Place the origin point for drill and place files" ),
+ wxITEM_CHECK );
+
+ m_drawToolBar->AddTool( ID_PCB_PLACE_GRID_COORD_BUTT, wxEmptyString,
+ KiBitmap( grid_select_axis_xpm ),
+ _( "Set the origin point for the grid" ),
+ wxITEM_CHECK );
+
+ m_drawToolBar->Realize();
+}
+
+
+/* Create the auxiliary vertical right toolbar, showing tools for microwave applications
+ */
+void PCB_EDIT_FRAME::ReCreateMicrowaveVToolbar()
+{
+ if( m_microWaveToolBar )
+ return;
+
+ wxWindowUpdateLocker dummy(this);
+
+ m_microWaveToolBar = new wxAuiToolBar( this, ID_MICROWAVE_V_TOOLBAR, wxDefaultPosition,
+ wxDefaultSize,
+ wxAUI_TB_DEFAULT_STYLE | wxAUI_TB_VERTICAL );
+
+ // Set up toolbar
+ m_microWaveToolBar->AddTool( ID_PCB_MUWAVE_TOOL_SELF_CMD, wxEmptyString,
+ KiBitmap( mw_add_line_xpm ),
+ _( "Create line of specified length for microwave applications" ),
+ wxITEM_CHECK );
+
+ m_microWaveToolBar->AddTool( ID_PCB_MUWAVE_TOOL_GAP_CMD, wxEmptyString,
+ KiBitmap( mw_add_gap_xpm ),
+ _( "Create gap of specified length for microwave applications" ),
+ wxITEM_CHECK );
+
+ m_microWaveToolBar->AddSeparator();
+
+ m_microWaveToolBar->AddTool( ID_PCB_MUWAVE_TOOL_STUB_CMD, wxEmptyString,
+ KiBitmap( mw_add_stub_xpm ),
+ _( "Create stub of specified length for microwave applications" ),
+ wxITEM_CHECK );
+
+ m_microWaveToolBar->AddTool( ID_PCB_MUWAVE_TOOL_STUB_ARC_CMD, wxEmptyString,
+ KiBitmap( mw_add_stub_arc_xpm ),
+ _( "Create stub (arc) of specified length for microwave applications" ),
+ wxITEM_CHECK );
+
+ m_microWaveToolBar->AddTool( ID_PCB_MUWAVE_TOOL_FUNCTION_SHAPE_CMD, wxEmptyString,
+ KiBitmap( mw_add_shape_xpm ),
+ _( "Create a polynomial shape for microwave applications" ),
+ wxITEM_CHECK );
+
+ m_microWaveToolBar->Realize();
+}
+
+
+void PCB_EDIT_FRAME::ReCreateAuxiliaryToolbar()
+{
+ wxWindowUpdateLocker dummy( this );
+
+ if( m_auxiliaryToolBar )
+ {
+ updateTraceWidthSelectBox();
+ updateViaSizeSelectBox();
+
+ // combobox sizes can have changed: apply new best sizes
+ wxAuiToolBarItem* item = m_auxiliaryToolBar->FindTool( ID_AUX_TOOLBAR_PCB_TRACK_WIDTH );
+ item->SetMinSize( m_SelTrackWidthBox->GetBestSize() );
+ item = m_auxiliaryToolBar->FindTool( ID_AUX_TOOLBAR_PCB_VIA_SIZE );
+ item->SetMinSize( m_SelViaSizeBox->GetBestSize() );
+
+ m_auxiliaryToolBar->Realize();
+ m_auimgr.Update();
+ return;
+ }
+
+ m_auxiliaryToolBar = new wxAuiToolBar( this, ID_AUX_TOOLBAR, wxDefaultPosition, wxDefaultSize,
+ wxAUI_TB_DEFAULT_STYLE | wxAUI_TB_HORZ_LAYOUT );
+
+ /* Set up toolbar items */
+
+ // Creates box to display and choose tracks widths:
+ m_SelTrackWidthBox = new wxChoice( m_auxiliaryToolBar,
+ ID_AUX_TOOLBAR_PCB_TRACK_WIDTH,
+ wxDefaultPosition, wxDefaultSize,
+ 0, NULL );
+ updateTraceWidthSelectBox();
+ m_auxiliaryToolBar->AddControl( m_SelTrackWidthBox );
+
+ // Creates box to display and choose vias diameters:
+ m_SelViaSizeBox = new wxChoice( m_auxiliaryToolBar,
+ ID_AUX_TOOLBAR_PCB_VIA_SIZE,
+ wxDefaultPosition, wxDefaultSize,
+ 0, NULL );
+ updateViaSizeSelectBox();
+ m_auxiliaryToolBar->AddControl( m_SelViaSizeBox );
+ m_auxiliaryToolBar->AddSeparator();
+
+ // Creates box to display and choose strategy to handle tracks an vias sizes:
+ m_auxiliaryToolBar->AddTool( ID_AUX_TOOLBAR_PCB_SELECT_AUTO_WIDTH,
+ wxEmptyString,
+ KiBitmap( auto_track_width_xpm ),
+ _( "Auto track width: when starting on an existing track "
+ "use its width\notherwise, use current width setting" ),
+ wxITEM_CHECK );
+
+ // Add the box to display and select the current grid size:
+ m_auxiliaryToolBar->AddSeparator();
+ m_gridSelectBox = new wxChoice( m_auxiliaryToolBar,
+ ID_ON_GRID_SELECT,
+ wxDefaultPosition, wxDefaultSize,
+ 0, NULL );
+ updateGridSelectBox();
+ m_auxiliaryToolBar->AddControl( m_gridSelectBox );
+
+ // Add the box to display and select the current Zoom
+ m_auxiliaryToolBar->AddSeparator();
+ m_zoomSelectBox = new wxChoice( m_auxiliaryToolBar,
+ ID_ON_ZOOM_SELECT,
+ wxDefaultPosition, wxDefaultSize,
+ 0, NULL );
+ updateZoomSelectBox();
+ m_auxiliaryToolBar->AddControl( m_zoomSelectBox );
+
+ // after adding the buttons to the toolbar, must call Realize()
+ m_auxiliaryToolBar->Realize();
+}
+
+
+void PCB_EDIT_FRAME::updateTraceWidthSelectBox()
+{
+ if( m_SelTrackWidthBox == NULL )
+ return;
+
+ wxString msg;
+ bool mmFirst = g_UserUnit != INCHES;
+
+ m_SelTrackWidthBox->Clear();
+
+ for( unsigned ii = 0; ii < GetDesignSettings().m_TrackWidthList.size(); ii++ )
+ {
+ int size = GetDesignSettings().m_TrackWidthList[ii];
+
+ double valueMils = To_User_Unit( INCHES, size ) * 1000;
+ double value_mm = To_User_Unit( MILLIMETRES, size );
+
+ if( mmFirst )
+ msg.Printf( _( "Track: %.3f mm (%.2f mils)" ),
+ value_mm, valueMils );
+ else
+ msg.Printf( _( "Track: %.2f mils (%.3f mm)" ),
+ valueMils, value_mm );
+
+ // Mark the netclass track width value (the first in list)
+ if( ii == 0 )
+ msg << wxT( " *" );
+
+ m_SelTrackWidthBox->Append( msg );
+ }
+
+ if( GetDesignSettings().GetTrackWidthIndex() >= GetDesignSettings().m_TrackWidthList.size() )
+ GetDesignSettings().SetTrackWidthIndex( 0 );
+
+ m_SelTrackWidthBox->SetSelection( GetDesignSettings().GetTrackWidthIndex() );
+}
+
+
+void PCB_EDIT_FRAME::updateViaSizeSelectBox()
+{
+ if( m_SelViaSizeBox == NULL )
+ return;
+
+ wxString msg;
+
+ m_SelViaSizeBox->Clear();
+ bool mmFirst = g_UserUnit != INCHES;
+
+ for( unsigned ii = 0; ii < GetDesignSettings().m_ViasDimensionsList.size(); ii++ )
+ {
+ int diam = GetDesignSettings().m_ViasDimensionsList[ii].m_Diameter;
+
+ double valueMils = To_User_Unit( INCHES, diam ) * 1000;
+ double value_mm = To_User_Unit( MILLIMETRES, diam );
+
+ if( mmFirst )
+ msg.Printf( _( "Via: %.2f mm (%.1f mils)" ),
+ value_mm, valueMils );
+ else
+ msg.Printf( _( "Via: %.1f mils (%.2f mm)" ),
+ valueMils, value_mm );
+
+ int hole = GetDesignSettings().m_ViasDimensionsList[ii].m_Drill;
+
+ if( hole )
+ {
+ msg << wxT("/ ");
+ wxString hole_str;
+ double valueMils = To_User_Unit( INCHES, hole ) * 1000;
+ double value_mm = To_User_Unit( MILLIMETRES, hole );
+
+ if( mmFirst )
+ hole_str.Printf( _( "%.2f mm (%.1f mils)" ),
+ value_mm, valueMils );
+ else
+ hole_str.Printf( _( "%.1f mils (%.2f mm)" ),
+ valueMils, value_mm );
+
+ msg += hole_str;
+ }
+
+ // Mark the netclass via size value (the first in list)
+ if( ii == 0 )
+ msg << wxT( " *" );
+
+ m_SelViaSizeBox->Append( msg );
+ }
+
+ if( GetDesignSettings().GetViaSizeIndex() >= GetDesignSettings().m_ViasDimensionsList.size() )
+ GetDesignSettings().SetViaSizeIndex( 0 );
+
+ m_SelViaSizeBox->SetSelection( GetDesignSettings().GetViaSizeIndex() );
+}
+
+
+void PCB_EDIT_FRAME::ReCreateLayerBox( bool aForceResizeToolbar )
+{
+ if( m_SelLayerBox == NULL || m_mainToolBar == NULL )
+ return;
+
+ m_SelLayerBox->SetToolTip( _( "+/- to switch" ) );
+ m_SelLayerBox->m_hotkeys = g_Board_Editor_Hokeys_Descr;
+ m_SelLayerBox->Resync();
+
+ if( aForceResizeToolbar )
+ {
+ // the layer box can have its size changed
+ // Update the aui manager, to take in account the new size
+ m_auimgr.Update();
+ }
+}
+
+
+void PCB_EDIT_FRAME::OnSelectOptionToolbar( wxCommandEvent& event )
+{
+ int id = event.GetId();
+ bool state = event.IsChecked();
+ DISPLAY_OPTIONS* displ_opts = (DISPLAY_OPTIONS*)GetDisplayOptions();
+
+ switch( id )
+ {
+ case ID_TB_OPTIONS_DRC_OFF:
+ g_Drc_On = !state;
+
+ if( GetToolId() == ID_TRACK_BUTT )
+ {
+ if( g_Drc_On )
+ m_canvas->SetCursor( wxCURSOR_PENCIL );
+ else
+ m_canvas->SetCursor( wxCURSOR_QUESTION_ARROW );
+ }
+ break;
+
+ case ID_TB_OPTIONS_SHOW_RATSNEST:
+ SetElementVisibility( RATSNEST_VISIBLE, state );
+ OnModify();
+
+ if( state && (GetBoard()->m_Status_Pcb & LISTE_RATSNEST_ITEM_OK) == 0 )
+ Compile_Ratsnest( NULL, true );
+
+ m_canvas->Refresh();
+ break;
+
+ case ID_TB_OPTIONS_SHOW_MODULE_RATSNEST:
+ displ_opts->m_Show_Module_Ratsnest = state; // TODO: see if we can use the visibility list
+ break;
+
+ case ID_TB_OPTIONS_AUTO_DEL_TRACK:
+ g_AutoDeleteOldTrack = state;
+ break;
+
+ case ID_TB_OPTIONS_SHOW_ZONES:
+ displ_opts->m_DisplayZonesMode = 0;
+ m_canvas->Refresh();
+ break;
+
+ case ID_TB_OPTIONS_SHOW_ZONES_DISABLE:
+ displ_opts->m_DisplayZonesMode = 1;
+ m_canvas->Refresh();
+ break;
+
+ case ID_TB_OPTIONS_SHOW_ZONES_OUTLINES_ONLY:
+ displ_opts->m_DisplayZonesMode = 2;
+ m_canvas->Refresh();
+ break;
+
+ case ID_TB_OPTIONS_SHOW_VIAS_SKETCH:
+ displ_opts->m_DisplayViaFill = !state;
+ m_canvas->Refresh();
+ break;
+
+ case ID_TB_OPTIONS_SHOW_TRACKS_SKETCH:
+ displ_opts->m_DisplayPcbTrackFill = !state;
+ m_canvas->Refresh();
+ break;
+
+ case ID_TB_OPTIONS_SHOW_HIGH_CONTRAST_MODE:
+ {
+ displ_opts->m_ContrastModeDisplay = state;
+ m_canvas->Refresh();
+ break;
+ }
+
+ case ID_TB_OPTIONS_SHOW_EXTRA_VERTICAL_TOOLBAR_MICROWAVE:
+ m_show_microwave_tools = state;
+ m_auimgr.GetPane( wxT( "m_microWaveToolBar" ) ).Show( m_show_microwave_tools );
+ m_auimgr.Update();
+
+ GetMenuBar()->SetLabel( ID_MENU_PCB_SHOW_HIDE_MUWAVE_TOOLBAR,
+ m_show_microwave_tools ?
+ _( "Hide Microwave Toolbar" ): _( "Show Microwave Toolbar" ));
+ break;
+
+ case ID_TB_OPTIONS_SHOW_MANAGE_LAYERS_VERTICAL_TOOLBAR:
+ // show auxiliary Vertical layers and visibility manager toolbar
+ m_show_layer_manager_tools = state;
+ m_auimgr.GetPane( wxT( "m_LayersManagerToolBar" ) ).Show( m_show_layer_manager_tools );
+ m_auimgr.Update();
+
+ GetMenuBar()->SetLabel( ID_MENU_PCB_SHOW_HIDE_LAYERS_MANAGER_DIALOG,
+ m_show_layer_manager_tools ?
+ _( "Hide &Layers Manager" ) : _( "Show &Layers Manager" ) );
+ break;
+
+ default:
+ DisplayError( this,
+ wxT( "PCB_EDIT_FRAME::OnSelectOptionToolbar error \n (event not handled!)" ) );
+ break;
+ }
+}