2010-09-28 14:42:05 +00:00
|
|
|
/**************/
|
|
|
|
/* dcode.h */
|
|
|
|
/**************/
|
|
|
|
|
2010-10-01 19:11:30 +00:00
|
|
|
/*
|
|
|
|
* 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
|
|
|
|
*/
|
|
|
|
|
2010-09-28 14:42:05 +00:00
|
|
|
#ifndef _DCODE_H_
|
|
|
|
#define _DCODE_H_
|
|
|
|
|
|
|
|
#include <vector>
|
|
|
|
#include <set>
|
|
|
|
|
|
|
|
#include "base_struct.h"
|
2010-10-01 19:11:30 +00:00
|
|
|
class GERBER_DRAW_ITEM;
|
2010-09-28 14:42:05 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* 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
|
|
|
|
*/
|
2010-09-28 19:34:16 +00:00
|
|
|
enum APERTURE_T {
|
2010-09-29 19:00:35 +00:00
|
|
|
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)
|
2010-09-28 14:42:05 +00:00
|
|
|
};
|
|
|
|
|
2010-09-28 19:34:16 +00:00
|
|
|
// In aperture definition, round, oval and rectangular flashed shapes
|
|
|
|
// can have a hole (ropund 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
|
|
|
|
};
|
2010-09-28 14:42:05 +00:00
|
|
|
|
2010-09-28 19:34:16 +00:00
|
|
|
/* define min and max values for D Codes values.
|
|
|
|
* note: values >= 0 and > FIRST_DCODE can be used for specila purposes
|
|
|
|
*/
|
|
|
|
#define FIRST_DCODE 10
|
|
|
|
#define LAST_DCODE 999
|
|
|
|
#define TOOLS_MAX_COUNT (LAST_DCODE + 1)
|
2010-09-28 14:42:05 +00:00
|
|
|
|
2010-10-01 19:11:30 +00:00
|
|
|
class APERTURE_MACRO;
|
2010-09-28 14:42:05 +00:00
|
|
|
class D_CODE;
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Class DCODE_PARAM
|
|
|
|
* holds a parameter for a DCODE or an "aperture macro" as defined within
|
|
|
|
* standard RS274X. The \a value field can be a constant, i.e. "immediate"
|
|
|
|
* parameter or it may not be used if this param is going to defer to the
|
|
|
|
* referencing aperture macro. In that case, the \a index field is an index
|
|
|
|
* into the aperture macro's parameters.
|
|
|
|
*/
|
|
|
|
class DCODE_PARAM
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
DCODE_PARAM() :
|
2010-09-28 19:34:16 +00:00
|
|
|
index( -1 ),
|
|
|
|
value( 0.0 )
|
2010-09-28 14:42:05 +00:00
|
|
|
{}
|
|
|
|
|
2010-09-28 19:34:16 +00:00
|
|
|
double GetValue( const D_CODE* aDcode ) const;
|
|
|
|
|
2010-09-28 14:42:05 +00:00
|
|
|
void SetValue( double aValue )
|
|
|
|
{
|
|
|
|
value = aValue;
|
|
|
|
index = -1;
|
|
|
|
}
|
|
|
|
|
2010-09-28 19:34:16 +00:00
|
|
|
|
2010-09-28 14:42:05 +00:00
|
|
|
/**
|
|
|
|
* Function IsImmediate
|
|
|
|
* tests if this DCODE_PARAM holds an immediate parameter or is a pointer
|
|
|
|
* into a parameter held by an owning D_CODE.
|
|
|
|
*/
|
|
|
|
bool IsImmediate() const { return index == -1; }
|
|
|
|
|
|
|
|
unsigned GetIndex() const
|
|
|
|
{
|
|
|
|
return (unsigned) index;
|
|
|
|
}
|
|
|
|
|
2010-09-28 19:34:16 +00:00
|
|
|
|
2010-09-28 14:42:05 +00:00
|
|
|
void SetIndex( int aIndex )
|
|
|
|
{
|
|
|
|
index = aIndex;
|
|
|
|
}
|
|
|
|
|
2010-09-28 19:34:16 +00:00
|
|
|
|
2010-09-28 14:42:05 +00:00
|
|
|
private:
|
2010-09-28 19:34:16 +00:00
|
|
|
int index; ///< if -1, then \a value field is an immediate value,
|
2010-09-28 14:42:05 +00:00
|
|
|
// else this is an index into parent's
|
|
|
|
// D_CODE.m_am_params.
|
2010-09-28 19:34:16 +00:00
|
|
|
double value; ///< if IsImmediate()==true then use the value, else
|
2010-09-28 14:42:05 +00:00
|
|
|
// not used.
|
|
|
|
};
|
|
|
|
|
2010-09-28 19:34:16 +00:00
|
|
|
typedef std::vector<DCODE_PARAM> DCODE_PARAMS;
|
2010-09-28 14:42:05 +00:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Class D_CODE
|
|
|
|
* holds a gerber DCODE definition.
|
|
|
|
*/
|
|
|
|
class D_CODE
|
|
|
|
{
|
|
|
|
friend class DCODE_PARAM;
|
|
|
|
|
|
|
|
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.
|
|
|
|
*/
|
2010-09-28 19:34:16 +00:00
|
|
|
DCODE_PARAMS m_am_params;
|
2010-09-28 14:42:05 +00:00
|
|
|
|
2010-09-29 19:00:35 +00:00
|
|
|
std::vector <wxPoint> m_PolyCorners; /* Polygon used to draw APT_POLYGON shape and some other
|
2010-09-28 14:42:05 +00:00
|
|
|
* complex shapes which are converted to polygon
|
2010-09-29 19:00:35 +00:00
|
|
|
* (shapes with hole )
|
2010-09-28 14:42:05 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
public:
|
2010-10-01 19:11:30 +00:00
|
|
|
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 */
|
2010-10-05 11:44:34 +00:00
|
|
|
int m_EdgesCount; /* in aperture definition Polygon only: number of edges for the polygon */
|
2010-10-01 19:11:30 +00:00
|
|
|
bool m_InUse; /* FALSE if not used */
|
|
|
|
bool m_Defined; /* FALSE if not defined */
|
2010-09-28 19:34:16 +00:00
|
|
|
wxString m_SpecialDescr;
|
2010-09-28 14:42:05 +00:00
|
|
|
|
|
|
|
public:
|
|
|
|
D_CODE( int num_dcode );
|
|
|
|
~D_CODE();
|
|
|
|
void Clear_D_CODE_Data();
|
|
|
|
|
|
|
|
void AppendParam( double aValue )
|
|
|
|
{
|
|
|
|
DCODE_PARAM param;
|
|
|
|
|
|
|
|
param.SetValue( aValue );
|
|
|
|
|
|
|
|
m_am_params.push_back( param );
|
|
|
|
}
|
|
|
|
|
2010-09-28 19:34:16 +00:00
|
|
|
|
2010-09-28 14:42:05 +00:00
|
|
|
void SetMacro( APERTURE_MACRO* aMacro )
|
|
|
|
{
|
|
|
|
m_Macro = aMacro;
|
|
|
|
}
|
2010-09-28 19:34:16 +00:00
|
|
|
|
|
|
|
|
2010-09-28 14:42:05 +00:00
|
|
|
APERTURE_MACRO* GetMacro() { 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
|
2010-10-10 17:57:54 +00:00
|
|
|
* @param aParent = the GERBER_DRAW_ITEM being drawn
|
2010-10-03 15:39:06 +00:00
|
|
|
* @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 aFilled = true to draw in filled mode, false to draw in skecth mode
|
|
|
|
* @param aPosition = the actual shape position
|
2010-09-28 14:42:05 +00:00
|
|
|
*/
|
2010-10-01 19:11:30 +00:00
|
|
|
void DrawFlashedShape( GERBER_DRAW_ITEM* aParent,
|
2010-10-03 15:39:06 +00:00
|
|
|
EDA_Rect* aClipBox, wxDC* aDC, int aColor, int aAltColor,
|
2010-10-01 19:11:30 +00:00
|
|
|
wxPoint aShapePos, bool aFilledShape );
|
2010-09-28 14:42:05 +00:00
|
|
|
|
|
|
|
/** function DrawFlashedPolygon
|
|
|
|
* a helper function used id ::Draw 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)
|
2010-10-10 17:57:54 +00:00
|
|
|
* @param aParent = the GERBER_DRAW_ITEM being drawn
|
2010-10-03 15:39:06 +00:00
|
|
|
* @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 skecth mode
|
|
|
|
* @param aPosition = the actual shape position
|
|
|
|
*/
|
2010-10-10 17:57:54 +00:00
|
|
|
void DrawFlashedPolygon( GERBER_DRAW_ITEM* aParent,
|
|
|
|
EDA_Rect* aClipBox, wxDC* aDC, int aColor,
|
2010-09-28 19:34:16 +00:00
|
|
|
bool aFilled, const wxPoint& aPosition );
|
2010-09-28 14:42:05 +00:00
|
|
|
|
|
|
|
/** 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.
|
|
|
|
*/
|
2010-09-28 19:34:16 +00:00
|
|
|
void ConvertShapeToPolygon();
|
2010-10-23 18:12:11 +00:00
|
|
|
|
|
|
|
/** GetShapeDim
|
|
|
|
* Calculate 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 );
|
2010-09-28 14:42:05 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
inline double DCODE_PARAM::GetValue( const D_CODE* aDcode ) const
|
|
|
|
{
|
|
|
|
if( IsImmediate() )
|
|
|
|
return value;
|
|
|
|
else
|
|
|
|
{
|
|
|
|
// the first one was numbered 1, not zero, as in $1, see page 19 of spec.
|
|
|
|
unsigned ndx = GetIndex() - 1;
|
2010-09-28 19:34:16 +00:00
|
|
|
wxASSERT( aDcode );
|
|
|
|
|
2010-09-28 14:42:05 +00:00
|
|
|
// get the parameter from the aDcode
|
|
|
|
if( ndx < aDcode->m_am_params.size() )
|
|
|
|
return aDcode->m_am_params[ndx].GetValue( NULL );
|
|
|
|
else
|
|
|
|
{
|
2010-09-28 19:34:16 +00:00
|
|
|
wxASSERT( GetIndex() - 1 < aDcode->m_am_params.size() );
|
2010-09-28 14:42:05 +00:00
|
|
|
return 0.0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#endif // ifndef _DCODE_H_
|