Commit 5a5b9098 authored by Andrey Fedorushkov's avatar Andrey Fedorushkov

all: new Russian GOST patch - author Konstantin Baranovskiy

pcbnew: fix print format in THROW_IO_ERROR
        fix properties file export_vrml.cpp
parent e90fc3a9
...@@ -59,17 +59,12 @@ void PlotWorkSheet( PLOTTER* plotter, const TITLE_BLOCK& aTitleBlock, ...@@ -59,17 +59,12 @@ void PlotWorkSheet( PLOTTER* plotter, const TITLE_BLOCK& aTitleBlock,
int iusPerMil = plotter->GetIUsPerDecimil() * 10; int iusPerMil = plotter->GetIUsPerDecimil() * 10;
wxSize pageSize = aPageInfo.GetSizeMils(); // in mils wxSize pageSize = aPageInfo.GetSizeMils(); // in mils
int xg, yg; int xg, yg;
wxPoint pos, ref; int refx, refy;
wxPoint pos, end, ref;
wxString msg; wxString msg;
wxSize text_size; wxSize text_size;
#if defined(KICAD_GOST)
wxSize text_size2;
wxSize text_size3;
wxSize text_size1_5;
#else
int UpperLimit = VARIABLE_BLOCK_START_POSITION; int UpperLimit = VARIABLE_BLOCK_START_POSITION;
#endif
EDA_COLOR_T plotClr; EDA_COLOR_T plotClr;
plotClr = plotter->GetColorMode() ? RED : BLACK; plotClr = plotter->GetColorMode() ? RED : BLACK;
...@@ -84,6 +79,19 @@ void PlotWorkSheet( PLOTTER* plotter, const TITLE_BLOCK& aTitleBlock, ...@@ -84,6 +79,19 @@ void PlotWorkSheet( PLOTTER* plotter, const TITLE_BLOCK& aTitleBlock,
yg = ( pageSize.y - aPageInfo.GetBottomMarginMils() ) * iusPerMil; yg = ( pageSize.y - aPageInfo.GetBottomMarginMils() ) * iusPerMil;
#if defined(KICAD_GOST) #if defined(KICAD_GOST)
int lnMsg, ln;
text_size.x = SIZETEXT * iusPerMil;
text_size.y = SIZETEXT * iusPerMil;
wxSize sz;
wxSize text_size0_8( SIZETEXT * iusPerMil * 0.8, SIZETEXT * iusPerMil * 1 );
wxSize text_size1_5( SIZETEXT * iusPerMil * 1.5, SIZETEXT * iusPerMil * 1.5 );
wxSize text_size2( SIZETEXT * iusPerMil * 2, SIZETEXT * iusPerMil * 2 );
wxSize text_size3( SIZETEXT * iusPerMil * 3, SIZETEXT * iusPerMil * 3 );
int lineOsn_widht = plotter->GetCurrentLineWidth() * 2;
int lineTonk_widht = plotter->GetCurrentLineWidth();
plotter->SetCurrentLineWidth( lineOsn_widht );
plotter->MoveTo( ref ); plotter->MoveTo( ref );
pos.x = xg; pos.x = xg;
pos.y = ref.y; pos.y = ref.y;
...@@ -95,6 +103,7 @@ void PlotWorkSheet( PLOTTER* plotter, const TITLE_BLOCK& aTitleBlock, ...@@ -95,6 +103,7 @@ void PlotWorkSheet( PLOTTER* plotter, const TITLE_BLOCK& aTitleBlock,
pos.y = yg; pos.y = yg;
plotter->LineTo( pos ); plotter->LineTo( pos );
plotter->FinishTo( ref ); plotter->FinishTo( ref );
plotter->SetCurrentLineWidth( PLOTTER::DEFAULT_LINE_WIDTH );
#else #else
...@@ -125,9 +134,6 @@ void PlotWorkSheet( PLOTTER* plotter, const TITLE_BLOCK& aTitleBlock, ...@@ -125,9 +134,6 @@ void PlotWorkSheet( PLOTTER* plotter, const TITLE_BLOCK& aTitleBlock,
#endif #endif
text_size.x = WSTEXTSIZE * iusPerMil;
text_size.y = WSTEXTSIZE * iusPerMil;
// upper left corner in mils // upper left corner in mils
ref.x = aPageInfo.GetLeftMarginMils(); ref.x = aPageInfo.GetLeftMarginMils();
ref.y = aPageInfo.GetTopMarginMils(); ref.y = aPageInfo.GetTopMarginMils();
...@@ -137,353 +143,603 @@ void PlotWorkSheet( PLOTTER* plotter, const TITLE_BLOCK& aTitleBlock, ...@@ -137,353 +143,603 @@ void PlotWorkSheet( PLOTTER* plotter, const TITLE_BLOCK& aTitleBlock,
yg = ( pageSize.y - aPageInfo.GetBottomMarginMils() ); yg = ( pageSize.y - aPageInfo.GetBottomMarginMils() );
#if defined(KICAD_GOST) #if defined(KICAD_GOST)
for( Ki_WorkSheetData* WsItem = &WS_Segm1_LU;
// Lower right corner
refx = xg;
refy = yg;
// First page
if( aSheetNumber == 1 )
{
for( Ki_WorkSheetData* WsItem = &WS_Osn1_Line1;
WsItem != NULL; WsItem != NULL;
WsItem = WsItem->Pnext ) WsItem = WsItem->Pnext )
{ {
pos.x = ( ref.x - WsItem->m_Posx ) * iusPerMil; pos.x = (refx - WsItem->m_Posx) * iusPerMil;
pos.y = ( yg - WsItem->m_Posy ) * iusPerMil; pos.y = (refy - WsItem->m_Posy) * iusPerMil;
msg.Empty(); end.x = (refx - WsItem->m_Endx) * iusPerMil;
end.y = (refy - WsItem->m_Endy) * iusPerMil;
msg = WsItem->m_Legende;
switch( WsItem->m_Type ) switch( WsItem->m_Type )
{ {
case WS_CADRE: case WS_OSN:
plotter->SetCurrentLineWidth( lineOsn_widht );
plotter->MoveTo( pos );
plotter->FinishTo( end );
plotter->SetCurrentLineWidth( PLOTTER::DEFAULT_LINE_WIDTH );
break; break;
case WS_PODPIS_LU: case WS_TONK:
if( WsItem->m_Legende ) plotter->SetCurrentLineWidth( lineTonk_widht );
msg = WsItem->m_Legende; plotter->MoveTo( pos );
plotter->FinishTo( end );
plotter->SetCurrentLineWidth( PLOTTER::DEFAULT_LINE_WIDTH );
break;
case WS_TEXT:
if( !msg.IsEmpty() )
{
if( WsItem == &WS_Osn1_Text1 )
plotter->Text( pos, plotClr, plotter->Text( pos, plotClr,
msg, TEXT_ORIENT_VERT, text_size, msg, TEXT_ORIENT_HORIZ, text_size0_8,
GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_BOTTOM, GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER,
PLOTTER::DEFAULT_LINE_WIDTH, false, false );
else
plotter->Text( pos, plotClr,
msg, TEXT_ORIENT_HORIZ, text_size,
GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER,
PLOTTER::DEFAULT_LINE_WIDTH, false, false ); PLOTTER::DEFAULT_LINE_WIDTH, false, false );
}
break; break;
case WS_SEGMENT_LU: case WS_TEXTL:
plotter->MoveTo( pos ); if( !msg.IsEmpty() )
pos.x = ( ref.x - WsItem->m_Endx ) * iusPerMil; plotter->Text( pos, plotClr,
pos.y = ( yg - WsItem->m_Endy ) * iusPerMil; msg, TEXT_ORIENT_HORIZ, text_size,
plotter->FinishTo( pos ); GR_TEXT_HJUSTIFY_LEFT, GR_TEXT_VJUSTIFY_CENTER,
PLOTTER::DEFAULT_LINE_WIDTH, false, false );
break; break;
}
}
for( Ki_WorkSheetData* WsItem = &WS_Segm1_LT;
WsItem != NULL;
WsItem = WsItem->Pnext )
{
pos.x = ( ref.x + WsItem->m_Posx ) * iusPerMil;
pos.y = ( ref.y + WsItem->m_Posy ) * iusPerMil;
msg.Empty();
switch( WsItem->m_Type )
{
case WS_SEGMENT_LT:
plotter->MoveTo( pos );
pos.x = ( ref.x + WsItem->m_Endx ) * iusPerMil;
pos.y = ( ref.y + WsItem->m_Endy ) * iusPerMil;
plotter->FinishTo( pos );
break;
} }
} }
#else // Sheet number
if( aNumberOfSheets > 1 )
// Plot legend along the X axis.
int ipas = ( xg - ref.x ) / PAS_REF;
int gxpas = ( xg - ref.x ) / ipas;
for( int ii = ref.x + gxpas, jj = 1; ipas > 0; ii += gxpas, jj++, ipas-- )
{ {
pos.x = (refx - Mm2mils( 36 )) * iusPerMil;
pos.y = (refy - Mm2mils( 17.5 )) * iusPerMil;
msg.Empty(); msg.Empty();
msg << jj; msg << aSheetNumber;
if( ii < xg - PAS_REF / 2 )
{
pos.x = ii * iusPerMil;
pos.y = ref.y * iusPerMil;
plotter->MoveTo( pos );
pos.x = ii * iusPerMil;
pos.y = ( ref.y + GRID_REF_W ) * iusPerMil;
plotter->FinishTo( pos );
}
pos.x = ( ii - gxpas / 2 ) * iusPerMil;
pos.y = ( ref.y + GRID_REF_W / 2 ) * iusPerMil;
plotter->Text( pos, plotClr, plotter->Text( pos, plotClr,
msg, TEXT_ORIENT_HORIZ, text_size, msg, TEXT_ORIENT_HORIZ, text_size,
GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER, GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER,
PLOTTER::DEFAULT_LINE_WIDTH, false, false ); PLOTTER::DEFAULT_LINE_WIDTH, false, false );
if( ii < xg - PAS_REF / 2 )
{
pos.x = ii * iusPerMil;
pos.y = yg * iusPerMil;
plotter->MoveTo( pos );
pos.x = ii * iusPerMil;
pos.y = (yg - GRID_REF_W) * iusPerMil;
plotter->FinishTo( pos );
} }
pos.x = ( ii - gxpas / 2 ) * iusPerMil;
pos.y = ( yg - GRID_REF_W / 2 ) * iusPerMil; // Count of sheets
pos.x = (refx - Mm2mils( 10 )) * iusPerMil;
pos.y = (refy - Mm2mils( 17.5 )) * iusPerMil;
msg.Empty();
msg << aNumberOfSheets;
plotter->Text( pos, plotClr, plotter->Text( pos, plotClr,
msg, TEXT_ORIENT_HORIZ, text_size, msg, TEXT_ORIENT_HORIZ, text_size,
GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER, GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER,
PLOTTER::DEFAULT_LINE_WIDTH, false, false ); PLOTTER::DEFAULT_LINE_WIDTH, false, false );
}
// Plot legend along the Y axis. // Company name
ipas = ( yg - ref.y ) / PAS_REF; msg = aTitleBlock.GetCompany();
int gypas = ( yg - ref.y ) / ipas; if( !msg.IsEmpty() )
for( int ii = ref.y + gypas, jj = 0; ipas > 0; ii += gypas, jj++, ipas-- )
{
if( jj < 26 )
msg.Printf( wxT( "%c" ), jj + 'A' );
else // I hope 52 identifiers are enough...
msg.Printf( wxT( "%c" ), 'a' + jj - 26 );
if( ii < yg - PAS_REF / 2 )
{ {
pos.x = ref.x * iusPerMil; sz = text_size1_5;
pos.y = ii * iusPerMil; lnMsg = ReturnGraphicTextWidth( msg, sz.x, false, false ) / iusPerMil;
plotter->MoveTo( pos ); ln = Mm2mils( 49 );
pos.x = ( ref.x + GRID_REF_W ) * iusPerMil; if( lnMsg > ln )
pos.y = ii * iusPerMil; sz.x *= float( ln ) / lnMsg;
plotter->FinishTo( pos ); pos.x = (refx - Mm2mils( 25 )) * iusPerMil;
} pos.y = (refy - Mm2mils( 7.5 )) * iusPerMil;
pos.x = ( ref.x + GRID_REF_W / 2 ) * iusPerMil;
pos.y = ( ii - gypas / 2 ) * iusPerMil;
plotter->Text( pos, plotClr, plotter->Text( pos, plotClr,
msg, TEXT_ORIENT_HORIZ, text_size, msg, TEXT_ORIENT_HORIZ, sz,
GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER, GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER,
PLOTTER::DEFAULT_LINE_WIDTH, false, false ); PLOTTER::DEFAULT_LINE_WIDTH, false, false );
}
if( ii < yg - PAS_REF / 2 ) // Title
msg = aTitleBlock.GetTitle();
if( !msg.IsEmpty() )
{ {
pos.x = xg * iusPerMil; sz = text_size1_5;
pos.y = ii * iusPerMil; wxArrayString lines;
plotter->MoveTo( pos ); int titleWidth = 0;
pos.x = ( xg - GRID_REF_W ) * iusPerMil; int titleHeight = (sz.y + sz.y * 0.5) / iusPerMil;
pos.y = ii * iusPerMil; int titleFieldWidth = Mm2mils( 69 );
plotter->FinishTo( pos ); int titleFieldHeight = Mm2mils( 24 );
int index = 0;
wxString fullMsg = msg;
do // Reduce the height of wrapped title until the fit
{
do // Wrap the title
{
titleWidth = ReturnGraphicTextWidth( msg, sz.x, false, false ) / iusPerMil;
if( titleWidth > titleFieldWidth )
{
index = 0;
do
{
msg = msg.Left( msg.Length() - 1 );
if( msg.Length() == 0 )
{
lines.Clear();
msg = fullMsg;
sz.x -= iusPerMil;
break;
} }
else
{
index++;
titleWidth = ReturnGraphicTextWidth( msg, sz.x, false, false ) / iusPerMil;
pos.x = ( xg - GRID_REF_W / 2 ) * iusPerMil; wxString ch = wxString( msg.Last() );
pos.y = ( ii - gypas / 2 ) * iusPerMil; if( titleWidth < titleFieldWidth && ch == wxT( " " ) )
plotter->Text( pos, plotClr, msg, TEXT_ORIENT_HORIZ, text_size, {
GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER, // New sentence on a new line
PLOTTER::DEFAULT_LINE_WIDTH, false, false ); int dot = msg.Index( wxT( ". " ) );
if( dot != wxNOT_FOUND )
{
index += msg.Length() - dot - 2;
msg = msg.Left( dot + 1 );
lines.Add( msg );
msg = fullMsg.Right( index );
break;
} }
else
#endif
// Plot the worksheet.
text_size.x = SIZETEXT * iusPerMil;
text_size.y = SIZETEXT * iusPerMil;
#if defined(KICAD_GOST)
text_size2.x = SIZETEXT * iusPerMil * 2;
text_size2.y = SIZETEXT * iusPerMil * 2;
text_size3.x = SIZETEXT * iusPerMil * 3;
text_size3.y = SIZETEXT * iusPerMil * 3;
text_size1_5.x = SIZETEXT * iusPerMil * 1.5;
text_size1_5.y = SIZETEXT * iusPerMil * 1.5;
ref.x = pageSize.x - aPageInfo.GetRightMarginMils();
ref.y = pageSize.y - aPageInfo.GetBottomMarginMils();
if( aSheetNumber == 1 )
{ {
for( Ki_WorkSheetData* WsItem = &WS_Date; msg = msg.Left( msg.Length() - 1 );
WsItem != NULL; lines.Add( msg );
WsItem = WsItem->Pnext ) msg = fullMsg.Right( index );
break;
}
}
}
}while( 1 );
}
else
{ {
pos.x = ( ref.x - WsItem->m_Posx ) * iusPerMil; // New sentence on a new line
pos.y = ( ref.y - WsItem->m_Posy ) * iusPerMil; int dot = msg.Index( wxT( ". " ) );
msg.Empty(); if( dot != wxNOT_FOUND )
switch( WsItem->m_Type )
{ {
case WS_DATE: lines.Add( msg.Left( dot + 1 ) );
lines.Add( fullMsg.Right( msg.Length() - dot - 2 ) );
}
else
lines.Add( msg );
break; break;
}
}while( 1 );
case WS_REV: if( titleFieldHeight < titleHeight * lines.Count() )
{
sz.y -= iusPerMil;
sz.x -= iusPerMil;
msg = fullMsg;
lines.Clear();
}
else
break; break;
}while( 1 );
case WS_KICAD_VERSION: pos.x = (refx - Mm2mils( 85 )) * iusPerMil;
break; pos.y = (refy - Mm2mils( 27.5 ) - (titleHeight * (lines.Count() - 1) / 2)) * iusPerMil;
case WS_PODPIS: for( int curLn = 0; curLn < lines.Count(); curLn++ )
if( WsItem->m_Legende ) {
msg = WsItem->m_Legende; msg = lines[curLn];
plotter->Text( pos, plotClr, plotter->Text( pos, plotClr,
msg, TEXT_ORIENT_HORIZ, text_size, msg, TEXT_ORIENT_HORIZ, sz,
GR_TEXT_HJUSTIFY_LEFT, GR_TEXT_VJUSTIFY_CENTER, GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER,
PLOTTER::DEFAULT_LINE_WIDTH, false, false ); PLOTTER::DEFAULT_LINE_WIDTH, false, false );
break; pos.y += titleHeight * iusPerMil;
}
case WS_SIZESHEET: }
break;
case WS_IDENTSHEET: // Decimal number
if( WsItem->m_Legende ) msg = aTitleBlock.GetComment1();
msg = WsItem->m_Legende; if( !msg.IsEmpty() )
if( aNumberOfSheets > 1 ) {
msg << aSheetNumber; sz = text_size3;
lnMsg = ReturnGraphicTextWidth( msg, sz.x, false, false ) / iusPerMil;
ln = Mm2mils( 119 );
if( lnMsg > ln )
sz.x *= float( ln ) / lnMsg;
pos.x = (refx - Mm2mils( 60 )) * iusPerMil;
pos.y = (refy - Mm2mils( 47.5 )) * iusPerMil;
plotter->Text( pos, plotClr, plotter->Text( pos, plotClr,
msg, TEXT_ORIENT_HORIZ, text_size, msg, TEXT_ORIENT_HORIZ, sz,
GR_TEXT_HJUSTIFY_LEFT, GR_TEXT_VJUSTIFY_CENTER, GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER,
PLOTTER::DEFAULT_LINE_WIDTH, false, false ); PLOTTER::DEFAULT_LINE_WIDTH, false, false );
break; }
case WS_SHEETS: // Developer
if( WsItem->m_Legende ) msg = aTitleBlock.GetComment2();
msg = WsItem->m_Legende; if( !msg.IsEmpty() )
msg << aNumberOfSheets; {
sz = text_size;
lnMsg = ReturnGraphicTextWidth( msg, sz.x, false, false ) / iusPerMil;
ln = Mm2mils( 22 );
if( lnMsg > ln )
sz.x *= float( ln ) / lnMsg;
pos.x = (refx - Mm2mils( 167.5 )) * iusPerMil;
pos.y = (refy - Mm2mils( 27.5 )) * iusPerMil;
plotter->Text( pos, plotClr, plotter->Text( pos, plotClr,
msg, TEXT_ORIENT_HORIZ, text_size, msg, TEXT_ORIENT_HORIZ, sz,
GR_TEXT_HJUSTIFY_LEFT, GR_TEXT_VJUSTIFY_CENTER, GR_TEXT_HJUSTIFY_LEFT, GR_TEXT_VJUSTIFY_CENTER,
PLOTTER::DEFAULT_LINE_WIDTH, false, false ); PLOTTER::DEFAULT_LINE_WIDTH, false, false );
break; }
case WS_COMPANY_NAME: // Verifier
msg = aTitleBlock.GetCompany(); msg = aTitleBlock.GetComment3();
if( !msg.IsEmpty() ) if( !msg.IsEmpty() )
{ {
sz = text_size;
lnMsg = ReturnGraphicTextWidth( msg, sz.x, false, false ) / iusPerMil;
ln = Mm2mils( 22 );
if( lnMsg > ln )
sz.x *= float( ln ) / lnMsg;
pos.x = (refx - Mm2mils( 167.5 )) * iusPerMil;
pos.y = (refy - Mm2mils( 22.5 )) * iusPerMil;
plotter->Text( pos, plotClr, plotter->Text( pos, plotClr,
msg, TEXT_ORIENT_HORIZ, text_size1_5, msg, TEXT_ORIENT_HORIZ, sz,
GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER, GR_TEXT_HJUSTIFY_LEFT, GR_TEXT_VJUSTIFY_CENTER,
PLOTTER::DEFAULT_LINE_WIDTH, false, false ); PLOTTER::DEFAULT_LINE_WIDTH, false, false );
} }
break;
case WS_TITLE: // Approver
msg = aTitleBlock.GetTitle(); msg = aTitleBlock.GetComment4();
if( !msg.IsEmpty() ) if( !msg.IsEmpty() )
{ {
sz = text_size;
lnMsg = ReturnGraphicTextWidth( msg, sz.x, false, false ) / iusPerMil;
ln = Mm2mils( 22 );
if( lnMsg > ln )
sz.x *= float( ln ) / lnMsg;
pos.x = (refx - Mm2mils( 167.5 )) * iusPerMil;
pos.y = (refy - Mm2mils( 2.5 )) * iusPerMil;
plotter->Text( pos, plotClr, plotter->Text( pos, plotClr,
msg, TEXT_ORIENT_HORIZ, text_size1_5, msg, TEXT_ORIENT_HORIZ, sz,
GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER, GR_TEXT_HJUSTIFY_LEFT, GR_TEXT_VJUSTIFY_CENTER,
PLOTTER::DEFAULT_LINE_WIDTH, false, false ); PLOTTER::DEFAULT_LINE_WIDTH, false, false );
} }
}
else // other pages
{
for( Ki_WorkSheetData* WsItem = &WS_Osn2a_Line1;
WsItem != NULL;
WsItem = WsItem->Pnext )
{
pos.x = (refx - WsItem->m_Posx) * iusPerMil;
pos.y = (refy - WsItem->m_Posy) * iusPerMil;
end.x = (refx - WsItem->m_Endx) * iusPerMil;
end.y = (refy - WsItem->m_Endy) * iusPerMil;
msg = WsItem->m_Legende;
switch( WsItem->m_Type )
{
case WS_OSN:
plotter->SetCurrentLineWidth( lineOsn_widht );
plotter->MoveTo( pos );
plotter->FinishTo( end );
plotter->SetCurrentLineWidth( PLOTTER::DEFAULT_LINE_WIDTH );
break; break;
case WS_COMMENT1: case WS_TONK:
msg = aTitleBlock.GetComment1(); plotter->SetCurrentLineWidth( lineTonk_widht );
plotter->MoveTo( pos );
plotter->FinishTo( end );
plotter->SetCurrentLineWidth( PLOTTER::DEFAULT_LINE_WIDTH );
break;
case WS_TEXT:
if( !msg.IsEmpty() ) if( !msg.IsEmpty() )
{ {
if( WsItem == &WS_Osn2a_Text1 )
plotter->Text( pos, plotClr, plotter->Text( pos, plotClr,
msg, TEXT_ORIENT_HORIZ, text_size3, msg, TEXT_ORIENT_HORIZ, text_size0_8,
GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER, GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER,
PLOTTER::DEFAULT_LINE_WIDTH, false, false ); PLOTTER::DEFAULT_LINE_WIDTH, false, false );
pos.x = (aPageInfo.GetLeftMarginMils() + 1260) * iusPerMil; else
pos.y = (aPageInfo.GetTopMarginMils() + 270) * iusPerMil;
plotter->Text( pos, plotClr, plotter->Text( pos, plotClr,
msg.GetData(), 1800, text_size2, msg, TEXT_ORIENT_HORIZ, text_size,
GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER, GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER,
PLOTTER::DEFAULT_LINE_WIDTH, false, false ); PLOTTER::DEFAULT_LINE_WIDTH, false, false );
} }
break; break;
case WS_COMMENT2: case WS_TEXTL:
msg = aTitleBlock.GetComment2();
if( !msg.IsEmpty() ) if( !msg.IsEmpty() )
{
plotter->Text( pos, plotClr, plotter->Text( pos, plotClr,
msg, TEXT_ORIENT_HORIZ, text_size, msg, TEXT_ORIENT_HORIZ, text_size,
GR_TEXT_HJUSTIFY_LEFT, GR_TEXT_VJUSTIFY_CENTER, GR_TEXT_HJUSTIFY_LEFT, GR_TEXT_VJUSTIFY_CENTER,
PLOTTER::DEFAULT_LINE_WIDTH, false, false ); PLOTTER::DEFAULT_LINE_WIDTH, false, false );
}
break; break;
}
}
case WS_COMMENT3: // Sheet number
msg = aTitleBlock.GetComment3(); pos.x = (refx - Mm2mils( 5 )) * iusPerMil;
pos.y = (refy - Mm2mils( 4 )) * iusPerMil;
msg.Empty();
msg << aSheetNumber;
plotter->Text( pos, plotClr,
msg, TEXT_ORIENT_HORIZ, text_size,
GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER,
PLOTTER::DEFAULT_LINE_WIDTH, false, false );
// Decimal number
msg = aTitleBlock.GetComment1();
if( !msg.IsEmpty() ) if( !msg.IsEmpty() )
{ {
sz = text_size3;
lnMsg = ReturnGraphicTextWidth( msg, sz.x, false, false ) / iusPerMil;
ln = Mm2mils( 109 );
if( lnMsg > ln )
sz.x *= float( ln ) / lnMsg;
pos.x = (refx - Mm2mils( 65 )) * iusPerMil;
pos.y = (refy - Mm2mils( 7.5 )) * iusPerMil;
plotter->Text( pos, plotClr,
msg, TEXT_ORIENT_HORIZ, sz,
GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER,
PLOTTER::DEFAULT_LINE_WIDTH, false, false );
}
}
// Format
pos.x = (refx - Mm2mils( 23 )) * iusPerMil;
pos.y = (refy + Mm2mils( 2.5 )) * iusPerMil;
msg.Empty();
msg << aPageInfo.GetType();
plotter->Text( pos, plotClr, plotter->Text( pos, plotClr,
msg, TEXT_ORIENT_HORIZ, text_size, msg, TEXT_ORIENT_HORIZ, text_size,
GR_TEXT_HJUSTIFY_LEFT, GR_TEXT_VJUSTIFY_CENTER, GR_TEXT_HJUSTIFY_LEFT, GR_TEXT_VJUSTIFY_CENTER,
PLOTTER::DEFAULT_LINE_WIDTH, false, false ); PLOTTER::DEFAULT_LINE_WIDTH, false, false );
}
// Lower left corner
refx = ref.x;
refy = yg;
for( Ki_WorkSheetData* WsItem = &WS_DopLeft_Line1;
WsItem != NULL;
WsItem = WsItem->Pnext )
{
if( aSheetNumber > 1 && WsItem == &WS_DopLeft_Line9 ) // Some fields for first page only
break; break;
case WS_COMMENT4: pos.x = (refx - WsItem->m_Posx) * iusPerMil;
msg = aTitleBlock.GetComment4(); pos.y = (refy - WsItem->m_Posy) * iusPerMil;
if( !msg.IsEmpty() ) end.x = (refx - WsItem->m_Endx) * iusPerMil;
end.y = (refy - WsItem->m_Endy) * iusPerMil;
msg = WsItem->m_Legende;
switch( WsItem->m_Type )
{ {
case WS_OSN:
plotter->SetCurrentLineWidth( lineOsn_widht );
plotter->MoveTo( pos );
plotter->FinishTo( end );
plotter->SetCurrentLineWidth( PLOTTER::DEFAULT_LINE_WIDTH );
break;
case WS_TONK:
plotter->SetCurrentLineWidth( lineTonk_widht );
plotter->MoveTo( pos );
plotter->FinishTo( end );
plotter->SetCurrentLineWidth( PLOTTER::DEFAULT_LINE_WIDTH );
break;
case WS_TEXT:
if( !msg.IsEmpty() )
plotter->Text( pos, plotClr, plotter->Text( pos, plotClr,
msg, TEXT_ORIENT_HORIZ, text_size, msg, TEXT_ORIENT_VERT, text_size,
GR_TEXT_HJUSTIFY_LEFT, GR_TEXT_VJUSTIFY_CENTER, GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER,
PLOTTER::DEFAULT_LINE_WIDTH, false, false ); PLOTTER::DEFAULT_LINE_WIDTH, false, false );
break;
} }
}
if( aPageInfo.GetType() == PAGE_INFO::A4 || !aPageInfo.IsPortrait() ) // A4 or Landscape
{
// Left Top corner
refx = ref.x;
refy = ref.y;
for( Ki_WorkSheetData* WsItem = &WS_DopTop_Line1;
WsItem != NULL;
WsItem = WsItem->Pnext )
{
if( aSheetNumber > 1 && WsItem == &WS_DopTop_Line3 )// Some fields for first page only
break; break;
case WS_UPPER_SEGMENT: pos.x = (refx + WsItem->m_Posx) * iusPerMil;
case WS_LEFT_SEGMENT: pos.y = (refy + WsItem->m_Posy) * iusPerMil;
case WS_SEGMENT: end.x = (refx + WsItem->m_Endx) * iusPerMil;
end.y = (refy + WsItem->m_Endy) * iusPerMil;
msg = WsItem->m_Legende;
switch( WsItem->m_Type )
{
case WS_OSN:
plotter->SetCurrentLineWidth( lineOsn_widht );
plotter->MoveTo( pos ); plotter->MoveTo( pos );
pos.x = ( ref.x - WsItem->m_Endx ) * iusPerMil; plotter->FinishTo( end );
pos.y = ( ref.y - WsItem->m_Endy ) * iusPerMil; plotter->SetCurrentLineWidth( PLOTTER::DEFAULT_LINE_WIDTH );
plotter->FinishTo( pos );
break; break;
case WS_TONK:
plotter->SetCurrentLineWidth( lineTonk_widht );
plotter->MoveTo( pos );
plotter->FinishTo( end );
plotter->SetCurrentLineWidth( PLOTTER::DEFAULT_LINE_WIDTH );
break;
}
} }
// Decimal number
msg = aTitleBlock.GetComment1();
if( !msg.IsEmpty() )
{
sz = text_size2;
lnMsg = ReturnGraphicTextWidth( msg, sz.x, false, false ) / iusPerMil;
ln = Mm2mils( 69 );
if( lnMsg > ln )
sz.x *= float( ln ) / lnMsg;
pos.x = (refx + Mm2mils( 35 )) * iusPerMil;
pos.y = (refy + Mm2mils( 7 )) * iusPerMil;
plotter->Text( pos, plotClr,
msg, 1800, sz,
GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER,
PLOTTER::DEFAULT_LINE_WIDTH, false, false );
} }
} }
else else // Portrait
{ {
for( Ki_WorkSheetData* WsItem = &WS_CADRE_D; // Right Top corner
// Lines are used from the upper left corner by the change of coordinates
refx = xg;
refy = ref.y;
for( Ki_WorkSheetData* WsItem = &WS_DopTop_Line1;
WsItem != NULL; WsItem != NULL;
WsItem = WsItem->Pnext ) WsItem = WsItem->Pnext )
{ {
pos.x = ( ref.x - WsItem->m_Posx ) * iusPerMil; if( aSheetNumber > 1 && WsItem == &WS_DopTop_Line3 )// Some fields for first page only
pos.y = ( ref.y - WsItem->m_Posy ) * iusPerMil; break;
msg.Empty();
pos.x = (refx - WsItem->m_Posy) * iusPerMil;
pos.y = (refy + WsItem->m_Posx) * iusPerMil;
end.x = (refx - WsItem->m_Endy) * iusPerMil;
end.y = (refy + WsItem->m_Endx) * iusPerMil;
msg = WsItem->m_Legende;
switch( WsItem->m_Type ) switch( WsItem->m_Type )
{ {
case WS_CADRE: case WS_OSN:
// Begin list number > 1 plotter->SetCurrentLineWidth( lineOsn_widht );
plotter->MoveTo( pos );
plotter->FinishTo( end );
plotter->SetCurrentLineWidth( PLOTTER::DEFAULT_LINE_WIDTH );
break;
case WS_TONK:
plotter->SetCurrentLineWidth( lineTonk_widht );
plotter->MoveTo( pos );
plotter->FinishTo( end );
plotter->SetCurrentLineWidth( PLOTTER::DEFAULT_LINE_WIDTH );
break;
}
}
// Decimal number
msg = aTitleBlock.GetComment1(); msg = aTitleBlock.GetComment1();
if( !msg.IsEmpty() ) if( !msg.IsEmpty() )
{ {
sz = text_size2;
lnMsg = ReturnGraphicTextWidth( msg, sz.x, false, false ) / iusPerMil;
ln = Mm2mils( 69 );
if( lnMsg > ln )
sz.x *= float( ln ) / lnMsg;
pos.x = (refx - Mm2mils( 7 )) * iusPerMil;
pos.y = (refy + Mm2mils( 35 )) * iusPerMil;
plotter->Text( pos, plotClr, plotter->Text( pos, plotClr,
msg, TEXT_ORIENT_HORIZ, text_size3, msg, TEXT_ORIENT_VERT, sz,
GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER, GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER,
PLOTTER::DEFAULT_LINE_WIDTH, false, false ); PLOTTER::DEFAULT_LINE_WIDTH, false, false );
pos.x = (aPageInfo.GetLeftMarginMils() + 1260) * iusPerMil; }
pos.y = (aPageInfo.GetTopMarginMils() + 270) * iusPerMil; }
#else
text_size.x = WSTEXTSIZE * iusPerMil;
text_size.y = WSTEXTSIZE * iusPerMil;
// Plot legend along the X axis.
int ipas = ( xg - ref.x ) / PAS_REF;
int gxpas = ( xg - ref.x ) / ipas;
for( int ii = ref.x + gxpas, jj = 1; ipas > 0; ii += gxpas, jj++, ipas-- )
{
msg.Empty();
msg << jj;
if( ii < xg - PAS_REF / 2 )
{
pos.x = ii * iusPerMil;
pos.y = ref.y * iusPerMil;
plotter->MoveTo( pos );
pos.x = ii * iusPerMil;
pos.y = ( ref.y + GRID_REF_W ) * iusPerMil;
plotter->FinishTo( pos );
}
pos.x = ( ii - gxpas / 2 ) * iusPerMil;
pos.y = ( ref.y + GRID_REF_W / 2 ) * iusPerMil;
plotter->Text( pos, plotClr, plotter->Text( pos, plotClr,
msg, 1800, text_size2, msg, TEXT_ORIENT_HORIZ, text_size,
GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER, GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER,
PLOTTER::DEFAULT_LINE_WIDTH, false, false ); PLOTTER::DEFAULT_LINE_WIDTH, false, false );
}
break;
case WS_PODPIS_D: if( ii < xg - PAS_REF / 2 )
if( WsItem->m_Legende ) {
msg = WsItem->m_Legende; pos.x = ii * iusPerMil;
plotter->Text( pos, plotClr, msg, TEXT_ORIENT_HORIZ, text_size, pos.y = yg * iusPerMil;
GR_TEXT_HJUSTIFY_LEFT, GR_TEXT_VJUSTIFY_CENTER, plotter->MoveTo( pos );
pos.x = ii * iusPerMil;
pos.y = (yg - GRID_REF_W) * iusPerMil;
plotter->FinishTo( pos );
}
pos.x = ( ii - gxpas / 2 ) * iusPerMil;
pos.y = ( yg - GRID_REF_W / 2 ) * iusPerMil;
plotter->Text( pos, plotClr,
msg, TEXT_ORIENT_HORIZ, text_size,
GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER,
PLOTTER::DEFAULT_LINE_WIDTH, false, false ); PLOTTER::DEFAULT_LINE_WIDTH, false, false );
break; }
case WS_IDENTSHEET_D: // Plot legend along the Y axis.
if( WsItem->m_Legende ) ipas = ( yg - ref.y ) / PAS_REF;
msg = WsItem->m_Legende; int gypas = ( yg - ref.y ) / ipas;
msg << aSheetNumber; for( int ii = ref.y + gypas, jj = 0; ipas > 0; ii += gypas, jj++, ipas-- )
plotter->Text( pos, plotClr, msg, TEXT_ORIENT_HORIZ, text_size, {
GR_TEXT_HJUSTIFY_LEFT, GR_TEXT_VJUSTIFY_CENTER, if( jj < 26 )
msg.Printf( wxT( "%c" ), jj + 'A' );
else // I hope 52 identifiers are enough...
msg.Printf( wxT( "%c" ), 'a' + jj - 26 );
if( ii < yg - PAS_REF / 2 )
{
pos.x = ref.x * iusPerMil;
pos.y = ii * iusPerMil;
plotter->MoveTo( pos );
pos.x = ( ref.x + GRID_REF_W ) * iusPerMil;
pos.y = ii * iusPerMil;
plotter->FinishTo( pos );
}
pos.x = ( ref.x + GRID_REF_W / 2 ) * iusPerMil;
pos.y = ( ii - gypas / 2 ) * iusPerMil;
plotter->Text( pos, plotClr,
msg, TEXT_ORIENT_HORIZ, text_size,
GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER,
PLOTTER::DEFAULT_LINE_WIDTH, false, false ); PLOTTER::DEFAULT_LINE_WIDTH, false, false );
break;
case WS_LEFT_SEGMENT_D: if( ii < yg - PAS_REF / 2 )
case WS_SEGMENT_D: {
pos.x = xg * iusPerMil;
pos.y = ii * iusPerMil;
plotter->MoveTo( pos ); plotter->MoveTo( pos );
pos.x = ( ref.x - WsItem->m_Endx ) * iusPerMil; pos.x = ( xg - GRID_REF_W ) * iusPerMil;
pos.y = ( ref.y - WsItem->m_Endy ) * iusPerMil; pos.y = ii * iusPerMil;
plotter->FinishTo( pos ); plotter->FinishTo( pos );
break;
}
} }
pos.x = ( xg - GRID_REF_W / 2 ) * iusPerMil;
pos.y = ( ii - gypas / 2 ) * iusPerMil;
plotter->Text( pos, plotClr, msg, TEXT_ORIENT_HORIZ, text_size,
GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER,
PLOTTER::DEFAULT_LINE_WIDTH, false, false );
} }
#else // Plot the worksheet.
text_size.x = SIZETEXT * iusPerMil;
text_size.y = SIZETEXT * iusPerMil;
ref.x = pageSize.x - GRID_REF_W - aPageInfo.GetRightMarginMils(); ref.x = pageSize.x - GRID_REF_W - aPageInfo.GetRightMarginMils();
ref.y = pageSize.y - GRID_REF_W - aPageInfo.GetBottomMarginMils(); ref.y = pageSize.y - GRID_REF_W - aPageInfo.GetBottomMarginMils();
...@@ -603,4 +859,5 @@ void PlotWorkSheet( PLOTTER* plotter, const TITLE_BLOCK& aTitleBlock, ...@@ -603,4 +859,5 @@ void PlotWorkSheet( PLOTTER* plotter, const TITLE_BLOCK& aTitleBlock,
} }
#endif #endif
} }
...@@ -609,12 +609,20 @@ void DIALOG_PAGES_SETTINGS::UpdatePageLayoutExample() ...@@ -609,12 +609,20 @@ void DIALOG_PAGES_SETTINGS::UpdatePageLayoutExample()
wxPoint pointLeftTop( pageDUMMY.GetLeftMarginMils(), pageDUMMY.GetTopMarginMils() ); wxPoint pointLeftTop( pageDUMMY.GetLeftMarginMils(), pageDUMMY.GetTopMarginMils() );
wxPoint pointRightBottom( pageDUMMY.GetRightMarginMils(), pageDUMMY.GetBottomMarginMils() ); wxPoint pointRightBottom( pageDUMMY.GetRightMarginMils(), pageDUMMY.GetBottomMarginMils() );
// Get page type
int idx = m_paperSizeComboBox->GetSelection();
if( idx < 0 )
idx = 0;
wxString paperType = m_pageFmt[idx].Left( m_pageFmt[idx].Index( wxT( " " ) ) );
// Draw layout preview. // Draw layout preview.
wxString emptyString; wxString emptyString;
GRResetPenAndBrush( ( wxDC* ) &memDC ); GRResetPenAndBrush( ( wxDC* ) &memDC );
m_Parent->TraceWorkSheet( (wxDC*) &memDC, dummySize, pointLeftTop, pointRightBottom, m_Parent->TraceWorkSheet( (wxDC*) &memDC, dummySize, pointLeftTop, pointRightBottom,
emptyString, emptyString, m_tb, m_Screen->m_NumberOfScreens, paperType, emptyString, m_tb, m_Screen->m_NumberOfScreens,
m_Screen->m_ScreenNumber, 1, appScale, LIGHTGRAY, RED ); m_Screen->m_ScreenNumber, 1, appScale, LIGHTGRAY, RED );
memDC.SelectObject( wxNullBitmap ); memDC.SelectObject( wxNullBitmap );
......
...@@ -122,6 +122,10 @@ int NegableTextLength( const wxString& aText ) ...@@ -122,6 +122,10 @@ int NegableTextLength( const wxString& aText )
{ {
if( aText[i] == '~' ) if( aText[i] == '~' )
{ {
/* '~~' draw as '~' and count as two chars */
if( i > 0 && aText[i - 1] == '~' )
i--;
else
char_count--; char_count--;
} }
} }
...@@ -160,8 +164,12 @@ int ReturnGraphicTextWidth( const wxString& aText, int aXSize, bool aItalic, boo ...@@ -160,8 +164,12 @@ int ReturnGraphicTextWidth( const wxString& aText, int aXSize, bool aItalic, boo
{ {
int AsciiCode = aText[i]; int AsciiCode = aText[i];
if( AsciiCode == '~' ) /* Skip the negation marks */ /* Skip the negation marks
* and first '~' char of '~~'
* ('~~' draw as '~') */
if( AsciiCode == '~' )
{ {
if( i > 0 && aText[i - 1] != '~' )
continue; continue;
} }
...@@ -406,11 +414,17 @@ void DrawGraphicText( EDA_DRAW_PANEL* aPanel, ...@@ -406,11 +414,17 @@ void DrawGraphicText( EDA_DRAW_PANEL* aPanel,
overbar_italic_comp = 0; overbar_italic_comp = 0;
}; };
int overbars = 0; // Number of ~ seen int overbars = 0; /* Number of '~' seen (except '~~') */
ptr = 0; /* ptr = text index */ ptr = 0; /* ptr = text index */
while( ptr < char_count ) while( ptr < char_count )
{ {
if( aText[ptr + overbars] == '~' ) if( aText[ptr + overbars] == '~' )
{
if( ptr + overbars + 1 < aText.length() &&
aText[ptr + overbars + 1] == '~' ) /* '~~' draw as '~' */
ptr++; // skip first '~' char and draw second
else
{ {
/* Found an overbar, adjust the pointers */ /* Found an overbar, adjust the pointers */
overbars++; overbars++;
...@@ -438,6 +452,7 @@ void DrawGraphicText( EDA_DRAW_PANEL* aPanel, ...@@ -438,6 +452,7 @@ void DrawGraphicText( EDA_DRAW_PANEL* aPanel,
} }
continue; /* Skip ~ processing */ continue; /* Skip ~ processing */
} }
}
AsciiCode = aText.GetChar( ptr + overbars ); AsciiCode = aText.GetChar( ptr + overbars );
......
...@@ -123,7 +123,7 @@ const char* const newstroke_font[] = ...@@ -123,7 +123,7 @@ const char* const newstroke_font[] =
"KYVcUcSbR`RVQTOSQRRPRFSDUCVC", "KYVcUcSbR`RVQTOSQRRPRFSDUCVC",
"H\\RbRD", "H\\RbRD",
"KYNcOcQbR`RVSTUSSRRPRFQDOCNC", "KYNcOcQbR`RVSTUSSRRPRFQDOCNC",
"KZMHNGPFTHVGWF", "KZMSNRPQTSVRWQ",
"F^K[KFYFY[K[", "F^K[KFYFY[K[",
/* // LATIN-1 SUPPLEMENT (0080-00FF) */ /* // LATIN-1 SUPPLEMENT (0080-00FF) */
"F^K[KFYFY[K[", /* U+80 */ "F^K[KFYFY[K[", /* U+80 */
......
...@@ -20,988 +20,1029 @@ ...@@ -20,988 +20,1029 @@
// Must be defined in main applications: // Must be defined in main applications:
Ki_WorkSheetData WS_Date =
{
WS_DATE,
&WS_Licence,
BLOCK_DATE_X, BLOCK_DATE_Y,
0, 0,
#if defined(KICAD_GOST) #if defined(KICAD_GOST)
NULL, NULL
#else
wxT( "Date: " ),NULL
#endif
};
Ki_WorkSheetData WS_Licence = // Center - right bottom corner
Ki_WorkSheetData WS_Osn1_Line1 =
{ {
WS_KICAD_VERSION, WS_OSN,
&WS_Revision, &WS_Osn1_Line2,
BLOCK_KICAD_VERSION_X,BLOCK_KICAD_VERSION_Y, Mm2mils( 185 ), Mm2mils( 55 ),
0, 0, 0, Mm2mils( 55 ),
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Revision = Ki_WorkSheetData WS_Osn1_Line2 =
{ {
WS_REV, WS_OSN,
&WS_SizeSheet, &WS_Osn1_Line3,
#if defined(KICAD_GOST) Mm2mils( 120 ), Mm2mils( 40 ),
STAMP_X_185 - 30,STAMP_Y_30 + 90, 0, Mm2mils( 40 ),
#else
BLOCK_REV_X, BLOCK_REV_Y,
#endif
0, 0,
#if defined(KICAD_GOST)
NULL, NULL NULL, NULL
#else
wxT( "Rev: " ), NULL
#endif
}; };
Ki_WorkSheetData WS_SizeSheet = Ki_WorkSheetData WS_Osn1_Line3 =
{ {
WS_SIZESHEET, WS_OSN,
#if defined(KICAD_GOST) &WS_Osn1_Line4,
&WS_Title, Mm2mils( 185 ), Mm2mils( 35 ),
BLOCK_SIZE_SHEET_X,BLOCK_SIZE_SHEET_Y, Mm2mils( 120 ), Mm2mils( 35 ),
0, 0,
NULL, NULL NULL, NULL
}; };
#else
&WS_IdentSheet,
BLOCK_SIZE_SHEET_X, BLOCK_SIZE_SHEET_Y,
0, 0,
wxT( "Size: " ), NULL
};
Ki_WorkSheetData WS_IdentSheet = Ki_WorkSheetData WS_Osn1_Line4 =
{ {
WS_IDENTSHEET, WS_OSN,
&WS_Title, &WS_Osn1_Line5,
BLOCK_ID_SHEET_X,BLOCK_ID_SHEET_Y, Mm2mils( 50 ), Mm2mils( 35 ),
0, 0, 0, Mm2mils( 35 ),
wxT( "Id: " ), NULL NULL, NULL
}; };
#endif
Ki_WorkSheetData WS_Title = Ki_WorkSheetData WS_Osn1_Line5 =
{ {
WS_TITLE, WS_OSN,
&WS_SheetFilename, &WS_Osn1_Line6,
#if defined(KICAD_GOST) Mm2mils( 185 ), Mm2mils( 30 ),
STAMP_X_85, STAMP_Y_25 + 90, Mm2mils( 120 ), Mm2mils( 30 ),
0, 0,
NULL, NULL NULL, NULL
#else
BLOCK_TITLE_X, BLOCK_TITLE_Y,
0, 0,
wxT( "Title: " ), NULL
#endif
}; };
Ki_WorkSheetData WS_SheetFilename = Ki_WorkSheetData WS_Osn1_Line6 =
{ {
WS_FILENAME, WS_OSN,
&WS_FullSheetName, &WS_Osn1_Line7,
BLOCK_FILENAME_X, BLOCK_FILENAME_Y, Mm2mils( 50 ), Mm2mils( 20 ),
0, 0, 0, Mm2mils( 20 ),
wxT( "File: " ), NULL NULL, NULL
}; };
Ki_WorkSheetData WS_FullSheetName = Ki_WorkSheetData WS_Osn1_Line7 =
{ {
WS_FULLSHEETNAME, WS_OSN,
&WS_Company, &WS_Osn1_Line8,
BLOCK_FULLSHEETNAME_X,BLOCK_FULLSHEETNAME_Y, Mm2mils( 120 ), Mm2mils( 15 ),
0, 0, 0, Mm2mils( 15 ),
wxT( "Sheet: " ), NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Company = Ki_WorkSheetData WS_Osn1_Line8 =
{ {
WS_COMPANY_NAME, WS_OSN,
&WS_Comment1, &WS_Osn1_Line9,
#if defined(KICAD_GOST) Mm2mils( 185 ), Mm2mils( 55 ),
STAMP_X_50 / 2, STAMP_Y_0 + 270, Mm2mils( 185 ), 0,
0, 0,
#else
BLOCK_COMMENT_X,BLOCK_COMPANY_Y,
0, 0,
#endif
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Comment1 = Ki_WorkSheetData WS_Osn1_Line9 =
{ {
WS_COMMENT1, WS_OSN,
&WS_Comment2, &WS_Osn1_Line10,
#if defined(KICAD_GOST) Mm2mils( 178 ), Mm2mils( 55 ),
STAMP_X_120 / 2,STAMP_Y_40 + 270, Mm2mils( 178 ), Mm2mils( 30 ),
STAMP_OX, 0,
#else
BLOCK_COMMENT_X,BLOCK_COMMENT1_Y,
0, 0,
#endif
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Comment2 = Ki_WorkSheetData WS_Osn1_Line10 =
{ {
WS_COMMENT2, WS_OSN,
&WS_Comment3, &WS_Osn1_Line11,
#if defined(KICAD_GOST) Mm2mils( 168 ), Mm2mils( 55 ),
STAMP_X_168 - 30, STAMP_Y_25 + 90, Mm2mils( 168 ), 0,
STAMP_OX, 0,
#else
BLOCK_COMMENT_X,BLOCK_COMMENT2_Y,
0, 0,
#endif
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Comment3 = Ki_WorkSheetData WS_Osn1_Line11 =
{ {
WS_COMMENT3, WS_OSN,
&WS_Comment4, &WS_Osn1_Line12,
#if defined(KICAD_GOST) Mm2mils( 145 ), Mm2mils( 55 ),
STAMP_X_168 - 30, STAMP_Y_20 + 90, Mm2mils( 145 ), 0,
STAMP_OX, 0,
#else
BLOCK_COMMENT_X,BLOCK_COMMENT3_Y,
0, 0,
#endif
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Comment4 = Ki_WorkSheetData WS_Osn1_Line12 =
{ {
WS_COMMENT4, WS_OSN,
&WS_MostLeftLine, &WS_Osn1_Line13,
#if defined(KICAD_GOST) Mm2mils( 130 ), Mm2mils( 55 ),
STAMP_X_168 - 30, STAMP_Y_0 + 90, Mm2mils( 130 ), 0,
STAMP_OX, 0,
#else
BLOCK_COMMENT_X, BLOCK_COMMENT4_Y,
0, 0,
#endif
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Osn1_Line13 =
/// Left vertical segment
Ki_WorkSheetData WS_MostLeftLine =
{ {
WS_LEFT_SEGMENT, WS_OSN,
#if defined(KICAD_GOST) &WS_Osn1_Line14,
&WS_MostUpperLine, Mm2mils( 120 ), Mm2mils( 55 ),
STAMP_OX, STAMP_OY, Mm2mils( 120 ), 0,
STAMP_OX, 0,
#else
&WS_SeparatorLine,
BLOCK_OX, SIZETEXT * 16,
BLOCK_OX, 0,
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Osn1_Line14 =
/// horizontal segment between filename and comments
Ki_WorkSheetData WS_SeparatorLine =
{ {
WS_SEGMENT, WS_OSN,
&WS_MostUpperLine, &WS_Osn1_Line15,
BLOCK_OX, VARIABLE_BLOCK_START_POSITION, Mm2mils( 50 ), Mm2mils( 40 ),
0, VARIABLE_BLOCK_START_POSITION, Mm2mils( 50 ), 0,
#endif
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Osn1_Line15 =
/// superior horizontal segment
Ki_WorkSheetData WS_MostUpperLine =
{ {
WS_UPPER_SEGMENT, WS_OSN,
&WS_Segm3, &WS_Osn1_Line16,
#if defined(KICAD_GOST) Mm2mils( 35 ), Mm2mils( 40 ),
STAMP_OX, STAMP_OY, Mm2mils( 35 ), Mm2mils( 20 ),
0, STAMP_OY,
#else
BLOCK_OX, SIZETEXT * 16,
0, SIZETEXT * 16,
#endif
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Osn1_Line16 =
/// horizontal segment above COMPANY NAME
Ki_WorkSheetData WS_Segm3 =
{ {
WS_SEGMENT, WS_OSN,
&WS_Segm4, &WS_Osn1_Line17,
#if defined(KICAD_GOST) Mm2mils( 30 ), Mm2mils( 20 ),
STAMP_OX, STAMP_Y_50, Mm2mils( 30 ), Mm2mils( 15 ),
STAMP_X_120,STAMP_Y_50,
#else
BLOCK_OX, SIZETEXT * 6,
0, SIZETEXT * 6,
#endif
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Osn1_Line17 =
/// vertical segment of the left REV and SHEET
Ki_WorkSheetData WS_Segm4 =
{ {
WS_SEGMENT, WS_OSN,
&WS_Segm5, &WS_Osn1_Line18,
#if defined(KICAD_GOST) Mm2mils( 18 ), Mm2mils( 40 ),
STAMP_OX, STAMP_Y_45, Mm2mils( 18 ), Mm2mils( 20 ),
STAMP_X_120, STAMP_Y_45,
#else
BLOCK_REV_X + SIZETEXT,SIZETEXT * 4,
BLOCK_REV_X + SIZETEXT,0,
#endif
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Osn1_Line18 =
Ki_WorkSheetData WS_Segm5 =
{ {
WS_SEGMENT, WS_TONK,
&WS_Segm6, &WS_Osn1_Line19,
#if defined(KICAD_GOST) Mm2mils( 185 ), Mm2mils( 50 ),
STAMP_OX, STAMP_Y_40, Mm2mils( 120 ), Mm2mils( 50 ),
0, STAMP_Y_40,
#else
BLOCK_OX, SIZETEXT * 2,
0, SIZETEXT * 2,
#endif
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Osn1_Line19 =
Ki_WorkSheetData WS_Segm6 =
{ {
WS_SEGMENT, WS_TONK,
&WS_Segm7, &WS_Osn1_Line20,
#if defined(KICAD_GOST) Mm2mils( 185 ), Mm2mils( 45 ),
STAMP_OX, STAMP_Y_35, Mm2mils( 120 ), Mm2mils( 45 ),
STAMP_X_120,STAMP_Y_35,
#else
BLOCK_OX, SIZETEXT * 4,
0, SIZETEXT * 4,
#endif
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Osn1_Line20 =
Ki_WorkSheetData WS_Segm7 =
{ {
WS_SEGMENT, WS_TONK,
#if defined(KICAD_GOST) &WS_Osn1_Line21,
&WS_Segm8, Mm2mils( 185 ), Mm2mils( 40 ),
STAMP_X_50,STAMP_Y_35, Mm2mils( 120 ), Mm2mils( 40 ),
0, STAMP_Y_35,
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Segm8 = Ki_WorkSheetData WS_Osn1_Line21 =
{ {
WS_SEGMENT, WS_TONK,
&WS_Segm9, &WS_Osn1_Line22,
STAMP_OX, STAMP_Y_30, Mm2mils( 185 ), Mm2mils( 25 ),
STAMP_X_120,STAMP_Y_30, Mm2mils( 120 ), Mm2mils( 25 ),
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Segm9 = Ki_WorkSheetData WS_Osn1_Line22 =
{ {
WS_SEGMENT, WS_TONK,
&WS_Segm10, &WS_Osn1_Line23,
STAMP_OX, STAMP_Y_25, Mm2mils( 185 ), Mm2mils( 20 ),
STAMP_X_120,STAMP_Y_25, Mm2mils( 120 ), Mm2mils( 20 ),
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Segm10 = Ki_WorkSheetData WS_Osn1_Line23 =
{ {
WS_SEGMENT, WS_TONK,
&WS_Segm11, &WS_Osn1_Line24,
STAMP_OX, STAMP_Y_20, Mm2mils( 185 ), Mm2mils( 15 ),
STAMP_X_120,STAMP_Y_20, Mm2mils( 120 ), Mm2mils( 15 ),
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Segm11 = Ki_WorkSheetData WS_Osn1_Line24 =
{ {
WS_SEGMENT, WS_TONK,
&WS_Segm12, &WS_Osn1_Line25,
STAMP_X_50,STAMP_Y_20, Mm2mils( 185 ), Mm2mils( 10 ),
0, STAMP_Y_20, Mm2mils( 120 ), Mm2mils( 10 ),
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Segm12 = Ki_WorkSheetData WS_Osn1_Line25 =
{ {
WS_SEGMENT, WS_TONK,
&WS_Segm13, &WS_Osn1_Line26,
STAMP_OX, STAMP_Y_15, Mm2mils( 185 ), Mm2mils( 5 ),
0, STAMP_Y_15, Mm2mils( 120 ), Mm2mils( 5 ),
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Segm13 = Ki_WorkSheetData WS_Osn1_Line26 =
{ {
WS_SEGMENT, WS_TONK,
&WS_Segm14, &WS_Osn1_Line27,
STAMP_OX, STAMP_Y_10, Mm2mils( 45 ), Mm2mils( 35 ),
STAMP_X_120,STAMP_Y_10, Mm2mils( 45 ), Mm2mils( 20 ),
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Segm14 = Ki_WorkSheetData WS_Osn1_Line27 =
{ {
WS_SEGMENT, WS_TONK,
&WS_Segm15, &WS_Osn1_Text1,
STAMP_OX, STAMP_Y_5, Mm2mils( 40 ), Mm2mils( 35 ),
STAMP_X_120,STAMP_Y_5, Mm2mils( 40 ), Mm2mils( 20 ),
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Segm15 = Ki_WorkSheetData WS_Osn1_Text1 =
{ {
WS_SEGMENT, WS_TEXT,
&WS_Segm16, &WS_Osn1_Text2,
STAMP_X_178,STAMP_OY, Mm2mils( 181.5 ), Mm2mils( 32.5 ),
STAMP_X_178,STAMP_Y_30, 0, 0,
NULL, NULL wxT( "Изм." ), NULL
}; };
Ki_WorkSheetData WS_Segm16 = Ki_WorkSheetData WS_Osn1_Text2 =
{ {
WS_SEGMENT, WS_TEXTL,
&WS_Segm17, &WS_Osn1_Text3,
STAMP_X_168,STAMP_OY, Mm2mils( 184 ), Mm2mils( 27.5 ),
STAMP_X_168,0, 0, 0,
NULL, NULL wxT( "Разраб." ), NULL
}; };
Ki_WorkSheetData WS_Segm17 = Ki_WorkSheetData WS_Osn1_Text3 =
{ {
WS_SEGMENT, WS_TEXTL,
&WS_Segm18, &WS_Osn1_Text4,
STAMP_X_145,STAMP_OY, Mm2mils( 184 ), Mm2mils( 22.5 ),
STAMP_X_145,0, 0, 0,
NULL, NULL wxT( "Пров." ), NULL
}; };
Ki_WorkSheetData WS_Segm18 = Ki_WorkSheetData WS_Osn1_Text4 =
{ {
WS_SEGMENT, WS_TEXTL,
&WS_Segm19, &WS_Osn1_Text5,
STAMP_X_130,STAMP_OY, Mm2mils( 184 ), Mm2mils( 17.5 ),
STAMP_X_130,0, 0, 0,
NULL, NULL wxT( "Т.контр." ), NULL
}; };
Ki_WorkSheetData WS_Segm19 = Ki_WorkSheetData WS_Osn1_Text5 =
{ {
WS_SEGMENT, WS_TEXTL,
&WS_Segm20, &WS_Osn1_Text6,
STAMP_X_120,STAMP_OY, Mm2mils( 184 ), Mm2mils( 7.5 ),
STAMP_X_120,0, 0, 0,
NULL, NULL wxT( "Н.контр." ), NULL
}; };
Ki_WorkSheetData WS_Segm20 = Ki_WorkSheetData WS_Osn1_Text6 =
{ {
WS_SEGMENT, WS_TEXTL,
&WS_Segm21, &WS_Osn1_Text7,
STAMP_X_50,STAMP_Y_40, Mm2mils( 184 ), Mm2mils( 2.5 ),
STAMP_X_50,0, 0, 0,
NULL, NULL wxT( "Утв." ), NULL
}; };
Ki_WorkSheetData WS_Segm21 = Ki_WorkSheetData WS_Osn1_Text7 =
{ {
WS_SEGMENT, WS_TEXT,
&WS_Segm22, &WS_Osn1_Text8,
STAMP_X_45,STAMP_Y_35, Mm2mils( 173 ), Mm2mils( 32.5 ),
STAMP_X_45,STAMP_Y_20, 0, 0,
NULL, NULL wxT( "Лист" ), NULL
}; };
Ki_WorkSheetData WS_Segm22 = Ki_WorkSheetData WS_Osn1_Text8 =
{ {
WS_SEGMENT, WS_TEXT,
&WS_Segm23, &WS_Osn1_Text9,
STAMP_X_40,STAMP_Y_35, Mm2mils( 156.5 ), Mm2mils( 32.5 ),
STAMP_X_40,STAMP_Y_20, 0, 0,
NULL, NULL wxT( "N докум." ), NULL
}; };
Ki_WorkSheetData WS_Segm23 = Ki_WorkSheetData WS_Osn1_Text9 =
{ {
WS_SEGMENT, WS_TEXT,
&WS_Segm24, &WS_Osn1_Text10,
STAMP_X_35,STAMP_Y_40, Mm2mils( 137.5 ), Mm2mils( 32.5 ),
STAMP_X_35,STAMP_Y_20, 0, 0,
NULL, NULL wxT( "Подп." ), NULL
}; };
Ki_WorkSheetData WS_Segm24 = Ki_WorkSheetData WS_Osn1_Text10 =
{ {
WS_SEGMENT, WS_TEXT,
&WS_Segm25, &WS_Osn1_Text11,
STAMP_X_30,STAMP_Y_20, Mm2mils( 125 ), Mm2mils( 32.5 ),
STAMP_X_30,STAMP_Y_15, 0, 0,
NULL, NULL wxT( "Дата" ), NULL
}; };
Ki_WorkSheetData WS_Segm25 = Ki_WorkSheetData WS_Osn1_Text11 =
{ {
WS_SEGMENT, WS_TEXT,
&WS_Izm, &WS_Osn1_Text12,
STAMP_X_18,STAMP_Y_40, Mm2mils( 42.5 ), Mm2mils( 37.5 ),
STAMP_X_18,STAMP_Y_20, 0, 0,
NULL, NULL wxT( "Лит." ), NULL
}; };
Ki_WorkSheetData WS_Izm = Ki_WorkSheetData WS_Osn1_Text12 =
{ {
WS_PODPIS, WS_TEXT,
&WS_Razr, &WS_Osn1_Text13,
STAMP_X_185 - 30,STAMP_Y_30 + 90, Mm2mils( 26.5 ), Mm2mils( 37.5 ),
0, 0, 0, 0,
wxT( "Изм." ),NULL wxT( "Масса" ), NULL
}; };
Ki_WorkSheetData WS_Razr = Ki_WorkSheetData WS_Osn1_Text13 =
{ {
WS_PODPIS, WS_TEXT,
&WS_Prov, &WS_Osn1_Text14,
STAMP_X_185 - 30, STAMP_Y_25 + 90, Mm2mils( 9 ), Mm2mils( 37.5 ),
0, 0, 0, 0,
wxT( "Разраб." ),NULL wxT( "Масштаб" ), NULL
}; };
Ki_WorkSheetData WS_Prov = Ki_WorkSheetData WS_Osn1_Text14 =
{ {
WS_PODPIS, WS_TEXTL,
&WS_TKon, &WS_Osn1_Text15,
STAMP_X_185 - 30, STAMP_Y_20 + 90, Mm2mils( 49 ), Mm2mils( 17.5 ),
0, 0, 0, 0,
wxT( "Пров." ),NULL wxT( "Лист" ), NULL
}; };
Ki_WorkSheetData WS_TKon = Ki_WorkSheetData WS_Osn1_Text15 =
{ {
WS_PODPIS, WS_TEXTL,
&WS_NKon, &WS_Osn1_Text16,
STAMP_X_185 - 30, STAMP_Y_15 + 90, Mm2mils( 29 ), Mm2mils( 17.5 ),
0, 0, 0, 0,
wxT( "Т.контр." ),NULL wxT( "Листов" ), NULL
}; };
Ki_WorkSheetData WS_NKon = Ki_WorkSheetData WS_Osn1_Text16 =
{ {
WS_PODPIS, WS_TEXTL,
&WS_Utv, &WS_Osn1_Text17,
STAMP_X_185 - 30, STAMP_Y_5 + 90, Mm2mils( 40 ), -Mm2mils( 2.5 ),
0, 0, 0, 0,
wxT( "Н.контр." ),NULL wxT( "Формат" ), NULL
}; };
Ki_WorkSheetData WS_Utv = Ki_WorkSheetData WS_Osn1_Text17 =
{ {
WS_PODPIS, WS_TEXTL,
&WS_List, NULL,
STAMP_X_185 - 30,STAMP_Y_0 + 90, Mm2mils( 110 ), -Mm2mils( 2.5 ),
0, 0, 0, 0,
wxT( "Утв." ),NULL wxT( "Копировал" ), NULL
}; };
Ki_WorkSheetData WS_List = Ki_WorkSheetData WS_Osn2a_Line1 =
{ {
WS_PODPIS, WS_OSN,
&WS_NDoc, &WS_Osn2a_Line2,
STAMP_X_178 - 30, STAMP_Y_30 + 90, Mm2mils( 185 ), Mm2mils( 15 ),
0, 0, 0, Mm2mils( 15 ),
wxT( "Лист" ),NULL NULL, NULL
}; };
Ki_WorkSheetData WS_NDoc = Ki_WorkSheetData WS_Osn2a_Line2 =
{ {
WS_PODPIS, WS_OSN,
&WS_Podp, &WS_Osn2a_Line3,
STAMP_X_168 - 30, STAMP_Y_30 + 90, Mm2mils( 185 ), Mm2mils( 5 ),
0, 0, Mm2mils( 120 ), Mm2mils( 5 ),
wxT( "N докум." ),NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Podp = Ki_WorkSheetData WS_Osn2a_Line3 =
{ {
WS_PODPIS, WS_OSN,
&WS_Data, &WS_Osn2a_Line4,
STAMP_X_145 - 30, STAMP_Y_30 + 90, Mm2mils( 10 ), Mm2mils( 8 ),
0, 0, 0, Mm2mils( 8 ),
wxT( "Подп." ),NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Data = Ki_WorkSheetData WS_Osn2a_Line4 =
{ {
WS_PODPIS, WS_OSN,
&WS_Art, &WS_Osn2a_Line5,
STAMP_X_130 - 30, STAMP_Y_30 + 90, Mm2mils( 185 ), Mm2mils( 15 ),
0, 0, Mm2mils( 185 ), 0,
wxT( "Дата" ),NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Art = Ki_WorkSheetData WS_Osn2a_Line5 =
{ {
WS_PODPIS, WS_OSN,
&WS_Mass, &WS_Osn2a_Line6,
STAMP_X_50 - 30, STAMP_Y_35 + 90, Mm2mils( 178 ), Mm2mils( 15 ),
0, 0, Mm2mils( 178 ), 0,
wxT( "Лит." ),NULL NULL, NULL
};
Ki_WorkSheetData WS_Osn2a_Line6 =
{
WS_OSN,
&WS_Osn2a_Line7,
Mm2mils( 168 ), Mm2mils( 15 ),
Mm2mils( 168 ), 0,
NULL, NULL
};
Ki_WorkSheetData WS_Osn2a_Line7 =
{
WS_OSN,
&WS_Osn2a_Line8,
Mm2mils( 145 ), Mm2mils( 15 ),
Mm2mils( 145 ), 0,
NULL, NULL
};
Ki_WorkSheetData WS_Osn2a_Line8 =
{
WS_OSN,
&WS_Osn2a_Line9,
Mm2mils( 130 ), Mm2mils( 15 ),
Mm2mils( 130 ), 0,
NULL, NULL
};
Ki_WorkSheetData WS_Osn2a_Line9 =
{
WS_OSN,
&WS_Osn2a_Line10,
Mm2mils( 120 ), Mm2mils( 15 ),
Mm2mils( 120 ), 0,
NULL, NULL
}; };
Ki_WorkSheetData WS_Mass = Ki_WorkSheetData WS_Osn2a_Line10 =
{ {
WS_PODPIS, WS_OSN,
&WS_Msht, &WS_Osn2a_Line11,
STAMP_X_35 - 30, STAMP_Y_35 + 90, Mm2mils( 10 ), Mm2mils( 15 ),
Mm2mils( 10 ), 0,
NULL, NULL
};
Ki_WorkSheetData WS_Osn2a_Line11 =
{
WS_TONK,
&WS_Osn2a_Text1,
Mm2mils( 185 ), Mm2mils( 10 ),
Mm2mils( 120 ), Mm2mils( 10 ),
NULL, NULL
};
Ki_WorkSheetData WS_Osn2a_Text1 =
{
WS_TEXT,
&WS_Osn2a_Text2,
Mm2mils( 181.5 ), Mm2mils( 2.5 ),
0, 0, 0, 0,
wxT( "Масса" ),NULL wxT( "Изм." ), NULL
}; };
Ki_WorkSheetData WS_Msht = Ki_WorkSheetData WS_Osn2a_Text2 =
{ {
WS_PODPIS, WS_TEXT,
&WS_List1, &WS_Osn2a_Text3,
STAMP_X_18 - 30, STAMP_Y_35 + 90, Mm2mils( 173 ), Mm2mils( 2.5 ),
0, 0, 0, 0,
wxT( "Масштаб" ),NULL wxT( "Лист" ), NULL
}; };
Ki_WorkSheetData WS_List1 = Ki_WorkSheetData WS_Osn2a_Text3 =
{ {
WS_IDENTSHEET, WS_TEXT,
&WS_List2, &WS_Osn2a_Text4,
STAMP_X_50 - 30, STAMP_Y_15 + 90, Mm2mils( 156.5 ), Mm2mils( 2.5 ),
0, 0, 0, 0,
wxT( "Лист " ),NULL wxT( "N докум." ), NULL
}; };
Ki_WorkSheetData WS_List2 = Ki_WorkSheetData WS_Osn2a_Text4 =
{ {
WS_SHEETS, WS_TEXT,
NULL, &WS_Osn2a_Text5,
STAMP_X_30 - 30, STAMP_Y_15 + 90, Mm2mils( 137.5 ), Mm2mils( 2.5 ),
0, 0, 0, 0,
wxT( "Листов " ),NULL wxT( "Подп." ), NULL
}; };
Ki_WorkSheetData WS_CADRE_D = Ki_WorkSheetData WS_Osn2a_Text5 =
{ {
WS_CADRE, WS_TEXT,
&WS_Segm1_D, &WS_Osn2a_Text6,
STAMP_X_65, STAMP_Y_0 + 270, Mm2mils( 125 ), Mm2mils( 2.5 ),
0, 0, 0, 0,
NULL, NULL wxT( "Дата" ), NULL
}; };
Ki_WorkSheetData WS_Segm1_D = Ki_WorkSheetData WS_Osn2a_Text6 =
{ {
WS_LEFT_SEGMENT_D, WS_TEXT,
&WS_Segm2_D, &WS_Osn2a_Text7,
STAMP_OX, STAMP_Y_15, Mm2mils( 5 ), Mm2mils( 11.5 ),
STAMP_OX, 0, 0, 0,
NULL, NULL wxT( "Лист" ), NULL
}; };
Ki_WorkSheetData WS_Segm2_D = Ki_WorkSheetData WS_Osn2a_Text7 =
{ {
WS_SEGMENT_D, WS_TEXTL,
&WS_Segm3_D, &WS_Osn2a_Text8,
STAMP_X_178, STAMP_Y_15, Mm2mils( 40 ), -Mm2mils( 2.5 ),
STAMP_X_178, 0, 0, 0,
NULL, NULL wxT( "Формат" ), NULL
}; };
Ki_WorkSheetData WS_Segm3_D = Ki_WorkSheetData WS_Osn2a_Text8 =
{ {
WS_SEGMENT_D, WS_TEXTL,
&WS_Segm4_D, NULL,
STAMP_X_168, STAMP_Y_15, Mm2mils( 110 ), -Mm2mils( 2.5 ),
STAMP_X_168, 0, 0, 0,
NULL, NULL wxT( "Копировал" ), NULL
}; };
Ki_WorkSheetData WS_Segm4_D = // Center - left bottom corner
Ki_WorkSheetData WS_DopLeft_Line1 =
{ {
WS_SEGMENT_D, WS_OSN,
&WS_Segm5_D, &WS_DopLeft_Line2,
STAMP_X_145, STAMP_Y_15, Mm2mils( 12 ), Mm2mils( 145 ),
STAMP_X_145, 0, 0, Mm2mils( 145 ),
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Segm5_D = Ki_WorkSheetData WS_DopLeft_Line2 =
{ {
WS_SEGMENT_D, WS_OSN,
&WS_Segm6_D, &WS_DopLeft_Line3,
STAMP_X_130, STAMP_Y_15, Mm2mils( 12 ), Mm2mils( 110 ),
STAMP_X_130, 0, 0, Mm2mils( 110 ),
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Segm6_D = Ki_WorkSheetData WS_DopLeft_Line3 =
{ {
WS_SEGMENT_D, WS_OSN,
&WS_Segm7_D, &WS_DopLeft_Line4,
STAMP_X_120, STAMP_Y_15, Mm2mils( 12 ), Mm2mils( 85 ),
STAMP_X_120, 0, 0, Mm2mils( 85 ),
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Segm7_D = Ki_WorkSheetData WS_DopLeft_Line4 =
{ {
WS_SEGMENT_D, WS_OSN,
&WS_Segm8_D, &WS_DopLeft_Line5,
STAMP_X_10, STAMP_Y_15, Mm2mils( 12 ), Mm2mils( 60 ),
STAMP_X_10, 0, 0, Mm2mils( 60 ),
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Segm8_D = Ki_WorkSheetData WS_DopLeft_Line5 =
{ {
WS_SEGMENT_D, WS_OSN,
&WS_Segm9_D, &WS_DopLeft_Line6,
STAMP_X_185, STAMP_Y_10, Mm2mils( 12 ), Mm2mils( 25 ),
STAMP_X_120, STAMP_Y_10, 0, Mm2mils( 25 ),
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Segm9_D = Ki_WorkSheetData WS_DopLeft_Line6 =
{ {
WS_SEGMENT_D, WS_OSN,
&WS_Segm10_D, &WS_DopLeft_Line7,
STAMP_X_185, STAMP_Y_5, Mm2mils( 12 ), 0,
STAMP_X_120, STAMP_Y_5, 0, 0,
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Segm10_D = Ki_WorkSheetData WS_DopLeft_Line7 =
{ {
WS_SEGMENT_D, WS_OSN,
&WS_Segm11_D, &WS_DopLeft_Line8,
STAMP_X_10, STAMP_Y_8, Mm2mils( 12 ), Mm2mils( 145 ),
0, STAMP_Y_8, Mm2mils( 12 ), 0,
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Segm11_D = Ki_WorkSheetData WS_DopLeft_Line8 =
{ {
WS_SEGMENT_D, WS_OSN,
&WS_Izm_D, &WS_DopLeft_Text1,
STAMP_X_185, STAMP_Y_15, Mm2mils( 7 ), Mm2mils( 145 ),
0, STAMP_Y_15, Mm2mils( 7 ), 0,
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Izm_D = Ki_WorkSheetData WS_DopLeft_Text1 =
{ {
WS_PODPIS_D, WS_TEXT,
&WS_List_D, &WS_DopLeft_Text2,
STAMP_X_185 - 30,STAMP_Y_0 + 90, Mm2mils( 9.5 ), Mm2mils( 12.5 ),
0, 0, 0, 0,
wxT( зм." ),NULL wxT( нв.N подл." ), NULL
}; };
Ki_WorkSheetData WS_List_D = Ki_WorkSheetData WS_DopLeft_Text2 =
{ {
WS_PODPIS_D, WS_TEXT,
&WS_NDoc_D, &WS_DopLeft_Text3,
STAMP_X_178 - 30, STAMP_Y_0 + 90, Mm2mils( 9.5 ), Mm2mils( 42.5 ),
0, 0, 0, 0,
wxT( "Лист" ),NULL wxT( "Подп. и дата" ), NULL
}; };
Ki_WorkSheetData WS_NDoc_D = Ki_WorkSheetData WS_DopLeft_Text3 =
{ {
WS_PODPIS_D, WS_TEXT,
&WS_Podp_D, &WS_DopLeft_Text4,
STAMP_X_168 - 30, STAMP_Y_0 + 90, Mm2mils( 9.5 ), Mm2mils( 72.5 ),
0, 0, 0, 0,
wxT( "N докум." ),NULL wxT( "Взам.инв.N" ), NULL
}; };
Ki_WorkSheetData WS_Podp_D = Ki_WorkSheetData WS_DopLeft_Text4 =
{ {
WS_PODPIS_D, WS_TEXT,
&WS_Date_D, &WS_DopLeft_Text5,
STAMP_X_145 - 30, STAMP_Y_0 + 90, Mm2mils( 9.5 ), Mm2mils( 97.5 ),
0, 0, 0, 0,
wxT( "Подп." ),NULL wxT( "Инв.N дубл." ), NULL
}; };
Ki_WorkSheetData WS_Date_D = Ki_WorkSheetData WS_DopLeft_Text5 =
{ {
WS_PODPIS_D, WS_TEXT,
&WS_List1_D, &WS_DopLeft_Line9,
STAMP_X_130 - 30, STAMP_Y_0 + 90, Mm2mils( 9.5 ), Mm2mils( 127.5 ),
0, 0, 0, 0,
wxT( "Дата" ),NULL wxT( "Подп. и дата" ), NULL
}; };
Ki_WorkSheetData WS_List1_D = Ki_WorkSheetData WS_DopLeft_Line9 =
{ {
WS_PODPIS_D, WS_OSN,
&WS_ListN_D, &WS_DopLeft_Line10,
STAMP_X_10 - 30, STAMP_Y_8 + 90, Mm2mils( 7 ), Mm2mils( 287 ),
0, 0, Mm2mils( 7 ), Mm2mils( 167 ),
wxT( "Лист" ),NULL NULL, NULL
}; };
Ki_WorkSheetData WS_ListN_D = Ki_WorkSheetData WS_DopLeft_Line10 =
{ {
WS_IDENTSHEET_D, WS_OSN,
NULL, &WS_DopLeft_Line11,
STAMP_Y_0 + 196,STAMP_Y_0 + 90, Mm2mils( 12 ), Mm2mils( 287 ),
0, 0, Mm2mils( 12 ), Mm2mils( 167 ),
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Segm1_LU = Ki_WorkSheetData WS_DopLeft_Line11 =
{ {
WS_SEGMENT_LU, WS_OSN,
&WS_Segm2_LU, &WS_DopLeft_Line12,
STAMP_12, STAMP_145, Mm2mils( 12 ), Mm2mils( 287 ),
STAMP_12, 0, Mm2mils( 12 ), Mm2mils( 167 ),
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Segm2_LU = Ki_WorkSheetData WS_DopLeft_Line12 =
{ {
WS_SEGMENT_LU, WS_OSN,
&WS_Segm3_LU, &WS_DopLeft_Line13,
STAMP_7, STAMP_145, Mm2mils( 12 ), Mm2mils( 167 ),
STAMP_7, 0, 0, Mm2mils( 167 ),
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Segm3_LU = Ki_WorkSheetData WS_DopLeft_Line13 =
{ {
WS_SEGMENT_LU, WS_OSN,
&WS_Segm4_LU, &WS_DopLeft_Line14,
STAMP_12, STAMP_145, Mm2mils( 12 ), Mm2mils( 227 ),
0, STAMP_145, 0, Mm2mils( 227 ),
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Segm4_LU = Ki_WorkSheetData WS_DopLeft_Line14 =
{ {
WS_SEGMENT_LU, WS_OSN,
&WS_Segm5_LU, &WS_DopLeft_Text6,
STAMP_12, STAMP_110, Mm2mils( 12 ), Mm2mils( 287 ),
0, STAMP_110, 0, Mm2mils( 287 ),
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Segm5_LU = Ki_WorkSheetData WS_DopLeft_Text6 =
{ {
WS_SEGMENT_LU, WS_TEXT,
&WS_Segm6_LU, &WS_DopLeft_Text7,
STAMP_12, STAMP_85, Mm2mils( 9.5 ), Mm2mils( 197 ),
0, STAMP_85, 0, 0,
NULL, NULL wxT( "Справ. N" ), NULL
}; };
Ki_WorkSheetData WS_Segm6_LU = Ki_WorkSheetData WS_DopLeft_Text7 =
{ {
WS_SEGMENT_LU, WS_TEXT,
&WS_Segm7_LU, NULL,
STAMP_12, STAMP_60, Mm2mils( 9.5 ), Mm2mils( 257 ),
0, STAMP_60, 0, 0,
NULL, NULL wxT( "Перв. примен." ), NULL
}; };
Ki_WorkSheetData WS_Segm7_LU = // Center - left top corner
Ki_WorkSheetData WS_DopTop_Line1 =
{ {
WS_SEGMENT_LU, WS_OSN,
&WS_Segm8_LU, &WS_DopTop_Line2,
STAMP_12, STAMP_25, Mm2mils( 70 ), 0,
0, STAMP_25, Mm2mils( 70 ), Mm2mils( 14 ),
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Segm8_LU = Ki_WorkSheetData WS_DopTop_Line2 =
{ {
WS_SEGMENT_LU, WS_OSN,
&WS_Segm9_LU, &WS_DopTop_Line3,
STAMP_12, 0, Mm2mils( 70 ), Mm2mils( 14 ),
0, 0, 0, Mm2mils( 14 ),
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Segm9_LU = Ki_WorkSheetData WS_DopTop_Line3 =
{ {
WS_SEGMENT_LU, WS_OSN,
&WS_Segm10_LU, &WS_DopTop_Line4,
STAMP_12, STAMP_287, Mm2mils( 70 ), Mm2mils( 14 ),
STAMP_12, STAMP_167, Mm2mils( 137 ), Mm2mils( 14 ),
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Segm10_LU = Ki_WorkSheetData WS_DopTop_Line4 =
{ {
WS_SEGMENT_LU, WS_OSN,
&WS_Segm11_LU, &WS_DopTop_Line5,
STAMP_7, STAMP_287, Mm2mils( 84 ), Mm2mils( 7 ),
STAMP_7, STAMP_167, Mm2mils( 137 ), Mm2mils( 7 ),
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Segm11_LU = Ki_WorkSheetData WS_DopTop_Line5 =
{ {
WS_SEGMENT_LU, WS_OSN,
&WS_Segm12_LU, &WS_DopTop_Line6,
STAMP_12, STAMP_287, Mm2mils( 84 ), Mm2mils( 14 ),
0, STAMP_287, Mm2mils( 84 ), 0,
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Segm12_LU = Ki_WorkSheetData WS_DopTop_Line6 =
{ {
WS_SEGMENT_LU, WS_OSN,
&WS_Segm13_LU, NULL,
STAMP_12, STAMP_227, Mm2mils( 137 ), Mm2mils( 14 ),
0, STAMP_227, Mm2mils( 137 ), 0,
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Segm13_LU = #else
Ki_WorkSheetData WS_Date =
{ {
WS_SEGMENT_LU, WS_DATE,
&WS_Podp1_LU, &WS_Licence,
STAMP_12, STAMP_167, BLOCK_DATE_X, BLOCK_DATE_Y,
0, STAMP_167, 0, 0,
wxT( "Date: " ),NULL
};
Ki_WorkSheetData WS_Licence =
{
WS_KICAD_VERSION,
&WS_Revision,
BLOCK_KICAD_VERSION_X,BLOCK_KICAD_VERSION_Y,
0, 0,
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Podp1_LU = Ki_WorkSheetData WS_Revision =
{ {
WS_PODPIS_LU, WS_REV,
&WS_Podp2_LU, &WS_SizeSheet,
STAMP_7 + 90, 0 + 492, BLOCK_REV_X, BLOCK_REV_Y,
0, 0, 0, 0,
wxT( "Инв.N подл." ),NULL wxT( "Rev: " ), NULL
}; };
Ki_WorkSheetData WS_Podp2_LU = Ki_WorkSheetData WS_SizeSheet =
{ {
WS_PODPIS_LU, WS_SIZESHEET,
&WS_Podp3_LU, &WS_IdentSheet,
STAMP_7 + 90, STAMP_25 + 688, BLOCK_SIZE_SHEET_X, BLOCK_SIZE_SHEET_Y,
0, 0, 0, 0,
wxT( "Подп. и дата" ),NULL wxT( "Size: " ), NULL
}; };
Ki_WorkSheetData WS_Podp3_LU = Ki_WorkSheetData WS_IdentSheet =
{ {
WS_PODPIS_LU, WS_IDENTSHEET,
&WS_Podp4_LU, &WS_Title,
STAMP_7 + 90, STAMP_60 + 492, BLOCK_ID_SHEET_X,BLOCK_ID_SHEET_Y,
0, 0, 0, 0,
wxT( "Взам.инв.N" ),NULL wxT( "Id: " ), NULL
}; };
Ki_WorkSheetData WS_Podp4_LU = Ki_WorkSheetData WS_Title =
{ {
WS_PODPIS_LU, WS_TITLE,
&WS_Podp5_LU, &WS_SheetFilename,
STAMP_7 + 90, STAMP_85 + 492, BLOCK_TITLE_X, BLOCK_TITLE_Y,
0, 0, 0, 0,
wxT( "Инв.N дубл." ),NULL wxT( "Title: " ), NULL
}; };
Ki_WorkSheetData WS_Podp5_LU = Ki_WorkSheetData WS_SheetFilename =
{ {
WS_PODPIS_LU, WS_FILENAME,
&WS_Podp6_LU, &WS_FullSheetName,
STAMP_7 + 90, STAMP_110 + 688, BLOCK_FILENAME_X, BLOCK_FILENAME_Y,
0, 0, 0, 0,
wxT( "Подп. и дата" ),NULL wxT( "File: " ), NULL
}; };
Ki_WorkSheetData WS_Podp6_LU = Ki_WorkSheetData WS_FullSheetName =
{ {
WS_PODPIS_LU, WS_FULLSHEETNAME,
&WS_Podp7_LU, &WS_Company,
STAMP_7 + 90, STAMP_167 + 1180, BLOCK_FULLSHEETNAME_X,BLOCK_FULLSHEETNAME_Y,
0, 0, 0, 0,
wxT( "Справ. N" ),NULL wxT( "Sheet: " ), NULL
}; };
Ki_WorkSheetData WS_Podp7_LU = Ki_WorkSheetData WS_Company =
{ {
WS_PODPIS_LU, WS_COMPANY_NAME,
NULL, &WS_Comment1,
STAMP_7 + 90, STAMP_227 + 1180, BLOCK_COMMENT_X,BLOCK_COMPANY_Y,
0, 0,
NULL, NULL
};
Ki_WorkSheetData WS_Comment1 =
{
WS_COMMENT1,
&WS_Comment2,
BLOCK_COMMENT_X,BLOCK_COMMENT1_Y,
0, 0,
NULL, NULL
};
Ki_WorkSheetData WS_Comment2 =
{
WS_COMMENT2,
&WS_Comment3,
BLOCK_COMMENT_X,BLOCK_COMMENT2_Y,
0, 0, 0, 0,
wxT( "Перв. примен." ),NULL NULL, NULL
};
Ki_WorkSheetData WS_Comment3 =
{
WS_COMMENT3,
&WS_Comment4,
BLOCK_COMMENT_X,BLOCK_COMMENT3_Y,
0, 0,
NULL, NULL
}; };
Ki_WorkSheetData WS_Segm1_LT = Ki_WorkSheetData WS_Comment4 =
{ {
WS_SEGMENT_LT, WS_COMMENT4,
&WS_Segm2_LT, &WS_MostLeftLine,
STAMP_X_0, STAMP_Y_14, BLOCK_COMMENT_X, BLOCK_COMMENT4_Y,
STAMP_X_137, STAMP_Y_14, 0, 0,
NULL, NULL
};
/// Left vertical segment
Ki_WorkSheetData WS_MostLeftLine =
{
WS_LEFT_SEGMENT,
&WS_SeparatorLine,
BLOCK_OX, SIZETEXT * 16,
BLOCK_OX, 0,
NULL, NULL
};
/// horizontal segment between filename and comments
Ki_WorkSheetData WS_SeparatorLine =
{
WS_SEGMENT,
&WS_MostUpperLine,
BLOCK_OX, VARIABLE_BLOCK_START_POSITION,
0, VARIABLE_BLOCK_START_POSITION,
NULL, NULL
};
/// superior horizontal segment
Ki_WorkSheetData WS_MostUpperLine =
{
WS_UPPER_SEGMENT,
&WS_Segm3,
BLOCK_OX, SIZETEXT * 16,
0, SIZETEXT * 16,
NULL, NULL
};
/// horizontal segment above COMPANY NAME
Ki_WorkSheetData WS_Segm3 =
{
WS_SEGMENT,
&WS_Segm4,
BLOCK_OX, SIZETEXT * 6,
0, SIZETEXT * 6,
NULL, NULL
};
/// vertical segment of the left REV and SHEET
Ki_WorkSheetData WS_Segm4 =
{
WS_SEGMENT,
&WS_Segm5,
BLOCK_REV_X + SIZETEXT,SIZETEXT * 4,
BLOCK_REV_X + SIZETEXT,0,
NULL, NULL
};
Ki_WorkSheetData WS_Segm5 =
{
WS_SEGMENT,
&WS_Segm6,
BLOCK_OX, SIZETEXT * 2,
0, SIZETEXT * 2,
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Segm2_LT =
{
WS_SEGMENT_LT,
&WS_Segm3_LT,
STAMP_X_137, STAMP_Y_14,
STAMP_X_137, 0,
NULL, NULL
};
Ki_WorkSheetData WS_Segm3_LT = Ki_WorkSheetData WS_Segm6 =
{ {
WS_SEGMENT_LT, WS_SEGMENT,
&WS_Segm4_LT, &WS_Segm7,
STAMP_X_137, STAMP_Y_7, BLOCK_OX, SIZETEXT * 4,
STAMP_X_84, STAMP_Y_7, 0, SIZETEXT * 4,
NULL, NULL NULL, NULL
}; };
Ki_WorkSheetData WS_Segm4_LT =
{ Ki_WorkSheetData WS_Segm7 =
WS_SEGMENT_LT,
&WS_Segm5_LT,
STAMP_X_84, STAMP_Y_14,
STAMP_X_84, 0,
NULL, NULL
};
Ki_WorkSheetData WS_Segm5_LT =
{ {
WS_SEGMENT_LT, WS_SEGMENT,
NULL,
STAMP_X_70, STAMP_Y_14,
STAMP_X_70, 0,
#else
NULL, NULL,
BLOCK_OX - (SIZETEXT * 11),SIZETEXT * 4, BLOCK_OX - (SIZETEXT * 11),SIZETEXT * 4,
BLOCK_OX - (SIZETEXT * 11),SIZETEXT * 2, BLOCK_OX - (SIZETEXT * 11),SIZETEXT * 2,
#endif
NULL, NULL NULL, NULL
}; };
#endif
void EDA_DRAW_FRAME::TraceWorkSheet( wxDC* aDC, BASE_SCREEN* aScreen, int aLineWidth, void EDA_DRAW_FRAME::TraceWorkSheet( wxDC* aDC, BASE_SCREEN* aScreen, int aLineWidth,
double aScalar, const wxString &aFilename ) double aScalar, const wxString &aFilename )
...@@ -1041,6 +1082,7 @@ void EDA_DRAW_FRAME::TraceWorkSheet( wxDC* aDC, wxSize& aSz, wxPoint& aLT, wxPoi ...@@ -1041,6 +1082,7 @@ void EDA_DRAW_FRAME::TraceWorkSheet( wxDC* aDC, wxSize& aSz, wxPoint& aLT, wxPoi
EDA_COLOR_T aClr1, EDA_COLOR_T aClr2 ) EDA_COLOR_T aClr1, EDA_COLOR_T aClr2 )
{ {
wxPoint pos; wxPoint pos;
wxPoint end;
int refx, refy; int refx, refy;
wxString Line; wxString Line;
Ki_WorkSheetData* WsItem; Ki_WorkSheetData* WsItem;
...@@ -1060,261 +1102,488 @@ void EDA_DRAW_FRAME::TraceWorkSheet( wxDC* aDC, wxSize& aSz, wxPoint& aLT, wxPoi ...@@ -1060,261 +1102,488 @@ void EDA_DRAW_FRAME::TraceWorkSheet( wxDC* aDC, wxSize& aSz, wxPoint& aLT, wxPoi
yg = aSz.y - aRB.y; yg = aSz.y - aRB.y;
#if defined(KICAD_GOST) #if defined(KICAD_GOST)
// Draw the border.
GRRect( m_canvas->GetClipBox(), aDC, refx * aScalar, refy * aScalar,
xg * aScalar, yg * aScalar, aLnW, aClr1 );
refx = aLT.x;
refy = aSz.y - aRB.y; // Lower left corner
for( WsItem = &WS_Segm1_LU; WsItem != NULL; WsItem = WsItem->Pnext )
{
pos.x = ( refx - WsItem->m_Posx ) * aScalar;
pos.y = ( refy - WsItem->m_Posy ) * aScalar;
msg.Empty();
switch( WsItem->m_Type )
{
case WS_CADRE:
break;
case WS_PODPIS_LU:
if( WsItem->m_Legende )
msg = WsItem->m_Legende;
DrawGraphicText( m_canvas, aDC, pos, aClr1,
msg, TEXT_ORIENT_VERT, size,
GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_BOTTOM,
aLnW, false, false );
break;
case WS_SEGMENT_LU: int lnMsg, ln;
xg = aLT.x - WsItem->m_Endx; int lnWosn = aLnW * 2;
yg = aSz.y - aRB.y - WsItem->m_Endy; int lnWtonk = aLnW;
GRLine( m_canvas->GetClipBox(), aDC, pos.x, pos.y, wxSize sz;
xg * aScalar, yg * aScalar, aLnW, aClr1 ); wxSize size0_8( SIZETEXT * aScalar * 0.8, SIZETEXT * aScalar * 1 );
break; wxSize size1_5( SIZETEXT * aScalar * 1.5, SIZETEXT * aScalar * 1.5 );
} wxSize size2( SIZETEXT * aScalar * 2, SIZETEXT * aScalar * 2 );
} wxSize size3( SIZETEXT * aScalar * 3, SIZETEXT * aScalar * 3 );
refy = aRB.y; // Left Top corner // Draw the border.
for( WsItem = &WS_Segm1_LT; WsItem != NULL; WsItem = WsItem->Pnext ) GRRect( m_canvas->GetClipBox(), aDC, refx * aScalar, refy * aScalar,
{ xg * aScalar, yg * aScalar, lnWosn, aClr1 );
pos.x = ( refx + WsItem->m_Posx ) * aScalar;
pos.y = ( refy + WsItem->m_Posy ) * aScalar;
msg.Empty();
switch( WsItem->m_Type )
{
case WS_SEGMENT_LT:
xg = aLT.x + WsItem->m_Endx;
yg = aRB.y + WsItem->m_Endy;
GRLine( m_canvas->GetClipBox(), aDC, pos.x, pos.y,
xg * aScalar, yg * aScalar, aLnW, aClr1 );
break;
}
}
wxSize size2( SIZETEXT * aScalar * 2, SIZETEXT * aScalar * 2); // Center - right bottom corner
wxSize size3( SIZETEXT * aScalar * 3, SIZETEXT * aScalar * 3);
wxSize size1_5( SIZETEXT * aScalar * 1.5, SIZETEXT * aScalar * 1.5);
// lower right corner
refx = aSz.x - aRB.x; refx = aSz.x - aRB.x;
refy = aSz.y - aRB.y; refy = aSz.y - aRB.y;
// First page
if( aScr == 1 ) if( aScr == 1 )
{ {
for( WsItem = &WS_Date; WsItem != NULL; WsItem = WsItem->Pnext ) for( WsItem = &WS_Osn1_Line1; WsItem != NULL; WsItem = WsItem->Pnext )
{ {
pos.x = (refx - WsItem->m_Posx) * aScalar; pos.x = (refx - WsItem->m_Posx) * aScalar;
pos.y = (refy - WsItem->m_Posy) * aScalar; pos.y = (refy - WsItem->m_Posy) * aScalar;
msg.Empty(); end.x = (refx - WsItem->m_Endx) * aScalar;
end.y = (refy - WsItem->m_Endy) * aScalar;
msg = WsItem->m_Legende;
switch( WsItem->m_Type ) switch( WsItem->m_Type )
{ {
case WS_DATE: case WS_OSN:
GRLine( m_canvas->GetClipBox(), aDC, pos.x, pos.y, end.x, end.y,
lnWosn, aClr1 );
break; break;
case WS_REV: case WS_TONK:
GRLine( m_canvas->GetClipBox(), aDC, pos.x, pos.y, end.x, end.y,
lnWtonk, aClr1 );
break; break;
case WS_KICAD_VERSION: case WS_TEXT:
if( !msg.IsEmpty() )
{
if( WsItem == &WS_Osn1_Text1 )
DrawGraphicText( m_canvas, aDC, pos, aClr1,
msg, TEXT_ORIENT_HORIZ, size0_8,
GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER,
aLnW, false, false );
else
DrawGraphicText( m_canvas, aDC, pos, aClr1,
msg, TEXT_ORIENT_HORIZ, size,
GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER,
aLnW, false, false );
}
break; break;
case WS_PODPIS: case WS_TEXTL:
if( WsItem->m_Legende ) if( !msg.IsEmpty() )
msg = WsItem->m_Legende;
DrawGraphicText( m_canvas, aDC, pos, aClr1, DrawGraphicText( m_canvas, aDC, pos, aClr1,
msg, TEXT_ORIENT_HORIZ, size, msg, TEXT_ORIENT_HORIZ, size,
GR_TEXT_HJUSTIFY_LEFT, GR_TEXT_VJUSTIFY_CENTER, GR_TEXT_HJUSTIFY_LEFT, GR_TEXT_VJUSTIFY_CENTER,
aLnW, false, false ); aLnW, false, false );
break; break;
case WS_SIZESHEET: }
break; }
case WS_IDENTSHEET: // Sheet number
if( WsItem->m_Legende )
msg = WsItem->m_Legende;
if( aNScr > 1 ) if( aNScr > 1 )
{
pos.x = (refx - Mm2mils( 36 )) * aScalar;
pos.y = (refy - Mm2mils( 17.5 )) * aScalar;
msg.Empty();
msg << aScr; msg << aScr;
DrawGraphicText( m_canvas, aDC, pos, aClr1, msg, DrawGraphicText( m_canvas, aDC, pos, aClr1, msg,
TEXT_ORIENT_HORIZ, size, GR_TEXT_HJUSTIFY_LEFT, TEXT_ORIENT_HORIZ, size, GR_TEXT_HJUSTIFY_CENTER,
GR_TEXT_VJUSTIFY_CENTER, aLnW, false, false ); GR_TEXT_VJUSTIFY_CENTER, aLnW, false, false );
break; }
case WS_SHEETS: // Count of sheets
if( WsItem->m_Legende ) pos.x = (refx - Mm2mils( 10 )) * aScalar;
msg = WsItem->m_Legende; pos.y = (refy - Mm2mils( 17.5 )) * aScalar;
msg.Empty();
msg << aNScr; msg << aNScr;
DrawGraphicText( m_canvas, aDC, pos, aClr1, msg, DrawGraphicText( m_canvas, aDC, pos, aClr1, msg,
TEXT_ORIENT_HORIZ, size, GR_TEXT_HJUSTIFY_LEFT, TEXT_ORIENT_HORIZ, size, GR_TEXT_HJUSTIFY_LEFT,
GR_TEXT_VJUSTIFY_CENTER, aLnW, false, false ); GR_TEXT_VJUSTIFY_CENTER, aLnW, false, false );
break;
case WS_COMPANY_NAME: // Company name
msg = aTb.GetCompany(); msg = aTb.GetCompany();
if( !msg.IsEmpty() ) if( !msg.IsEmpty() )
{ {
sz = size1_5;
lnMsg = ReturnGraphicTextWidth( msg, sz.x, false, false ) / aScalar;
ln = Mm2mils( 49 );
if( lnMsg > ln )
sz.x *= float( ln ) / lnMsg;
pos.x = (refx - Mm2mils( 25 )) * aScalar;
pos.y = (refy - Mm2mils( 7.5 )) * aScalar;
DrawGraphicText( m_canvas, aDC, pos, aClr2, DrawGraphicText( m_canvas, aDC, pos, aClr2,
msg, TEXT_ORIENT_HORIZ, size1_5, msg, TEXT_ORIENT_HORIZ, sz,
GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER, GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER,
aLnW, false, false ); aLnW, false, false );
} }
break;
case WS_TITLE: // Title
msg = aTb.GetTitle(); msg = aTb.GetTitle();
if( !msg.IsEmpty() ) if( !msg.IsEmpty() )
{ {
sz = size1_5;
wxArrayString lines;
int titleWidth = 0;
int titleHeight = (sz.y + sz.y * 0.5) / aScalar;
int titleFieldWidth = Mm2mils( 69 );
int titleFieldHeight = Mm2mils( 24 );
int index = 0;
wxString fullMsg = msg;
do // Reduce the height of wrapped title until the fit
{
do // Wrap the title
{
titleWidth = ReturnGraphicTextWidth( msg, sz.x, false, false ) / aScalar;
if( titleWidth > titleFieldWidth )
{
index = 0;
do
{
msg = msg.Left( msg.Length() - 1 );
if( msg.Length() == 0 )
{
lines.Clear();
msg = fullMsg;
sz.x -= aScalar;
break;
}
else
{
index++;
titleWidth = ReturnGraphicTextWidth( msg, sz.x, false, false ) / aScalar;
wxString ch = wxString( msg.Last() );
if( titleWidth < titleFieldWidth && ch == wxT( " " ) )
{
// New sentence on a new line
int dot = msg.Index( wxT( ". " ) );
if( dot != wxNOT_FOUND )
{
index += msg.Length() - dot - 2;
msg = msg.Left( dot + 1 );
lines.Add( msg );
msg = fullMsg.Right( index );
break;
}
else
{
msg = msg.Left( msg.Length() - 1 );
lines.Add( msg );
msg = fullMsg.Right( index );
break;
}
}
}
}while( 1 );
}
else
{
// New sentence on a new line
int dot = msg.Index( wxT( ". " ) );
if( dot != wxNOT_FOUND )
{
lines.Add( msg.Left( dot + 1 ) );
lines.Add( fullMsg.Right( msg.Length() - dot - 2 ) );
}
else
lines.Add( msg );
break;
}
}while( 1 );
if( titleFieldHeight < titleHeight * lines.Count() )
{
sz.y -= aScalar;
sz.x -= aScalar;
msg = fullMsg;
lines.Clear();
}
else
break;
}while( 1 );
pos.x = (refx - Mm2mils( 85 )) * aScalar;
pos.y = (refy - Mm2mils( 27.5 ) - (titleHeight * (lines.Count() - 1) / 2)) * aScalar;
for( int curLn = 0; curLn < lines.Count(); curLn++ )
{
msg = lines[curLn];
DrawGraphicText( m_canvas, aDC, pos, aClr2, DrawGraphicText( m_canvas, aDC, pos, aClr2,
msg, TEXT_ORIENT_HORIZ, size1_5, msg, TEXT_ORIENT_HORIZ, sz,
GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER, GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER,
aLnW, false, false ); aLnW, false, false );
pos.y += titleHeight * aScalar;
}
} }
break;
case WS_COMMENT1: // Decimal number
msg = aTb.GetComment1(); msg = aTb.GetComment1();
if( !msg.IsEmpty() ) if( !msg.IsEmpty() )
{ {
sz = size3;
lnMsg = ReturnGraphicTextWidth( msg, sz.x, false, false ) / aScalar;
ln = Mm2mils( 119 );
if( lnMsg > ln )
sz.x *= float( ln ) / lnMsg;
pos.x = (refx - Mm2mils( 60 )) * aScalar;
pos.y = (refy - Mm2mils( 47.5 )) * aScalar;
DrawGraphicText( m_canvas, aDC, pos, aClr2, DrawGraphicText( m_canvas, aDC, pos, aClr2,
msg, TEXT_ORIENT_HORIZ, size3, msg, TEXT_ORIENT_HORIZ, sz,
GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER,
aLnW, false, false );
pos.x = (aLT.x + 1260) * aScalar;
pos.y = (aLT.y + 270) * aScalar;
DrawGraphicText( m_canvas, aDC, pos, aClr2,
msg, 1800, size2,
GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER, GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER,
aLnW, false, false ); aLnW, false, false );
} }
break;
case WS_COMMENT2: // Developer
msg = aTb.GetComment2(); msg = aTb.GetComment2();
if( !msg.IsEmpty() ) if( !msg.IsEmpty() )
{ {
sz = size;
lnMsg = ReturnGraphicTextWidth( msg, sz.x, false, false ) / aScalar;
ln = Mm2mils( 22 );
if( lnMsg > ln )
sz.x *= float( ln ) / lnMsg;
pos.x = (refx - Mm2mils( 167.5 )) * aScalar;
pos.y = (refy - Mm2mils( 27.5 )) * aScalar;
DrawGraphicText( m_canvas, aDC, pos, aClr2, DrawGraphicText( m_canvas, aDC, pos, aClr2,
msg, TEXT_ORIENT_HORIZ, size, msg, TEXT_ORIENT_HORIZ, sz,
GR_TEXT_HJUSTIFY_LEFT, GR_TEXT_VJUSTIFY_CENTER, GR_TEXT_HJUSTIFY_LEFT, GR_TEXT_VJUSTIFY_CENTER,
aLnW, false, false ); aLnW, false, false );
} }
break;
case WS_COMMENT3: // Verifier
msg = aTb.GetComment3(); msg = aTb.GetComment3();
if( !msg.IsEmpty() ) if( !msg.IsEmpty() )
{ {
sz = size;
lnMsg = ReturnGraphicTextWidth( msg, sz.x, false, false ) / aScalar;
ln = Mm2mils( 22 );
if( lnMsg > ln )
sz.x *= float( ln ) / lnMsg;
pos.x = (refx - Mm2mils( 167 )) * aScalar;
pos.y = (refy - Mm2mils( 22.5 )) * aScalar;
DrawGraphicText( m_canvas, aDC, pos, aClr2, DrawGraphicText( m_canvas, aDC, pos, aClr2,
msg, TEXT_ORIENT_HORIZ, size, msg, TEXT_ORIENT_HORIZ, sz,
GR_TEXT_HJUSTIFY_LEFT, GR_TEXT_VJUSTIFY_CENTER, GR_TEXT_HJUSTIFY_LEFT, GR_TEXT_VJUSTIFY_CENTER,
aLnW, false, false ); aLnW, false, false );
} }
break;
case WS_COMMENT4: // Approver
msg = aTb.GetComment4(); msg = aTb.GetComment4();
if( !msg.IsEmpty() ) if( !msg.IsEmpty() )
{ {
sz = size;
lnMsg = ReturnGraphicTextWidth( msg, sz.x, false, false ) / aScalar;
ln = Mm2mils( 22 );
if( lnMsg > ln )
sz.x *= float( ln ) / lnMsg;
pos.x = (refx - Mm2mils( 167 )) * aScalar;
pos.y = (refy - Mm2mils( 2.5 )) * aScalar;
DrawGraphicText( m_canvas, aDC, pos, aClr2, DrawGraphicText( m_canvas, aDC, pos, aClr2,
msg, TEXT_ORIENT_HORIZ, size, msg, TEXT_ORIENT_HORIZ, sz,
GR_TEXT_HJUSTIFY_LEFT, GR_TEXT_VJUSTIFY_CENTER, GR_TEXT_HJUSTIFY_LEFT, GR_TEXT_VJUSTIFY_CENTER,
aLnW, false, false ); aLnW, false, false );
} }
break;
case WS_UPPER_SEGMENT:
case WS_LEFT_SEGMENT:
WS_MostUpperLine.m_Posy = WS_MostUpperLine.m_Endy =
WS_MostLeftLine.m_Posy = STAMP_OY;
pos.y = ( refy - WsItem->m_Posy ) * aScalar;
case WS_SEGMENT:
xg = aSz.x - aRB.x - WsItem->m_Endx;
yg = aSz.y - aRB.y - WsItem->m_Endy;
GRLine( m_canvas->GetClipBox(), aDC, pos.x, pos.y,
xg * aScalar, yg * aScalar, aLnW, aClr1 );
break;
}
} }
} else // other pages
else
{ {
for( WsItem = &WS_CADRE_D; WsItem != NULL; WsItem = WsItem->Pnext ) for( WsItem = &WS_Osn2a_Line1; WsItem != NULL; WsItem = WsItem->Pnext )
{ {
pos.x = ( refx - WsItem->m_Posx ) * aScalar; pos.x = (refx - WsItem->m_Posx) * aScalar;
pos.y = ( refy - WsItem->m_Posy ) * aScalar; pos.y = (refy - WsItem->m_Posy) * aScalar;
msg.Empty(); end.x = (refx - WsItem->m_Endx) * aScalar;
end.y = (refy - WsItem->m_Endy) * aScalar;
msg = WsItem->m_Legende;
switch( WsItem->m_Type ) switch( WsItem->m_Type )
{ {
case WS_CADRE: case WS_OSN:
// Begin list number > 1 GRLine( m_canvas->GetClipBox(), aDC, pos.x, pos.y, end.x, end.y,
msg = aTb.GetComment1(); lnWosn, aClr1 );
break;
case WS_TONK:
GRLine( m_canvas->GetClipBox(), aDC, pos.x, pos.y, end.x, end.y,
lnWtonk, aClr1 );
break;
case WS_TEXT:
if( !msg.IsEmpty() ) if( !msg.IsEmpty() )
{ {
DrawGraphicText( m_canvas, aDC, pos, aClr2, if( WsItem == &WS_Osn2a_Text1 )
msg, TEXT_ORIENT_HORIZ, size3, DrawGraphicText( m_canvas, aDC, pos, aClr1,
msg, TEXT_ORIENT_HORIZ, size0_8,
GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER, GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER,
aLnW, false, false ); aLnW, false, false );
pos.x = (aLT.x + 1260) * aScalar; else
pos.y = (aLT.y + 270) * aScalar; DrawGraphicText( m_canvas, aDC, pos, aClr1,
DrawGraphicText( m_canvas, aDC, pos, aClr2, msg, TEXT_ORIENT_HORIZ, size,
msg, 1800, size2,
GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER, GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER,
aLnW, false, false ); aLnW, false, false );
} }
break; break;
case WS_PODPIS_D: case WS_TEXTL:
if( WsItem->m_Legende ) if( !msg.IsEmpty() )
msg = WsItem->m_Legende;
DrawGraphicText( m_canvas, aDC, pos, aClr1, DrawGraphicText( m_canvas, aDC, pos, aClr1,
msg, TEXT_ORIENT_HORIZ, size, msg, TEXT_ORIENT_HORIZ, size,
GR_TEXT_HJUSTIFY_LEFT, GR_TEXT_VJUSTIFY_CENTER, GR_TEXT_HJUSTIFY_LEFT, GR_TEXT_VJUSTIFY_CENTER,
aLnW, false, false ); aLnW, false, false );
break; break;
}
}
case WS_IDENTSHEET_D: // Sheet number
if( WsItem->m_Legende ) pos.x = (refx - Mm2mils( 5 )) * aScalar;
msg = WsItem->m_Legende; pos.y = (refy - Mm2mils( 4 )) * aScalar;
msg.Empty();
msg << aScr; msg << aScr;
DrawGraphicText( m_canvas, aDC, pos, aClr1, msg,
TEXT_ORIENT_HORIZ, size, GR_TEXT_HJUSTIFY_CENTER,
GR_TEXT_VJUSTIFY_CENTER, aLnW, false, false );
// Decimal number
msg = aTb.GetComment1();
if( !msg.IsEmpty() )
{
sz = size3;
lnMsg = ReturnGraphicTextWidth( msg, sz.x, false, false ) / aScalar;
ln = Mm2mils( 109 );
if( lnMsg > ln )
sz.x *= float( ln ) / lnMsg;
pos.x = (refx - Mm2mils( 65 )) * aScalar;
pos.y = (refy - Mm2mils( 7.5 )) * aScalar;
DrawGraphicText( m_canvas, aDC, pos, aClr2,
msg, TEXT_ORIENT_HORIZ, sz,
GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER,
aLnW, false, false );
}
}
// Format
pos.x = (refx - Mm2mils( 23 )) * aScalar;
pos.y = (refy + Mm2mils( 2.5 )) * aScalar;
msg.Empty();
msg << aType;
DrawGraphicText( m_canvas, aDC, pos, aClr1, DrawGraphicText( m_canvas, aDC, pos, aClr1,
msg, TEXT_ORIENT_HORIZ, size, msg, TEXT_ORIENT_HORIZ, size,
GR_TEXT_HJUSTIFY_LEFT, GR_TEXT_VJUSTIFY_CENTER, GR_TEXT_HJUSTIFY_LEFT, GR_TEXT_VJUSTIFY_CENTER,
aLnW, false, false ); aLnW, false, false );
// Center - left bottom corner
refx = aLT.x;
refy = aSz.y - aRB.y;
for( WsItem = &WS_DopLeft_Line1; WsItem != NULL; WsItem = WsItem->Pnext )
{
if( aScr > 1 && WsItem == &WS_DopLeft_Line9 ) // Some fields for first page only
break;
pos.x = (refx - WsItem->m_Posx) * aScalar;
pos.y = (refy - WsItem->m_Posy) * aScalar;
end.x = (refx - WsItem->m_Endx) * aScalar;
end.y = (refy - WsItem->m_Endy) * aScalar;
msg = WsItem->m_Legende;
switch( WsItem->m_Type )
{
case WS_OSN:
GRLine( m_canvas->GetClipBox(), aDC, pos.x, pos.y, end.x, end.y,
lnWosn, aClr1 );
break;
case WS_TEXT:
if( !msg.IsEmpty() )
DrawGraphicText( m_canvas, aDC, pos, aClr1,
msg, TEXT_ORIENT_VERT, size,
GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER,
aLnW, false, false );
break;
}
}
if( aType == PAGE_INFO::A4 || aSz.x > aSz.y ) // A4 or Landscape
{
// Center - left top corner
refx = aLT.x;
refy = aLT.y;
for( WsItem = &WS_DopTop_Line1; WsItem != NULL; WsItem = WsItem->Pnext )
{
if( aScr > 1 && WsItem == &WS_DopTop_Line3 ) // Some fields for first page only
break; break;
case WS_LEFT_SEGMENT_D: pos.x = (refx + WsItem->m_Posx) * aScalar;
pos.y = ( refy - WsItem->m_Posy ) * aScalar; pos.y = (refy + WsItem->m_Posy) * aScalar;
end.x = (refx + WsItem->m_Endx) * aScalar;
end.y = (refy + WsItem->m_Endy) * aScalar;
msg = WsItem->m_Legende;
switch( WsItem->m_Type )
{
case WS_OSN:
GRLine( m_canvas->GetClipBox(), aDC, pos.x, pos.y, end.x, end.y,
lnWosn, aClr1 );
break;
case WS_SEGMENT_D: case WS_TONK:
xg = aSz.x - aRB.x - WsItem->m_Endx; GRLine( m_canvas->GetClipBox(), aDC, pos.x, pos.y, end.x, end.y,
yg = aSz.y - aRB.y - WsItem->m_Endy; lnWtonk, aClr1 );
GRLine( m_canvas->GetClipBox(), aDC, pos.x, pos.y, break;
xg * aScalar, yg * aScalar, aLnW, aClr1 ); }
}
// Decimal number
msg = aTb.GetComment1();
if( !msg.IsEmpty() )
{
sz = size2;
lnMsg = ReturnGraphicTextWidth( msg, sz.x, false, false ) / aScalar;
ln = Mm2mils( 69 );
if( lnMsg > ln )
sz.x *= float( ln ) / lnMsg;
pos.x = (refx + Mm2mils( 35 )) * aScalar;
pos.y = (refy + Mm2mils( 7 )) * aScalar;
DrawGraphicText( m_canvas, aDC, pos, aClr2,
msg, 1800, sz,
GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER,
aLnW, false, false );
}
}
else // Portrait
{
// Center - right top corner
// Lines are used from the upper left corner by the change of coordinates
refx = aSz.x - aRB.x;
refy = aLT.y;
for( WsItem = &WS_DopTop_Line1; WsItem != NULL; WsItem = WsItem->Pnext )
{
if( aScr > 1 && WsItem == &WS_DopTop_Line3 ) // Some fields for first page only
break;
pos.x = (refx - WsItem->m_Posy) * aScalar;
pos.y = (refy + WsItem->m_Posx) * aScalar;
end.x = (refx - WsItem->m_Endy) * aScalar;
end.y = (refy + WsItem->m_Endx) * aScalar;
msg = WsItem->m_Legende;
switch( WsItem->m_Type )
{
case WS_OSN:
GRLine( m_canvas->GetClipBox(), aDC, pos.x, pos.y, end.x, end.y,
lnWosn, aClr1 );
break;
case WS_TONK:
GRLine( m_canvas->GetClipBox(), aDC, pos.x, pos.y, end.x, end.y,
lnWtonk, aClr1 );
break; break;
} }
} }
// Decimal number
msg = aTb.GetComment1();
if( !msg.IsEmpty() )
{
sz = size2;
lnMsg = ReturnGraphicTextWidth( msg, sz.x, false, false ) / aScalar;
ln = Mm2mils( 69 );
if( lnMsg > ln )
sz.x *= float( ln ) / lnMsg;
pos.x = (refx - Mm2mils( 7 )) * aScalar;
pos.y = (refy + Mm2mils( 35 )) * aScalar;
DrawGraphicText( m_canvas, aDC, pos, aClr2,
msg, TEXT_ORIENT_VERT, sz,
GR_TEXT_HJUSTIFY_CENTER, GR_TEXT_VJUSTIFY_CENTER,
aLnW, false, false );
}
} }
#else #else
// Draw the border. // Draw the border.
int ii, jj, ipas, gxpas, gypas; int ii, jj, ipas, gxpas, gypas;
for( ii = 0; ii < 2; ii++ ) for( ii = 0; ii < 2; ii++ )
...@@ -1602,6 +1871,7 @@ void EDA_DRAW_FRAME::TraceWorkSheet( wxDC* aDC, wxSize& aSz, wxPoint& aLT, wxPoi ...@@ -1602,6 +1871,7 @@ void EDA_DRAW_FRAME::TraceWorkSheet( wxDC* aDC, wxSize& aSz, wxPoint& aLT, wxPoi
} }
#endif #endif
} }
......
...@@ -155,7 +155,11 @@ static bool engStrToDouble( wxString aStr, double* aDouble ) ...@@ -155,7 +155,11 @@ static bool engStrToDouble( wxString aStr, double* aDouble )
aStr.Append( wxT( "R" ) ); aStr.Append( wxT( "R" ) );
// Regular expression for a value string, e.g., 47k2 // Regular expression for a value string, e.g., 47k2
#if defined(KICAD_GOST)
static wxRegEx valueRegEx( wxT( "^([0-9]+)(мк|[pnumRkKMGT.,кнМГ])([0-9]*)(мк*|[pnumRkKMGTкнМГ]*)" ) );
#else
static wxRegEx valueRegEx( wxT( "^([0-9]+)([pnumRkKMGT.,])([0-9]*)([pnumRkKMGT]*)" ) ); static wxRegEx valueRegEx( wxT( "^([0-9]+)([pnumRkKMGT.,])([0-9]*)([pnumRkKMGT]*)" ) );
#endif
if( !valueRegEx.Matches( aStr ) ) if( !valueRegEx.Matches( aStr ) )
return false; return false;
...@@ -164,7 +168,31 @@ static bool engStrToDouble( wxString aStr, double* aDouble ) ...@@ -164,7 +168,31 @@ static bool engStrToDouble( wxString aStr, double* aDouble )
+ wxT( "." ) + wxT( "." )
+ valueRegEx.GetMatch( aStr, 3 ) ); + valueRegEx.GetMatch( aStr, 3 ) );
wxString multiplierString = valueRegEx.GetMatch( aStr, 2 ); wxString multiplierString = valueRegEx.GetMatch( aStr, 2 );
#if defined(KICAD_GOST)
if ( multiplierString == wxT( "мк" ) )
multiplierString = wxT( "u" );
else if ( multiplierString == wxT( "к" ) )
multiplierString = wxT( "k" );
else if ( multiplierString == wxT( "н" ) )
multiplierString = wxT( "n" );
else if ( multiplierString == wxT( "М" ) )
multiplierString = wxT( "M" );
else if ( multiplierString == wxT( "Г" ) )
multiplierString = wxT( "G" );
#endif
wxString post_multiplierString = valueRegEx.GetMatch( aStr, 4 ); wxString post_multiplierString = valueRegEx.GetMatch( aStr, 4 );
#if defined(KICAD_GOST)
if ( post_multiplierString == wxT( "мк" ) )
multiplierString = wxT( "u" );
else if ( post_multiplierString == wxT( "к" ) )
multiplierString = wxT( "k" );
else if ( post_multiplierString == wxT( "н" ) )
multiplierString = wxT( "n" );
else if ( post_multiplierString == wxT( "М" ) )
multiplierString = wxT( "M" );
else if ( post_multiplierString == wxT( "Г" ) )
multiplierString = wxT( "G" );
#endif
double multiplier; double multiplier;
switch( (wxChar)multiplierString[0] ) switch( (wxChar)multiplierString[0] )
......
...@@ -36,7 +36,7 @@ ...@@ -36,7 +36,7 @@
#define PIN_LENGTH 300 /* Default Length of each pin to be drawn. */ #define PIN_LENGTH 300 /* Default Length of each pin to be drawn. */
#if defined(KICAD_GOST) #if defined(KICAD_GOST)
#define INVERT_PIN_RADIUS 20 /* Radius of inverted pin circle. */ #define INVERT_PIN_RADIUS 30 /* Radius of inverted pin circle. */
#else #else
#define INVERT_PIN_RADIUS 35 /* Radius of inverted pin circle. */ #define INVERT_PIN_RADIUS 35 /* Radius of inverted pin circle. */
#endif #endif
......
...@@ -469,7 +469,11 @@ void LIB_EDIT_FRAME::UpdatePartSelectList() ...@@ -469,7 +469,11 @@ void LIB_EDIT_FRAME::UpdatePartSelectList()
for( int i = 0; i < m_component->GetPartCount(); i++ ) for( int i = 0; i < m_component->GetPartCount(); i++ )
{ {
wxString msg; wxString msg;
#if defined(KICAD_GOST)
msg.Printf( _( "Part %d" ), i + 1 );
#else
msg.Printf( _( "Part %c" ), 'A' + i ); msg.Printf( _( "Part %c" ), 'A' + i );
#endif
m_partSelectBox->Append( msg ); m_partSelectBox->Append( msg );
} }
} }
......
...@@ -44,7 +44,11 @@ ...@@ -44,7 +44,11 @@
SCH_JUNCTION::SCH_JUNCTION( const wxPoint& pos ) : SCH_JUNCTION::SCH_JUNCTION( const wxPoint& pos ) :
SCH_ITEM( NULL, SCH_JUNCTION_T ) SCH_ITEM( NULL, SCH_JUNCTION_T )
{ {
#if defined(KICAD_GOST)
#define DRAWJUNCTION_DIAMETER 50 /* Diameter of junction symbol between wires by GOST*/
#else
#define DRAWJUNCTION_DIAMETER 32 /* Diameter of junction symbol between wires */ #define DRAWJUNCTION_DIAMETER 32 /* Diameter of junction symbol between wires */
#endif
m_pos = pos; m_pos = pos;
m_Layer = LAYER_JUNCTION; m_Layer = LAYER_JUNCTION;
m_size.x = m_size.y = DRAWJUNCTION_DIAMETER; m_size.x = m_size.y = DRAWJUNCTION_DIAMETER;
......
...@@ -10,72 +10,17 @@ ...@@ -10,72 +10,17 @@
#include <common.h> // Mm2mils() #include <common.h> // Mm2mils()
#define GRID_REF_W 70 // height of the band reference grid #define GRID_REF_W 70 // height of the band reference grid
#define SIZETEXT 60 // worksheet text size
#define SIZETEXT_REF 50 // worksheet frame reference text size
#define PAS_REF 2000 // no reference markings on worksheet frame
#if defined(KICAD_GOST) #if defined(KICAD_GOST)
#define SIZETEXT 100 // worksheet text size
// There is a page layout minor issue in GOST mode. #else
// This is the rounding-off error of 1 mil exactly. #define SIZETEXT 60 // worksheet text size
// I hope this problem will go away when we will go
// to nanometers (zaka62).
#define STAMP_OX Mm2mils( 185 ) + 1
#define STAMP_OY Mm2mils( 55 )
#define STAMP_Y_0 0
#define STAMP_Y_5 Mm2mils( 5 )
#define STAMP_Y_8 Mm2mils( 8 )
#define STAMP_Y_7 Mm2mils( 7 )
#define STAMP_Y_10 Mm2mils( 10 )
#define STAMP_Y_14 Mm2mils( 14 )
#define STAMP_Y_15 Mm2mils( 15 )
#define STAMP_Y_20 Mm2mils( 20 )
#define STAMP_Y_25 Mm2mils( 25 )
#define STAMP_Y_30 Mm2mils( 30 )
#define STAMP_Y_35 Mm2mils( 35 )
#define STAMP_Y_40 Mm2mils( 40 )
#define STAMP_Y_45 Mm2mils( 45 )
#define STAMP_Y_50 Mm2mils( 50 )
#define STAMP_Y_55 Mm2mils( 55 )
#define STAMP_X_0 0
#define STAMP_X_10 Mm2mils( 10 )
#define STAMP_X_14 Mm2mils( 14 )
#define STAMP_X_18 Mm2mils( 18 )
#define STAMP_X_30 Mm2mils( 30 )
#define STAMP_X_35 Mm2mils( 35 )
#define STAMP_X_40 Mm2mils( 40 )
#define STAMP_X_45 Mm2mils( 45 )
#define STAMP_X_50 Mm2mils( 50 )
#define STAMP_X_53 Mm2mils( 53 )
#define STAMP_X_65 Mm2mils( 65 )
#define STAMP_X_70 Mm2mils( 70 )
#define STAMP_X_84 Mm2mils( 84 )
#define STAMP_X_85 Mm2mils( 85 )
#define STAMP_X_120 Mm2mils( 120 )
#define STAMP_X_130 Mm2mils( 130 )
#define STAMP_X_137 Mm2mils( 137 )
#define STAMP_X_145 Mm2mils( 145 )
#define STAMP_X_168 Mm2mils( 168 )
#define STAMP_X_178 Mm2mils( 178 )
#define STAMP_X_185 Mm2mils( 185 )
#define STAMP_5 Mm2mils( 5 )
#define STAMP_7 Mm2mils( 7 )
#define STAMP_12 Mm2mils( 12 )
#define STAMP_145 Mm2mils( 145 )
#define STAMP_110 Mm2mils( 110 )
#define STAMP_85 Mm2mils( 85 )
#define STAMP_60 Mm2mils( 60 )
#define STAMP_25 Mm2mils( 25 )
#define STAMP_287 Mm2mils( 287 )
#define STAMP_227 Mm2mils( 227 )
#define STAMP_167 Mm2mils( 167 )
#endif #endif
#define SIZETEXT_REF 50 // worksheet frame reference text size
#define PAS_REF 2000 // no reference markings on worksheet frame
#if !defined(KICAD_GOST)
// The coordinates below are relative to the bottom right corner of page and // The coordinates below are relative to the bottom right corner of page and
// will be subtracted from this origin. // will be subtracted from this origin.
...@@ -97,13 +42,15 @@ ...@@ -97,13 +42,15 @@
#define BLOCK_FILENAME_X BLOCK_OX - SIZETEXT #define BLOCK_FILENAME_X BLOCK_OX - SIZETEXT
#define BLOCK_FILENAME_Y (SIZETEXT * 9) #define BLOCK_FILENAME_Y (SIZETEXT * 9)
#define BLOCK_COMMENT_X BLOCK_OX - SIZETEXT #define BLOCK_COMMENT_X BLOCK_OX - SIZETEXT
#define VARIABLE_BLOCK_START_POSITION (SIZETEXT * 10)
#define BLOCK_COMPANY_Y (SIZETEXT * 11) #define BLOCK_COMPANY_Y (SIZETEXT * 11)
#define BLOCK_COMMENT1_Y (SIZETEXT * 13) #define BLOCK_COMMENT1_Y (SIZETEXT * 13)
#define BLOCK_COMMENT2_Y (SIZETEXT * 15) #define BLOCK_COMMENT2_Y (SIZETEXT * 15)
#define BLOCK_COMMENT3_Y (SIZETEXT * 17) #define BLOCK_COMMENT3_Y (SIZETEXT * 17)
#define BLOCK_COMMENT4_Y (SIZETEXT * 19) #define BLOCK_COMMENT4_Y (SIZETEXT * 19)
#endif
#define VARIABLE_BLOCK_START_POSITION (SIZETEXT * 10)
struct Ki_WorkSheetData struct Ki_WorkSheetData
{ {
...@@ -119,17 +66,17 @@ public: ...@@ -119,17 +66,17 @@ public:
/// Work sheet structure type definitions. /// Work sheet structure type definitions.
enum TypeKi_WorkSheetData { enum TypeKi_WorkSheetData {
#if defined(KICAD_GOST)
WS_OSN,
WS_TONK,
WS_TEXT,
WS_TEXTL
#else
WS_DATE, WS_DATE,
WS_REV, WS_REV,
WS_KICAD_VERSION, WS_KICAD_VERSION,
#if defined(KICAD_GOST)
WS_PODPIS,
#endif
WS_SIZESHEET, WS_SIZESHEET,
WS_IDENTSHEET, WS_IDENTSHEET,
#if defined(KICAD_GOST)
WS_SHEETS,
#endif
WS_TITLE, WS_TITLE,
WS_FILENAME, WS_FILENAME,
WS_FULLSHEETNAME, WS_FULLSHEETNAME,
...@@ -141,20 +88,110 @@ enum TypeKi_WorkSheetData { ...@@ -141,20 +88,110 @@ enum TypeKi_WorkSheetData {
WS_SEGMENT, WS_SEGMENT,
WS_UPPER_SEGMENT, WS_UPPER_SEGMENT,
WS_LEFT_SEGMENT, WS_LEFT_SEGMENT,
#if defined(KICAD_GOST)
WS_CADRE,
WS_LEFT_SEGMENT_D,
WS_SEGMENT_D,
WS_PODPIS_D,
WS_IDENTSHEET_D,
WS_SEGMENT_LU,
WS_SEGMENT_LT,
WS_PODPIS_LU
#else
WS_CADRE WS_CADRE
#endif #endif
}; };
#if defined(KICAD_GOST)
extern Ki_WorkSheetData WS_Osn1_Line1;
extern Ki_WorkSheetData WS_Osn1_Line2;
extern Ki_WorkSheetData WS_Osn1_Line3;
extern Ki_WorkSheetData WS_Osn1_Line4;
extern Ki_WorkSheetData WS_Osn1_Line5;
extern Ki_WorkSheetData WS_Osn1_Line6;
extern Ki_WorkSheetData WS_Osn1_Line7;
extern Ki_WorkSheetData WS_Osn1_Line8;
extern Ki_WorkSheetData WS_Osn1_Line9;
extern Ki_WorkSheetData WS_Osn1_Line10;
extern Ki_WorkSheetData WS_Osn1_Line11;
extern Ki_WorkSheetData WS_Osn1_Line12;
extern Ki_WorkSheetData WS_Osn1_Line13;
extern Ki_WorkSheetData WS_Osn1_Line14;
extern Ki_WorkSheetData WS_Osn1_Line15;
extern Ki_WorkSheetData WS_Osn1_Line16;
extern Ki_WorkSheetData WS_Osn1_Line17;
extern Ki_WorkSheetData WS_Osn1_Line18;
extern Ki_WorkSheetData WS_Osn1_Line19;
extern Ki_WorkSheetData WS_Osn1_Line20;
extern Ki_WorkSheetData WS_Osn1_Line21;
extern Ki_WorkSheetData WS_Osn1_Line22;
extern Ki_WorkSheetData WS_Osn1_Line23;
extern Ki_WorkSheetData WS_Osn1_Line24;
extern Ki_WorkSheetData WS_Osn1_Line25;
extern Ki_WorkSheetData WS_Osn1_Line26;
extern Ki_WorkSheetData WS_Osn1_Line27;
extern Ki_WorkSheetData WS_Osn1_Text1;
extern Ki_WorkSheetData WS_Osn1_Text2;
extern Ki_WorkSheetData WS_Osn1_Text3;
extern Ki_WorkSheetData WS_Osn1_Text4;
extern Ki_WorkSheetData WS_Osn1_Text5;
extern Ki_WorkSheetData WS_Osn1_Text6;
extern Ki_WorkSheetData WS_Osn1_Text7;
extern Ki_WorkSheetData WS_Osn1_Text8;
extern Ki_WorkSheetData WS_Osn1_Text9;
extern Ki_WorkSheetData WS_Osn1_Text10;
extern Ki_WorkSheetData WS_Osn1_Text11;
extern Ki_WorkSheetData WS_Osn1_Text12;
extern Ki_WorkSheetData WS_Osn1_Text13;
extern Ki_WorkSheetData WS_Osn1_Text14;
extern Ki_WorkSheetData WS_Osn1_Text15;
extern Ki_WorkSheetData WS_Osn1_Text16;
extern Ki_WorkSheetData WS_Osn1_Text17;
extern Ki_WorkSheetData WS_Osn2a_Line1;
extern Ki_WorkSheetData WS_Osn2a_Line2;
extern Ki_WorkSheetData WS_Osn2a_Line3;
extern Ki_WorkSheetData WS_Osn2a_Line4;
extern Ki_WorkSheetData WS_Osn2a_Line5;
extern Ki_WorkSheetData WS_Osn2a_Line6;
extern Ki_WorkSheetData WS_Osn2a_Line7;
extern Ki_WorkSheetData WS_Osn2a_Line8;
extern Ki_WorkSheetData WS_Osn2a_Line9;
extern Ki_WorkSheetData WS_Osn2a_Line10;
extern Ki_WorkSheetData WS_Osn2a_Line11;
extern Ki_WorkSheetData WS_Osn2a_Text1;
extern Ki_WorkSheetData WS_Osn2a_Text2;
extern Ki_WorkSheetData WS_Osn2a_Text3;
extern Ki_WorkSheetData WS_Osn2a_Text4;
extern Ki_WorkSheetData WS_Osn2a_Text5;
extern Ki_WorkSheetData WS_Osn2a_Text6;
extern Ki_WorkSheetData WS_Osn2a_Text7;
extern Ki_WorkSheetData WS_Osn2a_Text8;
extern Ki_WorkSheetData WS_DopLeft_Line1;
extern Ki_WorkSheetData WS_DopLeft_Line2;
extern Ki_WorkSheetData WS_DopLeft_Line3;
extern Ki_WorkSheetData WS_DopLeft_Line4;
extern Ki_WorkSheetData WS_DopLeft_Line5;
extern Ki_WorkSheetData WS_DopLeft_Line6;
extern Ki_WorkSheetData WS_DopLeft_Line7;
extern Ki_WorkSheetData WS_DopLeft_Line8;
extern Ki_WorkSheetData WS_DopLeft_Line9;
extern Ki_WorkSheetData WS_DopLeft_Line10;
extern Ki_WorkSheetData WS_DopLeft_Line11;
extern Ki_WorkSheetData WS_DopLeft_Line12;
extern Ki_WorkSheetData WS_DopLeft_Line13;
extern Ki_WorkSheetData WS_DopLeft_Line14;
extern Ki_WorkSheetData WS_DopLeft_Text1;
extern Ki_WorkSheetData WS_DopLeft_Text2;
extern Ki_WorkSheetData WS_DopLeft_Text3;
extern Ki_WorkSheetData WS_DopLeft_Text4;
extern Ki_WorkSheetData WS_DopLeft_Text5;
extern Ki_WorkSheetData WS_DopLeft_Text6;
extern Ki_WorkSheetData WS_DopLeft_Text7;
extern Ki_WorkSheetData WS_DopTop_Line1;
extern Ki_WorkSheetData WS_DopTop_Line2;
extern Ki_WorkSheetData WS_DopTop_Line3;
extern Ki_WorkSheetData WS_DopTop_Line4;
extern Ki_WorkSheetData WS_DopTop_Line5;
extern Ki_WorkSheetData WS_DopTop_Line6;
#else
extern Ki_WorkSheetData WS_Date; extern Ki_WorkSheetData WS_Date;
extern Ki_WorkSheetData WS_Revision; extern Ki_WorkSheetData WS_Revision;
extern Ki_WorkSheetData WS_Licence; extern Ki_WorkSheetData WS_Licence;
...@@ -176,85 +213,6 @@ extern Ki_WorkSheetData WS_Segm4; ...@@ -176,85 +213,6 @@ extern Ki_WorkSheetData WS_Segm4;
extern Ki_WorkSheetData WS_Segm5; extern Ki_WorkSheetData WS_Segm5;
extern Ki_WorkSheetData WS_Segm6; extern Ki_WorkSheetData WS_Segm6;
extern Ki_WorkSheetData WS_Segm7; extern Ki_WorkSheetData WS_Segm7;
#if defined(KICAD_GOST)
extern Ki_WorkSheetData WS_Izm;
extern Ki_WorkSheetData WS_Razr;
extern Ki_WorkSheetData WS_Prov;
extern Ki_WorkSheetData WS_TKon;
extern Ki_WorkSheetData WS_NKon;
extern Ki_WorkSheetData WS_Utv;
extern Ki_WorkSheetData WS_List;
extern Ki_WorkSheetData WS_NDoc;
extern Ki_WorkSheetData WS_Podp;
extern Ki_WorkSheetData WS_Data;
extern Ki_WorkSheetData WS_Art;
extern Ki_WorkSheetData WS_Mass;
extern Ki_WorkSheetData WS_Msht;
extern Ki_WorkSheetData WS_List1;
extern Ki_WorkSheetData WS_List2;
extern Ki_WorkSheetData WS_Segm8;
extern Ki_WorkSheetData WS_Segm9;
extern Ki_WorkSheetData WS_Segm10;
extern Ki_WorkSheetData WS_Segm11;
extern Ki_WorkSheetData WS_Segm12;
extern Ki_WorkSheetData WS_Segm13;
extern Ki_WorkSheetData WS_Segm14;
extern Ki_WorkSheetData WS_Segm15;
extern Ki_WorkSheetData WS_Segm16;
extern Ki_WorkSheetData WS_Segm17;
extern Ki_WorkSheetData WS_Segm18;
extern Ki_WorkSheetData WS_Segm19;
extern Ki_WorkSheetData WS_Segm20;
extern Ki_WorkSheetData WS_Segm21;
extern Ki_WorkSheetData WS_Segm22;
extern Ki_WorkSheetData WS_Segm23;
extern Ki_WorkSheetData WS_Segm24;
extern Ki_WorkSheetData WS_Segm25;
extern Ki_WorkSheetData WS_CADRE_D;
extern Ki_WorkSheetData WS_Segm1_D;
extern Ki_WorkSheetData WS_Segm2_D;
extern Ki_WorkSheetData WS_Segm3_D;
extern Ki_WorkSheetData WS_Segm4_D;
extern Ki_WorkSheetData WS_Segm5_D;
extern Ki_WorkSheetData WS_Segm6_D;
extern Ki_WorkSheetData WS_Segm7_D;
extern Ki_WorkSheetData WS_Segm8_D;
extern Ki_WorkSheetData WS_Segm9_D;
extern Ki_WorkSheetData WS_Segm10_D;
extern Ki_WorkSheetData WS_Segm11_D;
extern Ki_WorkSheetData WS_Izm_D;
extern Ki_WorkSheetData WS_List_D;
extern Ki_WorkSheetData WS_NDoc_D;
extern Ki_WorkSheetData WS_Podp_D;
extern Ki_WorkSheetData WS_Date_D;
extern Ki_WorkSheetData WS_List1_D;
extern Ki_WorkSheetData WS_ListN_D;
extern Ki_WorkSheetData WS_Segm1_LU;
extern Ki_WorkSheetData WS_Segm2_LU;
extern Ki_WorkSheetData WS_Segm3_LU;
extern Ki_WorkSheetData WS_Segm4_LU;
extern Ki_WorkSheetData WS_Segm5_LU;
extern Ki_WorkSheetData WS_Segm6_LU;
extern Ki_WorkSheetData WS_Segm7_LU;
extern Ki_WorkSheetData WS_Segm8_LU;
extern Ki_WorkSheetData WS_Segm9_LU;
extern Ki_WorkSheetData WS_Segm10_LU;
extern Ki_WorkSheetData WS_Segm11_LU;
extern Ki_WorkSheetData WS_Segm12_LU;
extern Ki_WorkSheetData WS_Segm13_LU;
extern Ki_WorkSheetData WS_Podp1_LU;
extern Ki_WorkSheetData WS_Podp2_LU;
extern Ki_WorkSheetData WS_Podp3_LU;
extern Ki_WorkSheetData WS_Podp4_LU;
extern Ki_WorkSheetData WS_Podp5_LU;
extern Ki_WorkSheetData WS_Podp6_LU;
extern Ki_WorkSheetData WS_Podp7_LU;
extern Ki_WorkSheetData WS_Segm1_LT;
extern Ki_WorkSheetData WS_Segm2_LT;
extern Ki_WorkSheetData WS_Segm3_LT;
extern Ki_WorkSheetData WS_Segm4_LT;
extern Ki_WorkSheetData WS_Segm5_LT;
#endif #endif
#endif // WORKSHEET_H_ #endif // WORKSHEET_H_
File mode changed from 100755 to 100644
...@@ -924,7 +924,7 @@ bool GPCB_PLUGIN::FootprintLibDelete( const wxString& aLibraryPath, PROPERTIES* ...@@ -924,7 +924,7 @@ bool GPCB_PLUGIN::FootprintLibDelete( const wxString& aLibraryPath, PROPERTIES*
if( tmp.GetExt() != KiCadFootprintFileExtension ) if( tmp.GetExt() != KiCadFootprintFileExtension )
{ {
THROW_IO_ERROR( wxString::Format( _( "unexpected file '%s' has found in library path '%'" ), THROW_IO_ERROR( wxString::Format( _( "unexpected file '%s' has found in library path '%s'" ),
files[i].GetData(), aLibraryPath.GetData() ) ); files[i].GetData(), aLibraryPath.GetData() ) );
} }
} }
......
...@@ -1770,7 +1770,7 @@ bool PCB_IO::FootprintLibDelete( const wxString& aLibraryPath, PROPERTIES* aProp ...@@ -1770,7 +1770,7 @@ bool PCB_IO::FootprintLibDelete( const wxString& aLibraryPath, PROPERTIES* aProp
if( tmp.GetExt() != KiCadFootprintFileExtension ) if( tmp.GetExt() != KiCadFootprintFileExtension )
{ {
THROW_IO_ERROR( wxString::Format( _( "unexpected file '%s' has found in library path '%'" ), THROW_IO_ERROR( wxString::Format( _( "unexpected file '%s' has found in library path '%s'" ),
files[i].GetData(), aLibraryPath.GetData() ) ); files[i].GetData(), aLibraryPath.GetData() ) );
} }
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment