kicad/eeschema/cmpclass.cpp

300 lines
7.3 KiB
C++
Raw Normal View History

/***********************************************************************/
/* Methodes de base de gestion des classes des elements de schematique */
/***********************************************************************/
#include "fctsys.h"
#include "gr_basic.h"
#include "common.h"
#include "program.h"
#include "libcmp.h"
#include "general.h"
#include "id.h"
#include "protos.h"
/*******************************************************************/
2007-08-23 04:28:46 +00:00
DrawBusEntryStruct::DrawBusEntryStruct( const wxPoint& pos, int shape, int id ) :
EDA_BaseStruct( DRAW_BUSENTRY_STRUCT_TYPE )
/*******************************************************************/
{
2007-08-23 04:28:46 +00:00
m_Pos = pos;
m_Size.x = 100;
m_Size.y = 100;
m_Layer = LAYER_WIRE;
m_Width = 0;
if( id == BUS_TO_BUS )
{
m_Layer = LAYER_BUS;
m_Width = 1;
}
if( shape == '/' )
m_Size.y = -100;
}
/*************************************/
2007-09-01 12:00:30 +00:00
wxPoint DrawBusEntryStruct::m_End()
/*************************************/
2007-08-23 04:28:46 +00:00
// retourne la coord de fin du raccord
{
2007-08-23 04:28:46 +00:00
return wxPoint( m_Pos.x + m_Size.x, m_Pos.y + m_Size.y );
}
2007-08-23 04:28:46 +00:00
/***************************************************/
2007-09-01 12:00:30 +00:00
DrawBusEntryStruct* DrawBusEntryStruct::GenCopy()
/***************************************************/
{
2007-08-23 04:28:46 +00:00
DrawBusEntryStruct* newitem = new DrawBusEntryStruct( m_Pos, 0, 0 );
2007-08-23 04:28:46 +00:00
newitem->m_Layer = m_Layer;
newitem->m_Width = m_Width;
newitem->m_Size = m_Size;
newitem->m_Flags = m_Flags;
2007-08-23 04:28:46 +00:00
return newitem;
}
2007-08-23 04:28:46 +00:00
/****************************/
/* class DrawJunctionStruct */
/***************************/
/************************************************************/
2007-08-23 04:28:46 +00:00
DrawJunctionStruct::DrawJunctionStruct( const wxPoint& pos ) :
EDA_BaseStruct( DRAW_JUNCTION_STRUCT_TYPE )
/************************************************************/
{
2007-08-23 04:28:46 +00:00
m_Pos = pos;
m_Layer = LAYER_JUNCTION;
}
2007-08-23 04:28:46 +00:00
2007-09-01 12:00:30 +00:00
DrawJunctionStruct* DrawJunctionStruct::GenCopy()
{
2007-08-23 04:28:46 +00:00
DrawJunctionStruct* newitem = new DrawJunctionStruct( m_Pos );
2007-08-23 04:28:46 +00:00
newitem->m_Layer = m_Layer;
newitem->m_Flags = m_Flags;
2007-08-23 04:28:46 +00:00
return newitem;
}
2007-08-23 04:28:46 +00:00
/*****************************/
/* class DrawNoConnectStruct */
/*****************************/
2007-08-23 04:28:46 +00:00
DrawNoConnectStruct::DrawNoConnectStruct( const wxPoint& pos ) :
EDA_BaseStruct( DRAW_NOCONNECT_STRUCT_TYPE )
{
2007-08-23 04:28:46 +00:00
m_Pos = pos;
}
2007-08-23 04:28:46 +00:00
2007-09-01 12:00:30 +00:00
DrawNoConnectStruct* DrawNoConnectStruct::GenCopy()
{
2007-08-23 04:28:46 +00:00
DrawNoConnectStruct* newitem = new DrawNoConnectStruct( m_Pos );
2007-08-23 04:28:46 +00:00
newitem->m_Flags = m_Flags;
2007-08-23 04:28:46 +00:00
return newitem;
}
2007-08-23 04:28:46 +00:00
/**************************/
/* class DrawMarkerStruct */
/**************************/
2007-08-23 04:28:46 +00:00
DrawMarkerStruct::DrawMarkerStruct( const wxPoint& pos, const wxString& text ) :
EDA_BaseStruct( DRAW_MARKER_STRUCT_TYPE )
{
2007-08-23 04:28:46 +00:00
m_Pos = pos; /* XY coordinates of marker. */
m_Type = MARQ_UNSPEC;
m_MarkFlags = 0; // complements d'information
m_Comment = text;
}
2007-08-23 04:28:46 +00:00
2007-09-01 12:00:30 +00:00
DrawMarkerStruct::~DrawMarkerStruct()
{
}
2007-08-23 04:28:46 +00:00
2007-09-01 12:00:30 +00:00
DrawMarkerStruct* DrawMarkerStruct::GenCopy()
{
2007-08-23 04:28:46 +00:00
DrawMarkerStruct* newitem = new DrawMarkerStruct( m_Pos, m_Comment );
newitem->m_Type = m_Type;
newitem->m_MarkFlags = m_MarkFlags;
2007-08-23 04:28:46 +00:00
return newitem;
}
2007-09-01 12:00:30 +00:00
wxString DrawMarkerStruct::GetComment()
{
2007-08-23 04:28:46 +00:00
return m_Comment;
}
2007-09-20 21:06:49 +00:00
#if defined(DEBUG)
/**
* Function Show
* is used to output the object tree, currently for debugging only.
* @param nestLevel An aid to prettier tree indenting, and is the level
* of nesting of this object within the overall tree.
* @param os The ostream& to output to.
*/
void DrawMarkerStruct::Show( int nestLevel, std::ostream& os )
{
// for now, make it look like XML:
NestedSpace( nestLevel, os ) << '<' << GetClass().Lower().mb_str() << m_Pos
<< "/>\n";
}
#endif
2007-08-23 04:28:46 +00:00
/***************************/
/* Class EDA_DrawLineStruct */
/***************************/
2007-08-23 04:28:46 +00:00
EDA_DrawLineStruct::EDA_DrawLineStruct( const wxPoint& pos, int layer ) :
EDA_BaseStruct( NULL, DRAW_SEGMENT_STRUCT_TYPE )
{
2007-08-23 04:28:46 +00:00
m_Start = pos;
m_End = pos;
m_StartIsDangling = m_EndIsDangling = FALSE;
switch( layer )
{
default:
m_Layer = LAYER_NOTES; /* Mettre ds Notes */
m_Width = GR_NORM_WIDTH;
break;
case LAYER_WIRE:
m_Layer = LAYER_WIRE;
m_Width = GR_NORM_WIDTH;
break;
case LAYER_BUS:
m_Layer = LAYER_BUS;
m_Width = GR_THICK_WIDTH;
break;
}
}
2007-08-23 04:28:46 +00:00
/***************************************************/
2007-09-01 12:00:30 +00:00
EDA_DrawLineStruct* EDA_DrawLineStruct::GenCopy()
/***************************************************/
{
2007-08-23 04:28:46 +00:00
EDA_DrawLineStruct* newitem = new EDA_DrawLineStruct( m_Start, m_Layer );
2007-08-23 04:28:46 +00:00
newitem->m_End = m_End;
2007-08-23 04:28:46 +00:00
return newitem;
}
2007-08-23 04:28:46 +00:00
/************************************************************/
2007-08-23 04:28:46 +00:00
bool EDA_DrawLineStruct::IsOneEndPointAt( const wxPoint& pos )
/************************************************************/
2007-08-23 04:28:46 +00:00
/* Return TRUE if the start or the end point is in position pos
2007-08-23 04:28:46 +00:00
*/
{
2007-08-23 04:28:46 +00:00
if( (pos.x == m_Start.x) && (pos.y == m_Start.y) )
return TRUE;
if( (pos.x == m_End.x) && (pos.y == m_End.y) )
return TRUE;
return FALSE;
}
2007-08-23 04:28:46 +00:00
2007-09-20 21:06:49 +00:00
#if defined(DEBUG)
/**
* Function Show
* is used to output the object tree, currently for debugging only.
* @param nestLevel An aid to prettier tree indenting, and is the level
* of nesting of this object within the overall tree.
* @param os The ostream& to output to.
*/
void EDA_DrawLineStruct::Show( int nestLevel, std::ostream& os )
{
NestedSpace( nestLevel, os ) << '<' << GetClass().Lower().mb_str() <<
" layer=\"" << m_Layer << '"' <<
" width=\"" << m_Width << '"' <<
" startIsDangling=\"" << m_StartIsDangling << '"' <<
" endIsDangling=\"" << m_EndIsDangling << '"' << ">" <<
" <start" << m_Start << "/>" <<
" <end" << m_End << "/>" <<
"</" << GetClass().Lower().mb_str() << ">\n";
}
#endif
2007-08-23 04:28:46 +00:00
/****************************/
/* Class DrawPolylineStruct */
/****************************/
/***********************************************************/
2007-08-23 04:28:46 +00:00
DrawPolylineStruct::DrawPolylineStruct( int layer ) :
EDA_BaseStruct( DRAW_POLYLINE_STRUCT_TYPE )
/***********************************************************/
{
2007-08-23 04:28:46 +00:00
m_NumOfPoints = 0; /* Number of XY pairs in Points array. */
m_Points = NULL; /* XY pairs that forms the polyline. */
m_Width = GR_NORM_WIDTH;
switch( layer )
{
default:
m_Layer = LAYER_NOTES;
break;
case LAYER_WIRE:
case LAYER_NOTES:
m_Layer = layer;
break;
case LAYER_BUS:
m_Layer = layer;
m_Width = GR_THICK_WIDTH;
break;
}
}
/********************************************/
2007-09-01 12:00:30 +00:00
DrawPolylineStruct::~DrawPolylineStruct()
/*********************************************/
{
2007-08-23 04:28:46 +00:00
if( m_Points )
free( m_Points );
}
2007-08-23 04:28:46 +00:00
/*****************************************************/
2007-09-01 12:00:30 +00:00
DrawPolylineStruct* DrawPolylineStruct::GenCopy()
/*****************************************************/
{
2007-08-23 04:28:46 +00:00
int memsize;
2007-08-23 04:28:46 +00:00
DrawPolylineStruct* newitem =
new DrawPolylineStruct( m_Layer );
2007-08-23 04:28:46 +00:00
memsize = sizeof(int) * 2 * m_NumOfPoints;
newitem->m_NumOfPoints = m_NumOfPoints;
newitem->m_Points = (int*) MyZMalloc( memsize );
memcpy( newitem->m_Points, m_Points, memsize );
2007-08-23 04:28:46 +00:00
return newitem;
}