diff options
author | saurabhb17 | 2020-02-26 16:11:59 +0530 |
---|---|---|
committer | GitHub | 2020-02-26 16:11:59 +0530 |
commit | e255d0622297488c1c52755be670733418c994cf (patch) | |
tree | 1392c90227aeea231c1d86371131e04c40382918 /pcbnew/pcb_painter.h | |
parent | 0db48f6533517ecebfd9f0693f89deca28408b76 (diff) | |
parent | c38609295ad4b617aef472b9c575aee18710a50f (diff) | |
download | KiCad-eSim-e255d0622297488c1c52755be670733418c994cf.tar.gz KiCad-eSim-e255d0622297488c1c52755be670733418c994cf.tar.bz2 KiCad-eSim-e255d0622297488c1c52755be670733418c994cf.zip |
Merge pull request #1 from saurabhb17/develop
Secondary files
Diffstat (limited to 'pcbnew/pcb_painter.h')
-rw-r--r-- | pcbnew/pcb_painter.h | 219 |
1 files changed, 219 insertions, 0 deletions
diff --git a/pcbnew/pcb_painter.h b/pcbnew/pcb_painter.h new file mode 100644 index 0000000..c6ea211 --- /dev/null +++ b/pcbnew/pcb_painter.h @@ -0,0 +1,219 @@ +/* + * This program source code file is part of KiCad, a free EDA CAD application. + * + * Copyright (C) 2013 CERN + * @author Tomasz Wlostowski <tomasz.wlostowski@cern.ch> + * @author Maciej Suminski <maciej.suminski@cern.ch> + * + * 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 2 + * 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, you may find one here: + * http://www.gnu.org/licenses/old-licenses/gpl-2.0.html + * or you may search the http://www.gnu.org website for the version 2 license, + * or you may write to the Free Software Foundation, Inc., + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA + */ + +#ifndef __CLASS_PCB_PAINTER_H +#define __CLASS_PCB_PAINTER_H + +#include <layers_id_colors_and_visibility.h> +#include <boost/shared_ptr.hpp> +#include <painter.h> + + +class EDA_ITEM; +class COLORS_DESIGN_SETTINGS; +class DISPLAY_OPTIONS; + +class BOARD_ITEM; +class BOARD; +class VIA; +class TRACK; +class D_PAD; +class DRAWSEGMENT; +class MODULE; +class SEGZONE; +class ZONE_CONTAINER; +class TEXTE_PCB; +class TEXTE_MODULE; +class DIMENSION; +class PCB_TARGET; +class MARKER_PCB; + +namespace KIGFX +{ +class GAL; + +/** + * Class PCB_RENDER_SETTINGS + * Stores PCB specific render settings. + */ +class PCB_RENDER_SETTINGS : public RENDER_SETTINGS +{ +public: + friend class PCB_PAINTER; + + enum ClearanceMode { + CL_VIAS = 0x1, + CL_PADS = 0x2, + CL_TRACKS = 0x4 + }; + + ///> Determines how zones should be displayed + enum DisplayZonesMode { + DZ_HIDE_FILLED = 0, + DZ_SHOW_FILLED, + DZ_SHOW_OUTLINED + }; + + PCB_RENDER_SETTINGS(); + + /// @copydoc RENDER_SETTINGS::ImportLegacyColors() + void ImportLegacyColors( const COLORS_DESIGN_SETTINGS* aSettings ); + + /** + * Function LoadDisplayOptions + * Loads settings related to display options (high-contrast mode, full or outline modes + * for vias/pads/tracks and so on). + * @param aOptions are settings that you want to use for displaying items. + */ + void LoadDisplayOptions( const DISPLAY_OPTIONS* aOptions ); + + /// @copydoc RENDER_SETTINGS::GetColor() + virtual const COLOR4D& GetColor( const VIEW_ITEM* aItem, int aLayer ) const; + + /** + * Function GetLayerColor + * Returns the color used to draw a layer. + * @param aLayer is the layer number. + */ + inline const COLOR4D& GetLayerColor( int aLayer ) const + { + return m_layerColors[aLayer]; + } + + /** + * Function SetLayerColor + * Changes the color used to draw a layer. + * @param aLayer is the layer number. + * @param aColor is the new color. + */ + inline void SetLayerColor( int aLayer, const COLOR4D& aColor ) + { + m_layerColors[aLayer] = aColor; + + update(); // recompute other shades of the color + } + + /** + * Function SetSketchMode + * Turns on/off sketch mode for given item layer. + * @param aItemLayer is the item layer that is changed. + * @param aEnabled decides if it is drawn in sketch mode (true for sketched mode, + * false for filled mode). + */ + inline void SetSketchMode( int aItemLayer, bool aEnabled ) + { + m_sketchMode[aItemLayer] = aEnabled; + } + + /** + * Function GetSketchMode + * Returns sketch mode setting for a given item layer. + * @param aItemLayer is the item layer that is changed. + */ + inline bool GetSketchMode( int aItemLayer ) const + { + return m_sketchMode[aItemLayer]; + } + +protected: + ///> @copydoc RENDER_SETTINGS::Update() + void update(); + + ///> Colors for all layers (normal) + COLOR4D m_layerColors[TOTAL_LAYER_COUNT]; + + ///> Colors for all layers (highlighted) + COLOR4D m_layerColorsHi[TOTAL_LAYER_COUNT]; + + ///> Colors for all layers (selected) + COLOR4D m_layerColorsSel[TOTAL_LAYER_COUNT]; + + ///> Colors for all layers (darkened) + COLOR4D m_layerColorsDark[TOTAL_LAYER_COUNT]; + + ///> Flag determining if items on a given layer should be drawn as an outline or a filled item + bool m_sketchMode[TOTAL_LAYER_COUNT]; + + ///> Flag determining if pad numbers should be visible + bool m_padNumbers; + + ///> Flag determining if net names should be visible for pads + bool m_netNamesOnPads; + + ///> Flag determining if net names should be visible for tracks + bool m_netNamesOnTracks; + + ///> Maximum font size for netnames (and other dynamically shown strings) + static const double MAX_FONT_SIZE; + + ///> Option for different display modes for zones + DisplayZonesMode m_displayZoneMode; +}; + + +/** + * Class PCB_PAINTER + * Contains methods for drawing PCB-specific items. + */ +class PCB_PAINTER : public PAINTER +{ +public: + PCB_PAINTER( GAL* aGal ); + + /// @copydoc PAINTER::ApplySettings() + virtual void ApplySettings( const RENDER_SETTINGS* aSettings ) + { + m_pcbSettings = *static_cast<const PCB_RENDER_SETTINGS*>( aSettings ); + } + + /// @copydoc PAINTER::GetSettings() + virtual RENDER_SETTINGS* GetSettings() + { + return &m_pcbSettings; + } + + /// @copydoc PAINTER::Draw() + virtual bool Draw( const VIEW_ITEM* aItem, int aLayer ); + +protected: + PCB_RENDER_SETTINGS m_pcbSettings; + + // Drawing functions for various types of PCB-specific items + void draw( const TRACK* aTrack, int aLayer ); + void draw( const VIA* aVia, int aLayer ); + void draw( const D_PAD* aPad, int aLayer ); + void draw( const DRAWSEGMENT* aSegment, int aLayer ); + void draw( const TEXTE_PCB* aText, int aLayer ); + void draw( const TEXTE_MODULE* aText, int aLayer ); + void draw( const MODULE* aModule, int aLayer ); + void draw( const ZONE_CONTAINER* aZone ); + void draw( const DIMENSION* aDimension, int aLayer ); + void draw( const PCB_TARGET* aTarget ); + void draw( const MARKER_PCB* aMarker ); +}; +} // namespace KIGFX + +#endif /* __CLASS_PAINTER_H */ + |