mirror of
https://gitlab.com/kicad/code/kicad.git
synced 2024-11-21 22:55:04 +00:00
377 lines
11 KiB
C++
377 lines
11 KiB
C++
/*
|
|
* This program source code file is part of KiCad, a free EDA CAD application.
|
|
*
|
|
* Copyright (C) 2020 Jon Evans <jon@craftyjon.com>
|
|
* Copyright (C) 2020-2023 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 3 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, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#ifndef KICAD_BOARD_PROJECT_SETTINGS_H
|
|
#define KICAD_BOARD_PROJECT_SETTINGS_H
|
|
|
|
#include <layer_ids.h>
|
|
#include <lset.h>
|
|
#include <settings/parameters.h>
|
|
|
|
// Can be removed by refactoring PARAM_LAYER_PRESET
|
|
#include <nlohmann/json.hpp>
|
|
#include <math/box2.h>
|
|
#include <glm/glm.hpp>
|
|
|
|
/**
|
|
* This file contains data structures that are saved in the project file or project local settings
|
|
* file that are specific to PcbNew. This is done so that these structures are available in common.
|
|
*/
|
|
|
|
|
|
/**
|
|
* Selection filtering that applies all the time (not the "filter selection" dialog that modifies
|
|
* the current selection)
|
|
*/
|
|
struct KICOMMON_API PCB_SELECTION_FILTER_OPTIONS
|
|
{
|
|
bool lockedItems; ///< Allow selecting locked items
|
|
bool footprints; ///< Allow selecting entire footprints
|
|
bool text; ///< Text (free or attached to a footprint)
|
|
bool tracks; ///< Copper tracks
|
|
bool vias; ///< Vias (all types>
|
|
bool pads; ///< Footprint pads
|
|
bool graphics; ///< Graphic lines, shapes, polygons
|
|
bool zones; ///< Copper zones
|
|
bool keepouts; ///< Keepout zones
|
|
bool dimensions; ///< Dimension items
|
|
bool otherItems; ///< Anything not fitting one of the above categories
|
|
|
|
PCB_SELECTION_FILTER_OPTIONS()
|
|
{
|
|
lockedItems = true;
|
|
footprints = true;
|
|
text = true;
|
|
tracks = true;
|
|
vias = true;
|
|
pads = true;
|
|
graphics = true;
|
|
zones = true;
|
|
keepouts = true;
|
|
dimensions = true;
|
|
otherItems = true;
|
|
}
|
|
|
|
/**
|
|
* @return true if any of the item types are enabled (excluding "locked items" which is special)
|
|
*/
|
|
bool Any()
|
|
{
|
|
return ( footprints || text || tracks || vias || pads || graphics || zones
|
|
|| keepouts || dimensions || otherItems );
|
|
}
|
|
|
|
/**
|
|
* @return true if all the item types are enabled (excluding "locked items" which is special)
|
|
*/
|
|
bool All()
|
|
{
|
|
return ( footprints && text && tracks && vias && pads && graphics && zones
|
|
&& keepouts && dimensions && otherItems );
|
|
}
|
|
};
|
|
|
|
/**
|
|
* Determine how inactive layers should be displayed.
|
|
*/
|
|
enum class HIGH_CONTRAST_MODE
|
|
{
|
|
NORMAL = 0, ///< Inactive layers are shown normally (no high-contrast mode)
|
|
DIMMED, ///< Inactive layers are dimmed (old high-contrast mode)
|
|
HIDDEN ///< Inactive layers are hidden
|
|
};
|
|
|
|
///< Determine how zones should be displayed.
|
|
enum class ZONE_DISPLAY_MODE
|
|
{
|
|
SHOW_FILLED,
|
|
SHOW_ZONE_OUTLINE,
|
|
|
|
// Debug modes
|
|
|
|
SHOW_FRACTURE_BORDERS,
|
|
SHOW_TRIANGULATION
|
|
};
|
|
|
|
///< Determine how net color overrides should be applied.
|
|
enum class NET_COLOR_MODE
|
|
{
|
|
OFF, ///< Net (and netclass) colors are not shown
|
|
RATSNEST, ///< Net/netclass colors are shown on ratsnest lines only
|
|
ALL ///< Net/netclass colors are shown on all net copper
|
|
};
|
|
|
|
///< Determine how ratsnest lines are drawn.
|
|
enum class RATSNEST_MODE
|
|
{
|
|
ALL, ///< Ratsnest lines are drawn to items on all layers (default)
|
|
VISIBLE ///< Ratsnest lines are drawn to items on visible layers only
|
|
};
|
|
|
|
///< BOM Data choices for IPC2581 export
|
|
struct KICOMMON_API IP2581_BOM
|
|
{
|
|
wxString mfg; ///< Manufacturer name column
|
|
wxString MPN; ///< Manufacturer part number column
|
|
wxString dist; ///< Distributor name column
|
|
wxString distPN; ///< Distributor part number column
|
|
wxString id; ///< Internal ID column
|
|
};
|
|
|
|
/**
|
|
* A saved set of layers that are visible.
|
|
*/
|
|
struct KICOMMON_API LAYER_PRESET
|
|
{
|
|
LAYER_PRESET( const wxString& aName = wxS( "" ) ) :
|
|
name( aName ),
|
|
layers( LSET::AllLayersMask() ),
|
|
renderLayers( GAL_SET::DefaultVisible() ),
|
|
flipBoard( false ),
|
|
activeLayer( UNSELECTED_LAYER )
|
|
{
|
|
readOnly = false;
|
|
}
|
|
|
|
LAYER_PRESET( const wxString& aName, const LSET& aVisibleLayers, bool aFlipBoard ) :
|
|
name( aName ),
|
|
layers( aVisibleLayers ),
|
|
renderLayers( GAL_SET::DefaultVisible() ),
|
|
flipBoard( aFlipBoard ),
|
|
activeLayer( UNSELECTED_LAYER )
|
|
{
|
|
readOnly = false;
|
|
}
|
|
|
|
LAYER_PRESET( const wxString& aName, const LSET& aVisibleLayers, const GAL_SET& aVisibleObjects,
|
|
PCB_LAYER_ID aActiveLayer, bool aFlipBoard ) :
|
|
name( aName ),
|
|
layers( aVisibleLayers ),
|
|
renderLayers( aVisibleObjects ),
|
|
flipBoard( aFlipBoard ),
|
|
activeLayer( aActiveLayer )
|
|
{
|
|
readOnly = false;
|
|
}
|
|
|
|
bool LayersMatch( const LAYER_PRESET& aOther )
|
|
{
|
|
return aOther.layers == layers && aOther.renderLayers == renderLayers;
|
|
}
|
|
|
|
wxString name; ///< A name for this layer set
|
|
LSET layers; ///< Board layers that are visible
|
|
GAL_SET renderLayers; ///< Render layers (e.g. object types) that are visible
|
|
bool flipBoard; ///< True if the flip board is enabled
|
|
PCB_LAYER_ID activeLayer; ///< Optional layer to set active when this preset is loaded
|
|
bool readOnly; ///< True if this is a read-only (built-in) preset
|
|
};
|
|
|
|
|
|
class KICOMMON_API PARAM_LAYER_PRESET : public PARAM_LAMBDA<nlohmann::json>
|
|
{
|
|
public:
|
|
PARAM_LAYER_PRESET( const std::string& aPath, std::vector<LAYER_PRESET>* aPresetList );
|
|
|
|
static void MigrateToV9Layers( nlohmann::json& aJson );
|
|
|
|
private:
|
|
nlohmann::json presetsToJson();
|
|
|
|
void jsonToPresets( const nlohmann::json& aJson );
|
|
|
|
std::vector<LAYER_PRESET>* m_presets;
|
|
};
|
|
|
|
|
|
struct KICOMMON_API VIEWPORT
|
|
{
|
|
VIEWPORT( const wxString& aName = wxEmptyString ) :
|
|
name( aName )
|
|
{ }
|
|
|
|
VIEWPORT( const wxString& aName, const BOX2D& aRect ) :
|
|
name( aName ),
|
|
rect( aRect )
|
|
{ }
|
|
|
|
wxString name;
|
|
BOX2D rect;
|
|
};
|
|
|
|
|
|
class KICOMMON_API PARAM_VIEWPORT : public PARAM_LAMBDA<nlohmann::json>
|
|
{
|
|
public:
|
|
PARAM_VIEWPORT( const std::string& aPath, std::vector<VIEWPORT>* aViewportList );
|
|
|
|
private:
|
|
nlohmann::json viewportsToJson();
|
|
|
|
void jsonToViewports( const nlohmann::json& aJson );
|
|
|
|
std::vector<VIEWPORT>* m_viewports;
|
|
};
|
|
|
|
|
|
struct KICOMMON_API VIEWPORT3D
|
|
{
|
|
VIEWPORT3D( const wxString& aName = wxEmptyString ) :
|
|
name( aName )
|
|
{ }
|
|
|
|
VIEWPORT3D( const wxString& aName, glm::mat4 aViewMatrix ) :
|
|
name( aName ),
|
|
matrix( std::move( aViewMatrix ) )
|
|
{ }
|
|
|
|
wxString name;
|
|
glm::mat4 matrix;
|
|
};
|
|
|
|
|
|
class KICOMMON_API PARAM_VIEWPORT3D : public PARAM_LAMBDA<nlohmann::json>
|
|
{
|
|
public:
|
|
PARAM_VIEWPORT3D( const std::string& aPath, std::vector<VIEWPORT3D>* aViewportList );
|
|
|
|
private:
|
|
nlohmann::json viewportsToJson();
|
|
|
|
void jsonToViewports( const nlohmann::json & aJson );
|
|
|
|
std::vector<VIEWPORT3D>* m_viewports;
|
|
};
|
|
|
|
|
|
class KICOMMON_API LAYER_PAIR
|
|
{
|
|
public:
|
|
LAYER_PAIR() :
|
|
m_layerA( UNDEFINED_LAYER ), m_layerB( UNDEFINED_LAYER )
|
|
{
|
|
}
|
|
|
|
LAYER_PAIR( PCB_LAYER_ID a, PCB_LAYER_ID b ) :
|
|
m_layerA( a ), m_layerB( b )
|
|
{
|
|
}
|
|
|
|
PCB_LAYER_ID GetLayerA() const { return m_layerA; }
|
|
PCB_LAYER_ID GetLayerB() const { return m_layerB; }
|
|
|
|
void SetLayerA( PCB_LAYER_ID aLayer ) { m_layerA = aLayer; }
|
|
void SetLayerB( PCB_LAYER_ID aLayer ) { m_layerB = aLayer; }
|
|
|
|
/**
|
|
* @return true if the two layer pairs have the same layers, regardless of order
|
|
*/
|
|
bool HasSameLayers( const LAYER_PAIR& aOther ) const
|
|
{
|
|
return ( m_layerA == aOther.m_layerA && m_layerB == aOther.m_layerB )
|
|
|| ( m_layerA == aOther.m_layerB && m_layerB == aOther.m_layerA );
|
|
}
|
|
|
|
private:
|
|
PCB_LAYER_ID m_layerA;
|
|
PCB_LAYER_ID m_layerB;
|
|
};
|
|
|
|
|
|
/**
|
|
* All information about a layer pair as stored in the layer pair store.
|
|
*/
|
|
class KICOMMON_API LAYER_PAIR_INFO
|
|
{
|
|
public:
|
|
LAYER_PAIR_INFO( LAYER_PAIR aPair, bool aEnabled, std::optional<wxString> aName ) :
|
|
m_pair( std::move( aPair ) ), m_enabled( aEnabled), m_name( std::move( aName ) )
|
|
{
|
|
}
|
|
|
|
const LAYER_PAIR& GetLayerPair() const { return m_pair; }
|
|
|
|
const std::optional<wxString>& GetName() const { return m_name; }
|
|
|
|
void SetName( const wxString& aNewName ) { m_name = aNewName; }
|
|
void UnsetName() { m_name = std::nullopt; }
|
|
|
|
bool IsEnabled() const { return m_enabled; }
|
|
void SetEnabled( bool aNewEnabled ) { m_enabled = aNewEnabled; }
|
|
|
|
private:
|
|
LAYER_PAIR m_pair;
|
|
bool m_enabled = true;
|
|
std::optional<wxString> m_name;
|
|
};
|
|
|
|
|
|
class KICOMMON_API PARAM_LAYER_PAIRS : public PARAM_LAMBDA<nlohmann::json>
|
|
{
|
|
public:
|
|
PARAM_LAYER_PAIRS( const std::string& aPath, std::vector<LAYER_PAIR_INFO>& m_layerPairInfos );
|
|
|
|
private:
|
|
nlohmann::json layerPairsToJson();
|
|
|
|
void jsonToLayerPairs( const nlohmann::json& aJson );
|
|
|
|
std::vector<LAYER_PAIR_INFO>& m_layerPairInfos;
|
|
};
|
|
|
|
|
|
/**
|
|
* Persisted state for the net inspector panel
|
|
*/
|
|
struct KICOMMON_API PANEL_NET_INSPECTOR_SETTINGS
|
|
{
|
|
wxString filter_text;
|
|
bool filter_by_net_name;
|
|
bool filter_by_netclass;
|
|
bool group_by_netclass;
|
|
bool group_by_constraint;
|
|
std::vector<wxString> custom_group_rules;
|
|
bool show_zero_pad_nets;
|
|
bool show_unconnected_nets;
|
|
int sorting_column;
|
|
bool sort_order_asc;
|
|
std::vector<int> col_order;
|
|
std::vector<int> col_widths;
|
|
std::vector<bool> col_hidden;
|
|
|
|
std::vector<wxString> expanded_rows;
|
|
|
|
PANEL_NET_INSPECTOR_SETTINGS()
|
|
{
|
|
filter_text = "";
|
|
filter_by_net_name = true;
|
|
filter_by_netclass = true;
|
|
group_by_netclass = false;
|
|
group_by_constraint = false;
|
|
show_zero_pad_nets = false;
|
|
show_unconnected_nets = false;
|
|
sorting_column = -1;
|
|
sort_order_asc = true;
|
|
}
|
|
};
|
|
|
|
|
|
#endif // KICAD_BOARD_PROJECT_SETTINGS_H
|