KiCad PCB EDA Suite
Loading...
Searching...
No Matches
board_project_settings.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) 2020 Jon Evans <[email protected]>
5 * Copyright (C) 2020-2023 KiCad Developers, see AUTHORS.txt for contributors.
6 *
7 * This program is free software: you can redistribute it and/or modify it
8 * under the terms of the GNU General Public License as published by the
9 * Free Software Foundation, either version 3 of the License, or (at your
10 * option) any later version.
11 *
12 * This program is distributed in the hope that it will be useful, but
13 * WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 * General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License along
18 * with this program. If not, see <http://www.gnu.org/licenses/>.
19 */
20
21#ifndef KICAD_BOARD_PROJECT_SETTINGS_H
22#define KICAD_BOARD_PROJECT_SETTINGS_H
23
24#include <layer_ids.h>
25#include <lset.h>
26#include <settings/parameters.h>
27
28// Can be removed by refactoring PARAM_LAYER_PRESET
29#include <nlohmann/json.hpp>
30#include <math/box2.h>
31#include <glm/glm.hpp>
32
44{
47 bool text;
48 bool tracks;
49 bool vias;
50 bool pads;
51 bool graphics;
52 bool zones;
53 bool keepouts;
56
58 {
59 lockedItems = true;
60 footprints = true;
61 text = true;
62 tracks = true;
63 vias = true;
64 pads = true;
65 graphics = true;
66 zones = true;
67 keepouts = true;
68 dimensions = true;
69 otherItems = true;
70 }
71
75 bool Any()
76 {
77 return ( footprints || text || tracks || vias || pads || graphics || zones
78 || keepouts || dimensions || otherItems );
79 }
80
84 bool All()
85 {
86 return ( footprints && text && tracks && vias && pads && graphics && zones
87 && keepouts && dimensions && otherItems );
88 }
89};
90
95{
96 NORMAL = 0,
97 DIMMED,
98 HIDDEN
99};
100
103{
106
107 // Debug modes
108
111};
112
115{
116 OFF,
117 RATSNEST,
118 ALL
119};
120
123{
124 ALL,
125 VISIBLE
126};
127
130{
131 wxString mfg;
132 wxString MPN;
133 wxString dist;
134 wxString distPN;
135 wxString id;
136};
137
142{
143 LAYER_PRESET( const wxString& aName = wxS( "" ) ) :
144 name( aName ),
145 layers( LSET::AllLayersMask() ),
146 renderLayers( GAL_SET::DefaultVisible() ),
147 flipBoard( false ),
148 activeLayer( UNSELECTED_LAYER )
149 {
150 readOnly = false;
151 }
152
153 LAYER_PRESET( const wxString& aName, const LSET& aVisibleLayers, bool aFlipBoard ) :
154 name( aName ),
155 layers( aVisibleLayers ),
156 renderLayers( GAL_SET::DefaultVisible() ),
157 flipBoard( aFlipBoard ),
158 activeLayer( UNSELECTED_LAYER )
159 {
160 readOnly = false;
161 }
162
163 LAYER_PRESET( const wxString& aName, const LSET& aVisibleLayers, const GAL_SET& aVisibleObjects,
164 PCB_LAYER_ID aActiveLayer, bool aFlipBoard ) :
165 name( aName ),
166 layers( aVisibleLayers ),
167 renderLayers( aVisibleObjects ),
168 flipBoard( aFlipBoard ),
169 activeLayer( aActiveLayer )
170 {
171 readOnly = false;
172 }
173
174 bool LayersMatch( const LAYER_PRESET& aOther )
175 {
176 return aOther.layers == layers && aOther.renderLayers == renderLayers;
177 }
178
179 wxString name;
184 bool readOnly;
185};
186
187
188class KICOMMON_API PARAM_LAYER_PRESET : public PARAM_LAMBDA<nlohmann::json>
189{
190public:
191 PARAM_LAYER_PRESET( const std::string& aPath, std::vector<LAYER_PRESET>* aPresetList );
192
193 static void MigrateToV9Layers( nlohmann::json& aJson );
194
195private:
196 nlohmann::json presetsToJson();
197
198 void jsonToPresets( const nlohmann::json& aJson );
199
200 std::vector<LAYER_PRESET>* m_presets;
201};
202
203
205{
206 VIEWPORT( const wxString& aName = wxEmptyString ) :
207 name( aName )
208 { }
209
210 VIEWPORT( const wxString& aName, const BOX2D& aRect ) :
211 name( aName ),
212 rect( aRect )
213 { }
214
215 wxString name;
217};
218
219
220class KICOMMON_API PARAM_VIEWPORT : public PARAM_LAMBDA<nlohmann::json>
221{
222public:
223 PARAM_VIEWPORT( const std::string& aPath, std::vector<VIEWPORT>* aViewportList );
224
225private:
226 nlohmann::json viewportsToJson();
227
228 void jsonToViewports( const nlohmann::json& aJson );
229
230 std::vector<VIEWPORT>* m_viewports;
231};
232
233
235{
236 VIEWPORT3D( const wxString& aName = wxEmptyString ) :
237 name( aName )
238 { }
239
240 VIEWPORT3D( const wxString& aName, glm::mat4 aViewMatrix ) :
241 name( aName ),
242 matrix( std::move( aViewMatrix ) )
243 { }
244
245 wxString name;
246 glm::mat4 matrix;
247};
248
249
250class KICOMMON_API PARAM_VIEWPORT3D : public PARAM_LAMBDA<nlohmann::json>
251{
252public:
253 PARAM_VIEWPORT3D( const std::string& aPath, std::vector<VIEWPORT3D>* aViewportList );
254
255private:
256 nlohmann::json viewportsToJson();
257
258 void jsonToViewports( const nlohmann::json & aJson );
259
260 std::vector<VIEWPORT3D>* m_viewports;
261};
262
263
265{
266public:
268 m_layerA( UNDEFINED_LAYER ), m_layerB( UNDEFINED_LAYER )
269 {
270 }
271
273 m_layerA( a ), m_layerB( b )
274 {
275 }
276
277 PCB_LAYER_ID GetLayerA() const { return m_layerA; }
278 PCB_LAYER_ID GetLayerB() const { return m_layerB; }
279
280 void SetLayerA( PCB_LAYER_ID aLayer ) { m_layerA = aLayer; }
281 void SetLayerB( PCB_LAYER_ID aLayer ) { m_layerB = aLayer; }
282
286 bool HasSameLayers( const LAYER_PAIR& aOther ) const
287 {
288 return ( m_layerA == aOther.m_layerA && m_layerB == aOther.m_layerB )
289 || ( m_layerA == aOther.m_layerB && m_layerB == aOther.m_layerA );
290 }
291
292private:
295};
296
297
302{
303public:
304 LAYER_PAIR_INFO( LAYER_PAIR aPair, bool aEnabled, std::optional<wxString> aName ) :
305 m_pair( std::move( aPair ) ), m_enabled( aEnabled), m_name( std::move( aName ) )
306 {
307 }
308
309 const LAYER_PAIR& GetLayerPair() const { return m_pair; }
310
311 const std::optional<wxString>& GetName() const { return m_name; }
312
313 void SetName( const wxString& aNewName ) { m_name = aNewName; }
314 void UnsetName() { m_name = std::nullopt; }
315
316 bool IsEnabled() const { return m_enabled; }
317 void SetEnabled( bool aNewEnabled ) { m_enabled = aNewEnabled; }
318
319private:
321 bool m_enabled = true;
322 std::optional<wxString> m_name;
323};
324
325
326class KICOMMON_API PARAM_LAYER_PAIRS : public PARAM_LAMBDA<nlohmann::json>
327{
328public:
329 PARAM_LAYER_PAIRS( const std::string& aPath, std::vector<LAYER_PAIR_INFO>& m_layerPairInfos );
330
331private:
332 nlohmann::json layerPairsToJson();
333
334 void jsonToLayerPairs( const nlohmann::json& aJson );
335
336 std::vector<LAYER_PAIR_INFO>& m_layerPairInfos;
337};
338
339
344{
345 wxString filter_text;
350 std::vector<wxString> custom_group_rules;
355 std::vector<int> col_order;
356 std::vector<int> col_widths;
357 std::vector<bool> col_hidden;
358
359 std::vector<wxString> expanded_rows;
360
362 {
363 filter_text = "";
364 filter_by_net_name = true;
365 filter_by_netclass = true;
366 group_by_netclass = false;
367 group_by_constraint = false;
368 show_zero_pad_nets = false;
369 show_unconnected_nets = false;
370 sorting_column = -1;
371 sort_order_asc = true;
372 }
373};
374
375
376#endif // KICAD_BOARD_PROJECT_SETTINGS_H
const char * name
Definition: DXF_plotter.cpp:57
HIGH_CONTRAST_MODE
Determine how inactive layers should be displayed.
@ NORMAL
Inactive layers are shown normally (no high-contrast mode)
@ HIDDEN
Inactive layers are hidden.
@ DIMMED
Inactive layers are dimmed (old high-contrast mode)
@ RATSNEST
Net/netclass colors are shown on ratsnest lines only.
@ ALL
Net/netclass colors are shown on all net copper.
@ OFF
Net (and netclass) colors are not shown.
@ VISIBLE
Ratsnest lines are drawn to items on visible layers only.
Helper for storing and iterating over GAL_LAYER_IDs.
Definition: layer_ids.h:307
All information about a layer pair as stored in the layer pair store.
const LAYER_PAIR & GetLayerPair() const
void SetName(const wxString &aNewName)
const std::optional< wxString > & GetName() const
std::optional< wxString > m_name
void SetEnabled(bool aNewEnabled)
LAYER_PAIR_INFO(LAYER_PAIR aPair, bool aEnabled, std::optional< wxString > aName)
PCB_LAYER_ID GetLayerA() const
PCB_LAYER_ID m_layerA
void SetLayerB(PCB_LAYER_ID aLayer)
PCB_LAYER_ID GetLayerB() const
LAYER_PAIR(PCB_LAYER_ID a, PCB_LAYER_ID b)
PCB_LAYER_ID m_layerB
void SetLayerA(PCB_LAYER_ID aLayer)
bool HasSameLayers(const LAYER_PAIR &aOther) const
LSET is a set of PCB_LAYER_IDs.
Definition: lset.h:36
Like a normal param, but with custom getter and setter functions.
Definition: parameters.h:295
std::vector< LAYER_PAIR_INFO > & m_layerPairInfos
std::vector< LAYER_PRESET > * m_presets
std::vector< VIEWPORT3D > * m_viewports
std::vector< VIEWPORT > * m_viewports
#define KICOMMON_API
Definition: kicommon.h:28
PCB_LAYER_ID
A quick note on layer IDs:
Definition: layer_ids.h:60
@ UNSELECTED_LAYER
Definition: layer_ids.h:62
@ UNDEFINED_LAYER
Definition: layer_ids.h:61
STL namespace.
wxString mfg
Manufacturer name column.
wxString MPN
Manufacturer part number column.
wxString id
Internal ID column.
wxString dist
Distributor name column.
wxString distPN
Distributor part number column.
A saved set of layers that are visible.
GAL_SET renderLayers
Render layers (e.g. object types) that are visible.
wxString name
A name for this layer set.
LAYER_PRESET(const wxString &aName=wxS(""))
bool flipBoard
True if the flip board is enabled.
LSET layers
Board layers that are visible.
bool readOnly
True if this is a read-only (built-in) preset.
bool LayersMatch(const LAYER_PRESET &aOther)
PCB_LAYER_ID activeLayer
Optional layer to set active when this preset is loaded.
LAYER_PRESET(const wxString &aName, const LSET &aVisibleLayers, bool aFlipBoard)
LAYER_PRESET(const wxString &aName, const LSET &aVisibleLayers, const GAL_SET &aVisibleObjects, PCB_LAYER_ID aActiveLayer, bool aFlipBoard)
Persisted state for the net inspector panel.
std::vector< wxString > expanded_rows
std::vector< wxString > custom_group_rules
This file contains data structures that are saved in the project file or project local settings file ...
bool otherItems
Anything not fitting one of the above categories.
bool graphics
Graphic lines, shapes, polygons.
bool footprints
Allow selecting entire footprints.
bool text
Text (free or attached to a footprint)
bool lockedItems
Allow selecting locked items.
VIEWPORT3D(const wxString &aName=wxEmptyString)
VIEWPORT3D(const wxString &aName, glm::mat4 aViewMatrix)
VIEWPORT(const wxString &aName, const BOX2D &aRect)
VIEWPORT(const wxString &aName=wxEmptyString)