2007-08-23 04:28:46 +00:00
|
|
|
/*******************************/
|
|
|
|
/**** Routine de trace HPGL ****/
|
|
|
|
/*******************************/
|
2007-06-05 12:10:51 +00:00
|
|
|
|
|
|
|
#include "fctsys.h"
|
|
|
|
#include "common.h"
|
|
|
|
#include "plot_common.h"
|
2009-02-04 15:25:03 +00:00
|
|
|
#include "confirm.h"
|
2007-06-05 12:10:51 +00:00
|
|
|
#include "pcbnew.h"
|
|
|
|
#include "pcbplot.h"
|
|
|
|
#include "trigo.h"
|
|
|
|
|
|
|
|
#include "protos.h"
|
|
|
|
|
|
|
|
/*****************************************************************************/
|
2009-06-28 16:50:42 +00:00
|
|
|
void WinEDA_BasePcbFrame::Genere_HPGL( const wxString& FullFileName, int Layer,
|
|
|
|
GRTraceMode trace_mode)
|
2007-06-05 12:10:51 +00:00
|
|
|
/*****************************************************************************/
|
|
|
|
{
|
2007-08-23 04:28:46 +00:00
|
|
|
wxSize SheetSize;
|
|
|
|
wxSize BoardSize;
|
|
|
|
wxPoint BoardCenter;
|
|
|
|
bool Center = FALSE;
|
2009-06-28 16:50:42 +00:00
|
|
|
Ki_PageDescr* currentsheet = GetScreen()->m_CurrentSheetDesc;
|
|
|
|
double scale;
|
|
|
|
wxPoint offset;
|
2007-08-23 04:28:46 +00:00
|
|
|
|
2009-06-28 16:50:42 +00:00
|
|
|
MsgPanel->EraseMsgBox();
|
2007-08-23 04:28:46 +00:00
|
|
|
// Compute pen_dim (from g_HPGL_Pen_Diam in mils) in pcb units,
|
|
|
|
// with plot scale (if Scale is 2, pen diametre is always g_HPGL_Pen_Diam
|
|
|
|
// so apparent pen diam is real pen diam / Scale
|
2009-06-28 16:50:42 +00:00
|
|
|
int pen_diam = wxRound( (g_pcb_plot_options.HPGL_Pen_Diam * U_PCB) / g_pcb_plot_options.Scale );
|
2007-08-23 04:28:46 +00:00
|
|
|
|
|
|
|
// compute pen_recouvrement (from g_HPGL_Pen_Recouvrement in mils)
|
|
|
|
// with plot scale
|
2009-06-28 16:50:42 +00:00
|
|
|
if( g_pcb_plot_options.HPGL_Pen_Recouvrement < 0 )
|
|
|
|
g_pcb_plot_options.HPGL_Pen_Recouvrement = 0;
|
|
|
|
if( g_pcb_plot_options.HPGL_Pen_Recouvrement >= g_pcb_plot_options.HPGL_Pen_Diam )
|
|
|
|
g_pcb_plot_options.HPGL_Pen_Recouvrement = g_pcb_plot_options.HPGL_Pen_Diam - 1;
|
|
|
|
int pen_recouvrement = wxRound( g_pcb_plot_options.HPGL_Pen_Recouvrement * 10.0 / g_pcb_plot_options.Scale );
|
2007-08-23 04:28:46 +00:00
|
|
|
|
2009-06-28 16:50:42 +00:00
|
|
|
FILE *output_file = wxFopen( FullFileName, wxT( "wt" ) );
|
|
|
|
if( output_file == NULL )
|
2007-08-23 04:28:46 +00:00
|
|
|
{
|
2009-06-28 16:50:42 +00:00
|
|
|
wxString msg = _( "Unable to create file " ) + FullFileName;
|
2007-08-23 04:28:46 +00:00
|
|
|
DisplayError( this, msg );
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2009-03-18 15:38:16 +00:00
|
|
|
SetLocaleTo_C_standard();
|
2007-08-23 04:28:46 +00:00
|
|
|
Affiche_1_Parametre( this, 0, _( "File" ), FullFileName, CYAN );
|
|
|
|
|
2009-06-28 16:50:42 +00:00
|
|
|
if( g_pcb_plot_options.PlotScaleOpt != 1 )
|
|
|
|
Center = TRUE; // Echelle != 1 donc trace centree du PCB
|
2007-08-23 04:28:46 +00:00
|
|
|
|
2009-06-28 16:50:42 +00:00
|
|
|
|
|
|
|
// calcul en unites internes des dimensions des feuilles ( connues en 1/1000 pouce )
|
|
|
|
SheetSize.x = currentsheet->m_Size.x * U_PCB;
|
|
|
|
SheetSize.y = currentsheet->m_Size.y * U_PCB;
|
2007-08-23 04:28:46 +00:00
|
|
|
|
|
|
|
/* calcul des dimensions et centre du PCB */
|
|
|
|
m_Pcb->ComputeBoundaryBox();
|
|
|
|
BoardSize = m_Pcb->m_BoundaryBox.GetSize();
|
|
|
|
BoardCenter = m_Pcb->m_BoundaryBox.Centre();
|
|
|
|
|
2009-06-28 16:50:42 +00:00
|
|
|
if( g_pcb_plot_options.PlotScaleOpt == 0 ) // Optimum scale
|
2007-08-23 04:28:46 +00:00
|
|
|
{
|
2009-06-28 16:50:42 +00:00
|
|
|
double Xscale, Yscale;
|
|
|
|
// Fit to 80% of the page
|
|
|
|
Xscale = ( (SheetSize.x*0.8) / BoardSize.x);
|
|
|
|
Yscale = ( (SheetSize.y*0.8) / BoardSize.y);
|
|
|
|
scale = MIN( Xscale, Yscale );
|
2007-08-23 04:28:46 +00:00
|
|
|
}
|
2009-06-28 16:50:42 +00:00
|
|
|
else
|
|
|
|
scale = g_pcb_plot_options.Scale;
|
2007-08-23 04:28:46 +00:00
|
|
|
|
2009-06-28 16:50:42 +00:00
|
|
|
// Calcul du cadrage (echelle != 1 donc recadrage du trace)
|
2007-08-23 04:28:46 +00:00
|
|
|
if( Center )
|
|
|
|
{
|
2009-06-28 16:50:42 +00:00
|
|
|
offset.x = BoardCenter.x-(SheetSize.x/2)/scale;
|
|
|
|
offset.y = BoardCenter.y-(SheetSize.y/2)/scale;
|
2007-08-23 04:28:46 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2009-06-28 16:50:42 +00:00
|
|
|
offset.x = 0;
|
|
|
|
offset.y = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
HPGL_Plotter *plotter = new HPGL_Plotter();
|
|
|
|
plotter->set_paper_size(currentsheet);
|
|
|
|
plotter->set_viewport(offset, scale,
|
|
|
|
g_pcb_plot_options.PlotOrient);
|
|
|
|
plotter->set_default_line_width( g_pcb_plot_options.PlotLine_Width );
|
|
|
|
plotter->set_creator(wxT("PCBNEW-HPGL"));
|
|
|
|
plotter->set_filename(FullFileName);
|
|
|
|
plotter->set_pen_speed(g_pcb_plot_options.HPGL_Pen_Speed);
|
|
|
|
plotter->set_pen_number(g_pcb_plot_options.HPGL_Pen_Num);
|
|
|
|
plotter->set_pen_overlap(pen_recouvrement);
|
|
|
|
plotter->set_pen_diameter(pen_diam);
|
|
|
|
plotter->start_plot(output_file);
|
|
|
|
|
|
|
|
/* The worksheet is not significant with scale!=1... It is with
|
|
|
|
* paperscale!=1, anyway */
|
|
|
|
if( g_pcb_plot_options.Plot_Frame_Ref && !Center)
|
|
|
|
PlotWorkSheet( plotter, GetScreen() );
|
|
|
|
|
|
|
|
Plot_Layer(plotter, Layer, trace_mode);
|
|
|
|
plotter->end_plot();
|
|
|
|
delete plotter;
|
2009-03-18 15:38:16 +00:00
|
|
|
SetLocaleTo_Default();
|
2007-06-05 12:10:51 +00:00
|
|
|
}
|
|
|
|
|