2009-11-12 15:43:38 +00:00
|
|
|
/*****************************/
|
|
|
|
/* COTATION class definition */
|
|
|
|
/*****************************/
|
2007-06-05 12:10:51 +00:00
|
|
|
|
|
|
|
#include "fctsys.h"
|
|
|
|
#include "gr_basic.h"
|
|
|
|
#include "common.h"
|
|
|
|
#include "pcbnew.h"
|
2007-08-08 20:51:08 +00:00
|
|
|
#include "trigo.h"
|
2007-08-20 19:33:15 +00:00
|
|
|
#include "wxstruct.h"
|
2009-10-28 11:48:47 +00:00
|
|
|
#include "class_board_design_settings.h"
|
2009-02-04 15:25:03 +00:00
|
|
|
#include "class_drawpanel.h"
|
2010-01-29 20:36:12 +00:00
|
|
|
#include "colors_selection.h"
|
2009-02-04 15:25:03 +00:00
|
|
|
#include "kicad_string.h"
|
2009-08-01 19:26:05 +00:00
|
|
|
#include "protos.h"
|
2007-06-05 12:10:51 +00:00
|
|
|
|
2008-12-04 04:28:11 +00:00
|
|
|
COTATION::COTATION( BOARD_ITEM* aParent ) :
|
|
|
|
BOARD_ITEM( aParent, TYPE_COTATION )
|
2007-06-05 12:10:51 +00:00
|
|
|
{
|
2007-08-08 20:51:08 +00:00
|
|
|
m_Layer = DRAW_LAYER;
|
|
|
|
m_Width = 50;
|
|
|
|
m_Value = 0;
|
|
|
|
m_Shape = 0;
|
|
|
|
m_Unit = INCHES;
|
|
|
|
m_Text = new TEXTE_PCB( this );
|
2007-06-05 12:10:51 +00:00
|
|
|
}
|
|
|
|
|
2007-08-08 20:51:08 +00:00
|
|
|
|
2007-08-23 04:28:46 +00:00
|
|
|
COTATION::~COTATION()
|
2007-06-05 12:10:51 +00:00
|
|
|
{
|
2007-08-08 20:51:08 +00:00
|
|
|
delete m_Text;
|
2007-06-05 12:10:51 +00:00
|
|
|
}
|
|
|
|
|
2007-08-08 20:51:08 +00:00
|
|
|
|
2007-09-25 08:23:53 +00:00
|
|
|
/* Setup the dimension text */
|
2010-01-31 20:01:46 +00:00
|
|
|
void COTATION::SetText( const wxString& NewText )
|
2007-06-05 12:10:51 +00:00
|
|
|
{
|
2007-08-08 20:51:08 +00:00
|
|
|
m_Text->m_Text = NewText;
|
2007-06-05 12:10:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-11-12 15:43:38 +00:00
|
|
|
/* Return the dimension text
|
2007-09-25 08:23:53 +00:00
|
|
|
*/
|
2009-11-12 15:43:38 +00:00
|
|
|
wxString COTATION::GetText( void )
|
2007-09-25 08:23:53 +00:00
|
|
|
{
|
2008-04-01 05:21:50 +00:00
|
|
|
return m_Text->m_Text;
|
2007-09-25 08:23:53 +00:00
|
|
|
}
|
|
|
|
|
2009-08-03 07:55:08 +00:00
|
|
|
/**
|
|
|
|
* Function SetLayer
|
|
|
|
* sets the layer this item is on.
|
|
|
|
* @param aLayer The layer number.
|
|
|
|
*/
|
|
|
|
void COTATION::SetLayer( int aLayer )
|
|
|
|
{
|
|
|
|
m_Layer = aLayer;
|
|
|
|
m_Text->SetLayer( aLayer);
|
|
|
|
}
|
2007-09-25 08:23:53 +00:00
|
|
|
|
2009-11-12 15:43:38 +00:00
|
|
|
|
2007-08-08 20:51:08 +00:00
|
|
|
void COTATION::Copy( COTATION* source )
|
2007-06-05 12:10:51 +00:00
|
|
|
{
|
2007-08-08 20:51:08 +00:00
|
|
|
m_Value = source->m_Value;
|
2007-08-23 04:28:46 +00:00
|
|
|
SetLayer( source->GetLayer() );
|
2007-08-08 20:51:08 +00:00
|
|
|
m_Width = source->m_Width;
|
|
|
|
m_Pos = source->m_Pos;
|
|
|
|
m_Shape = source->m_Shape;
|
|
|
|
m_Unit = source->m_Unit;
|
|
|
|
m_TimeStamp = GetTimeStamp();
|
|
|
|
m_Text->Copy( source->m_Text );
|
|
|
|
|
2009-11-12 15:43:38 +00:00
|
|
|
Barre_ox = source->Barre_ox;
|
|
|
|
Barre_oy = source->Barre_oy;
|
|
|
|
Barre_fx = source->Barre_fx;
|
|
|
|
Barre_fy = source->Barre_fy;
|
|
|
|
TraitG_ox = source->TraitG_ox;
|
|
|
|
TraitG_oy = source->TraitG_oy;
|
|
|
|
TraitG_fx = source->TraitG_fx;
|
|
|
|
TraitG_fy = source->TraitG_fy;
|
|
|
|
TraitD_ox = source->TraitD_ox;
|
|
|
|
TraitD_oy = source->TraitD_oy;
|
|
|
|
TraitD_fx = source->TraitD_fx;
|
|
|
|
TraitD_fy = source->TraitD_fy;
|
|
|
|
FlecheD1_ox = source->FlecheD1_ox;
|
|
|
|
FlecheD1_oy = source->FlecheD1_oy;
|
|
|
|
FlecheD1_fx = source->FlecheD1_fx;
|
|
|
|
FlecheD1_fy = source->FlecheD1_fy;
|
|
|
|
FlecheD2_ox = source->FlecheD2_ox;
|
|
|
|
FlecheD2_oy = source->FlecheD2_oy;
|
|
|
|
FlecheD2_fx = source->FlecheD2_fx;
|
|
|
|
FlecheD2_fy = source->FlecheD2_fy;
|
|
|
|
FlecheG1_ox = source->FlecheG1_ox;
|
|
|
|
FlecheG1_oy = source->FlecheG1_oy;
|
|
|
|
FlecheG1_fx = source->FlecheG1_fx;
|
|
|
|
FlecheG1_fy = source->FlecheG1_fy;
|
|
|
|
FlecheG2_ox = source->FlecheG2_ox;
|
|
|
|
FlecheG2_oy = source->FlecheG2_oy;
|
|
|
|
FlecheG2_fx = source->FlecheG2_fx;
|
|
|
|
FlecheG2_fy = source->FlecheG2_fy;
|
2007-06-05 12:10:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-08-08 20:51:08 +00:00
|
|
|
bool COTATION::ReadCotationDescr( FILE* File, int* LineNum )
|
2007-06-05 12:10:51 +00:00
|
|
|
{
|
2007-08-08 20:51:08 +00:00
|
|
|
char Line[2048], Text[2048];
|
|
|
|
|
|
|
|
while( GetLine( File, Line, LineNum ) != NULL )
|
|
|
|
{
|
|
|
|
if( strnicmp( Line, "$EndCOTATION", 4 ) == 0 )
|
|
|
|
return TRUE;
|
|
|
|
|
|
|
|
if( Line[0] == 'V' )
|
|
|
|
{
|
|
|
|
sscanf( Line + 2, " %d", &m_Value );
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
if( Line[0] == 'G' )
|
|
|
|
{
|
2007-08-23 04:28:46 +00:00
|
|
|
int layer;
|
2008-04-01 05:21:50 +00:00
|
|
|
|
2007-08-23 04:28:46 +00:00
|
|
|
sscanf( Line + 2, " %d %d %lX", &m_Shape, &layer, &m_TimeStamp );
|
2007-08-08 20:51:08 +00:00
|
|
|
|
2007-08-23 04:28:46 +00:00
|
|
|
if( layer < FIRST_NO_COPPER_LAYER )
|
|
|
|
layer = FIRST_NO_COPPER_LAYER;
|
|
|
|
if( layer > LAST_NO_COPPER_LAYER )
|
|
|
|
layer = LAST_NO_COPPER_LAYER;
|
2007-08-08 20:51:08 +00:00
|
|
|
|
2007-08-23 04:28:46 +00:00
|
|
|
SetLayer( layer );
|
|
|
|
m_Text->SetLayer( layer );
|
2007-08-08 20:51:08 +00:00
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
if( Line[0] == 'T' )
|
|
|
|
{
|
|
|
|
ReadDelimitedText( Text, Line + 2, sizeof(Text) );
|
|
|
|
m_Text->m_Text = CONV_FROM_UTF8( Text );
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
if( Line[0] == 'P' )
|
|
|
|
{
|
2009-11-12 15:43:38 +00:00
|
|
|
int normal_display = 1;
|
2007-08-08 20:51:08 +00:00
|
|
|
sscanf( Line + 2, " %d %d %d %d %d %d %d",
|
|
|
|
&m_Text->m_Pos.x, &m_Text->m_Pos.y,
|
|
|
|
&m_Text->m_Size.x, &m_Text->m_Size.y,
|
|
|
|
&m_Text->m_Width, &m_Text->m_Orient,
|
2008-12-20 20:38:39 +00:00
|
|
|
&normal_display );
|
2007-08-08 20:51:08 +00:00
|
|
|
|
2009-11-12 15:43:38 +00:00
|
|
|
m_Text->m_Mirror = normal_display ? false : true;
|
2007-08-08 20:51:08 +00:00
|
|
|
m_Pos = m_Text->m_Pos;
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
if( Line[0] == 'S' )
|
|
|
|
{
|
|
|
|
switch( Line[1] )
|
|
|
|
{
|
|
|
|
int Dummy;
|
|
|
|
|
|
|
|
case 'b':
|
|
|
|
sscanf( Line + 2, " %d %d %d %d %d %d",
|
|
|
|
&Dummy,
|
|
|
|
&Barre_ox, &Barre_oy,
|
|
|
|
&Barre_fx, &Barre_fy,
|
|
|
|
&m_Width );
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'd':
|
|
|
|
sscanf( Line + 2, " %d %d %d %d %d %d",
|
|
|
|
&Dummy,
|
|
|
|
&TraitD_ox, &TraitD_oy,
|
|
|
|
&TraitD_fx, &TraitD_fy,
|
|
|
|
&Dummy );
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'g':
|
|
|
|
sscanf( Line + 2, " %d %d %d %d %d %d",
|
|
|
|
&Dummy,
|
|
|
|
&TraitG_ox, &TraitG_oy,
|
|
|
|
&TraitG_fx, &TraitG_fy,
|
|
|
|
&Dummy );
|
|
|
|
break;
|
|
|
|
|
|
|
|
case '1':
|
|
|
|
sscanf( Line + 2, " %d %d %d %d %d %d",
|
|
|
|
&Dummy,
|
|
|
|
&FlecheD1_ox, &FlecheD1_oy,
|
|
|
|
&FlecheD1_fx, &FlecheD1_fy,
|
|
|
|
&Dummy );
|
|
|
|
break;
|
|
|
|
|
|
|
|
case '2':
|
|
|
|
sscanf( Line + 2, " %d %d %d %d %d %d",
|
|
|
|
&Dummy,
|
|
|
|
&FlecheD2_ox, &FlecheD2_oy,
|
|
|
|
&FlecheD2_fx, &FlecheD2_fy,
|
|
|
|
&Dummy );
|
|
|
|
break;
|
|
|
|
|
|
|
|
case '3':
|
|
|
|
sscanf( Line + 2, " %d %d %d %d %d %d\n",
|
|
|
|
&Dummy,
|
|
|
|
&FlecheG1_ox, &FlecheG1_oy,
|
|
|
|
&FlecheG1_fx, &FlecheG1_fy,
|
|
|
|
&Dummy );
|
|
|
|
break;
|
|
|
|
|
|
|
|
case '4':
|
|
|
|
sscanf( Line + 2, " %d %d %d %d %d %d",
|
|
|
|
&Dummy,
|
|
|
|
&FlecheG2_ox, &FlecheG2_oy,
|
|
|
|
&FlecheG2_fx, &FlecheG2_fy,
|
|
|
|
&Dummy );
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return FALSE;
|
2007-06-05 12:10:51 +00:00
|
|
|
}
|
|
|
|
|
2009-11-12 15:43:38 +00:00
|
|
|
|
2008-01-06 12:43:57 +00:00
|
|
|
/**
|
|
|
|
* Function Move
|
|
|
|
* @param offset : moving vector
|
|
|
|
*/
|
2009-11-12 15:43:38 +00:00
|
|
|
void COTATION::Move(const wxPoint& offset)
|
2007-06-05 12:10:51 +00:00
|
|
|
{
|
2008-04-01 05:21:50 +00:00
|
|
|
m_Pos += offset;
|
|
|
|
m_Text->m_Pos += offset;
|
2009-11-12 15:43:38 +00:00
|
|
|
Barre_ox += offset.x;
|
|
|
|
Barre_oy += offset.y;
|
|
|
|
Barre_fx += offset.x;
|
|
|
|
Barre_fy += offset.y;
|
|
|
|
TraitG_ox += offset.x;
|
|
|
|
TraitG_oy += offset.y;
|
|
|
|
TraitG_fx += offset.x;
|
|
|
|
TraitG_fy += offset.y;
|
|
|
|
TraitD_ox += offset.x;
|
|
|
|
TraitD_oy += offset.y;
|
|
|
|
TraitD_fx += offset.x;
|
|
|
|
TraitD_fy += offset.y;
|
|
|
|
FlecheG1_ox += offset.x;
|
|
|
|
FlecheG1_oy += offset.y;
|
|
|
|
FlecheG1_fx += offset.x;
|
|
|
|
FlecheG1_fy += offset.y;
|
|
|
|
FlecheG2_ox += offset.x;
|
|
|
|
FlecheG2_oy += offset.y;
|
|
|
|
FlecheG2_fx += offset.x;
|
|
|
|
FlecheG2_fy += offset.y;
|
|
|
|
FlecheD1_ox += offset.x;
|
|
|
|
FlecheD1_oy += offset.y;
|
|
|
|
FlecheD1_fx += offset.x;
|
|
|
|
FlecheD1_fy += offset.y;
|
|
|
|
FlecheD2_ox += offset.x;
|
|
|
|
FlecheD2_oy += offset.y;
|
|
|
|
FlecheD2_fx += offset.x;
|
|
|
|
FlecheD2_fy += offset.y;
|
2008-01-06 12:43:57 +00:00
|
|
|
}
|
2007-06-05 12:10:51 +00:00
|
|
|
|
|
|
|
|
2008-01-06 12:43:57 +00:00
|
|
|
/**
|
|
|
|
* Function Rotate
|
2009-11-12 15:43:38 +00:00
|
|
|
* @param center : Rotation point
|
2008-01-06 12:43:57 +00:00
|
|
|
* @param angle : Rotation angle in 0.1 degrees
|
|
|
|
*/
|
2009-11-12 15:43:38 +00:00
|
|
|
void COTATION::Rotate(const wxPoint& centre, int angle)
|
2008-01-06 12:43:57 +00:00
|
|
|
{
|
2009-08-01 19:26:05 +00:00
|
|
|
RotatePoint( &m_Pos, centre, angle );
|
2008-04-01 05:21:50 +00:00
|
|
|
|
2009-08-01 19:26:05 +00:00
|
|
|
RotatePoint( &m_Text->m_Pos, centre, angle );
|
|
|
|
m_Text->m_Orient += angle;
|
2008-04-01 05:21:50 +00:00
|
|
|
if( m_Text->m_Orient >= 3600 )
|
|
|
|
m_Text->m_Orient -= 3600;
|
2009-11-12 15:43:38 +00:00
|
|
|
if( ( m_Text->m_Orient > 900 ) && ( m_Text->m_Orient <2700 ) )
|
2008-04-01 05:21:50 +00:00
|
|
|
m_Text->m_Orient -= 1800;
|
|
|
|
|
2009-08-01 19:26:05 +00:00
|
|
|
RotatePoint( &Barre_ox, &Barre_oy, centre.x, centre.y, angle );
|
|
|
|
RotatePoint( &Barre_fx, &Barre_fy, centre.x, centre.y, angle );
|
|
|
|
RotatePoint( &TraitG_ox, &TraitG_oy, centre.x, centre.y, angle );
|
|
|
|
RotatePoint( &TraitG_fx, &TraitG_fy, centre.x, centre.y, angle );
|
|
|
|
RotatePoint( &TraitD_ox, &TraitD_oy, centre.x, centre.y, angle );
|
|
|
|
RotatePoint( &TraitD_fx, &TraitD_fy, centre.x, centre.y, angle );
|
|
|
|
RotatePoint( &FlecheG1_ox, &FlecheG1_oy, centre.x, centre.y, angle );
|
|
|
|
RotatePoint( &FlecheG1_fx, &FlecheG1_fy, centre.x, centre.y, angle );
|
|
|
|
RotatePoint( &FlecheG2_ox, &FlecheG2_oy, centre.x, centre.y, angle );
|
|
|
|
RotatePoint( &FlecheG2_fx, &FlecheG2_fy, centre.x, centre.y, angle );
|
|
|
|
RotatePoint( &FlecheD1_ox, &FlecheD1_oy, centre.x, centre.y, angle );
|
|
|
|
RotatePoint( &FlecheD1_fx, &FlecheD1_fy, centre.x, centre.y, angle );
|
|
|
|
RotatePoint( &FlecheD2_ox, &FlecheD2_oy, centre.x, centre.y, angle );
|
|
|
|
RotatePoint( &FlecheD2_fx, &FlecheD2_fy, centre.x, centre.y, angle );
|
2008-01-06 12:43:57 +00:00
|
|
|
}
|
2007-06-05 12:10:51 +00:00
|
|
|
|
2009-11-12 15:43:38 +00:00
|
|
|
|
2009-08-01 19:26:05 +00:00
|
|
|
/**
|
|
|
|
* Function Flip
|
|
|
|
* Flip this object, i.e. change the board side for this object
|
|
|
|
* @param const wxPoint& aCentre - the rotation point.
|
|
|
|
*/
|
|
|
|
void COTATION::Flip(const wxPoint& aCentre )
|
|
|
|
{
|
|
|
|
Mirror( aCentre );
|
|
|
|
SetLayer( ChangeSideNumLayer( GetLayer() ) );
|
|
|
|
}
|
2007-06-05 12:10:51 +00:00
|
|
|
|
2009-11-12 15:43:38 +00:00
|
|
|
|
2008-01-06 12:43:57 +00:00
|
|
|
/**
|
|
|
|
* Function Mirror
|
|
|
|
* Mirror the Dimension , relative to a given horizontal axis
|
|
|
|
* the text is not mirrored. only its position (and angle) is mirrored
|
|
|
|
* the layer is not changed
|
|
|
|
* @param axis_pos : vertical axis position
|
|
|
|
*/
|
2009-11-12 15:43:38 +00:00
|
|
|
void COTATION::Mirror(const wxPoint& axis_pos)
|
2008-01-06 12:43:57 +00:00
|
|
|
{
|
|
|
|
#define INVERT( pos ) (pos) = axis_pos.y - ( (pos) - axis_pos.y )
|
|
|
|
#define INVERT_ANGLE( phi ) (phi) = -(phi)
|
2008-04-01 05:21:50 +00:00
|
|
|
INVERT( m_Pos.y );
|
|
|
|
INVERT( m_Text->m_Pos.y );
|
|
|
|
INVERT_ANGLE( m_Text->m_Orient );
|
|
|
|
if( m_Text->m_Orient >= 3600 )
|
|
|
|
m_Text->m_Orient -= 3600;
|
2009-11-12 15:43:38 +00:00
|
|
|
if( ( m_Text->m_Orient > 900 ) && ( m_Text->m_Orient < 2700 ) )
|
2008-04-01 05:21:50 +00:00
|
|
|
m_Text->m_Orient -= 1800;
|
|
|
|
|
|
|
|
INVERT( Barre_oy );
|
|
|
|
INVERT( Barre_fy );
|
|
|
|
INVERT( TraitG_oy );
|
|
|
|
INVERT( TraitG_fy );
|
|
|
|
INVERT( TraitD_oy );
|
|
|
|
INVERT( TraitD_fy );
|
|
|
|
INVERT( FlecheG1_oy );
|
|
|
|
INVERT( FlecheG1_fy );
|
|
|
|
INVERT( FlecheG2_oy );
|
|
|
|
INVERT( FlecheG2_fy );
|
|
|
|
INVERT( FlecheD1_oy );
|
|
|
|
INVERT( FlecheD1_fy );
|
|
|
|
INVERT( FlecheD2_oy );
|
|
|
|
INVERT( FlecheD2_fy );
|
2007-06-05 12:10:51 +00:00
|
|
|
}
|
2007-10-30 21:30:58 +00:00
|
|
|
|
2009-11-12 15:43:38 +00:00
|
|
|
|
2007-10-30 21:30:58 +00:00
|
|
|
bool COTATION::Save( FILE* aFile ) const
|
|
|
|
{
|
|
|
|
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, "$COTATION\n" ) != sizeof("$COTATION\n")-1 )
|
|
|
|
goto out;
|
|
|
|
|
|
|
|
fprintf( aFile, "Ge %d %d %lX\n", m_Shape, m_Layer, m_TimeStamp );
|
|
|
|
|
|
|
|
fprintf( aFile, "Va %d\n", m_Value );
|
|
|
|
|
|
|
|
if( !m_Text->m_Text.IsEmpty() )
|
|
|
|
fprintf( aFile, "Te \"%s\"\n", CONV_TO_UTF8( m_Text->m_Text ) );
|
|
|
|
else
|
|
|
|
fprintf( aFile, "Te \"?\"\n" );
|
|
|
|
|
|
|
|
fprintf( aFile, "Po %d %d %d %d %d %d %d\n",
|
|
|
|
m_Text->m_Pos.x, m_Text->m_Pos.y,
|
|
|
|
m_Text->m_Size.x, m_Text->m_Size.y,
|
|
|
|
m_Text->m_Width, m_Text->m_Orient,
|
2008-12-20 20:38:39 +00:00
|
|
|
m_Text->m_Mirror ? 0 : 1 );
|
2007-10-30 21:30:58 +00:00
|
|
|
|
|
|
|
fprintf( aFile, "Sb %d %d %d %d %d %d\n", S_SEGMENT,
|
|
|
|
Barre_ox, Barre_oy,
|
|
|
|
Barre_fx, Barre_fy, m_Width );
|
|
|
|
|
|
|
|
fprintf( aFile, "Sd %d %d %d %d %d %d\n", S_SEGMENT,
|
|
|
|
TraitD_ox, TraitD_oy,
|
|
|
|
TraitD_fx, TraitD_fy, m_Width );
|
|
|
|
|
|
|
|
fprintf( aFile, "Sg %d %d %d %d %d %d\n", S_SEGMENT,
|
|
|
|
TraitG_ox, TraitG_oy,
|
|
|
|
TraitG_fx, TraitG_fy, m_Width );
|
|
|
|
|
|
|
|
fprintf( aFile, "S1 %d %d %d %d %d %d\n", S_SEGMENT,
|
|
|
|
FlecheD1_ox, FlecheD1_oy,
|
|
|
|
FlecheD1_fx, FlecheD1_fy, m_Width );
|
|
|
|
|
|
|
|
fprintf( aFile, "S2 %d %d %d %d %d %d\n", S_SEGMENT,
|
|
|
|
FlecheD2_ox, FlecheD2_oy,
|
|
|
|
FlecheD2_fx, FlecheD2_fy, m_Width );
|
|
|
|
|
|
|
|
|
|
|
|
fprintf( aFile, "S3 %d %d %d %d %d %d\n", S_SEGMENT,
|
|
|
|
FlecheG1_ox, FlecheG1_oy,
|
|
|
|
FlecheG1_fx, FlecheG1_fy, m_Width );
|
|
|
|
|
|
|
|
fprintf( aFile, "S4 %d %d %d %d %d %d\n", S_SEGMENT,
|
|
|
|
FlecheG2_ox, FlecheG2_oy,
|
|
|
|
FlecheG2_fx, FlecheG2_fy, m_Width );
|
|
|
|
|
|
|
|
if( fprintf( aFile, "$EndCOTATION\n" ) != sizeof("$EndCOTATION\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
|
|
|
|
2007-10-30 21:30:58 +00:00
|
|
|
out:
|
|
|
|
return rc;
|
|
|
|
}
|
2008-04-01 05:21:50 +00:00
|
|
|
|
|
|
|
|
2007-06-05 12:10:51 +00:00
|
|
|
|
|
|
|
|
2009-11-12 15:43:38 +00:00
|
|
|
/* Print 1 dimension: series of n + 1 segments text
|
|
|
|
*/
|
2007-08-08 20:51:08 +00:00
|
|
|
void COTATION::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
|
|
|
int ox, oy, typeaff, width, gcolor;
|
|
|
|
|
|
|
|
ox = offset.x;
|
|
|
|
oy = offset.y;
|
|
|
|
|
2008-04-01 05:21:50 +00:00
|
|
|
m_Text->Draw( panel, DC, mode_color, offset );
|
2007-08-08 20:51:08 +00:00
|
|
|
|
2010-01-31 20:01:46 +00:00
|
|
|
BOARD * brd = GetBoard( );
|
|
|
|
if( brd->IsLayerVisible( m_Layer ) == false )
|
2007-08-08 20:51:08 +00:00
|
|
|
return;
|
|
|
|
|
2010-01-31 20:01:46 +00:00
|
|
|
gcolor = brd->GetLayerColor(m_Layer);
|
2009-10-10 01:25:53 +00:00
|
|
|
|
2007-08-08 20:51:08 +00:00
|
|
|
GRSetDrawMode( DC, mode_color );
|
|
|
|
typeaff = DisplayOpt.DisplayDrawItems;
|
|
|
|
width = m_Width;
|
2009-01-29 14:26:20 +00:00
|
|
|
|
2010-02-08 18:15:42 +00:00
|
|
|
#ifdef USE_WX_ZOOM
|
|
|
|
if( DC->LogicalToDeviceXRel( width ) < 2 )
|
|
|
|
#else
|
2009-01-29 14:26:20 +00:00
|
|
|
if( panel->GetScreen()->Scale( width ) < 2 )
|
2010-02-08 18:15:42 +00:00
|
|
|
#endif
|
2007-08-08 20:51:08 +00:00
|
|
|
typeaff = FILAIRE;
|
|
|
|
|
|
|
|
switch( typeaff )
|
|
|
|
{
|
|
|
|
case FILAIRE:
|
|
|
|
width = 0;
|
|
|
|
|
|
|
|
case FILLED:
|
|
|
|
GRLine( &panel->m_ClipBox, DC,
|
|
|
|
Barre_ox - ox, Barre_oy - oy,
|
|
|
|
Barre_fx - ox, Barre_fy - oy, width, gcolor );
|
|
|
|
GRLine( &panel->m_ClipBox, DC,
|
|
|
|
TraitG_ox - ox, TraitG_oy - oy,
|
|
|
|
TraitG_fx - ox, TraitG_fy - oy, width, gcolor );
|
|
|
|
GRLine( &panel->m_ClipBox, DC,
|
|
|
|
TraitD_ox - ox, TraitD_oy - oy,
|
|
|
|
TraitD_fx - ox, TraitD_fy - oy, width, gcolor );
|
|
|
|
GRLine( &panel->m_ClipBox, DC,
|
|
|
|
FlecheD1_ox - ox, FlecheD1_oy - oy,
|
|
|
|
FlecheD1_fx - ox, FlecheD1_fy - oy, width, gcolor );
|
|
|
|
GRLine( &panel->m_ClipBox, DC,
|
|
|
|
FlecheD2_ox - ox, FlecheD2_oy - oy,
|
|
|
|
FlecheD2_fx - ox, FlecheD2_fy - oy, width, gcolor );
|
|
|
|
GRLine( &panel->m_ClipBox, DC,
|
|
|
|
FlecheG1_ox - ox, FlecheG1_oy - oy,
|
|
|
|
FlecheG1_fx - ox, FlecheG1_fy - oy, width, gcolor );
|
|
|
|
GRLine( &panel->m_ClipBox, DC,
|
|
|
|
FlecheG2_ox - ox, FlecheG2_oy - oy,
|
|
|
|
FlecheG2_fx - ox, FlecheG2_fy - oy, width, gcolor );
|
|
|
|
break;
|
|
|
|
|
|
|
|
case SKETCH:
|
|
|
|
GRCSegm( &panel->m_ClipBox, DC,
|
|
|
|
Barre_ox - ox, Barre_oy - oy,
|
|
|
|
Barre_fx - ox, Barre_fy - oy,
|
|
|
|
width, gcolor );
|
|
|
|
GRCSegm( &panel->m_ClipBox, DC,
|
|
|
|
TraitG_ox - ox, TraitG_oy - oy,
|
|
|
|
TraitG_fx - ox, TraitG_fy - oy,
|
|
|
|
width, gcolor );
|
|
|
|
GRCSegm( &panel->m_ClipBox, DC,
|
|
|
|
TraitD_ox - ox, TraitD_oy - oy,
|
|
|
|
TraitD_fx - ox, TraitD_fy - oy,
|
|
|
|
width, gcolor );
|
|
|
|
GRCSegm( &panel->m_ClipBox, DC,
|
|
|
|
FlecheD1_ox - ox, FlecheD1_oy - oy,
|
|
|
|
FlecheD1_fx - ox, FlecheD1_fy - oy,
|
|
|
|
width, gcolor );
|
|
|
|
GRCSegm( &panel->m_ClipBox, DC,
|
|
|
|
FlecheD2_ox - ox, FlecheD2_oy - oy,
|
|
|
|
FlecheD2_fx - ox, FlecheD2_fy - oy,
|
|
|
|
width, gcolor );
|
|
|
|
GRCSegm( &panel->m_ClipBox, DC,
|
|
|
|
FlecheG1_ox - ox, FlecheG1_oy - oy,
|
|
|
|
FlecheG1_fx - ox, FlecheG1_fy - oy,
|
|
|
|
width, gcolor );
|
|
|
|
GRCSegm( &panel->m_ClipBox, DC,
|
|
|
|
FlecheG2_ox - ox, FlecheG2_oy - oy,
|
|
|
|
FlecheG2_fx - ox, FlecheG2_fy - oy,
|
|
|
|
width, gcolor );
|
|
|
|
break;
|
|
|
|
}
|
2007-06-05 12:10:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-08-20 19:33:15 +00:00
|
|
|
// see class_cotation.h
|
2009-04-17 08:51:02 +00:00
|
|
|
void COTATION::DisplayInfo( WinEDA_DrawFrame* frame )
|
2007-08-20 19:33:15 +00:00
|
|
|
{
|
|
|
|
// for now, display only the text within the COTATION using class TEXTE_PCB.
|
2009-04-17 08:51:02 +00:00
|
|
|
m_Text->DisplayInfo( frame );
|
2007-08-20 19:33:15 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-08-08 20:51:08 +00:00
|
|
|
/**
|
|
|
|
* Function HitTest
|
|
|
|
* tests if the given wxPoint is within the bounds of this object.
|
|
|
|
* @param ref_pos A wxPoint to test
|
|
|
|
* @return bool - true if a hit, else false
|
|
|
|
*/
|
|
|
|
bool COTATION::HitTest( const wxPoint& ref_pos )
|
|
|
|
{
|
|
|
|
int ux0, uy0;
|
|
|
|
int dx, dy, spot_cX, spot_cY;
|
|
|
|
|
2009-06-11 14:26:17 +00:00
|
|
|
if( m_Text && m_Text->TextHitTest( ref_pos ) )
|
2007-08-08 20:51:08 +00:00
|
|
|
return true;
|
|
|
|
|
2009-11-12 15:43:38 +00:00
|
|
|
/* Locate SEGMENTS? */
|
2008-04-01 05:21:50 +00:00
|
|
|
ux0 = Barre_ox;
|
2007-08-08 20:51:08 +00:00
|
|
|
uy0 = Barre_oy;
|
2008-04-01 05:21:50 +00:00
|
|
|
|
2009-11-12 15:43:38 +00:00
|
|
|
/* Recalculate coordinates with ux0, uy0 = origin. */
|
2008-04-01 05:21:50 +00:00
|
|
|
dx = Barre_fx - ux0;
|
2007-08-08 20:51:08 +00:00
|
|
|
dy = Barre_fy - uy0;
|
2008-04-01 05:21:50 +00:00
|
|
|
|
|
|
|
spot_cX = ref_pos.x - ux0;
|
2007-08-08 20:51:08 +00:00
|
|
|
spot_cY = ref_pos.y - uy0;
|
|
|
|
|
|
|
|
if( DistanceTest( m_Width / 2, dx, dy, spot_cX, spot_cY ) )
|
|
|
|
return true;
|
|
|
|
|
2008-04-01 05:21:50 +00:00
|
|
|
ux0 = TraitG_ox;
|
2007-08-08 20:51:08 +00:00
|
|
|
uy0 = TraitG_oy;
|
2008-04-01 05:21:50 +00:00
|
|
|
|
|
|
|
dx = TraitG_fx - ux0;
|
2007-08-08 20:51:08 +00:00
|
|
|
dy = TraitG_fy - uy0;
|
2008-04-01 05:21:50 +00:00
|
|
|
|
|
|
|
spot_cX = ref_pos.x - ux0;
|
2007-08-08 20:51:08 +00:00
|
|
|
spot_cY = ref_pos.y - uy0;
|
|
|
|
|
|
|
|
if( DistanceTest( m_Width / 2, dx, dy, spot_cX, spot_cY ) )
|
|
|
|
return true;
|
|
|
|
|
2008-04-01 05:21:50 +00:00
|
|
|
ux0 = TraitD_ox;
|
2007-08-08 20:51:08 +00:00
|
|
|
uy0 = TraitD_oy;
|
2008-04-01 05:21:50 +00:00
|
|
|
|
|
|
|
dx = TraitD_fx - ux0;
|
2007-08-08 20:51:08 +00:00
|
|
|
dy = TraitD_fy - uy0;
|
2008-04-01 05:21:50 +00:00
|
|
|
|
|
|
|
spot_cX = ref_pos.x - ux0;
|
2007-08-08 20:51:08 +00:00
|
|
|
spot_cY = ref_pos.y - uy0;
|
|
|
|
|
|
|
|
if( DistanceTest( m_Width / 2, dx, dy, spot_cX, spot_cY ) )
|
|
|
|
return true;
|
|
|
|
|
2008-04-01 05:21:50 +00:00
|
|
|
ux0 = FlecheD1_ox;
|
2007-08-08 20:51:08 +00:00
|
|
|
uy0 = FlecheD1_oy;
|
2008-04-01 05:21:50 +00:00
|
|
|
|
|
|
|
dx = FlecheD1_fx - ux0;
|
2007-08-08 20:51:08 +00:00
|
|
|
dy = FlecheD1_fy - uy0;
|
2008-04-01 05:21:50 +00:00
|
|
|
|
|
|
|
spot_cX = ref_pos.x - ux0;
|
2007-08-08 20:51:08 +00:00
|
|
|
spot_cY = ref_pos.y - uy0;
|
|
|
|
|
|
|
|
if( DistanceTest( m_Width / 2, dx, dy, spot_cX, spot_cY ) )
|
|
|
|
return true;
|
|
|
|
|
2008-04-01 05:21:50 +00:00
|
|
|
ux0 = FlecheD2_ox;
|
2007-08-08 20:51:08 +00:00
|
|
|
uy0 = FlecheD2_oy;
|
2008-04-01 05:21:50 +00:00
|
|
|
|
|
|
|
dx = FlecheD2_fx - ux0;
|
2007-08-08 20:51:08 +00:00
|
|
|
dy = FlecheD2_fy - uy0;
|
2008-04-01 05:21:50 +00:00
|
|
|
|
|
|
|
spot_cX = ref_pos.x - ux0;
|
2007-08-08 20:51:08 +00:00
|
|
|
spot_cY = ref_pos.y - uy0;
|
|
|
|
|
|
|
|
if( DistanceTest( m_Width / 2, dx, dy, spot_cX, spot_cY ) )
|
|
|
|
return true;
|
|
|
|
|
2008-04-01 05:21:50 +00:00
|
|
|
ux0 = FlecheG1_ox;
|
2007-08-08 20:51:08 +00:00
|
|
|
uy0 = FlecheG1_oy;
|
2008-04-01 05:21:50 +00:00
|
|
|
|
|
|
|
dx = FlecheG1_fx - ux0;
|
2007-08-08 20:51:08 +00:00
|
|
|
dy = FlecheG1_fy - uy0;
|
2008-04-01 05:21:50 +00:00
|
|
|
|
|
|
|
spot_cX = ref_pos.x - ux0;
|
2007-08-08 20:51:08 +00:00
|
|
|
spot_cY = ref_pos.y - uy0;
|
|
|
|
|
|
|
|
if( DistanceTest( m_Width / 2, dx, dy, spot_cX, spot_cY ) )
|
|
|
|
return true;
|
|
|
|
|
2008-04-01 05:21:50 +00:00
|
|
|
ux0 = FlecheG2_ox;
|
2007-08-08 20:51:08 +00:00
|
|
|
uy0 = FlecheG2_oy;
|
2008-04-01 05:21:50 +00:00
|
|
|
|
|
|
|
dx = FlecheG2_fx - ux0;
|
2007-08-08 20:51:08 +00:00
|
|
|
dy = FlecheG2_fy - uy0;
|
2008-04-01 05:21:50 +00:00
|
|
|
|
|
|
|
spot_cX = ref_pos.x - ux0;
|
2007-08-08 20:51:08 +00:00
|
|
|
spot_cY = ref_pos.y - uy0;
|
|
|
|
|
|
|
|
if( DistanceTest( m_Width / 2, dx, dy, spot_cX, spot_cY ) )
|
|
|
|
return true;
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2009-11-12 15:43:38 +00:00
|
|
|
|
2008-01-06 12:43:57 +00:00
|
|
|
/**
|
2009-11-12 15:43:38 +00:00
|
|
|
* Function HitTest (overlaid)
|
2008-01-06 12:43:57 +00:00
|
|
|
* tests if the given EDA_Rect intersect this object.
|
|
|
|
* @param EDA_Rect : the given EDA_Rect
|
|
|
|
* @return bool - true if a hit, else false
|
|
|
|
*/
|
2009-11-12 15:43:38 +00:00
|
|
|
bool COTATION::HitTest( EDA_Rect& refArea )
|
2008-01-06 12:43:57 +00:00
|
|
|
{
|
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
|
|
|
}
|