KiCad PCB EDA Suite
Loading...
Searching...
No Matches
zone_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) 2008-2018 Jean-Pierre Charras, [email protected]
5 * Copyright (C) 1992-2022 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
30#ifndef ZONE_SETTINGS_H_
31#define ZONE_SETTINGS_H_
32
33#include <layer_ids.h>
34#include <lset.h>
35#include <zones.h>
36#include <geometry/eda_angle.h>
38
39class wxDataViewListCtrl;
40
42{
43 POLYGONS = 0, // fill zone with polygons
44 HATCH_PATTERN = 1 // fill zone using a grid pattern
45};
46
47
50{
54 INVISIBLE_BORDER // Disable outline drawing for very special cases
55};
56
59{
60 ALWAYS = 0,
61 NEVER,
62 AREA
63};
64
66{
67 SHEETNAME = 0,
69};
70
78{
79public:
80 // the actual zone outline shape can be slightly modified (smoothed):
81 enum {
83 SMOOTHING_NONE = 0, // Zone outline is used without change
84 SMOOTHING_CHAMFER, // Zone outline is used after chamfering corners
85 SMOOTHING_FILLET, // Zone outline is used after rounding corners
86 SMOOTHING_LAST // sentinel
87 };
88
89 unsigned m_ZonePriority; // Priority (0 ... N) of the zone
90
92 int m_ZoneClearance; // Minimal clearance value
93 int m_ZoneMinThickness; // Min thickness value in filled areas
94 int m_HatchThickness; // HatchBorder thickness of lines (if 0 -> solid shape)
95 int m_HatchGap; // HatchBorder clearance between lines (0 -> solid shape)
96 EDA_ANGLE m_HatchOrientation; // HatchBorder orientation of grid lines
97 int m_HatchSmoothingLevel; // HatchBorder smoothing type, similar to corner smoothing type
98 // 0 = no smoothing, 1 = fillet, >= 2 = arc
99 double m_HatchSmoothingValue; // HatchBorder chamfer/fillet size as a ratio of hole size
100 double m_HatchHoleMinArea; // min size before holes are dropped (ratio)
101 int m_HatchBorderAlgorithm; // 0 = use min zone thickness
102
103 int m_NetcodeSelection; // Net code selection for the current zone
104
105 wxString m_Name; // Unique name for the current zone (can be blank)
106
107 LSET m_Layers; // Layers that this zone exists on
108
111 int m_BorderHatchPitch; // for hatched outlines: dist between 2 hatches
112
113 long m_ThermalReliefGap; // thickness of the gap in thermal reliefs
114 long m_ThermalReliefSpokeWidth; // thickness of the copper bridge in thermal reliefs
115
117
118 /* A zone outline can be a teardrop zone with different rules
119 * priority, smoothed corners, thermal relief...
120 */
122
123private:
124 int m_cornerSmoothingType; // Corner smoothing type
125 unsigned int m_cornerRadius; // Corner chamfer distance / fillet radius
127
128 /*
129 * Keepout zones and keepout flags.
130 * Note that DRC rules can set keepouts on zones whether they're a keepout or not.
131 */
133
140
146
148 long long int m_minIslandArea;
149
150public:
152
153 bool operator==( const ZONE_SETTINGS& aOther ) const;
154
155 bool operator!=( const ZONE_SETTINGS& aOther ) const { return !operator==( aOther ); }
156
163 ZONE_SETTINGS& operator << ( const ZONE& aSource );
164
168 static const ZONE_SETTINGS& GetDefaultSettings();
169
176 void SetupLayersList( wxDataViewListCtrl* aList, PCB_BASE_FRAME* aFrame, LSET aLayers,
177 bool aFpEditorMode );
178
188 void ExportSetting( ZONE& aTarget, bool aFullExport = true ) const;
189
190 void SetCornerSmoothingType( int aType) { m_cornerSmoothingType = aType; }
192
193 void SetCornerRadius( int aRadius );
194 unsigned int GetCornerRadius() const { return m_cornerRadius; }
195
197 void SetPadConnection( ZONE_CONNECTION aPadConnection ) { m_padConnection = aPadConnection; }
198
203 {
206 }
207
211 bool GetIsRuleArea() const { return m_isRuleArea; }
214 {
216 }
223
224 void SetIsRuleArea( bool aEnable ) { m_isRuleArea = aEnable; }
225 void SetRuleAreaPlacementEnabled( bool aEnabled ) { m_ruleAreaPlacementEnabled = aEnabled; }
227 {
229 }
230 void SetRuleAreaPlacementSource( const wxString& aSource )
231 {
233 }
234 void SetDoNotAllowCopperPour( bool aEnable ) { m_keepoutDoNotAllowCopperPour = aEnable; }
235 void SetDoNotAllowVias( bool aEnable ) { m_keepoutDoNotAllowVias = aEnable; }
236 void SetDoNotAllowTracks( bool aEnable ) { m_keepoutDoNotAllowTracks = aEnable; }
237 void SetDoNotAllowPads( bool aEnable ) { m_keepoutDoNotAllowPads = aEnable; }
238 void SetDoNotAllowFootprints( bool aEnable ) { m_keepoutDoNotAllowFootprints = aEnable; }
239
242
243 long long int GetMinIslandArea() const { return m_minIslandArea; }
244 void SetMinIslandArea( long long int aArea ) { m_minIslandArea = aArea; }
245};
246
247
248#endif // ZONE_SETTINGS_H_
LSET is a set of PCB_LAYER_IDs.
Definition: lset.h:36
Base PCB main window class for Pcbnew, Gerbview, and CvPcb footprint viewer.
ZONE_SETTINGS handles zones parameters.
Definition: zone_settings.h:78
bool GetDoNotAllowCopperPour() const
bool m_keepoutDoNotAllowPads
void SetIsRuleArea(bool aEnable)
bool operator==(const ZONE_SETTINGS &aOther) const
bool operator!=(const ZONE_SETTINGS &aOther) const
unsigned int m_cornerRadius
bool GetDoNotAllowTracks() const
EDA_ANGLE m_HatchOrientation
Definition: zone_settings.h:96
RULE_AREA_PLACEMENT_SOURCE_TYPE GetRuleAreaPlacementSourceType() const
int m_HatchBorderAlgorithm
void SetDoNotAllowVias(bool aEnable)
bool GetDoNotAllowFootprints() const
void SetRuleAreaPlacementSourceType(RULE_AREA_PLACEMENT_SOURCE_TYPE aType)
long long int m_minIslandArea
void SetIslandRemovalMode(ISLAND_REMOVAL_MODE aRemove)
wxString GetRuleAreaPlacementSource() const
bool m_keepoutDoNotAllowTracks
bool GetDoNotAllowPads() const
double m_HatchSmoothingValue
Definition: zone_settings.h:99
bool m_ruleAreaPlacementEnabled
Placement rule area data.
RULE_AREA_PLACEMENT_SOURCE_TYPE m_ruleAreaPlacementSourceType
void SetMinIslandArea(long long int aArea)
void ExportSetting(ZONE &aTarget, bool aFullExport=true) const
Function ExportSetting copy settings to a given zone.
void SetRuleAreaPlacementEnabled(bool aEnabled)
bool GetIsRuleArea() const
Accessors to parameters used in Rule Area zones:
void SetRuleAreaPlacementSource(const wxString &aSource)
int m_cornerSmoothingType
void SetDoNotAllowTracks(bool aEnable)
bool GetDoNotAllowVias() const
bool m_keepoutDoNotAllowCopperPour
ISLAND_REMOVAL_MODE m_removeIslands
double m_HatchHoleMinArea
void SetPadConnection(ZONE_CONNECTION aPadConnection)
int m_ZoneMinThickness
Definition: zone_settings.h:93
bool GetRuleAreaPlacementEnabled() const
long long int GetMinIslandArea() const
long m_ThermalReliefSpokeWidth
ZONE_CONNECTION GetPadConnection() const
TEARDROP_TYPE m_TeardropType
static const ZONE_SETTINGS & GetDefaultSettings()
unsigned m_ZonePriority
Definition: zone_settings.h:89
void SetCornerRadius(int aRadius)
void SetupLayersList(wxDataViewListCtrl *aList, PCB_BASE_FRAME *aFrame, LSET aLayers, bool aFpEditorMode)
A helper routine for the various zone dialogs (copper, non-copper, keepout).
bool HasKeepoutParametersSet() const
Accessor to determine if any keepout parameters are set.
wxString m_Name
int GetCornerSmoothingType() const
ZONE_FILL_MODE m_FillMode
Definition: zone_settings.h:91
ZONE_CONNECTION m_padConnection
long m_ThermalReliefGap
void SetDoNotAllowFootprints(bool aEnable)
void SetDoNotAllowPads(bool aEnable)
void SetCornerSmoothingType(int aType)
int m_HatchSmoothingLevel
Definition: zone_settings.h:97
unsigned int GetCornerRadius() const
ISLAND_REMOVAL_MODE GetIslandRemovalMode() const
ZONE_BORDER_DISPLAY_STYLE m_ZoneBorderDisplayStyle
Option to show the zone area (outlines only, short hatches or full hatches.
bool m_keepoutDoNotAllowFootprints
bool m_keepoutDoNotAllowVias
void SetDoNotAllowCopperPour(bool aEnable)
wxString m_ruleAreaPlacementSource
Handle a list of polygons defining a copper zone.
Definition: zone.h:73
TEARDROP_TYPE
define the type of a teardrop: on a via or pad, or a track end
RULE_AREA_PLACEMENT_SOURCE_TYPE
Definition: zone_settings.h:66
ISLAND_REMOVAL_MODE
Whether or not to remove isolated islands from a zone.
Definition: zone_settings.h:59
ZONE_FILL_MODE
Definition: zone_settings.h:42
ZONE_BORDER_DISPLAY_STYLE
Zone border styles.
Definition: zone_settings.h:50
ZONE_CONNECTION
How pads are covered by copper in zone.
Definition: zones.h:47