diff options
author | saurabhb17 | 2020-02-26 16:01:28 +0530 |
---|---|---|
committer | GitHub | 2020-02-26 16:01:28 +0530 |
commit | d51317f0193609fb43e932730d78aa86a4984083 (patch) | |
tree | 6acee185a4dc19113fcbf0f9a3d6941085dedaf7 /gerbview/dcode.h | |
parent | 0db48f6533517ecebfd9f0693f89deca28408b76 (diff) | |
parent | 886d9cb772e81d2e5262284bc3082664f084337f (diff) | |
download | KiCad-eSim-d51317f0193609fb43e932730d78aa86a4984083.tar.gz KiCad-eSim-d51317f0193609fb43e932730d78aa86a4984083.tar.bz2 KiCad-eSim-d51317f0193609fb43e932730d78aa86a4984083.zip |
Merge pull request #2 from FOSSEE/develop
Develop
Diffstat (limited to 'gerbview/dcode.h')
-rw-r--r-- | gerbview/dcode.h | 218 |
1 files changed, 218 insertions, 0 deletions
diff --git a/gerbview/dcode.h b/gerbview/dcode.h new file mode 100644 index 0000000..ebc36c1 --- /dev/null +++ b/gerbview/dcode.h @@ -0,0 +1,218 @@ +/* + * This program source code file is part of KiCad, a free EDA CAD application. + * + * Copyright (C) 1992-2010 Jean-Pierre Charras <jean-pierre.charras@gipsa-lab.inpg.fr> + * Copyright (C) 2010 SoftPLC Corporation, Dick Hollenbeck <dick@softplc.com> + * Copyright (C) 1992-2010 KiCad Developers, see change_log.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 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 + */ + +/** + * @file dcode.h + */ + +#ifndef _DCODE_H_ +#define _DCODE_H_ + +#include <vector> + +#include <base_struct.h> + + +class GERBER_DRAW_ITEM; + + +/** + * Enum APERTURE_T + * is the set of all gerber aperture types allowed, according to page 16 of + * http://gerbv.sourceforge.net/docs/rs274xrevd_e.pdf + */ +enum APERTURE_T { + APT_CIRCLE = 'C', // Flashed shape: Circle with or without hole + APT_RECT = 'R', // Flashed shape: Rectangle with or without hole + APT_OVAL = '0', // Flashed shape: Oval with or without hole + APT_POLYGON = 'P', // Flashed shape: Regular polygon (3 to 12 edges) + // with or without hole. Can be rotated + APT_MACRO = 'M' // Complex shape given by a macro definition (see AM_PRIMITIVE_ID) +}; + +// In aperture definition, round, oval and rectangular flashed shapes +// can have a hole (round or rectangular) +// this option is stored in .m_DrillShape D_CODE member +enum APERTURE_DEF_HOLETYPE { + APT_DEF_NO_HOLE = 0, + APT_DEF_ROUND_HOLE, + APT_DEF_RECT_HOLE +}; + +/* define min and max values for D Codes values. + * note: values >= 0 and > FIRST_DCODE can be used for special purposes + */ +#define FIRST_DCODE 10 +#define LAST_DCODE 999 +#define TOOLS_MAX_COUNT (LAST_DCODE + 1) + +struct APERTURE_MACRO; + + +/** + * Class D_CODE + * holds a gerber DCODE definition. + */ +class D_CODE +{ +private: + APERTURE_MACRO* m_Macro; ///< no ownership, points to + // GERBER.m_aperture_macros element + /** + * parameters used only when this D_CODE holds a reference to an aperture + * macro, and these parameters would customize the macro. + */ + std::vector<double> m_am_params; + + std::vector <wxPoint> m_PolyCorners; /* Polygon used to draw APT_POLYGON shape and some other + * complex shapes which are converted to polygon + * (shapes with hole ) + */ + +public: + wxSize m_Size; /* Horizontal and vertical dimensions. */ + APERTURE_T m_Shape; /* shape ( Line, rectangle, circle , oval .. ) */ + int m_Num_Dcode; /* D code ( >= 10 ) */ + wxSize m_Drill; /* dimension of the hole (if any) */ + APERTURE_DEF_HOLETYPE m_DrillShape; /* shape of the hole (0 = no hole, round = 1, rect = 2) */ + double m_Rotation; /* shape rotation in degrees */ + int m_EdgesCount; /* in aperture definition Polygon only: number of edges for the polygon */ + bool m_InUse; /* false if not used */ + bool m_Defined; /* false if not defined */ + wxString m_SpecialDescr; + +public: + D_CODE( int num_dcode ); + ~D_CODE(); + void Clear_D_CODE_Data(); + + /** + * AppendParam() + * Add a parameter to the D_CODE parameter list. + * used to customize the corresponding aperture macro + */ + void AppendParam( double aValue ) + { + m_am_params.push_back( aValue ); + } + + /** + * GetParamCount() + * Returns the number of parameters stored in parameter list. + */ + unsigned GetParamCount() const + { + return m_am_params.size(); + } + + /** + * GetParam() + * Returns a parameter stored in parameter list. + * @param aIdx = index of parameter + */ + double GetParam( unsigned aIdx ) const + { + wxASSERT( aIdx <= m_am_params.size() ); + if( aIdx <= m_am_params.size() ) + return m_am_params[aIdx - 1]; + else + return 0; + } + + + void SetMacro( APERTURE_MACRO* aMacro ) + { + m_Macro = aMacro; + } + + + APERTURE_MACRO* GetMacro() const { return m_Macro; } + + /** + * Function ShowApertureType + * returns a character string telling what type of aperture type \a aType is. + * @param aType The aperture type to show. + */ + static const wxChar* ShowApertureType( APERTURE_T aType ); + + /** + * Function DrawFlashedShape + * Draw the dcode shape for flashed items. + * When an item is flashed, the DCode shape is the shape of the item + * @param aParent = the GERBER_DRAW_ITEM being drawn + * @param aClipBox = DC clip box (NULL is no clip) + * @param aDC = device context + * @param aColor = the normal color to use + * @param aAltColor = the color used to draw with "reverse" exposure mode (used in + * aperture macros only) + * @param aShapePos = the actual shape position + * @param aFilledShape = true to draw in filled mode, false to draw in sketch mode + */ + void DrawFlashedShape( GERBER_DRAW_ITEM* aParent, EDA_RECT* aClipBox, + wxDC* aDC, EDA_COLOR_T aColor, EDA_COLOR_T aAltColor, + wxPoint aShapePos, bool aFilledShape ); + + /** + * Function DrawFlashedPolygon + * a helper function used to draw the polygon stored ion m_PolyCorners + * Draw some Apertures shapes when they are defined as filled polygons. + * APT_POLYGON is always a polygon, but some complex shapes are also converted to + * polygons (shapes with holes, some rotated shapes) + * @param aParent = the GERBER_DRAW_ITEM being drawn + * @param aClipBox = DC clip box (NULL is no clip) + * @param aDC = device context + * @param aColor = the normal color to use + * @param aFilled = true to draw in filled mode, false to draw in sketch mode + * @param aPosition = the actual shape position + */ + void DrawFlashedPolygon( GERBER_DRAW_ITEM* aParent, + EDA_RECT* aClipBox, wxDC* aDC, EDA_COLOR_T aColor, + bool aFilled, const wxPoint& aPosition ); + + /** + * Function ConvertShapeToPolygon + * convert a shape to an equivalent polygon. + * Arcs and circles are approximated by segments + * Useful when a shape is not a graphic primitive (shape with hole, + * rotated shape ... ) and cannot be easily drawn. + */ + void ConvertShapeToPolygon(); + + /** + * Function GetShapeDim + * calculates a value that can be used to evaluate the size of text + * when displaying the D-Code of an item + * due to the complexity of some shapes, + * one cannot calculate the "size" of a shape (only a bounding box) + * but here, the "dimension" of the shape is the diameter of the primitive + * or for lines the width of the line if the shape is a line + * @param aParent = the parent GERBER_DRAW_ITEM which is actually drawn + * @return a dimension, or -1 if no dim to calculate + */ + int GetShapeDim( GERBER_DRAW_ITEM* aParent ); +}; + + +#endif // ifndef _DCODE_H_ |