Minor bug and compiler warning fixes.
* Applied sheet reference plotting patch from Lorenzo. * Fixed bug in Pcbnew plot dialog, ignore user scaling when controls are disabled.
This commit is contained in:
parent
fd0e99bbd4
commit
161068b1c6
|
@ -236,7 +236,8 @@ void WinEDA_DrawFrame::PlotWorkSheet( int format_plot, BASE_SCREEN* screen )
|
||||||
gypas = ( yg - ref.y) / ipas;
|
gypas = ( yg - ref.y) / ipas;
|
||||||
for( ii = ref.y + gypas, jj = 0; ipas > 0; ii += gypas, jj++, ipas-- )
|
for( ii = ref.y + gypas, jj = 0; ipas > 0; ii += gypas, jj++, ipas-- )
|
||||||
{
|
{
|
||||||
msg.Empty(); msg << jj;
|
msg.Empty();
|
||||||
|
msg.Append('A' + jj);
|
||||||
if( ii < yg - PAS_REF / 2 )
|
if( ii < yg - PAS_REF / 2 )
|
||||||
{
|
{
|
||||||
pos.x = ref.x * conv_unit; pos.y = ii * conv_unit;
|
pos.x = ref.x * conv_unit; pos.y = ii * conv_unit;
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
/**********************************************************/
|
/**********************************************************/
|
||||||
/* wxwineda.cpp - fonctions des classes du type WinEDAxxxx */
|
/* wxwineda.cpp - fonctions des classes du type WinEDAxxxx */
|
||||||
/**********************************************************/
|
/**********************************************************/
|
||||||
|
|
||||||
|
@ -29,10 +29,10 @@ WinEDA_EnterText::WinEDA_EnterText( wxWindow* parent,
|
||||||
BoxSizer->Add( m_Title, 0, wxGROW | wxLEFT | wxRIGHT | wxTOP | wxADJUST_MINSIZE, 5 );
|
BoxSizer->Add( m_Title, 0, wxGROW | wxLEFT | wxRIGHT | wxTOP | wxADJUST_MINSIZE, 5 );
|
||||||
|
|
||||||
long style = 0;
|
long style = 0;
|
||||||
|
|
||||||
if (Multiline)
|
if (Multiline)
|
||||||
style = wxTE_MULTILINE;
|
style = wxTE_MULTILINE;
|
||||||
|
|
||||||
m_FrameText = new wxTextCtrl( parent, -1, TextToEdit, wxDefaultPosition, Size,style );
|
m_FrameText = new wxTextCtrl( parent, -1, TextToEdit, wxDefaultPosition, Size,style );
|
||||||
|
|
||||||
m_FrameText->SetInsertionPoint( 1 );
|
m_FrameText->SetInsertionPoint( 1 );
|
||||||
|
@ -410,15 +410,17 @@ void WinEDA_ValueCtrl::Enable( bool enbl )
|
||||||
/***************************************************************/
|
/***************************************************************/
|
||||||
/* Classe pour afficher et editer une valeur en double flottant*/
|
/* Classe pour afficher et editer une valeur en double flottant*/
|
||||||
/***************************************************************/
|
/***************************************************************/
|
||||||
WinEDA_DFloatValueCtrl::WinEDA_DFloatValueCtrl( wxWindow* parent, const wxString& title,
|
WinEDA_DFloatValueCtrl::WinEDA_DFloatValueCtrl( wxWindow* parent,
|
||||||
double value, wxBoxSizer* BoxSizer )
|
const wxString& title,
|
||||||
|
double value,
|
||||||
|
wxBoxSizer* BoxSizer )
|
||||||
{
|
{
|
||||||
wxString buffer;
|
wxString buffer;
|
||||||
wxString label = title;
|
wxString label = title;
|
||||||
|
|
||||||
m_Value = value;
|
m_Value = value;
|
||||||
|
|
||||||
m_Text = new wxStaticText( parent, -1, label );
|
m_Text = new wxStaticText( parent, -1, label );
|
||||||
|
|
||||||
BoxSizer->Add( m_Text, 0, wxGROW | wxLEFT | wxRIGHT | wxTOP, 5 );
|
BoxSizer->Add( m_Text, 0, wxGROW | wxLEFT | wxRIGHT | wxTOP, 5 );
|
||||||
|
|
||||||
|
|
|
@ -47,7 +47,8 @@ MODULE* WinEDA_DisplayFrame::Get_Module( const wxString& CmpName )
|
||||||
|
|
||||||
if( !tmp )
|
if( !tmp )
|
||||||
{
|
{
|
||||||
msg.Printf( _( "PCB foot print library file <%s> could not be found in the default search paths." ),
|
msg.Printf( _( "PCB foot print library file <%s> could not be \
|
||||||
|
found in the default search paths." ),
|
||||||
fn.GetFullName().c_str() );
|
fn.GetFullName().c_str() );
|
||||||
wxMessageBox( msg, titleLibLoadError, wxOK | wxICON_ERROR, this );
|
wxMessageBox( msg, titleLibLoadError, wxOK | wxICON_ERROR, this );
|
||||||
continue;
|
continue;
|
||||||
|
|
|
@ -173,9 +173,9 @@ static int SavePcbFormatAscii( WinEDA_GerberFrame* frame, FILE* aFile,
|
||||||
double b = atan2( track->m_End.y-cy, track->m_End.x-cx );
|
double b = atan2( track->m_End.y-cy, track->m_End.x-cx );
|
||||||
|
|
||||||
drawitem->m_Shape = S_ARC;
|
drawitem->m_Shape = S_ARC;
|
||||||
drawitem->m_Angle = fmod( (a-b)/M_PI*1800.0+3600.0, 3600.0 );
|
drawitem->m_Angle = (int)fmod( (a-b)/M_PI*1800.0+3600.0, 3600.0 );
|
||||||
drawitem->m_Start.x = cx;
|
drawitem->m_Start.x = (int)cx;
|
||||||
drawitem->m_Start.y = cy;
|
drawitem->m_Start.y = (int)cy;
|
||||||
}
|
}
|
||||||
|
|
||||||
pcb->Add( drawitem );
|
pcb->Add( drawitem );
|
||||||
|
|
|
@ -327,7 +327,8 @@ void WinEDA_PcbFrame::DrawInfoPlace( wxDC* DC )
|
||||||
*/
|
*/
|
||||||
{
|
{
|
||||||
int color, ii, jj;
|
int color, ii, jj;
|
||||||
int ox, oy, top_state, bottom_state;
|
int ox, oy;
|
||||||
|
BoardCell top_state, bottom_state;
|
||||||
|
|
||||||
GRSetDrawMode( DC, GR_COPY );
|
GRSetDrawMode( DC, GR_COPY );
|
||||||
for( ii = 0; ii < Nrows; ii++ )
|
for( ii = 0; ii < Nrows; ii++ )
|
||||||
|
|
109
pcbnew/cell.h
109
pcbnew/cell.h
|
@ -1,75 +1,74 @@
|
||||||
/* Bits caracterisant une cellule */
|
/* Bits caracterisant une cellule */
|
||||||
#define HOLE 0x00000001L /* a conducting hole, ou obstacle */
|
#define HOLE (char)0x01 /* a conducting hole, ou obstacle */
|
||||||
#define CELL_is_MODULE 2 /* autoplacement: occupe par un module */
|
#define CELL_is_MODULE (char)0x02 /* autoplacement: occupe par un module */
|
||||||
#define CELL_is_EDGE 0x20 /* zone et autoplacement: cellule limitant un contour (Board, Zone) */
|
#define CELL_is_EDGE (char)0x20 /* zone et autoplacement: cellule limitant un contour (Board, Zone) */
|
||||||
#define CELL_is_FRIEND 0x40 /* zone et autoplacement: cellule faisant partie du net */
|
#define CELL_is_FRIEND (char)0x40 /* zone et autoplacement: cellule faisant partie du net */
|
||||||
#define CELL_is_ZONE 0x80 /* zone et autoplacement: cellule disponible */
|
#define CELL_is_ZONE (char)0x80 /* zone et autoplacement: cellule disponible */
|
||||||
|
|
||||||
/* Bits Masques de presence d'obstacles pour autoroutage */
|
/* Bits Masques de presence d'obstacles pour autoroutage */
|
||||||
#define OCCUPE 1 /* autoroutage : obstacle pour pistes et vias */
|
#define OCCUPE 1 /* autoroutage : obstacle pour pistes et vias */
|
||||||
#define VIA_IMPOSSIBLE 2 /* autoroutage : obsacle pour vias */
|
#define VIA_IMPOSSIBLE 2 /* autoroutage : obsacle pour vias */
|
||||||
#define CURRENT_PAD 4
|
#define CURRENT_PAD 4
|
||||||
|
|
||||||
|
|
||||||
/* traces radiating outward from a hole to a side or corner */
|
/* traces radiating outward from a hole to a side or corner */
|
||||||
#define HOLE_NORTH 0x00000002L /* upward */
|
#define HOLE_NORTH 0x00000002L /* upward */
|
||||||
#define HOLE_NORTHEAST 0x00000004L /* upward and right */
|
#define HOLE_NORTHEAST 0x00000004L /* upward and right */
|
||||||
#define HOLE_EAST 0x00000008L /* to the right */
|
#define HOLE_EAST 0x00000008L /* to the right */
|
||||||
#define HOLE_SOUTHEAST 0x00000010L /* downward and right */
|
#define HOLE_SOUTHEAST 0x00000010L /* downward and right */
|
||||||
#define HOLE_SOUTH 0x00000020L /* downward */
|
#define HOLE_SOUTH 0x00000020L /* downward */
|
||||||
#define HOLE_SOUTHWEST 0x00000040L /* downward and left */
|
#define HOLE_SOUTHWEST 0x00000040L /* downward and left */
|
||||||
#define HOLE_WEST 0x00000080L /* to the left */
|
#define HOLE_WEST 0x00000080L /* to the left */
|
||||||
#define HOLE_NORTHWEST 0x00000100L /* upward and left */
|
#define HOLE_NORTHWEST 0x00000100L /* upward and left */
|
||||||
|
|
||||||
/* straight lines through the center */
|
/* straight lines through the center */
|
||||||
#define LINE_HORIZONTAL 0x00000002L /* left-to-right line */
|
#define LINE_HORIZONTAL 0x00000002L /* left-to-right line */
|
||||||
#define LINE_VERTICAL 0x00000004L /* top-to-bottom line */
|
#define LINE_VERTICAL 0x00000004L /* top-to-bottom line */
|
||||||
|
|
||||||
/* lines cutting across a corner, connecting adjacent sides */
|
/* lines cutting across a corner, connecting adjacent sides */
|
||||||
#define CORNER_NORTHEAST 0x00000008L /* upper right corner */
|
#define CORNER_NORTHEAST 0x00000008L /* upper right corner */
|
||||||
#define CORNER_SOUTHEAST 0x00000010L /* lower right corner */
|
#define CORNER_SOUTHEAST 0x00000010L /* lower right corner */
|
||||||
#define CORNER_SOUTHWEST 0x00000020L /* lower left corner */
|
#define CORNER_SOUTHWEST 0x00000020L /* lower left corner */
|
||||||
#define CORNER_NORTHWEST 0x00000040L /* upper left corner */
|
#define CORNER_NORTHWEST 0x00000040L /* upper left corner */
|
||||||
|
|
||||||
/* diagonal lines through the center */
|
/* diagonal lines through the center */
|
||||||
#define DIAG_NEtoSW 0x00000080L /* northeast to southwest */
|
#define DIAG_NEtoSW 0x00000080L /* northeast to southwest */
|
||||||
#define DIAG_SEtoNW 0x00000100L /* southeast to northwest */
|
#define DIAG_SEtoNW 0x00000100L /* southeast to northwest */
|
||||||
|
|
||||||
/* 135 degree angle side-to-far-corner lines */
|
/* 135 degree angle side-to-far-corner lines */
|
||||||
#define BENT_NtoSE 0x00000200L /* north to southeast */
|
#define BENT_NtoSE 0x00000200L /* north to southeast */
|
||||||
#define BENT_NtoSW 0x00000400L /* north to southwest */
|
#define BENT_NtoSW 0x00000400L /* north to southwest */
|
||||||
#define BENT_EtoSW 0x00000800L /* east to southwest */
|
#define BENT_EtoSW 0x00000800L /* east to southwest */
|
||||||
#define BENT_EtoNW 0x00001000L /* east to northwest */
|
#define BENT_EtoNW 0x00001000L /* east to northwest */
|
||||||
#define BENT_StoNW 0x00002000L /* south to northwest */
|
#define BENT_StoNW 0x00002000L /* south to northwest */
|
||||||
#define BENT_StoNE 0x00004000L /* south to northeast */
|
#define BENT_StoNE 0x00004000L /* south to northeast */
|
||||||
#define BENT_WtoNE 0x00008000L /* west to northeast */
|
#define BENT_WtoNE 0x00008000L /* west to northeast */
|
||||||
#define BENT_WtoSE 0x00010000L /* west to southeast */
|
#define BENT_WtoSE 0x00010000L /* west to southeast */
|
||||||
|
|
||||||
/* 90 degree corner-to-adjacent-corner lines */
|
/* 90 degree corner-to-adjacent-corner lines */
|
||||||
#define ANGLE_NEtoSE 0x00020000L /* northeast to southeast */
|
#define ANGLE_NEtoSE 0x00020000L /* northeast to southeast */
|
||||||
#define ANGLE_SEtoSW 0x00040000L /* southeast to southwest */
|
#define ANGLE_SEtoSW 0x00040000L /* southeast to southwest */
|
||||||
#define ANGLE_SWtoNW 0x00080000L /* southwest to northwest */
|
#define ANGLE_SWtoNW 0x00080000L /* southwest to northwest */
|
||||||
#define ANGLE_NWtoNE 0x00100000L /* northwest to northeast */
|
#define ANGLE_NWtoNE 0x00100000L /* northwest to northeast */
|
||||||
|
|
||||||
/* 45 degree angle side-to-near-corner lines */
|
/* 45 degree angle side-to-near-corner lines */
|
||||||
#define SHARP_NtoNE 0x00200000L /* north to northeast */
|
#define SHARP_NtoNE 0x00200000L /* north to northeast */
|
||||||
#define SHARP_EtoNE 0x00400000L /* east to northeast */
|
#define SHARP_EtoNE 0x00400000L /* east to northeast */
|
||||||
#define SHARP_EtoSE 0x00800000L /* east to southeast */
|
#define SHARP_EtoSE 0x00800000L /* east to southeast */
|
||||||
#define SHARP_StoSE 0x01000000L /* south to southeast */
|
#define SHARP_StoSE 0x01000000L /* south to southeast */
|
||||||
#define SHARP_StoSW 0x02000000L /* south to southwest */
|
#define SHARP_StoSW 0x02000000L /* south to southwest */
|
||||||
#define SHARP_WtoSW 0x04000000L /* west to southwest */
|
#define SHARP_WtoSW 0x04000000L /* west to southwest */
|
||||||
#define SHARP_WtoNW 0x08000000L /* west to northwest */
|
#define SHARP_WtoNW 0x08000000L /* west to northwest */
|
||||||
#define SHARP_NtoNW 0x10000000L /* north to northwest */
|
#define SHARP_NtoNW 0x10000000L /* north to northwest */
|
||||||
|
|
||||||
/* directions the cell can be reached from (point to previous cell) */
|
/* directions the cell can be reached from (point to previous cell) */
|
||||||
#define FROM_NOWHERE 0
|
#define FROM_NOWHERE 0
|
||||||
#define FROM_NORTH 1
|
#define FROM_NORTH 1
|
||||||
#define FROM_NORTHEAST 2
|
#define FROM_NORTHEAST 2
|
||||||
#define FROM_EAST 3
|
#define FROM_EAST 3
|
||||||
#define FROM_SOUTHEAST 4
|
#define FROM_SOUTHEAST 4
|
||||||
#define FROM_SOUTH 5
|
#define FROM_SOUTH 5
|
||||||
#define FROM_SOUTHWEST 6
|
#define FROM_SOUTHWEST 6
|
||||||
#define FROM_WEST 7
|
#define FROM_WEST 7
|
||||||
#define FROM_NORTHWEST 8
|
#define FROM_NORTHWEST 8
|
||||||
#define FROM_OTHERSIDE 9
|
#define FROM_OTHERSIDE 9
|
||||||
|
|
||||||
|
|
|
@ -92,10 +92,12 @@ public:
|
||||||
WinEDA_ValueCtrl* m_HPGLPenOverlayOpt;
|
WinEDA_ValueCtrl* m_HPGLPenOverlayOpt;
|
||||||
wxStaticBox* m_HPGL_OptionsBox;
|
wxStaticBox* m_HPGL_OptionsBox;
|
||||||
|
|
||||||
WinEDA_DFloatValueCtrl* m_FineAdjustXscaleOpt, * m_FineAdjustYscaleOpt;
|
WinEDA_DFloatValueCtrl* m_FineAdjustXscaleOpt;
|
||||||
double m_XScaleAdjust, m_YScaleAdjust;
|
WinEDA_DFloatValueCtrl* m_FineAdjustYscaleOpt;
|
||||||
|
double m_XScaleAdjust;
|
||||||
|
double m_YScaleAdjust;
|
||||||
|
|
||||||
bool useA4()
|
bool useA4()
|
||||||
{
|
{
|
||||||
return m_PlotFormatOpt->GetSelection() == 3;
|
return m_PlotFormatOpt->GetSelection() == 3;
|
||||||
}
|
}
|
||||||
|
@ -110,7 +112,8 @@ public:
|
||||||
{
|
{
|
||||||
int radioNdx = m_PlotFormatOpt->GetSelection();
|
int radioNdx = m_PlotFormatOpt->GetSelection();
|
||||||
|
|
||||||
// change the A4 to the simple postscript, according to the PlotFormat enum
|
// change the A4 to the simple postscript, according to the
|
||||||
|
// PlotFormat enum
|
||||||
if( radioNdx == 3 )
|
if( radioNdx == 3 )
|
||||||
radioNdx = PLOT_FORMAT_POST;
|
radioNdx = PLOT_FORMAT_POST;
|
||||||
|
|
||||||
|
@ -133,56 +136,48 @@ private:
|
||||||
};
|
};
|
||||||
|
|
||||||
BEGIN_EVENT_TABLE( WinEDA_PlotFrame, wxDialog )
|
BEGIN_EVENT_TABLE( WinEDA_PlotFrame, wxDialog )
|
||||||
EVT_INIT_DIALOG( WinEDA_PlotFrame::OnInitDialog )
|
EVT_INIT_DIALOG( WinEDA_PlotFrame::OnInitDialog )
|
||||||
EVT_CLOSE( WinEDA_PlotFrame::OnClose )
|
EVT_CLOSE( WinEDA_PlotFrame::OnClose )
|
||||||
EVT_BUTTON( wxID_CANCEL, WinEDA_PlotFrame::OnQuit )
|
EVT_BUTTON( wxID_CANCEL, WinEDA_PlotFrame::OnQuit )
|
||||||
EVT_BUTTON( ID_EXEC_PLOT, WinEDA_PlotFrame::Plot )
|
EVT_BUTTON( ID_EXEC_PLOT, WinEDA_PlotFrame::Plot )
|
||||||
EVT_BUTTON( ID_SAVE_OPT_PLOT, WinEDA_PlotFrame::SaveOptPlot )
|
EVT_BUTTON( ID_SAVE_OPT_PLOT, WinEDA_PlotFrame::SaveOptPlot )
|
||||||
EVT_BUTTON( ID_CREATE_DRILL_FILE, WinEDA_PlotFrame::CreateDrillFile )
|
EVT_BUTTON( ID_CREATE_DRILL_FILE, WinEDA_PlotFrame::CreateDrillFile )
|
||||||
EVT_RADIOBOX( ID_SEL_PLOT_FORMAT, WinEDA_PlotFrame::SetCommands )
|
EVT_RADIOBOX( ID_SEL_PLOT_FORMAT, WinEDA_PlotFrame::SetCommands )
|
||||||
END_EVENT_TABLE()
|
END_EVENT_TABLE()
|
||||||
|
|
||||||
|
|
||||||
const int UNITS_MILS = 1000;
|
const int UNITS_MILS = 1000;
|
||||||
|
|
||||||
|
|
||||||
/********************************************************************/
|
|
||||||
WinEDA_PlotFrame::WinEDA_PlotFrame( WinEDA_BasePcbFrame* parent ) :
|
WinEDA_PlotFrame::WinEDA_PlotFrame( WinEDA_BasePcbFrame* parent ) :
|
||||||
wxDialog( parent, -1, _( "Plot" ),
|
wxDialog( parent, -1, _( "Plot" ), wxPoint( -1, -1 ), wxDefaultSize,
|
||||||
wxPoint( -1, -1 ), wxDefaultSize,
|
|
||||||
wxDEFAULT_DIALOG_STYLE )
|
wxDEFAULT_DIALOG_STYLE )
|
||||||
/********************************************************************/
|
|
||||||
{
|
{
|
||||||
m_Parent = parent;
|
m_Parent = parent;
|
||||||
Centre();
|
Centre();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**************************************************************/
|
|
||||||
void WinEDA_PlotFrame::OnInitDialog( wxInitDialogEvent& event )
|
void WinEDA_PlotFrame::OnInitDialog( wxInitDialogEvent& event )
|
||||||
/**************************************************************/
|
|
||||||
{
|
{
|
||||||
|
|
||||||
wxButton* button;
|
wxButton* button;
|
||||||
|
|
||||||
BOARD* board = m_Parent->GetBoard();
|
BOARD* board = m_Parent->GetBoard();
|
||||||
|
|
||||||
wxConfig* config = wxGetApp().m_EDA_Config; // Current config used by application
|
wxConfig* config = wxGetApp().m_EDA_Config;
|
||||||
|
|
||||||
|
|
||||||
m_Plot_Sheet_Ref = NULL;
|
m_Plot_Sheet_Ref = NULL;
|
||||||
|
|
||||||
wxBoxSizer* MainBoxSizer = new wxBoxSizer( wxHORIZONTAL );
|
wxBoxSizer* MainBoxSizer = new wxBoxSizer( wxHORIZONTAL );
|
||||||
|
|
||||||
SetSizer( MainBoxSizer );
|
SetSizer( MainBoxSizer );
|
||||||
wxBoxSizer* RightBoxSizer = new wxBoxSizer( wxVERTICAL );
|
wxBoxSizer* RightBoxSizer = new wxBoxSizer( wxVERTICAL );
|
||||||
|
|
||||||
wxBoxSizer* MidRightBoxSizer = new wxBoxSizer( wxVERTICAL );
|
wxBoxSizer* MidRightBoxSizer = new wxBoxSizer( wxVERTICAL );
|
||||||
|
|
||||||
wxBoxSizer* MidLeftBoxSizer = new wxBoxSizer( wxVERTICAL );
|
wxBoxSizer* MidLeftBoxSizer = new wxBoxSizer( wxVERTICAL );
|
||||||
|
|
||||||
wxBoxSizer* LeftBoxSizer = new wxBoxSizer( wxVERTICAL );
|
wxBoxSizer* LeftBoxSizer = new wxBoxSizer( wxVERTICAL );
|
||||||
|
|
||||||
MainBoxSizer->Add( LeftBoxSizer, 0, wxGROW | wxALL, 5 );
|
MainBoxSizer->Add( LeftBoxSizer, 0, wxGROW | wxALL, 5 );
|
||||||
MainBoxSizer->Add( MidLeftBoxSizer, 0, wxGROW | wxALL, 5 );
|
MainBoxSizer->Add( MidLeftBoxSizer, 0, wxGROW | wxALL, 5 );
|
||||||
|
@ -193,19 +188,24 @@ void WinEDA_PlotFrame::OnInitDialog( wxInitDialogEvent& event )
|
||||||
|
|
||||||
LeftBoxSizer->Add( LayersBoxSizer, 0, wxGROW | wxALL, 5 );
|
LeftBoxSizer->Add( LayersBoxSizer, 0, wxGROW | wxALL, 5 );
|
||||||
|
|
||||||
static const wxString fmtmsg[4] = {
|
static const wxString fmtmsg[4] =
|
||||||
wxT( "HPGL" ), wxT( "Gerber" ), wxT( "Postscript" ), wxT( "Postscript A4" )
|
{
|
||||||
|
wxT( "HPGL" ),
|
||||||
|
wxT( "Gerber" ),
|
||||||
|
wxT( "Postscript" ),
|
||||||
|
wxT( "Postscript A4" )
|
||||||
};
|
};
|
||||||
|
|
||||||
m_PlotFormatOpt = new wxRadioBox( this, ID_SEL_PLOT_FORMAT,
|
m_PlotFormatOpt = new wxRadioBox( this, ID_SEL_PLOT_FORMAT,
|
||||||
_( "Plot Format" ), wxDefaultPosition, wxSize( -1, -1 ),
|
_( "Plot Format" ), wxDefaultPosition,
|
||||||
4, fmtmsg, 1, wxRA_SPECIFY_COLS );
|
wxSize( -1, -1 ),
|
||||||
|
4, fmtmsg, 1, wxRA_SPECIFY_COLS );
|
||||||
MidRightBoxSizer->Add( m_PlotFormatOpt, 0, wxGROW | wxALL, 5 );
|
MidRightBoxSizer->Add( m_PlotFormatOpt, 0, wxGROW | wxALL, 5 );
|
||||||
|
|
||||||
if( config )
|
if( config )
|
||||||
{
|
{
|
||||||
config->Read( OPTKEY_OUTPUT_FORMAT, &g_PlotFormat );
|
config->Read( OPTKEY_OUTPUT_FORMAT, &g_PlotFormat );
|
||||||
config->Read( OPTKEY_PLOT_LINEWIDTH_VALUE, &g_PlotLine_Width);
|
config->Read( OPTKEY_PLOT_LINEWIDTH_VALUE, &g_PlotLine_Width );
|
||||||
}
|
}
|
||||||
|
|
||||||
m_PlotFormatOpt->SetSelection( g_PlotFormat );
|
m_PlotFormatOpt->SetSelection( g_PlotFormat );
|
||||||
|
@ -213,40 +213,50 @@ void WinEDA_PlotFrame::OnInitDialog( wxInitDialogEvent& event )
|
||||||
|
|
||||||
// Creation des menus d'option du format HPGL
|
// Creation des menus d'option du format HPGL
|
||||||
m_HPGL_OptionsBox = new wxStaticBox( this, wxID_ANY, _( "HPGL Options:" ) );
|
m_HPGL_OptionsBox = new wxStaticBox( this, wxID_ANY, _( "HPGL Options:" ) );
|
||||||
wxStaticBoxSizer* HPGL_OptionsBoxSizer = new wxStaticBoxSizer( m_HPGL_OptionsBox, wxVERTICAL );
|
wxStaticBoxSizer* HPGL_OptionsBoxSizer =
|
||||||
|
new wxStaticBoxSizer( m_HPGL_OptionsBox, wxVERTICAL );
|
||||||
MidRightBoxSizer->Add( HPGL_OptionsBoxSizer, 0, wxGROW | wxALL, 5 );
|
MidRightBoxSizer->Add( HPGL_OptionsBoxSizer, 0, wxGROW | wxALL, 5 );
|
||||||
|
|
||||||
m_HPGLPenSizeOpt = new WinEDA_ValueCtrl( this, _( "Pen Size" ),
|
m_HPGLPenSizeOpt = new WinEDA_ValueCtrl( this, _( "Pen Size" ),
|
||||||
g_HPGL_Pen_Diam, g_UnitMetric, HPGL_OptionsBoxSizer,
|
g_HPGL_Pen_Diam,
|
||||||
UNITS_MILS );
|
g_UnitMetric,
|
||||||
|
HPGL_OptionsBoxSizer,
|
||||||
|
UNITS_MILS );
|
||||||
|
|
||||||
// unites standards = cm pour vitesse plume en HPGL
|
// unites standards = cm pour vitesse plume en HPGL
|
||||||
m_HPGLPenSpeedOpt = new WinEDA_ValueCtrl( this, _( "Pen Speed (cm/s)" ),
|
m_HPGLPenSpeedOpt = new WinEDA_ValueCtrl( this, _( "Pen Speed (cm/s)" ),
|
||||||
g_HPGL_Pen_Speed, CENTIMETRE, HPGL_OptionsBoxSizer,
|
g_HPGL_Pen_Speed, CENTIMETRE,
|
||||||
1 );
|
HPGL_OptionsBoxSizer, 1 );
|
||||||
|
|
||||||
m_HPGLPenSpeedOpt->SetToolTip( _( "Set pen speed in cm/s" ) );
|
m_HPGLPenSpeedOpt->SetToolTip( _( "Set pen speed in cm/s" ) );
|
||||||
|
|
||||||
m_HPGLPenOverlayOpt = new WinEDA_ValueCtrl( this, _( "Pen ovr" ),
|
m_HPGLPenOverlayOpt = new WinEDA_ValueCtrl( this, _( "Pen ovr" ),
|
||||||
g_HPGL_Pen_Recouvrement, g_UnitMetric,
|
g_HPGL_Pen_Recouvrement,
|
||||||
HPGL_OptionsBoxSizer, UNITS_MILS );
|
g_UnitMetric,
|
||||||
|
HPGL_OptionsBoxSizer,
|
||||||
|
UNITS_MILS );
|
||||||
|
|
||||||
m_HPGLPenOverlayOpt->SetToolTip( _( "Set plot overlay for filling" ) );
|
m_HPGLPenOverlayOpt->SetToolTip( _( "Set plot overlay for filling" ) );
|
||||||
|
|
||||||
m_LinesWidth = new WinEDA_ValueCtrl( this, _( "Lines Width" ),
|
m_LinesWidth = new WinEDA_ValueCtrl( this, _( "Lines Width" ),
|
||||||
g_PlotLine_Width, g_UnitMetric, MidRightBoxSizer,
|
g_PlotLine_Width,
|
||||||
PCB_INTERNAL_UNIT );
|
g_UnitMetric,
|
||||||
|
MidRightBoxSizer,
|
||||||
|
PCB_INTERNAL_UNIT );
|
||||||
|
|
||||||
m_LinesWidth->SetToolTip( _( "Set lines width used to plot in sketch mode and plot pads outlines on silk screen layers" ) );
|
m_LinesWidth->SetToolTip( _( "Set lines width used to plot in sketch \
|
||||||
|
mode and plot pads outlines on silk screen layers" ) );
|
||||||
|
|
||||||
// Create the right column commands
|
// Create the right column commands
|
||||||
static const wxString choice_plot_offset_msg[] =
|
static const wxString choice_plot_offset_msg[] =
|
||||||
{ _( "Absolute" ), _( "Auxiliary axis" ) };
|
{ _( "Absolute" ), _( "Auxiliary axis" ) };
|
||||||
|
|
||||||
m_Choice_Plot_Offset = new wxRadioBox( this, ID_SEL_PLOT_OFFSET_OPTION,
|
m_Choice_Plot_Offset = new wxRadioBox( this, ID_SEL_PLOT_OFFSET_OPTION,
|
||||||
_( "Plot Origin" ),
|
_( "Plot Origin" ),
|
||||||
wxDefaultPosition, wxSize( -1, -1 ),
|
wxDefaultPosition,
|
||||||
2, choice_plot_offset_msg, 1, wxRA_SPECIFY_COLS );
|
wxSize( -1, -1 ),
|
||||||
|
2, choice_plot_offset_msg, 1,
|
||||||
|
wxRA_SPECIFY_COLS );
|
||||||
|
|
||||||
if( s_PlotOriginIsAuxAxis )
|
if( s_PlotOriginIsAuxAxis )
|
||||||
m_Choice_Plot_Offset->SetSelection( 1 );
|
m_Choice_Plot_Offset->SetSelection( 1 );
|
||||||
|
@ -256,6 +266,7 @@ void WinEDA_PlotFrame::OnInitDialog( wxInitDialogEvent& event )
|
||||||
|
|
||||||
// Create scale adjust option
|
// Create scale adjust option
|
||||||
m_XScaleAdjust = m_YScaleAdjust = 1.0;
|
m_XScaleAdjust = m_YScaleAdjust = 1.0;
|
||||||
|
|
||||||
if( config )
|
if( config )
|
||||||
{
|
{
|
||||||
config->Read( OPTKEY_EDGELAYER_GERBER, &g_Exclude_Edges_Pcb );
|
config->Read( OPTKEY_EDGELAYER_GERBER, &g_Exclude_Edges_Pcb );
|
||||||
|
@ -264,43 +275,49 @@ void WinEDA_PlotFrame::OnInitDialog( wxInitDialogEvent& event )
|
||||||
}
|
}
|
||||||
|
|
||||||
// Test for a reasonnable scale value. Set to 1 if problem
|
// Test for a reasonnable scale value. Set to 1 if problem
|
||||||
if ( m_XScaleAdjust < MIN_SCALE || m_YScaleAdjust < MIN_SCALE || m_XScaleAdjust > MAX_SCALE || m_YScaleAdjust > MAX_SCALE )
|
if( m_XScaleAdjust < MIN_SCALE || m_YScaleAdjust < MIN_SCALE
|
||||||
|
|| m_XScaleAdjust > MAX_SCALE || m_YScaleAdjust > MAX_SCALE )
|
||||||
m_XScaleAdjust = m_YScaleAdjust = 1.0;
|
m_XScaleAdjust = m_YScaleAdjust = 1.0;
|
||||||
|
|
||||||
m_FineAdjustXscaleOpt = new WinEDA_DFloatValueCtrl( this,
|
m_FineAdjustXscaleOpt = new WinEDA_DFloatValueCtrl( this,
|
||||||
_( "X scale adjust" ), m_XScaleAdjust,
|
_( "X scale adjust" ),
|
||||||
RightBoxSizer );
|
m_XScaleAdjust,
|
||||||
m_FineAdjustXscaleOpt->SetToolTip( _( "Set X scale adjust for exact scale plotting" ) );
|
RightBoxSizer );
|
||||||
|
m_FineAdjustXscaleOpt->SetToolTip( _( "Set X scale adjust for exact \
|
||||||
|
scale plotting" ) );
|
||||||
|
|
||||||
m_FineAdjustYscaleOpt = new WinEDA_DFloatValueCtrl( this,
|
m_FineAdjustYscaleOpt = new WinEDA_DFloatValueCtrl( this,
|
||||||
_( "Y scale adjust" ), m_YScaleAdjust,
|
_( "Y scale adjust" ),
|
||||||
RightBoxSizer );
|
m_YScaleAdjust,
|
||||||
m_FineAdjustYscaleOpt->SetToolTip( _( "Set Y scale adjust for exact scale plotting" ) );
|
RightBoxSizer );
|
||||||
|
m_FineAdjustYscaleOpt->SetToolTip( _( "Set Y scale adjust for exact \
|
||||||
|
scale plotting" ) );
|
||||||
|
|
||||||
m_Plot_PS_Negative = new wxCheckBox( this, -1, _( "Plot negative" ) );
|
m_Plot_PS_Negative = new wxCheckBox( this, -1, _( "Plot negative" ) );
|
||||||
m_Plot_PS_Negative->SetValue( g_Plot_PS_Negative );
|
m_Plot_PS_Negative->SetValue( g_Plot_PS_Negative );
|
||||||
RightBoxSizer->Add( m_Plot_PS_Negative, 0, wxGROW | wxALL, 5 );
|
RightBoxSizer->Add( m_Plot_PS_Negative, 0, wxGROW | wxALL, 5 );
|
||||||
|
|
||||||
|
|
||||||
/* Create the command buttons */
|
/* Create the command buttons */
|
||||||
m_PlotButton = new wxButton( this, ID_EXEC_PLOT, _( "Plot" ) );
|
m_PlotButton = new wxButton( this, ID_EXEC_PLOT, _( "Plot" ) );
|
||||||
RightBoxSizer->Add( m_PlotButton, 0, wxGROW | wxALL, 5 );
|
RightBoxSizer->Add( m_PlotButton, 0, wxGROW | wxALL, 5 );
|
||||||
|
|
||||||
button = new wxButton( this, ID_SAVE_OPT_PLOT, _( "Save Options" ) );
|
button = new wxButton( this, ID_SAVE_OPT_PLOT, _( "Save Options" ) );
|
||||||
RightBoxSizer->Add( button, 0, wxGROW | wxALL, 5 );
|
RightBoxSizer->Add( button, 0, wxGROW | wxALL, 5 );
|
||||||
|
|
||||||
button = new wxButton( this, ID_CREATE_DRILL_FILE, _( "Generate drill file" ) );
|
button = new wxButton( this, ID_CREATE_DRILL_FILE,
|
||||||
|
_( "Generate drill file" ) );
|
||||||
RightBoxSizer->Add( button, 0, wxGROW | wxALL, 5 );
|
RightBoxSizer->Add( button, 0, wxGROW | wxALL, 5 );
|
||||||
|
|
||||||
button = new wxButton( this, wxID_CANCEL, _( "Close" ) );
|
button = new wxButton( this, wxID_CANCEL, _( "Close" ) );
|
||||||
RightBoxSizer->Add( button, 0, wxGROW | wxALL, 5 );
|
RightBoxSizer->Add( button, 0, wxGROW | wxALL, 5 );
|
||||||
|
|
||||||
|
|
||||||
// Creation de la liste des layers
|
// Creation de la liste des layers
|
||||||
wxBoxSizer* OneColumnLayerBoxSizer = new wxBoxSizer( wxVERTICAL );
|
wxBoxSizer* OneColumnLayerBoxSizer = new wxBoxSizer( wxVERTICAL );
|
||||||
LayersBoxSizer->Add( OneColumnLayerBoxSizer, 0, wxGROW | wxALL, 5 );
|
LayersBoxSizer->Add( OneColumnLayerBoxSizer, 0, wxGROW | wxALL, 5 );
|
||||||
|
|
||||||
int mask = 1;
|
int mask = 1;
|
||||||
|
|
||||||
for( int layer = 0; layer<NB_LAYERS; layer++, mask <<= 1 )
|
for( int layer = 0; layer<NB_LAYERS; layer++, mask <<= 1 )
|
||||||
{
|
{
|
||||||
if( layer == 16 )
|
if( layer == 16 )
|
||||||
|
@ -309,19 +326,21 @@ void WinEDA_PlotFrame::OnInitDialog( wxInitDialogEvent& event )
|
||||||
LayersBoxSizer->Add( OneColumnLayerBoxSizer, 0, wxGROW | wxALL, 5 );
|
LayersBoxSizer->Add( OneColumnLayerBoxSizer, 0, wxGROW | wxALL, 5 );
|
||||||
}
|
}
|
||||||
|
|
||||||
m_BoxSelectLayer[layer] = new wxCheckBox( this, -1, board->GetLayerName( layer ) );
|
m_BoxSelectLayer[layer] =
|
||||||
|
new wxCheckBox( this, -1, board->GetLayerName( layer ) );
|
||||||
|
|
||||||
if( mask & s_SelectedLayers )
|
if( mask & s_SelectedLayers )
|
||||||
m_BoxSelectLayer[layer]->SetValue( true );
|
m_BoxSelectLayer[layer]->SetValue( true );
|
||||||
|
|
||||||
OneColumnLayerBoxSizer->Add( m_BoxSelectLayer[layer], 0, wxGROW | wxALL, 1 );
|
OneColumnLayerBoxSizer->Add( m_BoxSelectLayer[layer],
|
||||||
|
0, wxGROW | wxALL, 1 );
|
||||||
}
|
}
|
||||||
|
|
||||||
if( config )
|
if( config )
|
||||||
{
|
{
|
||||||
wxString layerKey;
|
wxString layerKey;
|
||||||
|
|
||||||
for( int layer = 0; layer<NB_LAYERS; ++layer )
|
for( int layer = 0; layer < NB_LAYERS; ++layer )
|
||||||
{
|
{
|
||||||
bool option;
|
bool option;
|
||||||
|
|
||||||
|
@ -335,7 +354,8 @@ void WinEDA_PlotFrame::OnInitDialog( wxInitDialogEvent& event )
|
||||||
// Option for excluding contents of "Edges Pcb" layer
|
// Option for excluding contents of "Edges Pcb" layer
|
||||||
|
|
||||||
m_Exclude_Edges_Pcb = new wxCheckBox( this,
|
m_Exclude_Edges_Pcb = new wxCheckBox( this,
|
||||||
ID_EXCLUDE_EDGES_PCB, _( "Exclude Edges_Pcb layer" ) );
|
ID_EXCLUDE_EDGES_PCB,
|
||||||
|
_( "Exclude Edges_Pcb layer" ) );
|
||||||
|
|
||||||
m_Exclude_Edges_Pcb->SetValue( g_Exclude_Edges_Pcb );
|
m_Exclude_Edges_Pcb->SetValue( g_Exclude_Edges_Pcb );
|
||||||
m_Exclude_Edges_Pcb->SetToolTip(
|
m_Exclude_Edges_Pcb->SetToolTip(
|
||||||
|
@ -345,7 +365,8 @@ void WinEDA_PlotFrame::OnInitDialog( wxInitDialogEvent& event )
|
||||||
// Option to plot page references:
|
// Option to plot page references:
|
||||||
if( m_Parent->m_Print_Sheet_Ref )
|
if( m_Parent->m_Print_Sheet_Ref )
|
||||||
{
|
{
|
||||||
m_Plot_Sheet_Ref = new wxCheckBox( this, ID_PRINT_REF, _( "Print sheet ref" ) );
|
m_Plot_Sheet_Ref = new wxCheckBox( this, ID_PRINT_REF,
|
||||||
|
_( "Print sheet ref" ) );
|
||||||
|
|
||||||
m_Plot_Sheet_Ref->SetValue( g_Plot_Frame_Ref );
|
m_Plot_Sheet_Ref->SetValue( g_Plot_Frame_Ref );
|
||||||
LeftBoxSizer->Add( m_Plot_Sheet_Ref, 0, wxGROW | wxALL, 1 );
|
LeftBoxSizer->Add( m_Plot_Sheet_Ref, 0, wxGROW | wxALL, 1 );
|
||||||
|
@ -354,32 +375,38 @@ void WinEDA_PlotFrame::OnInitDialog( wxInitDialogEvent& event )
|
||||||
g_Plot_Frame_Ref = false;
|
g_Plot_Frame_Ref = false;
|
||||||
|
|
||||||
// Option to plot pads on silkscreen layers or all layers
|
// Option to plot pads on silkscreen layers or all layers
|
||||||
m_Plot_Pads_on_Silkscreen = new wxCheckBox( this, ID_PRINT_PAD_ON_SILKSCREEN,
|
m_Plot_Pads_on_Silkscreen = new wxCheckBox( this,
|
||||||
_( "Print pads on silkscreen" ) );
|
ID_PRINT_PAD_ON_SILKSCREEN,
|
||||||
|
_( "Print pads on silkscreen" ) );
|
||||||
|
|
||||||
if( config )
|
if( config )
|
||||||
config->Read( OPTKEY_PADS_ON_SILKSCREEN, &PlotPadsOnSilkLayer );
|
config->Read( OPTKEY_PADS_ON_SILKSCREEN, &PlotPadsOnSilkLayer );
|
||||||
|
|
||||||
m_Plot_Pads_on_Silkscreen->SetValue( PlotPadsOnSilkLayer );
|
m_Plot_Pads_on_Silkscreen->SetValue( PlotPadsOnSilkLayer );
|
||||||
m_Plot_Pads_on_Silkscreen->SetToolTip(
|
m_Plot_Pads_on_Silkscreen->SetToolTip(
|
||||||
_( "Enable/disable print/plot pads on silkscreen layers" ) );
|
_( "Enable/disable print/plot pads on silkscreen layers" ) );
|
||||||
LeftBoxSizer->Add( m_Plot_Pads_on_Silkscreen, 0, wxGROW | wxALL, 1 );
|
LeftBoxSizer->Add( m_Plot_Pads_on_Silkscreen, 0, wxGROW | wxALL, 1 );
|
||||||
|
|
||||||
m_Force_Plot_Pads = new wxCheckBox( this, ID_FORCE_PRINT_PAD,
|
m_Force_Plot_Pads = new wxCheckBox( this, ID_FORCE_PRINT_PAD,
|
||||||
_( "Always print pads" ) );
|
_( "Always print pads" ) );
|
||||||
if( config )
|
if( config )
|
||||||
config->Read( OPTKEY_ALWAYS_PRINT_PADS, &Plot_Pads_All_Layers );
|
config->Read( OPTKEY_ALWAYS_PRINT_PADS, &Plot_Pads_All_Layers );
|
||||||
|
|
||||||
m_Force_Plot_Pads->SetValue( Plot_Pads_All_Layers );
|
m_Force_Plot_Pads->SetValue( Plot_Pads_All_Layers );
|
||||||
m_Force_Plot_Pads->SetToolTip( _( "Force print/plot pads on ALL layers" ) );
|
m_Force_Plot_Pads->SetToolTip( _( "Force print/plot pads on ALL layers" ) );
|
||||||
LeftBoxSizer->Add( m_Force_Plot_Pads, 0, wxGROW | wxALL, 1 );
|
LeftBoxSizer->Add( m_Force_Plot_Pads, 0, wxGROW | wxALL, 1 );
|
||||||
|
|
||||||
// Options to plot texts on footprints
|
// Options to plot texts on footprints
|
||||||
m_Plot_Text_Value = new wxCheckBox( this, ID_PRINT_VALUE, _( "Print module value" ) );
|
m_Plot_Text_Value = new wxCheckBox( this, ID_PRINT_VALUE,
|
||||||
|
_( "Print module value" ) );
|
||||||
|
|
||||||
m_Plot_Text_Value->SetValue( Sel_Texte_Valeur );
|
m_Plot_Text_Value->SetValue( Sel_Texte_Valeur );
|
||||||
m_Plot_Text_Value->SetToolTip(
|
m_Plot_Text_Value->SetToolTip(
|
||||||
_( "Enable/disable print/plot module value on silkscreen layers" ) );
|
_( "Enable/disable print/plot module value on silkscreen layers" ) );
|
||||||
LeftBoxSizer->Add( m_Plot_Text_Value, 0, wxGROW | wxALL, 1 );
|
LeftBoxSizer->Add( m_Plot_Text_Value, 0, wxGROW | wxALL, 1 );
|
||||||
|
|
||||||
m_Plot_Text_Ref = new wxCheckBox( this, ID_PRINT_REF, _( "Print module reference" ) );
|
m_Plot_Text_Ref = new wxCheckBox( this, ID_PRINT_REF,
|
||||||
|
_( "Print module reference" ) );
|
||||||
|
|
||||||
m_Plot_Text_Ref->SetValue( Sel_Texte_Reference );
|
m_Plot_Text_Ref->SetValue( Sel_Texte_Reference );
|
||||||
m_Plot_Text_Ref->SetToolTip(
|
m_Plot_Text_Ref->SetToolTip(
|
||||||
|
@ -387,7 +414,7 @@ void WinEDA_PlotFrame::OnInitDialog( wxInitDialogEvent& event )
|
||||||
LeftBoxSizer->Add( m_Plot_Text_Ref, 0, wxGROW | wxALL, 1 );
|
LeftBoxSizer->Add( m_Plot_Text_Ref, 0, wxGROW | wxALL, 1 );
|
||||||
|
|
||||||
m_Plot_Text_Div = new wxCheckBox( this, ID_PRINT_MODULE_TEXTS,
|
m_Plot_Text_Div = new wxCheckBox( this, ID_PRINT_MODULE_TEXTS,
|
||||||
_( "Print other module texts" ) );
|
_( "Print other module texts" ) );
|
||||||
|
|
||||||
m_Plot_Text_Div->SetValue( Sel_Texte_Divers );
|
m_Plot_Text_Div->SetValue( Sel_Texte_Divers );
|
||||||
m_Plot_Text_Div->SetToolTip(
|
m_Plot_Text_Div->SetToolTip(
|
||||||
|
@ -395,8 +422,8 @@ void WinEDA_PlotFrame::OnInitDialog( wxInitDialogEvent& event )
|
||||||
LeftBoxSizer->Add( m_Plot_Text_Div, 0, wxGROW | wxALL, 1 );
|
LeftBoxSizer->Add( m_Plot_Text_Div, 0, wxGROW | wxALL, 1 );
|
||||||
|
|
||||||
m_Plot_Invisible_Text = new wxCheckBox( this,
|
m_Plot_Invisible_Text = new wxCheckBox( this,
|
||||||
ID_FORCE_PRINT_INVISIBLE_TEXT, _(
|
ID_FORCE_PRINT_INVISIBLE_TEXT,
|
||||||
"Force print invisible texts" ) );
|
_( "Force print invisible texts" ) );
|
||||||
|
|
||||||
m_Plot_Invisible_Text->SetValue( Sel_Texte_Invisible );
|
m_Plot_Invisible_Text->SetValue( Sel_Texte_Invisible );
|
||||||
m_Plot_Invisible_Text->SetToolTip(
|
m_Plot_Invisible_Text->SetToolTip(
|
||||||
|
@ -404,41 +431,55 @@ void WinEDA_PlotFrame::OnInitDialog( wxInitDialogEvent& event )
|
||||||
LeftBoxSizer->Add( m_Plot_Invisible_Text, 0, wxGROW | wxALL, 1 );
|
LeftBoxSizer->Add( m_Plot_Invisible_Text, 0, wxGROW | wxALL, 1 );
|
||||||
|
|
||||||
|
|
||||||
static const wxString drillmsg[3] = { _( "No drill mark" ), _( "Small mark" ), _( "Real drill" ) };
|
static const wxString drillmsg[3] = {
|
||||||
|
_( "No drill mark" ),
|
||||||
|
_( "Small mark" ),
|
||||||
|
_( "Real drill" )
|
||||||
|
};
|
||||||
|
|
||||||
m_Drill_Shape_Opt = new wxRadioBox( this, ID_DRILL_SHAPE_OPT,
|
m_Drill_Shape_Opt = new wxRadioBox( this, ID_DRILL_SHAPE_OPT,
|
||||||
_( "Pads Drill Opt" ), wxDefaultPosition, wxSize( -1, -1 ),
|
_( "Pads Drill Opt" ),
|
||||||
3, drillmsg, 1, wxRA_SPECIFY_COLS );
|
wxDefaultPosition, wxSize( -1, -1 ),
|
||||||
|
3, drillmsg, 1, wxRA_SPECIFY_COLS );
|
||||||
|
|
||||||
m_Drill_Shape_Opt->SetSelection( g_DrillShapeOpt );
|
m_Drill_Shape_Opt->SetSelection( g_DrillShapeOpt );
|
||||||
MidLeftBoxSizer->Add( m_Drill_Shape_Opt, 0, wxGROW | wxALL, 5 );
|
MidLeftBoxSizer->Add( m_Drill_Shape_Opt, 0, wxGROW | wxALL, 5 );
|
||||||
|
|
||||||
static const wxString scalemsg[5] =
|
static const wxString scalemsg[5] =
|
||||||
{ _( "Auto scale" ), _( "Scale 1" ), _( "Scale 1.5" ), _( "Scale 2" ), _( "Scale 3" ) };
|
{
|
||||||
|
_( "Auto scale" ),
|
||||||
|
_( "Scale 1" ),
|
||||||
|
_( "Scale 1.5" ),
|
||||||
|
_( "Scale 2" ),
|
||||||
|
_( "Scale 3" )
|
||||||
|
};
|
||||||
|
|
||||||
m_Scale_Opt = new wxRadioBox( this, ID_SCALE_OPT,
|
m_Scale_Opt = new wxRadioBox( this, ID_SCALE_OPT,
|
||||||
_( "Scale Opt" ), wxDefaultPosition, wxSize( -1, -1 ),
|
_( "Scale Opt" ), wxDefaultPosition,
|
||||||
5, scalemsg, 1, wxRA_SPECIFY_COLS );
|
wxSize( -1, -1 ),
|
||||||
|
5, scalemsg, 1, wxRA_SPECIFY_COLS );
|
||||||
|
|
||||||
m_Scale_Opt->SetSelection( g_PlotScaleOpt );
|
m_Scale_Opt->SetSelection( g_PlotScaleOpt );
|
||||||
MidLeftBoxSizer->Add( m_Scale_Opt, 0, wxGROW | wxALL, 5 );
|
MidLeftBoxSizer->Add( m_Scale_Opt, 0, wxGROW | wxALL, 5 );
|
||||||
|
|
||||||
static const wxString list_opt3[3] = { _( "Line" ), _( "Filled" ), _( "Sketch" ) };
|
static const wxString list_opt3[3] = { _( "Line" ), _( "Filled" ), _(
|
||||||
|
"Sketch" ) };
|
||||||
|
|
||||||
m_PlotModeOpt = new wxRadioBox( this, ID_PLOT_MODE_OPT, _( "Plot Mode" ),
|
m_PlotModeOpt = new wxRadioBox( this, ID_PLOT_MODE_OPT, _( "Plot Mode" ),
|
||||||
wxDefaultPosition, wxDefaultSize,
|
wxDefaultPosition, wxDefaultSize,
|
||||||
3, list_opt3, 1 );
|
3, list_opt3, 1 );
|
||||||
|
|
||||||
m_PlotModeOpt->SetSelection( g_Plot_Mode );
|
m_PlotModeOpt->SetSelection( g_Plot_Mode );
|
||||||
MidLeftBoxSizer->Add( m_PlotModeOpt, 0, wxGROW | wxALL, 5 );
|
MidLeftBoxSizer->Add( m_PlotModeOpt, 0, wxGROW | wxALL, 5 );
|
||||||
|
|
||||||
m_PlotMirorOpt = new wxCheckBox( this, ID_MIROR_OPT,
|
m_PlotMirorOpt = new wxCheckBox( this, ID_MIROR_OPT,
|
||||||
_( "Plot mirror" ) );
|
_( "Plot mirror" ) );
|
||||||
|
|
||||||
m_PlotMirorOpt->SetValue( Plot_Set_MIROIR );
|
m_PlotMirorOpt->SetValue( Plot_Set_MIROIR );
|
||||||
MidLeftBoxSizer->Add( m_PlotMirorOpt, 0, wxGROW | wxALL, 5 );
|
MidLeftBoxSizer->Add( m_PlotMirorOpt, 0, wxGROW | wxALL, 5 );
|
||||||
|
|
||||||
m_PlotNoViaOnMaskOpt = new wxCheckBox( this, ID_MASKVIA_OPT,
|
m_PlotNoViaOnMaskOpt = new wxCheckBox( this, ID_MASKVIA_OPT,
|
||||||
_( "Vias on mask" ) );
|
_( "Vias on mask" ) );
|
||||||
|
|
||||||
m_PlotNoViaOnMaskOpt->SetValue( g_DrawViaOnMaskLayer );
|
m_PlotNoViaOnMaskOpt->SetValue( g_DrawViaOnMaskLayer );
|
||||||
m_PlotNoViaOnMaskOpt->SetToolTip(
|
m_PlotNoViaOnMaskOpt->SetToolTip(
|
||||||
|
@ -446,7 +487,7 @@ void WinEDA_PlotFrame::OnInitDialog( wxInitDialogEvent& event )
|
||||||
MidLeftBoxSizer->Add( m_PlotNoViaOnMaskOpt, 0, wxGROW | wxALL, 5 );
|
MidLeftBoxSizer->Add( m_PlotNoViaOnMaskOpt, 0, wxGROW | wxALL, 5 );
|
||||||
|
|
||||||
m_HPGL_PlotCenter_Opt = new wxCheckBox( this, ID_PLOT_CENTRE_OPT,
|
m_HPGL_PlotCenter_Opt = new wxCheckBox( this, ID_PLOT_CENTRE_OPT,
|
||||||
_( "Org = Centre" ) );
|
_( "Org = Centre" ) );
|
||||||
|
|
||||||
m_HPGL_PlotCenter_Opt->SetValue( HPGL_Org_Centre );
|
m_HPGL_PlotCenter_Opt->SetValue( HPGL_Org_Centre );
|
||||||
m_HPGL_PlotCenter_Opt->SetToolTip( _( "Draw origin ( 0,0 ) in sheet center" ) );
|
m_HPGL_PlotCenter_Opt->SetToolTip( _( "Draw origin ( 0,0 ) in sheet center" ) );
|
||||||
|
@ -463,45 +504,26 @@ void WinEDA_PlotFrame::OnInitDialog( wxInitDialogEvent& event )
|
||||||
SetFocus();
|
SetFocus();
|
||||||
}
|
}
|
||||||
|
|
||||||
/***************************************************************/
|
|
||||||
void WinEDA_PlotFrame::OnQuit( wxCommandEvent& WXUNUSED (event) )
|
|
||||||
/***************************************************************/
|
|
||||||
|
|
||||||
/* Called by the close button
|
void WinEDA_PlotFrame::OnQuit( wxCommandEvent& WXUNUSED( event ) )
|
||||||
*/
|
|
||||||
{
|
{
|
||||||
Close( true ); // true is to force the frame to close
|
Close( true ); // true is to force the frame to close
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/****************************************************/
|
|
||||||
void WinEDA_PlotFrame::OnClose( wxCloseEvent& event )
|
void WinEDA_PlotFrame::OnClose( wxCloseEvent& event )
|
||||||
/****************************************************/
|
|
||||||
|
|
||||||
/* Called when WinEDA_PlotFrame is closed
|
|
||||||
*/
|
|
||||||
{
|
{
|
||||||
EndModal( 0 );
|
EndModal( 0 );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/*********************************************************/
|
|
||||||
void WinEDA_PlotFrame::CreateDrillFile( wxCommandEvent& event )
|
void WinEDA_PlotFrame::CreateDrillFile( wxCommandEvent& event )
|
||||||
/*********************************************************/
|
|
||||||
|
|
||||||
/* Create the board drill file used with gerber documents
|
|
||||||
*/
|
|
||||||
{
|
{
|
||||||
( (WinEDA_PcbFrame*) m_Parent )->InstallDrillFrame( event );
|
( (WinEDA_PcbFrame*) m_Parent )->InstallDrillFrame( event );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/*********************************************************/
|
|
||||||
void WinEDA_PlotFrame::SetCommands( wxCommandEvent& event )
|
void WinEDA_PlotFrame::SetCommands( wxCommandEvent& event )
|
||||||
/*********************************************************/
|
|
||||||
|
|
||||||
/* active ou désactive les différents menus d'option selon le standard choisi
|
|
||||||
*/
|
|
||||||
{
|
{
|
||||||
int format = getFormat();
|
int format = getFormat();
|
||||||
|
|
||||||
|
@ -570,9 +592,7 @@ void WinEDA_PlotFrame::SetCommands( wxCommandEvent& event )
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/*********************************************************/
|
|
||||||
void WinEDA_PlotFrame::SaveOptPlot( wxCommandEvent& event )
|
void WinEDA_PlotFrame::SaveOptPlot( wxCommandEvent& event )
|
||||||
/*********************************************************/
|
|
||||||
{
|
{
|
||||||
g_Exclude_Edges_Pcb = m_Exclude_Edges_Pcb->GetValue();
|
g_Exclude_Edges_Pcb = m_Exclude_Edges_Pcb->GetValue();
|
||||||
|
|
||||||
|
@ -582,7 +602,8 @@ void WinEDA_PlotFrame::SaveOptPlot( wxCommandEvent& event )
|
||||||
PlotPadsOnSilkLayer = m_Plot_Pads_on_Silkscreen->GetValue();
|
PlotPadsOnSilkLayer = m_Plot_Pads_on_Silkscreen->GetValue();
|
||||||
Plot_Pads_All_Layers = m_Force_Plot_Pads->GetValue();
|
Plot_Pads_All_Layers = m_Force_Plot_Pads->GetValue();
|
||||||
|
|
||||||
s_PlotOriginIsAuxAxis = (m_Choice_Plot_Offset->GetSelection() == 0) ? FALSE : TRUE;
|
s_PlotOriginIsAuxAxis =
|
||||||
|
(m_Choice_Plot_Offset->GetSelection() == 0) ? FALSE : TRUE;
|
||||||
|
|
||||||
Sel_Texte_Valeur = m_Plot_Text_Value->GetValue();
|
Sel_Texte_Valeur = m_Plot_Text_Value->GetValue();
|
||||||
Sel_Texte_Reference = m_Plot_Text_Ref->GetValue();
|
Sel_Texte_Reference = m_Plot_Text_Ref->GetValue();
|
||||||
|
@ -618,7 +639,7 @@ void WinEDA_PlotFrame::SaveOptPlot( wxCommandEvent& event )
|
||||||
config->Write( OPTKEY_PADS_ON_SILKSCREEN, PlotPadsOnSilkLayer );
|
config->Write( OPTKEY_PADS_ON_SILKSCREEN, PlotPadsOnSilkLayer );
|
||||||
config->Write( OPTKEY_ALWAYS_PRINT_PADS, Plot_Pads_All_Layers );
|
config->Write( OPTKEY_ALWAYS_PRINT_PADS, Plot_Pads_All_Layers );
|
||||||
|
|
||||||
int formatNdx = m_PlotFormatOpt->GetSelection();
|
int formatNdx = m_PlotFormatOpt->GetSelection();
|
||||||
config->Write( OPTKEY_OUTPUT_FORMAT, formatNdx );
|
config->Write( OPTKEY_OUTPUT_FORMAT, formatNdx );
|
||||||
|
|
||||||
config->Write( OPTKEY_PLOT_LINEWIDTH_VALUE, g_PlotLine_Width );
|
config->Write( OPTKEY_PLOT_LINEWIDTH_VALUE, g_PlotLine_Width );
|
||||||
|
@ -635,9 +656,7 @@ void WinEDA_PlotFrame::SaveOptPlot( wxCommandEvent& event )
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/***************************************************/
|
|
||||||
void WinEDA_PlotFrame::Plot( wxCommandEvent& event )
|
void WinEDA_PlotFrame::Plot( wxCommandEvent& event )
|
||||||
/***************************************************/
|
|
||||||
{
|
{
|
||||||
int layer_to_plot;
|
int layer_to_plot;
|
||||||
wxFileName fn;
|
wxFileName fn;
|
||||||
|
@ -667,8 +686,17 @@ void WinEDA_PlotFrame::Plot( wxCommandEvent& event )
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
Scale_X *= m_XScaleAdjust;
|
/* If the scale factor edit controls are disabled or the scale value
|
||||||
Scale_Y *= m_YScaleAdjust;
|
* is 0, don't adjust the base scale factor. This fixes a bug when
|
||||||
|
* the default scale adjust is initialized to 0 and saved in program
|
||||||
|
* settings resulting in a divide by zero fault.
|
||||||
|
*/
|
||||||
|
if( m_FineAdjustXscaleOpt->m_ValueCtrl->IsEnabled()
|
||||||
|
&& m_XScaleAdjust != 0.0 )
|
||||||
|
Scale_X *= m_XScaleAdjust;
|
||||||
|
if( m_FineAdjustYscaleOpt->m_ValueCtrl->IsEnabled()
|
||||||
|
&& m_YScaleAdjust != 0.0 )
|
||||||
|
Scale_Y *= m_YScaleAdjust;
|
||||||
|
|
||||||
int format = getFormat();
|
int format = getFormat();
|
||||||
|
|
||||||
|
@ -681,8 +709,8 @@ void WinEDA_PlotFrame::Plot( wxCommandEvent& event )
|
||||||
|
|
||||||
default:
|
default:
|
||||||
case PLOT_FORMAT_GERBER:
|
case PLOT_FORMAT_GERBER:
|
||||||
Scale_X = Scale_Y = 1.0; // No scale option allowed in gerber format
|
Scale_X = Scale_Y = 1.0; // No scale option allowed in gerber format
|
||||||
ext = wxT( "pho" );
|
ext = wxT( "pho" );
|
||||||
wildcard = _( "GERBER photo plot files (.pho)|*.pho" );
|
wildcard = _( "GERBER photo plot files (.pho)|*.pho" );
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -693,15 +721,19 @@ void WinEDA_PlotFrame::Plot( wxCommandEvent& event )
|
||||||
}
|
}
|
||||||
|
|
||||||
// Test for a reasonnable scale value
|
// Test for a reasonnable scale value
|
||||||
if ( Scale_X < MIN_SCALE || Scale_Y < MIN_SCALE )
|
if( Scale_X < MIN_SCALE || Scale_Y < MIN_SCALE )
|
||||||
DisplayInfoMessage(this, _("Warning: Scale option set to a very small value") );
|
DisplayInfoMessage( this,
|
||||||
if ( Scale_X > MAX_SCALE || Scale_Y > MAX_SCALE )
|
_( "Warning: Scale option set to a very small value" ) );
|
||||||
DisplayInfoMessage(this, _("Warning: Scale option set to a very large value") );
|
if( Scale_X > MAX_SCALE || Scale_Y > MAX_SCALE )
|
||||||
|
DisplayInfoMessage( this,
|
||||||
|
_( "Warning: Scale option set to a very large value" ) );
|
||||||
|
|
||||||
int mask = 1;
|
int mask = 1;
|
||||||
s_SelectedLayers = 0;
|
s_SelectedLayers = 0;
|
||||||
|
|
||||||
for( layer_to_plot = 0; layer_to_plot < NB_LAYERS; layer_to_plot++, mask <<= 1 )
|
for( layer_to_plot = 0;
|
||||||
|
layer_to_plot < NB_LAYERS;
|
||||||
|
layer_to_plot++, mask <<= 1 )
|
||||||
{
|
{
|
||||||
if( m_BoxSelectLayer[layer_to_plot]->GetValue() )
|
if( m_BoxSelectLayer[layer_to_plot]->GetValue() )
|
||||||
{
|
{
|
||||||
|
@ -735,16 +767,12 @@ void WinEDA_PlotFrame::Plot( wxCommandEvent& event )
|
||||||
|
|
||||||
// If no layer selected, we have no plot. prompt user if it happens
|
// If no layer selected, we have no plot. prompt user if it happens
|
||||||
// because he could think there is a bug in pcbnew:
|
// because he could think there is a bug in pcbnew:
|
||||||
if ( s_SelectedLayers == 0 )
|
if( s_SelectedLayers == 0 )
|
||||||
DisplayError( this, _("No layer selected") );
|
DisplayError( this, _( "No layer selected" ) );
|
||||||
|
|
||||||
// Close(true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**************************************************************/
|
|
||||||
void WinEDA_BasePcbFrame::ToPlotter( wxCommandEvent& event )
|
void WinEDA_BasePcbFrame::ToPlotter( wxCommandEvent& event )
|
||||||
/***************************************************************/
|
|
||||||
{
|
{
|
||||||
WinEDA_PlotFrame* frame = new WinEDA_PlotFrame( this );
|
WinEDA_PlotFrame* frame = new WinEDA_PlotFrame( this );
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue