mirror of
https://gitlab.com/kicad/code/kicad.git
synced 2025-04-06 15:45:30 +00:00
Recommendation is to avoid using the year nomenclature as this information is already encoded in the git repo. Avoids needing to repeatly update. Also updates AUTHORS.txt from current repo with contributor names
223 lines
8.1 KiB
C++
223 lines
8.1 KiB
C++
/*
|
|
* 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 The 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 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 <gal/color4d.h>
|
|
#include <geometry/shape_poly_set.h>
|
|
|
|
using KIGFX::COLOR4D;
|
|
|
|
class wxDC;
|
|
class GERBER_DRAW_ITEM;
|
|
|
|
|
|
/**
|
|
* The set of all gerber aperture types allowed
|
|
* from ADD dcode command, like %ADD11C,0.304800*% to add a DCode number 11, circle shape
|
|
*/
|
|
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 10000
|
|
#define TOOLS_MAX_COUNT (LAST_DCODE + 1)
|
|
|
|
class APERTURE_MACRO;
|
|
|
|
|
|
/**
|
|
* A gerber DCODE (also called Aperture) definition.
|
|
*/
|
|
class D_CODE
|
|
{
|
|
public:
|
|
D_CODE( int num_dcode );
|
|
~D_CODE();
|
|
void Clear_D_CODE_Data();
|
|
|
|
/**
|
|
* 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 );
|
|
}
|
|
|
|
/**
|
|
* Return the number of parameters stored in parameter list.
|
|
*/
|
|
unsigned GetParamCount() const
|
|
{
|
|
return m_am_params.size();
|
|
}
|
|
|
|
/**
|
|
* Return a parameter stored in parameter list.
|
|
*
|
|
* @param aIdx is the index of parameter.
|
|
* for n parameters from the Dcode definition, aIdx = 1 .. n, not 0
|
|
*/
|
|
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; }
|
|
|
|
/**
|
|
* Return a character string telling what type of aperture type \a aType is.
|
|
*
|
|
* @param aType is the aperture type to show.
|
|
*/
|
|
static const wxChar* ShowApertureType( APERTURE_T aType );
|
|
|
|
/**
|
|
* Draw the dcode shape for flashed items.
|
|
*
|
|
* When an item is flashed, the DCode shape is the shape of the item.
|
|
*
|
|
* @param aParent is the #GERBER_DRAW_ITEM being drawn.
|
|
* @param aDC is the device context.
|
|
* @param aColor is the normal color to use.
|
|
* @param aShapePos is the actual shape position
|
|
* @param aFilledShape set to true to draw in filled mode, false to draw in sketch mode
|
|
*/
|
|
void DrawFlashedShape( const GERBER_DRAW_ITEM* aParent, wxDC* aDC,
|
|
const COLOR4D& aColor,
|
|
const VECTOR2I& aShapePos, bool aFilledShape );
|
|
|
|
/**
|
|
* A helper function used to draw the polygon stored in 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 is the #GERBER_DRAW_ITEM being drawn.
|
|
* @param aDC is the device context.
|
|
* @param aColor is the normal color to use.
|
|
* @param aFilled set to true to draw in filled mode, false to draw in sketch mode.
|
|
* @param aPosition is the actual shape position.
|
|
*/
|
|
void DrawFlashedPolygon( const GERBER_DRAW_ITEM* aParent, wxDC* aDC,
|
|
const COLOR4D& aColor,
|
|
bool aFilled, const VECTOR2I& aPosition );
|
|
|
|
/**
|
|
* 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.
|
|
* @param aParent is the #GERBER_DRAW_ITEM using this DCode.
|
|
* Not used in all shapes, used for APT_MACRO
|
|
*/
|
|
void ConvertShapeToPolygon( const GERBER_DRAW_ITEM* aParent );
|
|
|
|
/**
|
|
* 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 is 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 );
|
|
|
|
public:
|
|
VECTOR2I m_Size; ///< Horizontal and vertical dimensions.
|
|
APERTURE_T m_ApertType; ///< Aperture type ( Line, rectangle, circle,
|
|
///< oval poly, macro )
|
|
int m_Num_Dcode; ///< D code value ( >= 10 )
|
|
VECTOR2I m_Drill; ///< dimension of the hole (if any) (drill file)
|
|
APERTURE_DEF_HOLETYPE m_DrillShape; ///< shape of the hole (0 = no hole, round = 1,
|
|
///< rect = 2).
|
|
EDA_ANGLE m_Rotation; ///< shape rotation
|
|
int m_EdgesCount; ///< in aperture definition Polygon only:
|
|
///< number of edges for the polygon
|
|
bool m_InUse; ///< false if the aperture (previously defined)
|
|
///< is not used to draw something
|
|
bool m_Defined; ///< false if the aperture is not defined in the header
|
|
wxString m_AperFunction; ///< the aperture attribute (created by a
|
|
///< %TA.AperFunction command).
|
|
///< attached to the D_CODE
|
|
SHAPE_POLY_SET m_Polygon; /* Polygon used to draw APT_POLYGON shape and some other
|
|
* complex shapes which are converted to polygon
|
|
* (shapes with hole )
|
|
*/
|
|
|
|
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;
|
|
};
|
|
|
|
|
|
#endif // ifndef _DCODE_H_
|