2014-10-19 22:17:43 +00:00
|
|
|
/*
|
|
|
|
* This program source code file is part of KiCad, a free EDA CAD application.
|
|
|
|
*
|
|
|
|
* Copyright (C) 2007 Jean-Pierre Charras, jp.charras at wanadoo.fr
|
2016-04-16 07:49:17 +00:00
|
|
|
* Copyright (C) 2016 KiCad Developers, see CHANGELOG.TXT for contributors.
|
2014-10-19 22:17:43 +00:00
|
|
|
*
|
|
|
|
* 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
|
|
|
|
*/
|
|
|
|
|
2011-10-07 14:41:30 +00:00
|
|
|
/**
|
|
|
|
* @file general.h
|
|
|
|
*/
|
2007-05-06 16:03:28 +00:00
|
|
|
|
2008-02-26 01:07:38 +00:00
|
|
|
#ifndef _GENERAL_H_
|
|
|
|
#define _GENERAL_H_
|
|
|
|
|
2013-09-25 19:09:57 +00:00
|
|
|
#include <colors.h> // for EDA_COLOR_T
|
2010-10-08 20:40:57 +00:00
|
|
|
|
2010-11-10 15:30:12 +00:00
|
|
|
class TRANSFORM;
|
2013-09-25 19:09:57 +00:00
|
|
|
class SCH_SHEET;
|
2010-11-10 15:30:12 +00:00
|
|
|
|
2008-02-12 22:34:40 +00:00
|
|
|
#define EESCHEMA_VERSION 2
|
2007-05-06 16:03:28 +00:00
|
|
|
#define SCHEMATIC_HEAD_STRING "Schematic File Version"
|
|
|
|
|
2013-09-25 19:09:57 +00:00
|
|
|
#define DANGLING_SYMBOL_SIZE 12
|
2007-05-06 16:03:28 +00:00
|
|
|
|
2015-04-22 11:39:00 +00:00
|
|
|
|
|
|
|
#define DEFAULT_REPEAT_OFFSET_X 0 ///< the default X value (overwritten by the eeschema config)
|
|
|
|
#define DEFAULT_REPEAT_OFFSET_Y 100 ///< the default Y value (overwritten by the eeschema config)
|
|
|
|
#define REPEAT_OFFSET_MAX 1000 ///< the max value of repeat offset value
|
|
|
|
#define DEFAULT_REPEAT_LABEL_INC 1 ///< the default value (overwritten by the eeschema config)
|
|
|
|
#define DEFAULT_REPEAT_OFFSET_PIN 100 ///< the default value (overwritten by the eeschema config)
|
|
|
|
///< when repeating a pin
|
|
|
|
|
2014-08-25 16:31:32 +00:00
|
|
|
///< The thickness to draw busses that do not have a specific width
|
2015-04-22 11:39:00 +00:00
|
|
|
///< (can be changed in preference menu)
|
2014-08-25 16:31:32 +00:00
|
|
|
#define DEFAULTBUSTHICKNESS 12
|
|
|
|
|
|
|
|
///< The thickness to draw lines that thickness is set to 0 (default thickness)
|
|
|
|
///< (can be changed in preference menu)
|
|
|
|
#define DEFAULTDRAWLINETHICKNESS 6
|
|
|
|
|
|
|
|
///< The default pin len value when creating pins(can be changed in preference menu)
|
|
|
|
#define DEFAULTPINLENGTH 200
|
|
|
|
|
|
|
|
///< The default pin len value when creating pins(can be changed in preference menu)
|
|
|
|
#define DEFAULTPINNUMSIZE 50
|
|
|
|
|
|
|
|
///< The default pin len value when creating pins(can be changed in preference menu)
|
|
|
|
#define DEFAULTPINNAMESIZE 50
|
|
|
|
|
2007-05-06 16:03:28 +00:00
|
|
|
#define GR_DEFAULT_DRAWMODE GR_COPY
|
|
|
|
|
2012-09-28 17:47:41 +00:00
|
|
|
// this enum is for color management
|
2014-09-26 10:35:11 +00:00
|
|
|
// Using here "LAYER" in name is due to historical reasons.
|
|
|
|
// Eeschema does not actually use layers. It just uses "LAYER_XX" as identifier
|
|
|
|
// mainly for item color
|
2012-09-28 17:47:41 +00:00
|
|
|
typedef enum {
|
2014-09-26 10:35:11 +00:00
|
|
|
LAYER_FIRST,
|
|
|
|
LAYER_WIRE = LAYER_FIRST,
|
2008-09-19 08:19:15 +00:00
|
|
|
LAYER_BUS,
|
|
|
|
LAYER_JUNCTION,
|
|
|
|
LAYER_LOCLABEL,
|
|
|
|
LAYER_GLOBLABEL,
|
|
|
|
LAYER_HIERLABEL,
|
|
|
|
LAYER_PINNUM,
|
|
|
|
LAYER_PINNAM,
|
|
|
|
LAYER_REFERENCEPART,
|
|
|
|
LAYER_VALUEPART,
|
|
|
|
LAYER_FIELDS,
|
|
|
|
LAYER_DEVICE,
|
|
|
|
LAYER_NOTES,
|
|
|
|
LAYER_NETNAM,
|
|
|
|
LAYER_PIN,
|
|
|
|
LAYER_SHEET,
|
|
|
|
LAYER_SHEETNAME,
|
|
|
|
LAYER_SHEETFILENAME,
|
|
|
|
LAYER_SHEETLABEL,
|
|
|
|
LAYER_NOCONNECT,
|
|
|
|
LAYER_ERC_WARN,
|
|
|
|
LAYER_ERC_ERR,
|
|
|
|
LAYER_DEVICE_BACKGROUND,
|
2010-12-02 21:41:56 +00:00
|
|
|
LAYER_GRID,
|
2014-09-26 10:35:11 +00:00
|
|
|
LAYER_BACKGROUND,
|
|
|
|
LAYERSCH_ID_COUNT
|
|
|
|
} LAYERSCH_ID;
|
2007-05-06 16:03:28 +00:00
|
|
|
|
2014-09-26 10:35:11 +00:00
|
|
|
inline LAYERSCH_ID operator++( LAYERSCH_ID& a )
|
2013-04-06 05:01:48 +00:00
|
|
|
{
|
2014-09-26 10:35:11 +00:00
|
|
|
a = LAYERSCH_ID( int( a ) + 1 );
|
2013-04-06 05:01:48 +00:00
|
|
|
return a;
|
|
|
|
}
|
|
|
|
|
2009-11-04 20:46:53 +00:00
|
|
|
|
2010-11-10 15:30:12 +00:00
|
|
|
/* Rotation, mirror of graphic items in components bodies are handled by a
|
2012-09-28 17:47:41 +00:00
|
|
|
* transform matrix. The default matrix is useful to draw lib entries with
|
|
|
|
* using this default matrix ( no rotation, no mirror but Y axis is bottom to top, and
|
2015-04-22 11:39:00 +00:00
|
|
|
* Y draw axis is to to bottom so we must have a default matrix that reverses
|
2010-11-10 15:30:12 +00:00
|
|
|
* the Y coordinate and keeps the X coordiate
|
|
|
|
*/
|
|
|
|
extern TRANSFORM DefaultTransform;
|
|
|
|
|
2009-06-02 07:26:49 +00:00
|
|
|
/* First and main (root) screen */
|
2012-09-28 17:47:41 +00:00
|
|
|
extern SCH_SHEET* g_RootSheet;
|
2011-10-15 13:25:57 +00:00
|
|
|
|
2012-04-05 18:27:56 +00:00
|
|
|
/**
|
2012-09-28 17:47:41 +00:00
|
|
|
* Default line thickness used to draw/plot items having a
|
2012-04-05 18:27:56 +00:00
|
|
|
* default thickness line value (i.e. = 0 ).
|
|
|
|
*/
|
2012-09-28 17:47:41 +00:00
|
|
|
int GetDefaultLineThickness();
|
2014-05-12 16:57:46 +00:00
|
|
|
void SetDefaultLineThickness( int aThickness );
|
|
|
|
|
2014-05-16 13:57:53 +00:00
|
|
|
/**
|
|
|
|
* Default size for text in general
|
|
|
|
*/
|
|
|
|
int GetDefaultTextSize();
|
|
|
|
void SetDefaultTextSize( int aSize );
|
|
|
|
|
2012-09-28 17:47:41 +00:00
|
|
|
/**
|
|
|
|
* Default line thickness used to draw/plot busses.
|
|
|
|
*/
|
|
|
|
int GetDefaultBusThickness();
|
|
|
|
void SetDefaultBusThickness( int aThickness );
|
2009-06-02 07:26:49 +00:00
|
|
|
|
2014-09-26 10:35:11 +00:00
|
|
|
EDA_COLOR_T GetLayerColor( LAYERSCH_ID aLayer );
|
|
|
|
void SetLayerColor( EDA_COLOR_T aColor, LAYERSCH_ID aLayer );
|
2008-09-13 18:59:57 +00:00
|
|
|
|
2012-09-28 17:47:41 +00:00
|
|
|
// Color to draw selected items
|
|
|
|
EDA_COLOR_T GetItemSelectedColor();
|
2010-12-31 19:47:39 +00:00
|
|
|
|
2012-09-28 17:47:41 +00:00
|
|
|
// Color to draw items flagged invisible, in libedit (they are invisible in Eeschema
|
|
|
|
EDA_COLOR_T GetInvisibleItemColor();
|
2010-12-31 19:47:39 +00:00
|
|
|
|
2012-09-28 17:47:41 +00:00
|
|
|
#endif // _GENERAL_H_
|