2007-06-05 12:10:51 +00:00
|
|
|
/****************************************************/
|
|
|
|
/* fonctions de la classe MIRE (targets for photos) */
|
|
|
|
/****************************************************/
|
|
|
|
|
|
|
|
#include "fctsys.h"
|
|
|
|
#include "gr_basic.h"
|
|
|
|
|
|
|
|
#include "common.h"
|
|
|
|
#include "pcbnew.h"
|
|
|
|
|
|
|
|
|
2007-08-23 04:28:46 +00:00
|
|
|
MIREPCB::MIREPCB( BOARD_ITEM* StructFather ) :
|
|
|
|
BOARD_ITEM( StructFather, TYPEMIRE )
|
2007-06-05 12:10:51 +00:00
|
|
|
{
|
2007-08-08 20:51:08 +00:00
|
|
|
m_Shape = 0;
|
|
|
|
m_Size = 5000;
|
2007-06-05 12:10:51 +00:00
|
|
|
}
|
|
|
|
|
2007-08-08 20:51:08 +00:00
|
|
|
|
2007-08-23 04:28:46 +00:00
|
|
|
MIREPCB::~MIREPCB()
|
2007-06-05 12:10:51 +00:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/***************************/
|
2007-09-01 12:00:30 +00:00
|
|
|
void MIREPCB::UnLink()
|
2007-06-05 12:10:51 +00:00
|
|
|
/***************************/
|
2007-08-08 20:51:08 +00:00
|
|
|
|
2007-06-05 12:10:51 +00:00
|
|
|
/* supprime du chainage la structure Struct
|
2007-08-08 20:51:08 +00:00
|
|
|
* les structures arrieres et avant sont chainees directement
|
2007-06-05 12:10:51 +00:00
|
|
|
*/
|
|
|
|
{
|
2007-08-08 20:51:08 +00:00
|
|
|
/* Modification du chainage arriere */
|
|
|
|
if( Pback )
|
|
|
|
{
|
2007-09-01 12:00:30 +00:00
|
|
|
if( Pback->Type() != TYPEPCB )
|
2007-08-08 20:51:08 +00:00
|
|
|
{
|
|
|
|
Pback->Pnext = Pnext;
|
|
|
|
}
|
|
|
|
else /* Le chainage arriere pointe sur la structure "Pere" */
|
|
|
|
{
|
2007-08-23 04:28:46 +00:00
|
|
|
( (BOARD*) Pback )->m_Drawings = (BOARD_ITEM*) Pnext;
|
2007-08-08 20:51:08 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Modification du chainage avant */
|
|
|
|
if( Pnext )
|
|
|
|
Pnext->Pback = Pback;
|
|
|
|
|
|
|
|
Pnext = Pback = NULL;
|
2007-06-05 12:10:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**********************************/
|
2007-08-08 20:51:08 +00:00
|
|
|
void MIREPCB::Copy( MIREPCB* source )
|
2007-06-05 12:10:51 +00:00
|
|
|
/**********************************/
|
|
|
|
{
|
2007-08-08 20:51:08 +00:00
|
|
|
m_Layer = source->m_Layer;
|
|
|
|
m_Width = source->m_Width;
|
|
|
|
m_Pos = source->m_Pos;
|
|
|
|
m_Shape = source->m_Shape;
|
|
|
|
m_Size = source->m_Size;
|
|
|
|
m_TimeStamp = GetTimeStamp();
|
2007-06-05 12:10:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**************************************************************/
|
2007-08-08 20:51:08 +00:00
|
|
|
bool MIREPCB::ReadMirePcbDescr( FILE* File, int* LineNum )
|
2007-06-05 12:10:51 +00:00
|
|
|
/**************************************************************/
|
2007-08-08 20:51:08 +00:00
|
|
|
|
2007-06-05 12:10:51 +00:00
|
|
|
/* Lecture de la description de 1 segment type Drawing PCB
|
2007-08-08 20:51:08 +00:00
|
|
|
*/
|
2007-06-05 12:10:51 +00:00
|
|
|
{
|
2007-08-08 20:51:08 +00:00
|
|
|
char Line[256];
|
|
|
|
|
|
|
|
while( GetLine( File, Line, LineNum ) != NULL )
|
|
|
|
{
|
|
|
|
if( strnicmp( Line, "$End", 4 ) == 0 )
|
|
|
|
return TRUE; /* fin de liste */
|
|
|
|
if( Line[0] == 'P' )
|
|
|
|
{
|
|
|
|
sscanf( Line + 2, " %X %d %d %d %d %d %lX",
|
|
|
|
&m_Shape, &m_Layer,
|
|
|
|
&m_Pos.x, &m_Pos.y,
|
|
|
|
&m_Size, &m_Width, &m_TimeStamp );
|
|
|
|
if( m_Layer < FIRST_NO_COPPER_LAYER )
|
|
|
|
m_Layer = FIRST_NO_COPPER_LAYER;
|
|
|
|
if( m_Layer > LAST_NO_COPPER_LAYER )
|
|
|
|
m_Layer = LAST_NO_COPPER_LAYER;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return FALSE;
|
2007-06-05 12:10:51 +00:00
|
|
|
}
|
|
|
|
|
2007-12-29 19:15:58 +00:00
|
|
|
/**************************************/
|
2007-10-30 21:30:58 +00:00
|
|
|
bool MIREPCB::Save( FILE* aFile ) const
|
2007-12-29 19:15:58 +00:00
|
|
|
/**************************************/
|
2007-10-30 21:30:58 +00:00
|
|
|
{
|
|
|
|
if( GetState( DELETED ) )
|
|
|
|
return true;
|
|
|
|
|
|
|
|
bool rc = false;
|
2008-04-01 05:21:50 +00:00
|
|
|
|
2007-10-30 21:30:58 +00:00
|
|
|
if( fprintf( aFile, "$MIREPCB\n" ) != sizeof("$MIREPCB\n")-1 )
|
|
|
|
goto out;
|
2008-04-01 05:21:50 +00:00
|
|
|
|
2007-10-30 21:30:58 +00:00
|
|
|
fprintf( aFile, "Po %X %d %d %d %d %d %8.8lX\n",
|
|
|
|
m_Shape, m_Layer,
|
|
|
|
m_Pos.x, m_Pos.y,
|
|
|
|
m_Size, m_Width, m_TimeStamp );
|
2008-04-01 05:21:50 +00:00
|
|
|
|
2007-10-30 21:30:58 +00:00
|
|
|
if( fprintf( aFile, "$EndMIREPCB\n" ) != sizeof("$EndMIREPCB\n")-1 )
|
|
|
|
goto out;
|
2008-04-01 05:21:50 +00:00
|
|
|
|
2007-10-30 21:30:58 +00:00
|
|
|
rc = true;
|
|
|
|
|
2008-04-01 05:21:50 +00:00
|
|
|
out:
|
2007-10-30 21:30:58 +00:00
|
|
|
return rc;
|
|
|
|
}
|
2008-04-01 05:21:50 +00:00
|
|
|
|
|
|
|
|
2007-06-05 12:10:51 +00:00
|
|
|
|
|
|
|
|
|
|
|
/**********************************************************/
|
2007-08-08 20:51:08 +00:00
|
|
|
void MIREPCB::Draw( WinEDA_DrawPanel* panel, wxDC* DC,
|
2008-04-01 05:21:50 +00:00
|
|
|
int mode_color, const wxPoint& offset )
|
2007-06-05 12:10:51 +00:00
|
|
|
/**********************************************************/
|
2007-08-08 20:51:08 +00:00
|
|
|
|
2007-06-05 12:10:51 +00:00
|
|
|
/* Affichage de 1 mire : 2 segments + 1 cercle
|
2007-08-08 20:51:08 +00:00
|
|
|
* le cercle a pour rayon le demi rayon de la mire
|
|
|
|
* les 2 traits ont pour longueur le diametre de la mire
|
|
|
|
*/
|
2007-06-05 12:10:51 +00:00
|
|
|
{
|
2007-08-08 20:51:08 +00:00
|
|
|
int rayon, ox, oy, gcolor, width;
|
|
|
|
int dx1, dx2, dy1, dy2;
|
|
|
|
int typeaff;
|
|
|
|
int zoom;
|
|
|
|
|
|
|
|
ox = m_Pos.x + offset.x;
|
|
|
|
oy = m_Pos.y + offset.y;
|
|
|
|
|
|
|
|
gcolor = g_DesignSettings.m_LayerColor[m_Layer];
|
|
|
|
if( (gcolor & ITEM_NOT_SHOW) != 0 )
|
|
|
|
return;
|
|
|
|
|
|
|
|
zoom = panel->GetZoom();
|
|
|
|
|
|
|
|
GRSetDrawMode( DC, mode_color );
|
|
|
|
typeaff = DisplayOpt.DisplayDrawItems;
|
|
|
|
width = m_Width;
|
|
|
|
if( width / zoom < 2 )
|
|
|
|
typeaff = FILAIRE;
|
|
|
|
|
|
|
|
/* Trace du cercle: */
|
|
|
|
rayon = m_Size / 4;
|
|
|
|
|
|
|
|
switch( typeaff )
|
|
|
|
{
|
|
|
|
case FILAIRE:
|
|
|
|
width = 0;
|
|
|
|
|
|
|
|
case FILLED:
|
|
|
|
GRCircle( &panel->m_ClipBox, DC, ox, oy, rayon, width, gcolor );
|
|
|
|
break;
|
|
|
|
|
|
|
|
case SKETCH:
|
|
|
|
GRCircle( &panel->m_ClipBox, DC, ox, oy, rayon + (width / 2), gcolor );
|
|
|
|
GRCircle( &panel->m_ClipBox, DC, ox, oy, rayon - (width / 2), gcolor );
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/* Trace des 2 traits */
|
|
|
|
rayon = m_Size / 2;
|
|
|
|
dx1 = rayon, dy1 = 0;
|
|
|
|
dx2 = 0, dy2 = rayon;
|
|
|
|
|
|
|
|
if( m_Shape ) /* Forme X */
|
|
|
|
{
|
|
|
|
dx1 = dy1 = (rayon * 7) / 5;
|
|
|
|
dx2 = dx1; dy2 = -dy1;
|
|
|
|
}
|
|
|
|
|
|
|
|
switch( typeaff )
|
|
|
|
{
|
|
|
|
case FILAIRE:
|
|
|
|
case FILLED:
|
|
|
|
GRLine( &panel->m_ClipBox, DC, ox - dx1, oy - dy1,
|
|
|
|
ox + dx1, oy + dy1, width, gcolor );
|
|
|
|
GRLine( &panel->m_ClipBox, DC, ox - dx2, oy - dy2,
|
|
|
|
ox + dx2, oy + dy2, width, gcolor );
|
|
|
|
break;
|
|
|
|
|
|
|
|
case SKETCH:
|
|
|
|
GRCSegm( &panel->m_ClipBox, DC, ox - dx1, oy - dy1,
|
|
|
|
ox + dx1, oy + dy1,
|
|
|
|
width, gcolor );
|
|
|
|
GRCSegm( &panel->m_ClipBox, DC, ox - dx2, oy - dy2,
|
|
|
|
ox + dx2, oy + dy2,
|
|
|
|
width, gcolor );
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function HitTest
|
|
|
|
* tests if the given wxPoint is within the bounds of this object.
|
|
|
|
* @param refPos A wxPoint to test
|
|
|
|
* @return bool - true if a hit, else false
|
|
|
|
*/
|
|
|
|
bool MIREPCB::HitTest( const wxPoint& refPos )
|
|
|
|
{
|
|
|
|
int dX = refPos.x - m_Pos.x;
|
|
|
|
int dY = refPos.y - m_Pos.y;
|
|
|
|
int rayon = m_Size / 2;
|
|
|
|
return abs(dX)<=rayon && abs(dY)<=rayon;
|
2007-06-05 12:10:51 +00:00
|
|
|
}
|
|
|
|
|
2008-01-06 12:43:57 +00:00
|
|
|
/**
|
|
|
|
* Function HitTest (overlayed)
|
|
|
|
* tests if the given EDA_Rect intersect this object.
|
|
|
|
* @param EDA_Rect : the given EDA_Rect
|
|
|
|
* @return bool - true if a hit, else false
|
|
|
|
*/
|
|
|
|
bool MIREPCB::HitTest( EDA_Rect& refArea )
|
|
|
|
{
|
2008-04-01 05:21:50 +00:00
|
|
|
if( refArea.Inside( m_Pos ) )
|
|
|
|
return true;
|
|
|
|
return false;
|
2008-01-06 12:43:57 +00:00
|
|
|
}
|
|
|
|
|