KiCad PCB EDA Suite
pcb_layer_box_selector.h
Go to the documentation of this file.
1 /*
2  * This program source code file is part of KiCad, a free EDA CAD application.
3  *
4  * Copyright (C) 2012-2015 Jean-Pierre Charras, jean-pierre.charras@ujf-grenoble.fr
5  * Copyright (C) 1992-2015 KiCad Developers, see AUTHORS.txt for contributors.
6  *
7  * This program is free software; you can redistribute it and/or
8  * modify it under the terms of the GNU General Public License
9  * as published by the Free Software Foundation; either version 2
10  * of the License, or (at your option) any later version.
11  *
12  * This program is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15  * GNU General Public License for more details.
16  *
17  * You should have received a copy of the GNU General Public License
18  * along with this program; if not, you may find one here:
19  * http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
20  * or you may search the http://www.gnu.org website for the version 2 license,
21  * or you may write to the Free Software Foundation, Inc.,
22  * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
23  */
24 
25 #ifndef PCB_LAYER_BOX_SELECTOR_H
26 #define PCB_LAYER_BOX_SELECTOR_H
27 
29 
30 class PCB_BASE_FRAME;
31 
36 {
38 
39  LSET m_layerMaskDisable; // A mask to remove some (not allowed) layers
40  // from layer list
41  bool m_showNotEnabledBrdlayers; // true to list all allowed layers
42  // (with not activated layers flagged)
43  wxString m_undefinedLayerName; // if not empty add an item with this name which sets
44  // the layer to UNDEFINED_LAYER
45 
46 public:
47  // If you are thinking the constructor is a bit curious, just remember it is automatically
48  // generated when used in wxFormBuilder files, and so must have the same signature as the
49  // wxBitmapComboBox constructor. In particular, value and style are not used by this class.
50  PCB_LAYER_BOX_SELECTOR( wxWindow* parent, wxWindowID id,
51  const wxString& value = wxEmptyString,
52  const wxPoint& pos = wxDefaultPosition,
53  const wxSize& size = wxDefaultSize,
54  int n = 0, const wxString choices[] = NULL, int style = 0 ) :
55  LAYER_BOX_SELECTOR( parent, id, pos, size, n, choices )
56  {
59  }
60 
61  // SetBoardFrame should be called after creating a PCB_LAYER_BOX_SELECTOR. It is not passed
62  // through the constructor because it must have the same signature as wxBitmapComboBox for
63  // use with wxFormBuilder.
64  void SetBoardFrame( PCB_BASE_FRAME* aFrame ) { m_boardFrame = aFrame; };
65 
66  // SetLayerSet allows disableing some layers, which are not shown in list
67  void SetNotAllowedLayerSet( LSET aMask ) { m_layerMaskDisable = aMask; }
68 
69  // If the UNDEFINED_LAYER should be selectable, give it a name here. Usually either
70  // INDETERMINATE_STATE or INDETERMINATE_ACTION.
71  void SetUndefinedLayerName( const wxString& aName ) { m_undefinedLayerName = aName; }
72 
73  // Reload the Layers names and bitmaps
74  void Resync() override;
75 
76  // Allow (or not) the layers not activated for the current board to be shown in layer
77  // selector. Not actavated layers have their names appended with "(not activated)".
78  void ShowNonActivatedLayers( bool aShow ) { m_showNotEnabledBrdlayers = aShow; }
79 
80 private:
81  // Returns a color index from the layer id
82  COLOR4D getLayerColor( LAYER_NUM aLayer ) const override;
83 
84  // Returns true if the layer id is enabled (i.e. if it should be displayed)
85  bool isLayerEnabled( LAYER_NUM aLayer ) const override;
86 
87  // Returns the name of the layer id
88  wxString getLayerName( LAYER_NUM aLayer ) const override;
89 
90  LSET getEnabledLayers() const;
91 };
92 
93 #endif // PCB_LAYER_BOX_SELECTOR_H
void SetNotAllowedLayerSet(LSET aMask)
Class to display a pcb layer list in a wxBitmapComboBox.
void SetBoardFrame(PCB_BASE_FRAME *aFrame)
bool isLayerEnabled(LAYER_NUM aLayer) const override
COLOR4D getLayerColor(LAYER_NUM aLayer) const override
LSET is a set of PCB_LAYER_IDs.
#define NULL
void ShowNonActivatedLayers(bool aShow)
wxString getLayerName(LAYER_NUM aLayer) const override
PCB_LAYER_BOX_SELECTOR(wxWindow *parent, wxWindowID id, const wxString &value=wxEmptyString, const wxPoint &pos=wxDefaultPosition, const wxSize &size=wxDefaultSize, int n=0, const wxString choices[]=NULL, int style=0)
int LAYER_NUM
Type LAYER_NUM can be replaced with int and removed.
void SetUndefinedLayerName(const wxString &aName)
PCB_BASE_FRAME basic PCB main window class for Pcbnew, Gerbview, and CvPcb footprint viewer.
COLOR4D is the color representation with 4 components: red, green, blue, alpha.
Definition: color4d.h:99