140#define MAX_CU_LAYERS 32
173#define NETNAMES_LAYER_INDEX( layer ) ( static_cast<int>( NETNAMES_LAYER_ID_START ) + layer )
175#define GAL_UI_LAYER_COUNT 10
272#define GAL_LAYER_INDEX( x ) ( x - GAL_LAYER_ID_START )
275#define BITMAP_LAYER_FOR( boardLayer ) ( LAYER_BITMAP_START + boardLayer )
276#define ZONE_LAYER_FOR( boardLayer ) ( LAYER_ZONE_START + boardLayer )
331 GAL_BASE_SET::set( aPos, aVal );
337 GAL_BASE_SET::set(
static_cast<std::size_t
>( aPos ) - start, aVal );
343 return test(
static_cast<std::size_t
>( aPos ) - start );
346 std::vector<GAL_LAYER_ID> Seq()
const;
348 static GAL_SET DefaultVisible();
409#define SCH_LAYER_ID_COUNT ( SCH_LAYER_ID_END - SCH_LAYER_ID_START )
411#define SCH_LAYER_INDEX( x ) ( x - SCH_LAYER_ID_START )
420#define GERBER_DRAWLAYERS_COUNT static_cast<int>( PCB_LAYER_ID_COUNT )
441#define GERBER_DRAW_LAYER( x ) ( GERBVIEW_LAYER_ID_START + x )
443#define GERBER_DCODE_LAYER( x ) ( GERBER_DRAWLAYERS_COUNT + x )
445#define GERBER_DRAW_LAYER_INDEX( x ) ( x - GERBVIEW_LAYER_ID_START )
481#define LAYER_ID_COUNT LAYER_3D_END
495#define MIN_VISIBILITY_MASK int( ( 1 << GAL_LAYER_INDEX( LAYER_PAD_PLATEDHOLES ) ) +\
496 ( 1 << GAL_LAYER_INDEX( LAYER_VIA_HOLES ) ) +\
497 ( 1 << GAL_LAYER_INDEX( LAYER_SELECT_OVERLAY ) ) +\
498 ( 1 << GAL_LAYER_INDEX( LAYER_GP_OVERLAY ) ) +\
499 ( 1 << GAL_LAYER_INDEX( LAYER_RATSNEST ) ) )
533 return !( aLayerId & 1 ) && aLayerId < PCB_LAYER_ID_COUNT && aLayerId >= 0;
544 return aLayerId ==
F_Cu || aLayerId ==
B_Cu;
577inline bool IsCopperLayer(
int aLayerId,
bool aIncludeSyntheticCopperLayers )
579 if( aIncludeSyntheticCopperLayers )
678 if( aLayerA == aLayerB )
681 if( aLayerA ==
B_Cu )
684 if( aLayerB ==
B_Cu )
687 return aLayerA > aLayerB;
749 default:
return ( aLayer -
B_Cu ) / 2;
Helper for storing and iterating over GAL_LAYER_IDs.
bool Contains(GAL_LAYER_ID aPos)
GAL_SET(const GAL_SET &aOther)
GAL_SET & set(int aPos, bool aVal=true)
GAL_SET & set(GAL_LAYER_ID aPos, bool aVal=true)
bool IsSolderMaskLayer(int aLayer)
NETNAMES_LAYER_ID
Dedicated layers for net names used in Pcbnew.
@ LAYER_PAD_FR_NETNAMES
Additional netnames layers (not associated with a PCB layer)
@ NETNAMES_LAYER_ID_START
@ NETNAMES_LAYER_ID_RESERVED
Reserved space for board layer netnames.
std::bitset< GAL_LAYER_ID_COUNT > GAL_BASE_SET
Wraps a std::bitset.
GAL_LAYER_ID operator++(GAL_LAYER_ID &a)
GERBVIEW_LAYER_ID
GerbView draw layers.
@ GERBVIEW_LAYER_ID_RESERVED
GerbView draw layers and d-code layers.
@ LAYER_GERBVIEW_DRAWINGSHEET
@ GERBVIEW_LAYER_ID_START
@ LAYER_GERBVIEW_BACKGROUND
@ LAYER_GERBVIEW_PAGE_LIMITS
GAL_LAYER_ID operator+(const GAL_LAYER_ID &a, int b)
Used for via types.
bool IsPcbLayer(int aLayer)
Test whether a layer is a valid layer for Pcbnew.
LAYER_3D_ID
3D Viewer virtual layers for color settings
@ LAYER_3D_SOLDERMASK_TOP
@ LAYER_3D_BOUNDING_BOXES
@ LAYER_3D_BACKGROUND_TOP
@ LAYER_3D_SOLDERMASK_BOTTOM
@ LAYER_3D_SILKSCREEN_TOP
@ LAYER_3D_VIRTUAL_MODELS
@ LAYER_3D_MODELS_MARKED_DNP
@ LAYER_3D_OFF_BOARD_SILK
@ LAYER_3D_MODELS_NOT_IN_POS
@ LAYER_3D_BACKGROUND_BOTTOM
@ LAYER_3D_SILKSCREEN_BOTTOM
bool IsUserLayer(PCB_LAYER_ID aLayerId)
Test whether a layer is a non copper and a non tech layer.
bool IsCopperLayerLowerThan(PCB_LAYER_ID aLayerA, PCB_LAYER_ID aLayerB)
Returns true if copper aLayerA is placed lower than aLayerB, false otherwise.
constexpr PCB_LAYER_ID PCBNEW_LAYER_ID_START
KICOMMON_API PCB_LAYER_ID BoardLayerFromLegacyId(int aLegacyId)
Retrieves a layer ID from an integer converted from a legacy (pre-V9) enum value.
#define NETNAMES_LAYER_INDEX(layer)
Macro for obtaining netname layer for a given PCB layer.
GAL_LAYER_ID ToGalLayer(int aInteger)
constexpr int GAL_LAYER_ID_COUNT
bool IsFrontLayer(PCB_LAYER_ID aLayerId)
Layer classification: check if it's a front layer.
FLASHING
Enum used during connectivity building to ensure we do not query connectivity while building the data...
bool IsDCodeLayer(int aLayer)
bool IsBackLayer(PCB_LAYER_ID aLayerId)
Layer classification: check if it's a back layer.
KICOMMON_API PCB_LAYER_ID FlipLayer(PCB_LAYER_ID aLayerId, int aCopperLayersCount=0)
bool IsNonCopperLayer(int aLayerId)
Test whether a layer is a non copper layer.
int GetNetnameLayer(int aLayer)
Returns a netname layer corresponding to the given layer.
KICOMMON_API wxString LayerName(int aLayer)
Returns the string equivalent of a given layer.
#define GAL_UI_LAYER_COUNT
bool IsCopperLayer(int aLayerId)
Tests whether a layer is a copper layer.
GAL_LAYER_ID
GAL layers are "virtual" layers, i.e.
@ LAYER_PAGE_LIMITS
color for drawing the page extents (visibility stored in PCBNEW_SETTINGS::m_ShowPageLimits)
@ LAYER_LOCKED_ITEM_SHADOW
shadow layer for locked items
@ LAYER_DRAWINGSHEET_PAGEn
for drawingsheetEditor previewing
@ LAYER_CONFLICTS_SHADOW
shadow layer for items flagged conficting
@ LAYER_FOOTPRINTS_FR
show footprints on front
@ LAYER_DRC_SHAPE1
Custom shape for DRC marker.
@ LAYER_NON_PLATEDHOLES
handle color for not plated holes (holes, not pads)
@ LAYER_DRAWINGSHEET
drawingsheet frame and titleblock
@ LAYER_DRAW_BITMAPS
to handle and draw images bitmaps
@ LAYER_FP_REFERENCES
show footprints references (when texts are visible)
@ LAYER_DRC_EXCLUSION
layer for drc markers which have been individually excluded
@ LAYER_PCB_BACKGROUND
PCB background color.
@ LAYER_ZONES
Control for copper zone opacity/visibility (color ignored)
@ LAYER_SHAPES
Copper graphic shape opacity/visibility (color ignored)
@ LAYER_PADS
Meta control for all pads opacity/visibility (color ignored)
@ LAYER_DRC_WARNING
layer for drc markers with SEVERITY_WARNING
@ LAYER_PAD_PLATEDHOLES
to draw pad holes (plated)
@ LAYER_GP_OVERLAY
general purpose overlay
@ GAL_LAYER_ID_BITMASK_END
This is the end of the layers used for visibility bit masks in legacy board files.
@ LAYER_CURSOR
PCB cursor.
@ LAYER_AUX_ITEMS
Auxiliary items (guides, rule, etc)
@ LAYER_DRC_SHAPE2
Custom shape for DRC marker.
@ LAYER_ZONE_START
Virtual layers for stacking zones and tracks on a given copper layer.
@ LAYER_FOOTPRINTS_BK
show footprints on back
@ LAYER_ANCHOR
anchor of items having an anchor point (texts, footprints)
@ LAYER_DRAWINGSHEET_PAGE1
for drawingsheetEditor previewing
@ LAYER_MARKER_SHADOWS
shadows for drc markers
@ LAYER_VIA_HOLES
to draw via holes (pad holes do not use this layer)
@ LAYER_FP_VALUES
show footprints values (when texts are visible)
@ LAYER_VIA_MICROVIA
to draw micro vias
@ LAYER_SELECT_OVERLAY
currently selected items overlay
@ LAYER_VIA_THROUGH
to draw usual through hole vias
@ LAYER_BITMAP_START
Virtual layers for background images per board layer.
@ LAYER_DRC_ERROR
layer for drc markers with SEVERITY_ERROR
@ LAYER_VIAS
Meta control for all vias opacity/visibility.
@ LAYER_VIA_BBLIND
to draw blind/buried vias
SCH_LAYER_ID
Eeschema drawing layers.
@ LAYER_EXCLUDED_FROM_SIM
@ LAYER_NET_COLOR_HIGHLIGHT
@ LAYER_DEVICE_BACKGROUND
@ LAYER_SCHEMATIC_DRAWINGSHEET
@ LAYER_SCHEMATIC_GRID_AXES
@ LAYER_SCHEMATIC_PAGE_LIMITS
@ LAYER_SELECTION_SHADOWS
@ LAYER_SCHEMATIC_BACKGROUND
@ LAYER_SCHEMATIC_AUX_ITEMS
size_t CopperLayerToOrdinal(PCB_LAYER_ID aLayer)
! Converts KiCad copper layer enum to an ordinal between the front and back layers
bool IsNetnameLayer(int aLayer)
Test whether a layer is a netname layer.
KICOMMON_API PCB_LAYER_ID ToLAYER_ID(int aLayer)
bool IsHoleLayer(int aLayer)
bool IsViaPadLayer(int aLayer)
bool IsInnerCopperLayer(int aLayerId)
Tests whether a layer is an inner (In1_Cu to In30_Cu) copper layer.
bool IsExternalCopperLayer(int aLayerId)
Tests whether a layer is an external (F_Cu or B_Cu) copper layer.
PCB_LAYER_ID
A quick note on layer IDs:
bool IsValidLayer(int aLayerId)
Test whether a given integer is a valid layer index, i.e.
#define GERBER_DRAWLAYERS_COUNT
bool IsZoneFillLayer(int aLayer)