summaryrefslogtreecommitdiff
path: root/pcbnew/dialogs/dialog_copper_zones.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'pcbnew/dialogs/dialog_copper_zones.cpp')
-rw-r--r--pcbnew/dialogs/dialog_copper_zones.cpp718
1 files changed, 718 insertions, 0 deletions
diff --git a/pcbnew/dialogs/dialog_copper_zones.cpp b/pcbnew/dialogs/dialog_copper_zones.cpp
new file mode 100644
index 0000000..46c7728
--- /dev/null
+++ b/pcbnew/dialogs/dialog_copper_zones.cpp
@@ -0,0 +1,718 @@
+/**
+ * @file dialog_copper_zones.cpp
+ */
+
+/*
+ * 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) 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
+ */
+
+#include <wx/wx.h>
+#include <fctsys.h>
+#include <kiface_i.h>
+#include <confirm.h>
+#include <PolyLine.h>
+#include <pcbnew.h>
+#include <wxPcbStruct.h>
+#include <zones.h>
+#include <base_units.h>
+
+#include <class_zone.h>
+#include <class_board.h>
+#include <dialog_copper_zones_base.h>
+
+#include <wx/imaglist.h> // needed for wx/listctrl.h, in wxGTK 2.8.12
+#include <wx/listctrl.h>
+#include <layers_id_colors_and_visibility.h>
+
+
+/**
+ * Class DIALOG_COPPER_ZONE
+ * is the derived class from dialog_copper_zone_frame created by wxFormBuilder
+ */
+class DIALOG_COPPER_ZONE : public DIALOG_COPPER_ZONE_BASE
+{
+public:
+ DIALOG_COPPER_ZONE( PCB_BASE_FRAME* aParent, ZONE_SETTINGS* aSettings );
+
+private:
+ PCB_BASE_FRAME* m_Parent;
+ wxConfigBase* m_Config; ///< Current config
+
+ ZONE_EDIT_T m_OnExitCode; ///< exit code: ZONE_ABORT if no change,
+ ///< ZONE_OK if new values accepted
+ ///< ZONE_EXPORT_VALUES if values are exported to others zones
+
+ ZONE_SETTINGS m_settings;
+ ZONE_SETTINGS* m_ptr;
+
+ bool m_NetSortingByPadCount; ///< false = alphabetic sort.
+ ///< true = pad count sort.
+
+ long m_NetFiltering;
+
+ std::vector<LAYER_ID> m_LayerId; ///< Handle the real layer number from layer
+ ///< name position in m_LayerSelectionCtrl
+
+ static wxString m_netNameShowFilter; ///< the filter to show nets (default * "*").
+ ///< static to keep this pattern for an entire Pcbnew session
+
+ /**
+ * Function initDialog
+ * fills in the dialog controls using the current settings.
+ */
+ void initDialog();
+
+ void OnButtonOkClick( wxCommandEvent& event );
+ void OnButtonCancelClick( wxCommandEvent& event );
+ void OnClose( wxCloseEvent& event );
+ void OnCornerSmoothingModeChoice( wxCommandEvent& event );
+
+ /**
+ * Function AcceptOptions
+ * @param aPromptForErrors is true to prompt user on incorrect params.
+ * @param aUseExportableSetupOnly is true to use exportable parameters only (used to export this setup to other zones).
+ * @return bool - false if incorrect options, true if ok.
+ */
+ bool AcceptOptions( bool aPromptForErrors, bool aUseExportableSetupOnly = false );
+
+ void OnNetSortingOptionSelected( wxCommandEvent& event );
+ void ExportSetupToOtherCopperZones( wxCommandEvent& event );
+ void OnPadsInZoneClick( wxCommandEvent& event );
+ void OnRunFiltersButtonClick( wxCommandEvent& event );
+
+ void buildAvailableListOfNets();
+
+ /**
+ * Function initListNetsParams
+ * initializes m_NetSortingByPadCount and m_NetFiltering values
+ * according to m_NetDisplayOption selection.
+ */
+ void initListNetsParams();
+
+ /**
+ * Function makeLayerBitmap
+ * creates the colored rectangle bitmaps used in the layer selection widget.
+ * @param aColor is the color to fill the rectangle with.
+ */
+ wxBitmap makeLayerBitmap( EDA_COLOR_T aColor );
+};
+
+
+#define LAYER_BITMAP_SIZE_X 20
+#define LAYER_BITMAP_SIZE_Y 10
+
+// Initialize static member variables
+wxString DIALOG_COPPER_ZONE::m_netNameShowFilter( wxT( "*" ) );
+
+
+ZONE_EDIT_T InvokeCopperZonesEditor( PCB_BASE_FRAME* aCaller, ZONE_SETTINGS* aSettings )
+{
+ DIALOG_COPPER_ZONE dlg( aCaller, aSettings );
+
+ ZONE_EDIT_T result = ZONE_EDIT_T( dlg.ShowModal() );
+ return result;
+}
+
+
+DIALOG_COPPER_ZONE::DIALOG_COPPER_ZONE( PCB_BASE_FRAME* aParent, ZONE_SETTINGS* aSettings ) :
+ DIALOG_COPPER_ZONE_BASE( aParent )
+{
+ m_Parent = aParent;
+ m_Config = Kiface().KifaceSettings();
+
+ m_ptr = aSettings;
+ m_settings = *aSettings;
+
+ m_NetSortingByPadCount = true; // false = alphabetic sort, true = pad count sort
+ m_OnExitCode = ZONE_ABORT;
+
+ SetReturnCode( ZONE_ABORT ); // Will be changed on buttons click
+
+ // Fix static text widget minimum width to a suitable value so that
+ // resizing the dialog is not necessary when changing the corner smoothing type.
+ // Depends on the default text in the widget.
+ m_cornerSmoothingTitle->SetMinSize( m_cornerSmoothingTitle->GetSize() );
+
+ initDialog();
+
+ m_sdbSizerOK->SetDefault();
+ GetSizer()->SetSizeHints( this );
+ Center();
+}
+
+
+void DIALOG_COPPER_ZONE::initDialog()
+{
+ BOARD* board = m_Parent->GetBoard();
+
+ wxString msg;
+
+ if( m_settings.m_Zone_45_Only )
+ m_OrientEdgesOpt->SetSelection( 1 );
+
+ m_FillModeCtrl->SetSelection( m_settings.m_FillMode ? 1 : 0 );
+
+ AddUnitSymbol( *m_ClearanceValueTitle, g_UserUnit );
+ msg = StringFromValue( g_UserUnit, m_settings.m_ZoneClearance );
+ m_ZoneClearanceCtrl->SetValue( msg );
+
+ AddUnitSymbol( *m_MinThicknessValueTitle, g_UserUnit );
+ msg = StringFromValue( g_UserUnit, m_settings.m_ZoneMinThickness );
+ m_ZoneMinThicknessCtrl->SetValue( msg );
+
+ switch( m_settings.GetPadConnection() )
+ {
+ case PAD_ZONE_CONN_THT_THERMAL: // Thermals only for THT pads
+ m_PadInZoneOpt->SetSelection( 2 );
+ break;
+
+ case PAD_ZONE_CONN_NONE: // Pads are not covered
+ m_PadInZoneOpt->SetSelection( 3 );
+ break;
+
+ default:
+ case PAD_ZONE_CONN_THERMAL: // Use thermal relief for pads
+ m_PadInZoneOpt->SetSelection( 1 );
+ break;
+
+ case PAD_ZONE_CONN_FULL: // pads are covered by copper
+ m_PadInZoneOpt->SetSelection( 0 );
+ break;
+ }
+
+ // Antipad and spokes are significant only for thermals
+ if( m_settings.GetPadConnection() != PAD_ZONE_CONN_THERMAL &&
+ m_settings.GetPadConnection() != PAD_ZONE_CONN_THT_THERMAL )
+ {
+ m_AntipadSizeValue->Enable( false );
+ m_CopperWidthValue->Enable( false );
+ }
+ else
+ {
+ m_AntipadSizeValue->Enable( true );
+ m_CopperWidthValue->Enable( true );
+ }
+
+ m_PriorityLevelCtrl->SetValue( m_settings.m_ZonePriority );
+
+ AddUnitSymbol( *m_AntipadSizeText, g_UserUnit );
+ AddUnitSymbol( *m_CopperBridgeWidthText, g_UserUnit );
+ PutValueInLocalUnits( *m_AntipadSizeValue, m_settings.m_ThermalReliefGap );
+ PutValueInLocalUnits( *m_CopperWidthValue, m_settings.m_ThermalReliefCopperBridge );
+
+ m_cornerSmoothingChoice->SetSelection( m_settings.GetCornerSmoothingType() );
+
+ PutValueInLocalUnits( *m_cornerSmoothingCtrl, m_settings.GetCornerRadius() );
+
+ switch( m_settings.m_Zone_HatchingStyle )
+ {
+ case CPolyLine::NO_HATCH:
+ m_OutlineAppearanceCtrl->SetSelection( 0 );
+ break;
+
+ case CPolyLine::DIAGONAL_EDGE:
+ m_OutlineAppearanceCtrl->SetSelection( 1 );
+ break;
+
+ case CPolyLine::DIAGONAL_FULL:
+ m_OutlineAppearanceCtrl->SetSelection( 2 );
+ break;
+ }
+
+ m_ArcApproximationOpt->SetSelection(
+ m_settings.m_ArcToSegmentsCount == ARC_APPROX_SEGMENTS_COUNT_HIGHT_DEF ? 1 : 0 );
+
+ // Create one column in m_LayerSelectionCtrl
+ wxListItem column0;
+ column0.SetId( 0 );
+ m_LayerSelectionCtrl->InsertColumn( 0, column0 );
+
+ wxImageList* imageList = new wxImageList( LAYER_BITMAP_SIZE_X, LAYER_BITMAP_SIZE_Y );
+ m_LayerSelectionCtrl->AssignImageList( imageList, wxIMAGE_LIST_SMALL );
+
+ int ctrlWidth = 0; // Min width for m_LayerSelectionCtrl to show the layers names
+ int imgIdx = 0;
+
+ LSET cu_set = LSET::AllCuMask( board->GetCopperLayerCount() );
+
+ for( LSEQ cu_stack = cu_set.UIOrder(); cu_stack; ++cu_stack, imgIdx++ )
+ {
+ LAYER_ID layer = *cu_stack;
+
+ m_LayerId.push_back( layer );
+
+ msg = board->GetLayerName( layer );
+
+ msg.Trim();
+
+ EDA_COLOR_T layerColor = board->GetLayerColor( layer );
+
+ imageList->Add( makeLayerBitmap( layerColor ) );
+
+ int itemIndex = m_LayerSelectionCtrl->InsertItem(
+ m_LayerSelectionCtrl->GetItemCount(), msg, imgIdx );
+
+ if( m_settings.m_CurrentZone_Layer == layer )
+ m_LayerSelectionCtrl->Select( itemIndex );
+
+ wxSize tsize( GetTextSize( msg, m_LayerSelectionCtrl ) );
+ ctrlWidth = std::max( ctrlWidth, tsize.x );
+ }
+
+ // The most easy way to ensure the right size is to use wxLIST_AUTOSIZE
+ // unfortunately this option does not work well both on
+ // wxWidgets 2.8 ( column width too small), and
+ // wxWidgets 2.9 ( column width too large)
+ ctrlWidth += LAYER_BITMAP_SIZE_X + 25; // Add bitmap width + margin between bitmap and text
+ m_LayerSelectionCtrl->SetColumnWidth( 0, ctrlWidth );
+
+ ctrlWidth += 25; // add small margin between text and window borders
+ // and room for vertical scroll bar
+ m_LayerSelectionCtrl->SetMinSize( wxSize( ctrlWidth, -1 ) );
+
+ wxString netNameDoNotShowFilter = wxT( "Net-*" );
+ if( m_Config )
+ {
+ int opt = m_Config->Read( ZONE_NET_SORT_OPTION_KEY, 1l );
+ m_NetDisplayOption->SetSelection( opt );
+ m_Config->Read( ZONE_NET_FILTER_STRING_KEY, netNameDoNotShowFilter );
+ }
+ else
+ m_NetDisplayOption->SetSelection( 1 );
+
+ m_ShowNetNameFilter->SetValue( m_netNameShowFilter );
+ initListNetsParams();
+
+ // Build list of nets:
+ m_DoNotShowNetNameFilter->SetValue( netNameDoNotShowFilter );
+ buildAvailableListOfNets();
+
+ wxCommandEvent event;
+ OnCornerSmoothingModeChoice( event );
+}
+
+
+void DIALOG_COPPER_ZONE::OnButtonCancelClick( wxCommandEvent& event )
+{
+ Close( true );
+}
+
+void DIALOG_COPPER_ZONE::OnButtonOkClick( wxCommandEvent& event )
+{
+ m_netNameShowFilter = m_ShowNetNameFilter->GetValue();
+
+ if( AcceptOptions( true ) )
+ {
+ *m_ptr = m_settings;
+ EndModal( ZONE_OK );
+ }
+}
+
+
+// called on system close button
+void DIALOG_COPPER_ZONE::OnClose( wxCloseEvent& event )
+{
+ if( m_OnExitCode != ZONE_ABORT )
+ *m_ptr = m_settings;
+
+ EndModal( m_OnExitCode );
+}
+
+
+bool DIALOG_COPPER_ZONE::AcceptOptions( bool aPromptForErrors, bool aUseExportableSetupOnly )
+{
+ switch( m_PadInZoneOpt->GetSelection() )
+ {
+ case 3:
+ // Pads are not covered
+ m_settings.SetPadConnection( PAD_ZONE_CONN_NONE );
+ break;
+
+ case 2:
+ // Use thermal relief for THT pads
+ m_settings.SetPadConnection( PAD_ZONE_CONN_THT_THERMAL );
+ break;
+
+ case 1:
+ // Use thermal relief for pads
+ m_settings.SetPadConnection( PAD_ZONE_CONN_THERMAL );
+ break;
+
+ case 0:
+ // pads are covered by copper
+ m_settings.SetPadConnection( PAD_ZONE_CONN_FULL );
+ break;
+ }
+
+ switch( m_OutlineAppearanceCtrl->GetSelection() )
+ {
+ case 0:
+ m_settings.m_Zone_HatchingStyle = CPolyLine::NO_HATCH;
+ break;
+
+ case 1:
+ m_settings.m_Zone_HatchingStyle = CPolyLine::DIAGONAL_EDGE;
+ break;
+
+ case 2:
+ m_settings.m_Zone_HatchingStyle = CPolyLine::DIAGONAL_FULL;
+ break;
+ }
+
+ m_settings.m_ArcToSegmentsCount = m_ArcApproximationOpt->GetSelection() == 1 ?
+ ARC_APPROX_SEGMENTS_COUNT_HIGHT_DEF :
+ ARC_APPROX_SEGMENTS_COUNT_LOW_DEF;
+
+ if( m_Config )
+ {
+ m_Config->Write( ZONE_NET_OUTLINES_HATCH_OPTION_KEY,
+ (long) m_settings.m_Zone_HatchingStyle );
+ wxString filter = m_DoNotShowNetNameFilter->GetValue();
+ m_Config->Write( ZONE_NET_FILTER_STRING_KEY, filter );
+ }
+
+ m_netNameShowFilter = m_ShowNetNameFilter->GetValue();
+ m_settings.m_FillMode = (m_FillModeCtrl->GetSelection() == 0) ? 0 : 1;
+
+ wxString txtvalue = m_ZoneClearanceCtrl->GetValue();
+ m_settings.m_ZoneClearance = ValueFromString( g_UserUnit, txtvalue );
+
+ // Test if this is a reasonable value for this parameter
+ // A too large value can hang Pcbnew
+ #define CLEARANCE_MAX_VALUE ZONE_CLEARANCE_MAX_VALUE_MIL*IU_PER_MILS
+
+ if( m_settings.m_ZoneClearance > CLEARANCE_MAX_VALUE )
+ {
+ wxString msg;
+ msg.Printf( _( "Clearance must be smaller than %f\" / %f mm." ),
+ ZONE_CLEARANCE_MAX_VALUE_MIL / 1000.0, ZONE_CLEARANCE_MAX_VALUE_MIL * 0.0254 );
+ DisplayError( this, msg );
+ return false;
+ }
+
+ txtvalue = m_ZoneMinThicknessCtrl->GetValue();
+ m_settings.m_ZoneMinThickness = ValueFromString( g_UserUnit, txtvalue );
+
+ if( m_settings.m_ZoneMinThickness < (ZONE_THICKNESS_MIN_VALUE_MIL*IU_PER_MILS) )
+ {
+ wxString msg;
+ msg.Printf( _( "Minimum width must be larger than %f\" / %f mm." ),
+ ZONE_THICKNESS_MIN_VALUE_MIL / 1000.0, ZONE_THICKNESS_MIN_VALUE_MIL * 0.0254 );
+ DisplayError( this, msg );
+ return false;
+ }
+
+ m_settings.SetCornerSmoothingType( m_cornerSmoothingChoice->GetSelection() );
+ txtvalue = m_cornerSmoothingCtrl->GetValue();
+ m_settings.SetCornerRadius( ValueFromString( g_UserUnit, txtvalue ) );
+
+ m_settings.m_ZonePriority = m_PriorityLevelCtrl->GetValue();
+
+ if( m_OrientEdgesOpt->GetSelection() == 0 )
+ m_settings.m_Zone_45_Only = false;
+ else
+ m_settings.m_Zone_45_Only = true;
+
+ m_settings.m_ThermalReliefGap = ValueFromTextCtrl( *m_AntipadSizeValue );
+ m_settings.m_ThermalReliefCopperBridge = ValueFromTextCtrl( *m_CopperWidthValue );
+
+ if( m_Config )
+ {
+ ConfigBaseWriteDouble( m_Config, ZONE_CLEARANCE_WIDTH_STRING_KEY,
+ (double) m_settings.m_ZoneClearance / IU_PER_MILS );
+
+ ConfigBaseWriteDouble( m_Config, ZONE_MIN_THICKNESS_WIDTH_STRING_KEY,
+ (double) m_settings.m_ZoneMinThickness / IU_PER_MILS );
+
+ ConfigBaseWriteDouble( m_Config, ZONE_THERMAL_RELIEF_GAP_STRING_KEY,
+ (double) m_settings.m_ThermalReliefGap / IU_PER_MILS );
+
+ ConfigBaseWriteDouble( m_Config, ZONE_THERMAL_RELIEF_COPPER_WIDTH_STRING_KEY,
+ (double) m_settings.m_ThermalReliefCopperBridge / IU_PER_MILS );
+ }
+
+ if( ( m_settings.GetPadConnection() == PAD_ZONE_CONN_THT_THERMAL
+ || m_settings.GetPadConnection() == PAD_ZONE_CONN_THERMAL )
+ && m_settings.m_ThermalReliefCopperBridge <= m_settings.m_ZoneMinThickness )
+ {
+ DisplayError( this,
+ _( "Thermal relief spoke must be greater than the minimum width." ) );
+ return false;
+ }
+
+ // If we use only exportable to others zones parameters, exit here:
+ if( aUseExportableSetupOnly )
+ return true;
+
+ // Get the layer selection for this zone
+ int ii = m_LayerSelectionCtrl->GetFirstSelected();
+
+ if( ii < 0 && aPromptForErrors )
+ {
+ DisplayError( this, _( "No layer selected." ) );
+ return false;
+ }
+
+ m_settings.m_CurrentZone_Layer = ToLAYER_ID( m_LayerId[ii] );
+
+ // Get the net name selection for this zone
+ ii = m_ListNetNameSelection->GetSelection();
+
+ if( ii < 0 && aPromptForErrors )
+ {
+ DisplayError( this, _( "No net selected." ) );
+ return false;
+ }
+
+ if( ii == 0 ) // the not connected option was selected: this is not a good practice: warn:
+ {
+ if( !IsOK( this, _( "You have chosen the \"not connected\" option. This will create "
+ "insulated copper islands. Are you sure ?" ) ) )
+ return false;
+ }
+
+ wxString net_name = m_ListNetNameSelection->GetString( ii );
+
+ m_settings.m_NetcodeSelection = 0;
+
+ // Search net_code for this net, if a net was selected
+ if( m_ListNetNameSelection->GetSelection() > 0 )
+ {
+ NETINFO_ITEM* net = m_Parent->GetBoard()->FindNet( net_name );
+
+ if( net )
+ m_settings.m_NetcodeSelection = net->GetNet();
+ }
+
+ return true;
+}
+
+
+void DIALOG_COPPER_ZONE::OnCornerSmoothingModeChoice( wxCommandEvent& event )
+{
+ int selection = m_cornerSmoothingChoice->GetSelection();
+
+ switch( selection )
+ {
+ case ZONE_SETTINGS::SMOOTHING_NONE:
+ m_cornerSmoothingTitle->Enable( false );
+ m_cornerSmoothingCtrl->Enable( false );
+ break;
+ case ZONE_SETTINGS::SMOOTHING_CHAMFER:
+ m_cornerSmoothingTitle->Enable( true );
+ m_cornerSmoothingCtrl->Enable( true );
+ m_cornerSmoothingTitle->SetLabel( _( "Chamfer distance" ) );
+ AddUnitSymbol( *m_cornerSmoothingTitle, g_UserUnit );
+ break;
+ case ZONE_SETTINGS::SMOOTHING_FILLET:
+ m_cornerSmoothingTitle->Enable( true );
+ m_cornerSmoothingCtrl->Enable( true );
+ m_cornerSmoothingTitle->SetLabel( _( "Fillet radius" ) );
+ AddUnitSymbol( *m_cornerSmoothingTitle, g_UserUnit );
+ break;
+ }
+}
+
+
+void DIALOG_COPPER_ZONE::OnNetSortingOptionSelected( wxCommandEvent& event )
+{
+ initListNetsParams();
+ buildAvailableListOfNets();
+
+ m_netNameShowFilter = m_ShowNetNameFilter->GetValue();
+
+ if( m_Config )
+ {
+ m_Config->Write( ZONE_NET_SORT_OPTION_KEY, (long) m_NetDisplayOption->GetSelection() );
+ wxString Filter = m_DoNotShowNetNameFilter->GetValue();
+ m_Config->Write( ZONE_NET_FILTER_STRING_KEY, Filter );
+ }
+}
+
+
+void DIALOG_COPPER_ZONE::ExportSetupToOtherCopperZones( wxCommandEvent& event )
+{
+ if( !AcceptOptions( true, true ) )
+ return;
+
+ // Export settings ( but layer and netcode ) to others copper zones
+ BOARD* pcb = m_Parent->GetBoard();
+
+ for( int ii = 0; ii < pcb->GetAreaCount(); ii++ )
+ {
+ ZONE_CONTAINER* zone = pcb->GetArea( ii );
+
+ // Cannot export settings from a copper zone
+ // to a zone keepout:
+ if( zone->GetIsKeepout() )
+ continue;
+
+ m_settings.ExportSetting( *zone, false ); // false = partial export
+ m_Parent->OnModify();
+ }
+
+ m_OnExitCode = ZONE_EXPORT_VALUES; // values are exported to others zones
+}
+
+
+void DIALOG_COPPER_ZONE::OnPadsInZoneClick( wxCommandEvent& event )
+{
+ switch( m_PadInZoneOpt->GetSelection() )
+ {
+ default:
+ m_AntipadSizeValue->Enable( false );
+ m_CopperWidthValue->Enable( false );
+ break;
+
+ case 2:
+ case 1:
+ m_AntipadSizeValue->Enable( true );
+ m_CopperWidthValue->Enable( true );
+ break;
+ }
+}
+
+
+void DIALOG_COPPER_ZONE::initListNetsParams()
+{
+ switch( m_NetDisplayOption->GetSelection() )
+ {
+ case 0:
+ m_NetSortingByPadCount = false;
+ m_NetFiltering = false;
+ break;
+
+ case 1:
+ m_NetSortingByPadCount = true;
+ m_NetFiltering = false;
+ break;
+
+ case 2:
+ m_NetSortingByPadCount = false;
+ m_NetFiltering = true;
+ break;
+
+ case 3:
+ m_NetSortingByPadCount = true;
+ m_NetFiltering = true;
+ break;
+ }
+}
+
+
+void DIALOG_COPPER_ZONE::OnRunFiltersButtonClick( wxCommandEvent& event )
+{
+ m_netNameShowFilter = m_ShowNetNameFilter->GetValue();
+
+ // Ensure filtered option for nets
+ if( m_NetDisplayOption->GetSelection() == 0 )
+ m_NetDisplayOption->SetSelection( 2 );
+ else if( m_NetDisplayOption->GetSelection() == 1 )
+ m_NetDisplayOption->SetSelection( 3 );
+
+ initListNetsParams();
+ buildAvailableListOfNets();
+}
+
+
+void DIALOG_COPPER_ZONE::buildAvailableListOfNets()
+{
+ wxArrayString listNetName;
+
+ m_Parent->GetBoard()->SortedNetnamesList( listNetName, m_NetSortingByPadCount );
+
+ if( m_NetFiltering )
+ {
+ wxString doNotShowFilter = m_DoNotShowNetNameFilter->GetValue();
+ wxString ShowFilter = m_ShowNetNameFilter->GetValue();
+
+ for( unsigned ii = 0; ii < listNetName.GetCount(); ii++ )
+ {
+ if( listNetName[ii].Matches( doNotShowFilter ) )
+ {
+ listNetName.RemoveAt( ii );
+ ii--;
+ }
+ else if( !listNetName[ii].Matches( ShowFilter ) )
+ {
+ listNetName.RemoveAt( ii );
+ ii--;
+ }
+ }
+ }
+
+ listNetName.Insert( wxT( "<no net>" ), 0 );
+
+ // Ensure currently selected net for the zone is visible, regardless of filters
+ int selectedNetListNdx = -1;
+ int net_select = m_settings.m_NetcodeSelection;
+
+ if( net_select > 0 )
+ {
+ NETINFO_ITEM* equipot = m_Parent->GetBoard()->FindNet( net_select );
+ if( equipot )
+ {
+ selectedNetListNdx = listNetName.Index( equipot->GetNetname() );
+
+ if( wxNOT_FOUND == selectedNetListNdx )
+ {
+ // the currently selected net must *always* be visible.
+ listNetName.Insert( equipot->GetNetname(), 0 );
+ selectedNetListNdx = 0;
+ }
+ }
+ }
+ else if( net_select == 0 )
+ selectedNetListNdx = 0; // SetSelection() on "<no net>"
+ else
+ {
+ // selectedNetListNdx remains -1, no net selected.
+ }
+
+ m_ListNetNameSelection->Clear();
+ m_ListNetNameSelection->InsertItems( listNetName, 0 );
+ m_ListNetNameSelection->SetSelection( 0 );
+
+ if( selectedNetListNdx >= 0 )
+ {
+ m_ListNetNameSelection->SetSelection( selectedNetListNdx );
+ m_ListNetNameSelection->EnsureVisible( selectedNetListNdx );
+ }
+}
+
+
+wxBitmap DIALOG_COPPER_ZONE::makeLayerBitmap( EDA_COLOR_T aColor )
+{
+ wxBitmap bitmap( LAYER_BITMAP_SIZE_X, LAYER_BITMAP_SIZE_Y );
+ wxBrush brush;
+ wxMemoryDC iconDC;
+
+ iconDC.SelectObject( bitmap );
+ brush.SetColour( MakeColour( aColor ) );
+ brush.SetStyle( wxBRUSHSTYLE_SOLID );
+ iconDC.SetBrush( brush );
+ iconDC.DrawRectangle( 0, 0, LAYER_BITMAP_SIZE_X, LAYER_BITMAP_SIZE_Y );
+
+ return bitmap;
+}