2011-09-23 13:57:12 +00:00
|
|
|
/**
|
|
|
|
* @file gen_modules_placefile.cpp
|
|
|
|
*/
|
2007-06-05 12:10:51 +00:00
|
|
|
|
|
|
|
/*
|
2007-08-23 04:28:46 +00:00
|
|
|
* 1 - create ascii files for automatic placement of smd components
|
|
|
|
* 2 - create a module report (pos and module descr) (ascii file)
|
|
|
|
*/
|
2011-09-23 13:57:12 +00:00
|
|
|
|
2012-01-23 04:33:36 +00:00
|
|
|
#include <fctsys.h>
|
|
|
|
#include <confirm.h>
|
|
|
|
#include <kicad_string.h>
|
|
|
|
#include <gestfich.h>
|
|
|
|
#include <wxPcbStruct.h>
|
|
|
|
#include <trigo.h>
|
|
|
|
#include <appl_wxstruct.h>
|
|
|
|
#include <build_version.h>
|
|
|
|
#include <macros.h>
|
|
|
|
|
|
|
|
#include <class_board.h>
|
|
|
|
#include <class_module.h>
|
|
|
|
#include <class_drawsegment.h>
|
|
|
|
|
|
|
|
#include <pcbnew.h>
|
2011-09-23 13:57:12 +00:00
|
|
|
|
2010-01-05 08:48:49 +00:00
|
|
|
|
2009-11-14 22:15:22 +00:00
|
|
|
class LIST_MOD /* Can list the elements of useful modules. */
|
2007-06-05 12:10:51 +00:00
|
|
|
{
|
|
|
|
public:
|
2007-08-23 04:28:46 +00:00
|
|
|
MODULE* m_Module;
|
|
|
|
const wxChar* m_Reference;
|
|
|
|
const wxChar* m_Value;
|
2007-06-05 12:10:51 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
++PCBNew
* Removed Pcb_Frame argument from BOARD() constructor, since it precludes
having a BOARD being edited by more than one editor, it was a bad design.
And this meant removing m_PcbFrame from BOARD.
* removed BOARD::SetWindowFrame(), and BOARD::m_PcbFrame
* Removed the global BOARD_DESIGN_SETTINGS which was in class_board.cpp
* added BOARD_DESIGN_SETTINGS to the BOARD class, a full instance
* a couple dialogs now only change BOARD_DESIGN_SETTINGS when OK is pressed,
such as dialog_mask_clearance, dialog_drc, etc.
* Removed common/pcbcommon.cpp's int g_CurrentVersionPCB = 1 and replaced it
with build_version.h's #define BOARD_FILE_VERSION, although there may be a
better place for this constant.
* Made the public functions in PARAM_CFG_ARRAY be type const.
void SaveParam(..) const and void ReadParam(..) const
* PARAM_CFG_BASE now has virtual destructor since we have various way of
destroying the derived class and boost::ptr_vector must be told about this.
* Pass const PARAM_CFG_ARRAY& instead of PARAM_CFG_ARRAY so that we can use
an automatic PARAM_CFG_ARRAY which is on the stack.\
* PCB_EDIT_FRAME::GetProjectFileParameters() may no longer cache the array,
since it has to access the current BOARD and the BOARD can change.
Remember BOARD_DESIGN_SETTINGS are now in the BOARD.
* Made the m_BoundingBox member private, this was a brutally hard task,
and indicative of the lack of commitment to accessors and object oriented
design on the part of KiCad developers. We must do better.
Added BOARD::GetBoundingBox, SetBoundingBox(), ComputeBoundingBox().
* Added PCB_BASE_FRAME::GetBoardBoundingBox() which calls BOARD::ComputeBoundingBox()
2011-12-05 06:15:33 +00:00
|
|
|
#if 1
|
|
|
|
static const double conv_unit = 0.0001; // units = INCHES
|
|
|
|
#else
|
|
|
|
static const double conv_unit = 0.000254; // units = mm
|
|
|
|
#endif
|
|
|
|
|
2009-11-14 22:15:22 +00:00
|
|
|
static wxPoint File_Place_Offset; /* Offset coordinates for generated file. */
|
2007-06-05 12:10:51 +00:00
|
|
|
|
2007-08-23 04:28:46 +00:00
|
|
|
static void WriteDrawSegmentPcb( DRAWSEGMENT* PtDrawSegment, FILE* rptfile );
|
2007-06-05 12:10:51 +00:00
|
|
|
|
2009-11-14 22:15:22 +00:00
|
|
|
|
|
|
|
/* Sort function use by GenereModulesPosition() */
|
2008-10-01 23:35:31 +00:00
|
|
|
static int ListeModCmp( const void* o1, const void* o2 )
|
2007-06-05 12:10:51 +00:00
|
|
|
{
|
2011-11-08 16:37:25 +00:00
|
|
|
LIST_MOD* ref = (LIST_MOD*) o1;
|
|
|
|
LIST_MOD* cmp = (LIST_MOD*) o2;
|
2008-10-01 23:35:31 +00:00
|
|
|
|
2011-11-08 16:37:25 +00:00
|
|
|
return StrNumCmp( ref->m_Reference, cmp->m_Reference, 16 );
|
2007-06-05 12:10:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2008-04-23 18:11:36 +00:00
|
|
|
#if defined(DEBUG)
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function HasNonSMDPins
|
|
|
|
* returns true if the given module has any non smd pins, such as through hole
|
|
|
|
* and therefore cannot be placed automatically.
|
|
|
|
*/
|
|
|
|
static bool HasNonSMDPins( MODULE* aModule )
|
|
|
|
{
|
|
|
|
D_PAD* pad;
|
|
|
|
|
|
|
|
for( pad = aModule->m_Pads; pad; pad = pad->Next() )
|
|
|
|
{
|
|
|
|
if( pad->m_Attribut != PAD_SMD )
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
2011-03-01 19:26:17 +00:00
|
|
|
void PCB_EDIT_FRAME::GenModulesPosition( wxCommandEvent& event )
|
2007-06-05 12:10:51 +00:00
|
|
|
{
|
2008-10-01 16:00:35 +00:00
|
|
|
bool doBoardBack = false;
|
|
|
|
MODULE* module;
|
2011-11-10 15:55:05 +00:00
|
|
|
LIST_MOD* list = NULL;
|
2008-10-01 16:00:35 +00:00
|
|
|
char line[1024];
|
2009-04-05 20:49:15 +00:00
|
|
|
wxFileName fnFront;
|
|
|
|
wxFileName fnBack;
|
2008-10-01 16:00:35 +00:00
|
|
|
wxString msg;
|
|
|
|
wxString frontLayerName;
|
|
|
|
wxString backLayerName;
|
|
|
|
wxString Title;
|
2008-10-01 23:35:31 +00:00
|
|
|
FILE* fpFront = 0;
|
|
|
|
FILE* fpBack = 0;
|
2008-10-01 16:05:20 +00:00
|
|
|
bool switchedLocale = false;
|
2007-08-23 04:28:46 +00:00
|
|
|
|
2011-12-31 05:44:00 +00:00
|
|
|
File_Place_Offset = GetOriginAxisPosition();
|
2007-08-23 04:28:46 +00:00
|
|
|
|
2009-11-14 22:15:22 +00:00
|
|
|
/* Calculating the number of useful modules (CMS attribute, not VIRTUAL) */
|
2008-10-01 16:00:35 +00:00
|
|
|
int moduleCount = 0;
|
2008-04-23 18:11:36 +00:00
|
|
|
|
2009-01-05 05:21:35 +00:00
|
|
|
for( module = GetBoard()->m_Modules; module; module = module->Next() )
|
2007-08-23 04:28:46 +00:00
|
|
|
{
|
2008-10-01 16:00:35 +00:00
|
|
|
if( module->m_Attributs & MOD_VIRTUAL )
|
2008-04-23 18:11:36 +00:00
|
|
|
{
|
2009-11-14 22:15:22 +00:00
|
|
|
D( printf( "skipping module %s because it's virtual\n",
|
2011-02-28 18:36:19 +00:00
|
|
|
TO_UTF8( module->GetReference() ) );)
|
2007-08-23 04:28:46 +00:00
|
|
|
continue;
|
2008-04-23 18:11:36 +00:00
|
|
|
}
|
|
|
|
|
2009-11-14 22:15:22 +00:00
|
|
|
if( ( module->m_Attributs & MOD_CMS ) == 0 )
|
2008-04-23 18:11:36 +00:00
|
|
|
{
|
2008-10-01 23:35:31 +00:00
|
|
|
#if 1 && defined(DEBUG) // enable this code to fix a bunch of mis-labeled modules:
|
2008-10-01 16:00:35 +00:00
|
|
|
if( !HasNonSMDPins( module ) )
|
2008-10-01 23:35:31 +00:00
|
|
|
{
|
|
|
|
// all module's pins are SMD, mark the part for pick and place
|
|
|
|
module->m_Attributs |= MOD_CMS;
|
|
|
|
}
|
2008-04-23 18:11:36 +00:00
|
|
|
else
|
|
|
|
{
|
2009-11-14 22:15:22 +00:00
|
|
|
printf( "skipping %s because its attribute is not CMS and it has non SMD pins\n",
|
2011-02-28 18:36:19 +00:00
|
|
|
TO_UTF8(module->GetReference()) );
|
2008-04-23 18:11:36 +00:00
|
|
|
continue;
|
|
|
|
}
|
|
|
|
#else
|
2007-08-23 04:28:46 +00:00
|
|
|
continue;
|
2008-04-23 18:11:36 +00:00
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
2009-12-07 03:46:13 +00:00
|
|
|
if( module->GetLayer() == LAYER_N_BACK )
|
2008-10-01 16:00:35 +00:00
|
|
|
doBoardBack = true;
|
|
|
|
|
|
|
|
moduleCount++;
|
2007-08-23 04:28:46 +00:00
|
|
|
}
|
|
|
|
|
2008-10-01 16:00:35 +00:00
|
|
|
if( moduleCount == 0 )
|
2007-08-23 04:28:46 +00:00
|
|
|
{
|
2009-11-14 22:15:22 +00:00
|
|
|
DisplayError( this, _( "No modules for automated placement." ) );
|
2008-10-01 16:00:35 +00:00
|
|
|
return;
|
2007-08-23 04:28:46 +00:00
|
|
|
}
|
|
|
|
|
2011-02-27 23:25:07 +00:00
|
|
|
wxString boardFilePath = ( (wxFileName) GetScreen()->GetFileName()).GetPath();
|
|
|
|
wxDirDialog dirDialog( this, _( "Select Output Directory" ), boardFilePath );
|
|
|
|
|
|
|
|
if( dirDialog.ShowModal() == wxID_CANCEL )
|
|
|
|
return;
|
|
|
|
|
2011-01-20 16:34:57 +00:00
|
|
|
fnFront = GetScreen()->GetFileName();
|
2011-02-27 23:25:07 +00:00
|
|
|
fnFront.SetPath( dirDialog.GetPath() );
|
2009-12-07 03:46:13 +00:00
|
|
|
frontLayerName = GetBoard()->GetLayerName( LAYER_N_FRONT );
|
2011-02-27 23:25:07 +00:00
|
|
|
fnFront.SetName( fnFront.GetName() + wxT( "_" ) + frontLayerName );
|
2009-04-05 20:49:15 +00:00
|
|
|
fnFront.SetExt( wxT( "pos") );
|
|
|
|
fpFront = wxFopen( fnFront.GetFullPath(), wxT( "wt" ) );
|
2011-02-27 23:25:07 +00:00
|
|
|
|
2008-10-01 16:00:35 +00:00
|
|
|
if( fpFront == 0 )
|
2007-08-23 04:28:46 +00:00
|
|
|
{
|
2009-04-05 20:49:15 +00:00
|
|
|
msg = _( "Unable to create " ) + fnFront.GetFullPath();
|
2008-10-01 16:00:35 +00:00
|
|
|
DisplayError( this, msg );
|
|
|
|
goto exit;
|
2007-08-23 04:28:46 +00:00
|
|
|
}
|
|
|
|
|
2008-10-01 16:00:35 +00:00
|
|
|
if( doBoardBack )
|
2007-08-23 04:28:46 +00:00
|
|
|
{
|
2011-01-20 16:34:57 +00:00
|
|
|
fnBack = GetScreen()->GetFileName();
|
2011-02-27 23:25:07 +00:00
|
|
|
fnBack.SetPath( dirDialog.GetPath() );
|
2009-12-07 03:46:13 +00:00
|
|
|
backLayerName = GetBoard()->GetLayerName( LAYER_N_BACK );
|
2011-02-27 23:25:07 +00:00
|
|
|
fnBack.SetName( fnBack.GetName() + wxT( "_" ) + backLayerName );
|
2009-04-05 20:49:15 +00:00
|
|
|
fnBack.SetExt( wxT( "pos" ) );
|
|
|
|
fpBack = wxFopen( fnBack.GetFullPath(), wxT( "wt" ) );
|
2008-10-01 16:00:35 +00:00
|
|
|
|
|
|
|
if( fpBack == 0 )
|
2007-08-23 04:28:46 +00:00
|
|
|
{
|
2009-04-05 20:49:15 +00:00
|
|
|
msg = _( "Unable to create " ) + fnBack.GetFullPath();
|
2007-08-23 04:28:46 +00:00
|
|
|
DisplayError( this, msg );
|
2008-10-01 16:00:35 +00:00
|
|
|
goto exit;
|
2007-08-23 04:28:46 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2009-11-14 22:15:22 +00:00
|
|
|
// Switch the locale to standard C (needed to print floating point
|
|
|
|
// numbers like 1.3)
|
2008-06-06 16:39:45 +00:00
|
|
|
SetLocaleTo_C_standard( );
|
2008-10-01 16:05:20 +00:00
|
|
|
switchedLocale = true;
|
2007-08-23 04:28:46 +00:00
|
|
|
|
2011-02-27 23:25:07 +00:00
|
|
|
// Display results
|
2011-04-12 14:19:59 +00:00
|
|
|
ClearMsgPanel();
|
|
|
|
AppendMsgPanel( _( "Component side place file:" ), fnFront.GetFullPath(), BLUE );
|
2007-08-23 04:28:46 +00:00
|
|
|
|
2008-10-01 16:00:35 +00:00
|
|
|
if( doBoardBack )
|
2011-04-12 14:19:59 +00:00
|
|
|
AppendMsgPanel( _( "Copper side place file:" ), fnBack.GetFullPath(), BLUE );
|
2007-08-23 04:28:46 +00:00
|
|
|
|
2008-10-01 16:00:35 +00:00
|
|
|
msg.Empty(); msg << moduleCount;
|
2011-04-12 14:19:59 +00:00
|
|
|
AppendMsgPanel( _( "Module count" ), msg, RED );
|
2007-08-23 04:28:46 +00:00
|
|
|
|
2011-02-27 23:25:07 +00:00
|
|
|
// Sort the list of modules alphabetically
|
2011-11-10 15:55:05 +00:00
|
|
|
list = new LIST_MOD[moduleCount];
|
2007-08-23 04:28:46 +00:00
|
|
|
|
2009-01-05 05:21:35 +00:00
|
|
|
module = GetBoard()->m_Modules;
|
2011-09-07 19:41:04 +00:00
|
|
|
|
2008-10-01 16:00:35 +00:00
|
|
|
for( int ii = 0; module; module = module->Next() )
|
2007-08-23 04:28:46 +00:00
|
|
|
{
|
2008-10-01 16:00:35 +00:00
|
|
|
if( module->m_Attributs & MOD_VIRTUAL )
|
2007-08-23 04:28:46 +00:00
|
|
|
continue;
|
2008-10-01 23:35:31 +00:00
|
|
|
|
2008-10-01 16:00:35 +00:00
|
|
|
if( (module->m_Attributs & MOD_CMS) == 0 )
|
2007-08-23 04:28:46 +00:00
|
|
|
continue;
|
|
|
|
|
2011-11-10 15:55:05 +00:00
|
|
|
list[ii].m_Module = module;
|
|
|
|
list[ii].m_Reference = module->m_Reference->m_Text;
|
|
|
|
list[ii].m_Value = module->m_Value->m_Text;
|
2007-08-23 04:28:46 +00:00
|
|
|
ii++;
|
|
|
|
}
|
|
|
|
|
2011-11-10 15:55:05 +00:00
|
|
|
qsort( list, moduleCount, sizeof(LIST_MOD), ListeModCmp );
|
2007-08-23 04:28:46 +00:00
|
|
|
|
2011-02-27 23:25:07 +00:00
|
|
|
// Write file header
|
2011-11-08 16:37:25 +00:00
|
|
|
sprintf( line, "### Module positions - created on %s ###\n", TO_UTF8( DateAndTime() ) );
|
2008-10-01 16:00:35 +00:00
|
|
|
fputs( line, fpFront );
|
2011-02-27 23:25:07 +00:00
|
|
|
|
2008-10-01 16:00:35 +00:00
|
|
|
if( doBoardBack )
|
|
|
|
fputs( line, fpBack );
|
2007-08-23 04:28:46 +00:00
|
|
|
|
2009-04-05 20:49:15 +00:00
|
|
|
Title = wxGetApp().GetAppName() + wxT( " " ) + GetBuildVersion();
|
2011-09-30 18:15:37 +00:00
|
|
|
sprintf( line, "### Printed by Pcbnew version %s\n", TO_UTF8( Title ) );
|
2008-10-01 16:00:35 +00:00
|
|
|
fputs( line, fpFront );
|
2011-02-27 23:25:07 +00:00
|
|
|
|
2008-10-01 16:00:35 +00:00
|
|
|
if( doBoardBack )
|
|
|
|
fputs( line, fpBack );
|
2007-08-23 04:28:46 +00:00
|
|
|
|
2008-10-01 16:00:35 +00:00
|
|
|
sprintf( line, "## Unit = inches, Angle = deg.\n" );
|
|
|
|
fputs( line, fpFront );
|
2011-02-27 23:25:07 +00:00
|
|
|
|
2008-10-01 16:00:35 +00:00
|
|
|
if( doBoardBack )
|
|
|
|
fputs( line, fpBack );
|
2007-08-23 04:28:46 +00:00
|
|
|
|
2011-02-28 18:36:19 +00:00
|
|
|
sprintf( line, "## Side : %s\n", TO_UTF8( frontLayerName ) );
|
2008-10-01 16:00:35 +00:00
|
|
|
fputs( line, fpFront );
|
2007-08-23 04:28:46 +00:00
|
|
|
|
2008-10-01 16:00:35 +00:00
|
|
|
if( doBoardBack )
|
2007-08-23 04:28:46 +00:00
|
|
|
{
|
2011-02-28 18:36:19 +00:00
|
|
|
sprintf( line, "## Side : %s\n", TO_UTF8( backLayerName ) );
|
2008-10-01 16:00:35 +00:00
|
|
|
fputs( line, fpBack );
|
2007-08-23 04:28:46 +00:00
|
|
|
}
|
|
|
|
|
2008-10-01 16:00:35 +00:00
|
|
|
sprintf( line,
|
2007-08-23 04:28:46 +00:00
|
|
|
"# Ref Val PosX PosY Rot Side\n" );
|
2008-10-01 16:00:35 +00:00
|
|
|
fputs( line, fpFront );
|
2011-09-07 19:41:04 +00:00
|
|
|
|
2008-10-01 16:00:35 +00:00
|
|
|
if( doBoardBack )
|
|
|
|
fputs( line, fpBack );
|
2007-08-23 04:28:46 +00:00
|
|
|
|
2008-10-01 16:00:35 +00:00
|
|
|
for( int ii = 0; ii < moduleCount; ii++ )
|
2007-08-23 04:28:46 +00:00
|
|
|
{
|
|
|
|
wxPoint module_pos;
|
2011-11-10 15:55:05 +00:00
|
|
|
wxString ref = list[ii].m_Reference;
|
|
|
|
wxString val = list[ii].m_Value;
|
2011-09-07 19:41:04 +00:00
|
|
|
sprintf( line, "%-8.8s %-16.16s ", TO_UTF8( ref ), TO_UTF8( val ) );
|
2007-08-23 04:28:46 +00:00
|
|
|
|
2011-11-10 15:55:05 +00:00
|
|
|
module_pos = list[ii].m_Module->m_Pos;
|
2007-08-23 04:28:46 +00:00
|
|
|
module_pos.x -= File_Place_Offset.x;
|
|
|
|
module_pos.y -= File_Place_Offset.y;
|
|
|
|
|
2008-10-01 16:00:35 +00:00
|
|
|
char* text = line + strlen( line );
|
2007-08-23 04:28:46 +00:00
|
|
|
sprintf( text, " %9.4f %9.4f %8.1f ",
|
2009-03-15 21:11:12 +00:00
|
|
|
module_pos.x * conv_unit,
|
|
|
|
module_pos.y * conv_unit,
|
2011-11-10 15:55:05 +00:00
|
|
|
double(list[ii].m_Module->m_Orient) / 10 );
|
2007-08-23 04:28:46 +00:00
|
|
|
|
2011-11-10 15:55:05 +00:00
|
|
|
int layer = list[ii].m_Module->GetLayer();
|
2008-10-01 23:35:31 +00:00
|
|
|
|
2009-12-07 03:46:13 +00:00
|
|
|
wxASSERT( layer==LAYER_N_FRONT || layer==LAYER_N_BACK );
|
2008-10-01 23:35:31 +00:00
|
|
|
|
2009-12-07 03:46:13 +00:00
|
|
|
if( layer == LAYER_N_FRONT )
|
2007-08-23 04:28:46 +00:00
|
|
|
{
|
2011-02-28 18:36:19 +00:00
|
|
|
strcat( line, TO_UTF8( frontLayerName ) );
|
2008-10-01 16:00:35 +00:00
|
|
|
strcat( line, "\n" );
|
|
|
|
fputs( line, fpFront );
|
2007-08-23 04:28:46 +00:00
|
|
|
}
|
2009-12-07 03:46:13 +00:00
|
|
|
else if( layer == LAYER_N_BACK )
|
2007-08-23 04:28:46 +00:00
|
|
|
{
|
2011-02-28 18:36:19 +00:00
|
|
|
strcat( line, TO_UTF8( backLayerName ) );
|
2008-10-01 16:00:35 +00:00
|
|
|
strcat( line, "\n" );
|
|
|
|
fputs( line, fpBack );
|
2007-08-23 04:28:46 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-02-27 23:25:07 +00:00
|
|
|
// Write EOF
|
2008-10-01 16:00:35 +00:00
|
|
|
fputs( "## End\n", fpFront );
|
|
|
|
|
|
|
|
if( doBoardBack )
|
|
|
|
fputs( "## End\n", fpBack );
|
|
|
|
|
2011-02-27 23:25:07 +00:00
|
|
|
msg = _( "Module position files created:" );
|
|
|
|
msg.Append( wxT( "\n\n" ) + frontLayerName + wxT( ":\n" ) );
|
|
|
|
msg.Append( fnFront.GetFullPath() );
|
2008-10-01 16:00:35 +00:00
|
|
|
|
|
|
|
if( doBoardBack )
|
2011-02-27 23:25:07 +00:00
|
|
|
{
|
|
|
|
msg.Append( wxT( "\n\n" ) + backLayerName + wxT( ":\n" ) );
|
|
|
|
msg.Append( fnBack.GetFullPath() );
|
|
|
|
}
|
2008-10-01 16:00:35 +00:00
|
|
|
|
2011-02-27 23:25:07 +00:00
|
|
|
wxMessageBox( msg, _( "Module Position File" ), wxICON_INFORMATION );
|
2008-10-01 23:35:31 +00:00
|
|
|
|
|
|
|
exit: // the only safe way out of here, no returns please.
|
|
|
|
|
2011-11-10 15:55:05 +00:00
|
|
|
if( list )
|
|
|
|
delete[] list;
|
2008-10-01 23:35:31 +00:00
|
|
|
|
2008-10-01 16:05:20 +00:00
|
|
|
if( switchedLocale )
|
2009-11-14 22:15:22 +00:00
|
|
|
SetLocaleTo_Default( ); // revert to the current locale
|
2008-10-01 16:05:20 +00:00
|
|
|
|
2008-10-01 16:00:35 +00:00
|
|
|
if( fpFront )
|
|
|
|
fclose( fpFront );
|
|
|
|
|
|
|
|
if( fpBack )
|
|
|
|
fclose( fpBack );
|
2007-06-05 12:10:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/* Print a module report.
|
2007-08-23 04:28:46 +00:00
|
|
|
*/
|
2011-03-01 19:26:17 +00:00
|
|
|
void PCB_EDIT_FRAME::GenModuleReport( wxCommandEvent& event )
|
2007-06-05 12:10:51 +00:00
|
|
|
{
|
2007-08-23 04:28:46 +00:00
|
|
|
MODULE* Module;
|
|
|
|
D_PAD* pad;
|
2011-11-08 16:37:25 +00:00
|
|
|
char line[1024];
|
2009-04-05 20:49:15 +00:00
|
|
|
wxFileName fn;
|
|
|
|
wxString fnFront, msg;
|
2007-08-23 04:28:46 +00:00
|
|
|
FILE* rptfile;
|
|
|
|
wxPoint module_pos;
|
|
|
|
|
|
|
|
File_Place_Offset = wxPoint( 0, 0 );
|
|
|
|
|
2011-02-27 23:25:07 +00:00
|
|
|
wxString boardFilePath = ( (wxFileName) GetScreen()->GetFileName()).GetPath();
|
|
|
|
wxDirDialog dirDialog( this, _( "Select Output Directory" ), boardFilePath );
|
|
|
|
|
|
|
|
if( dirDialog.ShowModal() == wxID_CANCEL )
|
|
|
|
return;
|
|
|
|
|
2011-01-20 16:34:57 +00:00
|
|
|
fn = GetScreen()->GetFileName();
|
2011-02-27 23:25:07 +00:00
|
|
|
fn.SetPath( dirDialog.GetPath() );
|
2009-04-05 20:49:15 +00:00
|
|
|
fn.SetExt( wxT( "rpt" ) );
|
2007-08-23 04:28:46 +00:00
|
|
|
|
2009-04-05 20:49:15 +00:00
|
|
|
rptfile = wxFopen( fn.GetFullPath(), wxT( "wt" ) );
|
2011-02-27 23:25:07 +00:00
|
|
|
|
2007-08-23 04:28:46 +00:00
|
|
|
if( rptfile == NULL )
|
|
|
|
{
|
2009-04-05 20:49:15 +00:00
|
|
|
msg = _( "Unable to create " ) + fn.GetFullPath();
|
|
|
|
DisplayError( this, msg );
|
|
|
|
return;
|
2007-08-23 04:28:46 +00:00
|
|
|
}
|
|
|
|
|
2009-11-14 22:15:22 +00:00
|
|
|
// Switch the locale to standard C (needed to print floating point
|
|
|
|
// numbers like 1.3)
|
2011-09-07 19:41:04 +00:00
|
|
|
SetLocaleTo_C_standard();
|
2007-08-23 04:28:46 +00:00
|
|
|
|
2009-11-14 22:15:22 +00:00
|
|
|
/* Generate header file comments.) */
|
2011-11-08 16:37:25 +00:00
|
|
|
sprintf( line, "## Module report - date %s\n", TO_UTF8( DateAndTime() ) );
|
2008-10-01 16:00:35 +00:00
|
|
|
fputs( line, rptfile );
|
2007-08-23 04:28:46 +00:00
|
|
|
|
2009-04-05 20:49:15 +00:00
|
|
|
wxString Title = wxGetApp().GetAppName() + wxT( " " ) + GetBuildVersion();
|
2011-09-30 18:15:37 +00:00
|
|
|
sprintf( line, "## Created by Pcbnew version %s\n", TO_UTF8( Title ) );
|
2008-10-01 16:00:35 +00:00
|
|
|
fputs( line, rptfile );
|
2007-08-23 04:28:46 +00:00
|
|
|
fputs( "## Unit = inches, Angle = deg.\n", rptfile );
|
|
|
|
|
|
|
|
fputs( "##\n", rptfile );
|
|
|
|
fputs( "\n$BeginDESCRIPTION\n", rptfile );
|
|
|
|
|
++PCBNew
* Removed Pcb_Frame argument from BOARD() constructor, since it precludes
having a BOARD being edited by more than one editor, it was a bad design.
And this meant removing m_PcbFrame from BOARD.
* removed BOARD::SetWindowFrame(), and BOARD::m_PcbFrame
* Removed the global BOARD_DESIGN_SETTINGS which was in class_board.cpp
* added BOARD_DESIGN_SETTINGS to the BOARD class, a full instance
* a couple dialogs now only change BOARD_DESIGN_SETTINGS when OK is pressed,
such as dialog_mask_clearance, dialog_drc, etc.
* Removed common/pcbcommon.cpp's int g_CurrentVersionPCB = 1 and replaced it
with build_version.h's #define BOARD_FILE_VERSION, although there may be a
better place for this constant.
* Made the public functions in PARAM_CFG_ARRAY be type const.
void SaveParam(..) const and void ReadParam(..) const
* PARAM_CFG_BASE now has virtual destructor since we have various way of
destroying the derived class and boost::ptr_vector must be told about this.
* Pass const PARAM_CFG_ARRAY& instead of PARAM_CFG_ARRAY so that we can use
an automatic PARAM_CFG_ARRAY which is on the stack.\
* PCB_EDIT_FRAME::GetProjectFileParameters() may no longer cache the array,
since it has to access the current BOARD and the BOARD can change.
Remember BOARD_DESIGN_SETTINGS are now in the BOARD.
* Made the m_BoundingBox member private, this was a brutally hard task,
and indicative of the lack of commitment to accessors and object oriented
design on the part of KiCad developers. We must do better.
Added BOARD::GetBoundingBox, SetBoundingBox(), ComputeBoundingBox().
* Added PCB_BASE_FRAME::GetBoardBoundingBox() which calls BOARD::ComputeBoundingBox()
2011-12-05 06:15:33 +00:00
|
|
|
EDA_RECT bbbox = GetBoard()->ComputeBoundingBox();
|
|
|
|
|
2007-08-23 04:28:46 +00:00
|
|
|
fputs( "\n$BOARD\n", rptfile );
|
|
|
|
fputs( "unit INCH\n", rptfile );
|
++PCBNew
* Removed Pcb_Frame argument from BOARD() constructor, since it precludes
having a BOARD being edited by more than one editor, it was a bad design.
And this meant removing m_PcbFrame from BOARD.
* removed BOARD::SetWindowFrame(), and BOARD::m_PcbFrame
* Removed the global BOARD_DESIGN_SETTINGS which was in class_board.cpp
* added BOARD_DESIGN_SETTINGS to the BOARD class, a full instance
* a couple dialogs now only change BOARD_DESIGN_SETTINGS when OK is pressed,
such as dialog_mask_clearance, dialog_drc, etc.
* Removed common/pcbcommon.cpp's int g_CurrentVersionPCB = 1 and replaced it
with build_version.h's #define BOARD_FILE_VERSION, although there may be a
better place for this constant.
* Made the public functions in PARAM_CFG_ARRAY be type const.
void SaveParam(..) const and void ReadParam(..) const
* PARAM_CFG_BASE now has virtual destructor since we have various way of
destroying the derived class and boost::ptr_vector must be told about this.
* Pass const PARAM_CFG_ARRAY& instead of PARAM_CFG_ARRAY so that we can use
an automatic PARAM_CFG_ARRAY which is on the stack.\
* PCB_EDIT_FRAME::GetProjectFileParameters() may no longer cache the array,
since it has to access the current BOARD and the BOARD can change.
Remember BOARD_DESIGN_SETTINGS are now in the BOARD.
* Made the m_BoundingBox member private, this was a brutally hard task,
and indicative of the lack of commitment to accessors and object oriented
design on the part of KiCad developers. We must do better.
Added BOARD::GetBoundingBox, SetBoundingBox(), ComputeBoundingBox().
* Added PCB_BASE_FRAME::GetBoardBoundingBox() which calls BOARD::ComputeBoundingBox()
2011-12-05 06:15:33 +00:00
|
|
|
|
2008-10-01 16:00:35 +00:00
|
|
|
sprintf( line, "upper_left_corner %9.6f %9.6f\n",
|
++PCBNew
* Removed Pcb_Frame argument from BOARD() constructor, since it precludes
having a BOARD being edited by more than one editor, it was a bad design.
And this meant removing m_PcbFrame from BOARD.
* removed BOARD::SetWindowFrame(), and BOARD::m_PcbFrame
* Removed the global BOARD_DESIGN_SETTINGS which was in class_board.cpp
* added BOARD_DESIGN_SETTINGS to the BOARD class, a full instance
* a couple dialogs now only change BOARD_DESIGN_SETTINGS when OK is pressed,
such as dialog_mask_clearance, dialog_drc, etc.
* Removed common/pcbcommon.cpp's int g_CurrentVersionPCB = 1 and replaced it
with build_version.h's #define BOARD_FILE_VERSION, although there may be a
better place for this constant.
* Made the public functions in PARAM_CFG_ARRAY be type const.
void SaveParam(..) const and void ReadParam(..) const
* PARAM_CFG_BASE now has virtual destructor since we have various way of
destroying the derived class and boost::ptr_vector must be told about this.
* Pass const PARAM_CFG_ARRAY& instead of PARAM_CFG_ARRAY so that we can use
an automatic PARAM_CFG_ARRAY which is on the stack.\
* PCB_EDIT_FRAME::GetProjectFileParameters() may no longer cache the array,
since it has to access the current BOARD and the BOARD can change.
Remember BOARD_DESIGN_SETTINGS are now in the BOARD.
* Made the m_BoundingBox member private, this was a brutally hard task,
and indicative of the lack of commitment to accessors and object oriented
design on the part of KiCad developers. We must do better.
Added BOARD::GetBoundingBox, SetBoundingBox(), ComputeBoundingBox().
* Added PCB_BASE_FRAME::GetBoardBoundingBox() which calls BOARD::ComputeBoundingBox()
2011-12-05 06:15:33 +00:00
|
|
|
bbbox.GetX() * conv_unit,
|
|
|
|
bbbox.GetY() * conv_unit );
|
|
|
|
|
2008-10-01 16:00:35 +00:00
|
|
|
fputs( line, rptfile );
|
2007-08-23 04:28:46 +00:00
|
|
|
|
2008-10-01 16:00:35 +00:00
|
|
|
sprintf( line, "lower_right_corner %9.6f %9.6f\n",
|
++PCBNew
* Removed Pcb_Frame argument from BOARD() constructor, since it precludes
having a BOARD being edited by more than one editor, it was a bad design.
And this meant removing m_PcbFrame from BOARD.
* removed BOARD::SetWindowFrame(), and BOARD::m_PcbFrame
* Removed the global BOARD_DESIGN_SETTINGS which was in class_board.cpp
* added BOARD_DESIGN_SETTINGS to the BOARD class, a full instance
* a couple dialogs now only change BOARD_DESIGN_SETTINGS when OK is pressed,
such as dialog_mask_clearance, dialog_drc, etc.
* Removed common/pcbcommon.cpp's int g_CurrentVersionPCB = 1 and replaced it
with build_version.h's #define BOARD_FILE_VERSION, although there may be a
better place for this constant.
* Made the public functions in PARAM_CFG_ARRAY be type const.
void SaveParam(..) const and void ReadParam(..) const
* PARAM_CFG_BASE now has virtual destructor since we have various way of
destroying the derived class and boost::ptr_vector must be told about this.
* Pass const PARAM_CFG_ARRAY& instead of PARAM_CFG_ARRAY so that we can use
an automatic PARAM_CFG_ARRAY which is on the stack.\
* PCB_EDIT_FRAME::GetProjectFileParameters() may no longer cache the array,
since it has to access the current BOARD and the BOARD can change.
Remember BOARD_DESIGN_SETTINGS are now in the BOARD.
* Made the m_BoundingBox member private, this was a brutally hard task,
and indicative of the lack of commitment to accessors and object oriented
design on the part of KiCad developers. We must do better.
Added BOARD::GetBoundingBox, SetBoundingBox(), ComputeBoundingBox().
* Added PCB_BASE_FRAME::GetBoardBoundingBox() which calls BOARD::ComputeBoundingBox()
2011-12-05 06:15:33 +00:00
|
|
|
bbbox.GetRight() * conv_unit,
|
|
|
|
bbbox.GetBottom() * conv_unit );
|
2008-10-01 16:00:35 +00:00
|
|
|
fputs( line, rptfile );
|
2007-08-23 04:28:46 +00:00
|
|
|
|
|
|
|
fputs( "$EndBOARD\n\n", rptfile );
|
|
|
|
|
2009-01-05 05:21:35 +00:00
|
|
|
Module = (MODULE*) GetBoard()->m_Modules;
|
2011-09-07 19:41:04 +00:00
|
|
|
|
2007-08-23 04:28:46 +00:00
|
|
|
for( ; Module != NULL; Module = Module->Next() )
|
|
|
|
{
|
2011-03-25 20:07:27 +00:00
|
|
|
sprintf( line, "$MODULE %s\n", EscapedUTF8( Module->m_Reference->m_Text ).c_str() );
|
2008-10-01 16:00:35 +00:00
|
|
|
fputs( line, rptfile );
|
2007-08-23 04:28:46 +00:00
|
|
|
|
2011-03-25 20:07:27 +00:00
|
|
|
sprintf( line, "reference %s\n", EscapedUTF8( Module->m_Reference->m_Text ).c_str() );
|
2008-10-01 16:00:35 +00:00
|
|
|
fputs( line, rptfile );
|
2011-03-25 20:07:27 +00:00
|
|
|
sprintf( line, "value %s\n", EscapedUTF8( Module->m_Value->m_Text ).c_str() );
|
2008-10-01 16:00:35 +00:00
|
|
|
fputs( line, rptfile );
|
2011-03-25 20:07:27 +00:00
|
|
|
sprintf( line, "footprint %s\n", EscapedUTF8( Module->m_LibRef ).c_str() );
|
2008-10-01 16:00:35 +00:00
|
|
|
fputs( line, rptfile );
|
2007-08-23 04:28:46 +00:00
|
|
|
|
|
|
|
msg = wxT( "attribut" );
|
2011-09-07 19:41:04 +00:00
|
|
|
|
2007-08-23 04:28:46 +00:00
|
|
|
if( Module->m_Attributs & MOD_VIRTUAL )
|
|
|
|
msg += wxT( " virtual" );
|
2011-09-07 19:41:04 +00:00
|
|
|
|
2007-08-23 04:28:46 +00:00
|
|
|
if( Module->m_Attributs & MOD_CMS )
|
|
|
|
msg += wxT( " smd" );
|
2011-09-07 19:41:04 +00:00
|
|
|
|
2007-08-23 04:28:46 +00:00
|
|
|
if( ( Module->m_Attributs & (MOD_VIRTUAL | MOD_CMS) ) == 0 )
|
|
|
|
msg += wxT( " none" );
|
2011-09-07 19:41:04 +00:00
|
|
|
|
2007-08-23 04:28:46 +00:00
|
|
|
msg += wxT( "\n" );
|
2011-02-28 18:36:19 +00:00
|
|
|
fputs( TO_UTF8( msg ), rptfile );
|
2007-08-23 04:28:46 +00:00
|
|
|
|
|
|
|
module_pos = Module->m_Pos;
|
|
|
|
module_pos.x -= File_Place_Offset.x;
|
|
|
|
module_pos.y -= File_Place_Offset.y;
|
2009-03-15 21:11:12 +00:00
|
|
|
|
2008-10-01 16:00:35 +00:00
|
|
|
sprintf( line, "position %9.6f %9.6f\n",
|
2009-03-15 21:11:12 +00:00
|
|
|
module_pos.x * conv_unit,
|
|
|
|
module_pos.y * conv_unit );
|
2008-10-01 16:00:35 +00:00
|
|
|
fputs( line, rptfile );
|
2007-08-23 04:28:46 +00:00
|
|
|
|
2009-03-15 21:11:12 +00:00
|
|
|
sprintf( line, "orientation %.2f\n", (double) Module->m_Orient / 10 );
|
2011-09-07 19:41:04 +00:00
|
|
|
|
2009-12-07 03:46:13 +00:00
|
|
|
if( Module->GetLayer() == LAYER_N_FRONT )
|
2008-10-01 16:00:35 +00:00
|
|
|
strcat( line, "layer component\n" );
|
2009-12-07 03:46:13 +00:00
|
|
|
else if( Module->GetLayer() == LAYER_N_BACK )
|
2008-10-01 16:00:35 +00:00
|
|
|
strcat( line, "layer copper\n" );
|
2007-08-23 04:28:46 +00:00
|
|
|
else
|
2008-10-01 16:00:35 +00:00
|
|
|
strcat( line, "layer other\n" );
|
2011-09-07 19:41:04 +00:00
|
|
|
|
2008-10-01 16:00:35 +00:00
|
|
|
fputs( line, rptfile );
|
2007-08-23 04:28:46 +00:00
|
|
|
|
|
|
|
Module->Write_3D_Descr( rptfile );
|
|
|
|
|
|
|
|
for( pad = Module->m_Pads; pad != NULL; pad = pad->Next() )
|
|
|
|
{
|
2011-12-16 17:03:25 +00:00
|
|
|
fprintf( rptfile, "$PAD \"%s\"\n", TO_UTF8( pad->GetPadName() ) );
|
2008-10-01 16:00:35 +00:00
|
|
|
sprintf( line, "position %9.6f %9.6f\n",
|
2011-11-24 17:32:51 +00:00
|
|
|
pad->m_Pos0.x * conv_unit,
|
|
|
|
pad->m_Pos0.y * conv_unit );
|
2008-10-01 16:00:35 +00:00
|
|
|
fputs( line, rptfile );
|
2007-08-23 04:28:46 +00:00
|
|
|
|
2008-10-01 16:00:35 +00:00
|
|
|
sprintf( line, "size %9.6f %9.6f\n",
|
2011-11-24 17:32:51 +00:00
|
|
|
pad->m_Size.x * conv_unit,
|
|
|
|
pad->m_Size.y * conv_unit );
|
2008-10-01 16:00:35 +00:00
|
|
|
fputs( line, rptfile );
|
2011-11-24 17:32:51 +00:00
|
|
|
sprintf( line, "drill %9.6f\n", pad->m_Drill.x * conv_unit );
|
2008-10-01 16:00:35 +00:00
|
|
|
fputs( line, rptfile );
|
|
|
|
sprintf( line, "shape_offset %9.6f %9.6f\n",
|
2011-11-24 17:32:51 +00:00
|
|
|
pad->m_Offset.x * conv_unit,
|
|
|
|
pad->m_Offset.y * conv_unit );
|
2008-10-01 16:00:35 +00:00
|
|
|
fputs( line, rptfile );
|
2007-08-23 04:28:46 +00:00
|
|
|
|
2009-11-14 22:15:22 +00:00
|
|
|
sprintf( line, "orientation %.2f\n",
|
|
|
|
double(pad->m_Orient - Module->m_Orient) / 10 );
|
2008-10-01 16:00:35 +00:00
|
|
|
fputs( line, rptfile );
|
2011-09-07 19:41:04 +00:00
|
|
|
const char* shape_name[6] = { "??? ", "Circ", "Rect", "Oval", "trap", "spec" };
|
2008-10-01 16:00:35 +00:00
|
|
|
sprintf( line, "Shape %s\n", shape_name[pad->m_PadShape] );
|
|
|
|
fputs( line, rptfile );
|
2007-08-23 04:28:46 +00:00
|
|
|
|
|
|
|
int layer = 0;
|
2011-09-07 19:41:04 +00:00
|
|
|
|
|
|
|
if( pad->m_layerMask & LAYER_BACK )
|
2007-08-23 04:28:46 +00:00
|
|
|
layer = 1;
|
2011-09-07 19:41:04 +00:00
|
|
|
|
|
|
|
if( pad->m_layerMask & LAYER_FRONT )
|
2007-08-23 04:28:46 +00:00
|
|
|
layer |= 2;
|
2011-09-07 19:41:04 +00:00
|
|
|
|
2007-11-08 10:00:38 +00:00
|
|
|
const char* layer_name[4] = { "??? ", "copper", "component", "all" };
|
2008-10-01 16:00:35 +00:00
|
|
|
sprintf( line, "Layer %s\n", layer_name[layer] );
|
|
|
|
fputs( line, rptfile );
|
2007-08-23 04:28:46 +00:00
|
|
|
fprintf( rptfile, "$EndPAD\n" );
|
|
|
|
}
|
|
|
|
|
|
|
|
fprintf( rptfile, "$EndMODULE %s\n\n",
|
2011-02-28 18:36:19 +00:00
|
|
|
TO_UTF8(Module->m_Reference->m_Text ) );
|
2007-08-23 04:28:46 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/* Write board Edges */
|
2010-12-08 20:12:46 +00:00
|
|
|
EDA_ITEM* PtStruct;
|
|
|
|
|
2009-01-05 05:21:35 +00:00
|
|
|
for( PtStruct = GetBoard()->m_Drawings; PtStruct != NULL; PtStruct = PtStruct->Next() )
|
2007-08-23 04:28:46 +00:00
|
|
|
{
|
2011-10-01 19:24:27 +00:00
|
|
|
if( PtStruct->Type() != PCB_LINE_T )
|
2007-08-23 04:28:46 +00:00
|
|
|
continue;
|
2010-12-08 20:12:46 +00:00
|
|
|
|
2007-08-23 04:28:46 +00:00
|
|
|
if( ( (DRAWSEGMENT*) PtStruct )->GetLayer() != EDGE_N )
|
|
|
|
continue;
|
2011-09-07 19:41:04 +00:00
|
|
|
|
2007-08-23 04:28:46 +00:00
|
|
|
WriteDrawSegmentPcb( (DRAWSEGMENT*) PtStruct, rptfile );
|
|
|
|
}
|
|
|
|
|
2009-11-14 22:15:22 +00:00
|
|
|
/* Generate EOF. */
|
2007-08-23 04:28:46 +00:00
|
|
|
fputs( "$EndDESCRIPTION\n", rptfile );
|
|
|
|
fclose( rptfile );
|
2009-11-14 22:15:22 +00:00
|
|
|
SetLocaleTo_Default( ); // revert to the current locale
|
2011-02-27 23:25:07 +00:00
|
|
|
|
|
|
|
msg = _( "Module report file created:" );
|
|
|
|
msg.Append( wxT( "\n" ) + fn.GetFullPath() );
|
|
|
|
|
|
|
|
wxMessageBox( msg, _( "Module Report" ), wxICON_INFORMATION );
|
2007-06-05 12:10:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-11-14 22:15:22 +00:00
|
|
|
/* Output to rpt file a segment type from the PCB drawing.
|
|
|
|
* The contours are of different types:
|
|
|
|
* Segment
|
|
|
|
* Circle
|
|
|
|
* Arc
|
2007-08-23 04:28:46 +00:00
|
|
|
*/
|
2009-11-14 22:15:22 +00:00
|
|
|
void WriteDrawSegmentPcb( DRAWSEGMENT* PtDrawSegment, FILE* rptfile )
|
2007-06-05 12:10:51 +00:00
|
|
|
{
|
++PCBNew
* Removed Pcb_Frame argument from BOARD() constructor, since it precludes
having a BOARD being edited by more than one editor, it was a bad design.
And this meant removing m_PcbFrame from BOARD.
* removed BOARD::SetWindowFrame(), and BOARD::m_PcbFrame
* Removed the global BOARD_DESIGN_SETTINGS which was in class_board.cpp
* added BOARD_DESIGN_SETTINGS to the BOARD class, a full instance
* a couple dialogs now only change BOARD_DESIGN_SETTINGS when OK is pressed,
such as dialog_mask_clearance, dialog_drc, etc.
* Removed common/pcbcommon.cpp's int g_CurrentVersionPCB = 1 and replaced it
with build_version.h's #define BOARD_FILE_VERSION, although there may be a
better place for this constant.
* Made the public functions in PARAM_CFG_ARRAY be type const.
void SaveParam(..) const and void ReadParam(..) const
* PARAM_CFG_BASE now has virtual destructor since we have various way of
destroying the derived class and boost::ptr_vector must be told about this.
* Pass const PARAM_CFG_ARRAY& instead of PARAM_CFG_ARRAY so that we can use
an automatic PARAM_CFG_ARRAY which is on the stack.\
* PCB_EDIT_FRAME::GetProjectFileParameters() may no longer cache the array,
since it has to access the current BOARD and the BOARD can change.
Remember BOARD_DESIGN_SETTINGS are now in the BOARD.
* Made the m_BoundingBox member private, this was a brutally hard task,
and indicative of the lack of commitment to accessors and object oriented
design on the part of KiCad developers. We must do better.
Added BOARD::GetBoundingBox, SetBoundingBox(), ComputeBoundingBox().
* Added PCB_BASE_FRAME::GetBoardBoundingBox() which calls BOARD::ComputeBoundingBox()
2011-12-05 06:15:33 +00:00
|
|
|
double ux0, uy0, dx, dy;
|
2011-09-07 19:41:04 +00:00
|
|
|
double radius, width;
|
2008-10-01 16:00:35 +00:00
|
|
|
char line[1024];
|
2007-08-23 04:28:46 +00:00
|
|
|
|
2011-12-14 04:29:25 +00:00
|
|
|
ux0 = PtDrawSegment->GetStart().x * conv_unit;
|
|
|
|
uy0 = PtDrawSegment->GetStart().y * conv_unit;
|
2008-10-01 16:00:35 +00:00
|
|
|
|
2011-12-14 04:29:25 +00:00
|
|
|
dx = PtDrawSegment->GetEnd().x * conv_unit;
|
|
|
|
dy = PtDrawSegment->GetEnd().y * conv_unit;
|
2007-08-23 04:28:46 +00:00
|
|
|
|
2011-12-14 04:29:25 +00:00
|
|
|
width = PtDrawSegment->GetWidth() * conv_unit;
|
2007-08-23 04:28:46 +00:00
|
|
|
|
2011-12-14 04:29:25 +00:00
|
|
|
switch( PtDrawSegment->GetShape() )
|
2007-08-23 04:28:46 +00:00
|
|
|
{
|
|
|
|
case S_CIRCLE:
|
2011-09-07 19:41:04 +00:00
|
|
|
radius = hypot( dx - ux0, dy - uy0 );
|
2009-01-18 15:51:06 +00:00
|
|
|
fprintf( rptfile, "$CIRCLE \n" );
|
|
|
|
fprintf( rptfile, "centre %.6lf %.6lf\n", ux0, uy0 );
|
2011-09-07 19:41:04 +00:00
|
|
|
fprintf( rptfile, "radius %.6lf\n", radius );
|
2009-01-18 15:51:06 +00:00
|
|
|
fprintf( rptfile, "width %.6lf\n", width );
|
|
|
|
fprintf( rptfile, "$EndCIRCLE \n" );
|
2007-08-23 04:28:46 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case S_ARC:
|
2008-10-01 16:00:35 +00:00
|
|
|
{
|
2011-12-14 04:29:25 +00:00
|
|
|
int endx = PtDrawSegment->GetEnd().x;
|
|
|
|
int endy = PtDrawSegment->GetEnd().y;
|
|
|
|
|
2011-09-07 19:41:04 +00:00
|
|
|
radius = hypot( dx - ux0, dy - uy0 );
|
2008-10-01 16:00:35 +00:00
|
|
|
RotatePoint( &endx,
|
|
|
|
&endy,
|
2011-12-14 04:29:25 +00:00
|
|
|
PtDrawSegment->GetStart().x,
|
|
|
|
PtDrawSegment->GetStart().y,
|
|
|
|
PtDrawSegment->GetAngle() );
|
2008-10-01 16:00:35 +00:00
|
|
|
|
2009-01-18 15:51:06 +00:00
|
|
|
fprintf( rptfile, "$ARC \n" );
|
|
|
|
fprintf( rptfile, "centre %.6lf %.6lf\n", ux0, uy0 );
|
2009-11-14 22:15:22 +00:00
|
|
|
fprintf( rptfile, "start %.6lf %.6lf\n",
|
|
|
|
endx * conv_unit, endy * conv_unit );
|
2009-01-18 15:51:06 +00:00
|
|
|
fprintf( rptfile, "end %.6lf %.6lf\n", dx, dy );
|
|
|
|
fprintf( rptfile, "width %.6lf\n", width );
|
|
|
|
fprintf( rptfile, "$EndARC \n" );
|
2008-10-01 16:00:35 +00:00
|
|
|
}
|
2007-08-23 04:28:46 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
2008-10-01 16:00:35 +00:00
|
|
|
sprintf( line, "$LINE \n" );
|
|
|
|
fputs( line, rptfile );
|
|
|
|
|
2009-01-18 15:51:06 +00:00
|
|
|
fprintf( rptfile, "start %.6lf %.6lf\n", ux0, uy0 );
|
|
|
|
fprintf( rptfile, "end %.6lf %.6lf\n", dx, dy );
|
|
|
|
fprintf( rptfile, "width %.6lf\n", width );
|
|
|
|
fprintf( rptfile, "$EndLINE \n" );
|
2007-08-23 04:28:46 +00:00
|
|
|
break;
|
|
|
|
}
|
2007-06-05 12:10:51 +00:00
|
|
|
}
|