80 if(
color != COLOR4D::WHITE )
101 if( size.
x > size.
y )
103 std::swap( size.
x, size.
y );
114 if( aTraceMode ==
FILLED )
115 ThickSegment( a + aPadPos, b + aPadPos, size.
x, aTraceMode,
nullptr );
124 if( aTraceMode ==
FILLED )
126 Circle( aPadPos, aDiameter, FILL_T::FILLED_SHAPE, 0 );
142 std::vector<VECTOR2I> cornerList;
144 cornerList.reserve( 4 );
146 if( aTraceMode ==
FILLED )
155 corner.
x = aPadPos.
x - dx;
156 corner.
y = aPadPos.
y + dy;
157 cornerList.push_back( corner );
158 corner.
x = aPadPos.
x - dx;
159 corner.
y = aPadPos.
y - dy;
160 cornerList.push_back( corner );
161 corner.
x = aPadPos.
x + dx;
162 corner.
y = aPadPos.
y - dy;
163 cornerList.push_back( corner );
164 corner.
x = aPadPos.
x + dx;
165 corner.
y = aPadPos.
y + dy,
166 cornerList.push_back( corner );
168 for(
unsigned ii = 0; ii < cornerList.size(); ii++ )
169 RotatePoint( cornerList[ii], aPadPos, aPadOrient );
171 cornerList.push_back( cornerList[0] );
173 PlotPoly( cornerList, ( aTraceMode ==
FILLED ) ? FILL_T::FILLED_SHAPE : FILL_T::NO_FILL,
179 int aCornerRadius,
const EDA_ANGLE& aOrient,
182 if( aTraceMode ==
FILLED )
191 std::vector<VECTOR2I> cornerList;
197 for(
int ii = 0; ii < poly.
PointCount(); ++ii )
198 cornerList.emplace_back( poly.
CPoint( ii ).
x, poly.
CPoint( ii ).
y );
201 cornerList.push_back( cornerList[0] );
203 PlotPoly( cornerList, ( aTraceMode ==
FILLED ) ? FILL_T::FILLED_SHAPE : FILL_T::NO_FILL,
212 if( aTraceMode ==
FILLED )
217 std::vector<VECTOR2I> cornerList;
219 for(
int cnt = 0; cnt < aPolygons->
OutlineCount(); ++cnt )
224 for(
int ii = 0; ii < poly.
PointCount(); ++ii )
225 cornerList.emplace_back( poly.
CPoint( ii ).
x, poly.
CPoint( ii ).
y );
228 cornerList.push_back( cornerList[0] );
230 PlotPoly( cornerList, ( aTraceMode ==
FILLED ) ? FILL_T::FILLED_SHAPE : FILL_T::NO_FILL,
240 static std::vector<VECTOR2I> cornerList;
243 for(
int ii = 0; ii < 4; ii++ )
244 cornerList.push_back( aCorners[ii] );
246 if( aTraceMode ==
FILLED )
255 for(
int ii = 0; ii < 4; ii++ )
258 cornerList[ii] += aPadPos;
261 cornerList.push_back( cornerList[0] );
262 PlotPoly( cornerList, ( aTraceMode ==
FILLED ) ? FILL_T::FILLED_SHAPE : FILL_T::NO_FILL,
279 std::string converted;
283 for(
unsigned i = 0; i < aUnicode.Len(); i++ )
286 wchar_t ch = aUnicode[i];
317 bool aItalic,
bool aBold )
323 for(
wchar_t asciiCode : aText)
326 if( asciiCode !=
'~' && asciiCode < 256 )
327 tally += width_table[asciiCode];
336 double aScale,
bool aMirror )
353 const wxString& aText,
362 double *wideningFactor,
369 double *heightFactor )
401 *wideningFactor = sz_dev.
x / sz_dev.
y;
405 *wideningFactor = -*wideningFactor;
409 double sinalpha = sin( alpha );
410 double cosalpha = cos( alpha );
432 else if( aWidth == 0 )
435 wxASSERT_MSG( aWidth > 0,
"Plotter called to set negative pen width" );
454 r = ( r * a ) + ( 1 - a );
455 g = ( g * a ) + ( 1 - a );
456 b = ( b * a ) + ( 1 - a );
460 fprintf(
m_outputFile,
"%.3g %.3g %.3g setrgbcolor\n", r, g, b );
468 case LINE_STYLE::DASH:
473 case LINE_STYLE::DOT:
478 case LINE_STYLE::DASHDOT:
484 case LINE_STYLE::DASHDOTDOT:
485 fprintf(
m_outputFile,
"[%d %d %d %d %d %d] 0 setdash\n",
499 if( fill == FILL_T::NO_FILL && width <= 0 )
506 fprintf(
m_outputFile,
"%g %g %g %g rect%d\n", p1_dev.
x, p1_dev.
y,
507 p2_dev.
x - p1_dev.
x, p2_dev.
y - p1_dev.
y,
getFillId( fill ) );
513 if( fill == FILL_T::NO_FILL && width <= 0 )
540 VECTOR2D start( aRadius * aStartAngle.
Cos(), aRadius * aStartAngle.
Sin() );
553 std::swap( startAngle, endAngle );
557 fprintf(
m_outputFile,
"%g %g %g %g %g arc%d\n", center_device.
x, center_device.
y,
564 if( aCornerList.size() <= 1 )
572 for(
unsigned ii = 1; ii < aCornerList.size(); ii++ )
586 pix_size.
x = aImage.GetWidth();
587 pix_size.
y = aImage.GetHeight();
588 VECTOR2D drawsize( aScaleFactor * pix_size.
x,
589 aScaleFactor * pix_size.
y );
593 start.
x -= drawsize.
x / 2;
594 start.
y += drawsize.
y / 2;
598 end.
x = start.
x + drawsize.
x;
599 end.
y = start.
y - drawsize.
y;
606 fprintf(
m_outputFile,
"%g %g translate\n", start_dev.
x, start_dev.
y );
618 fprintf(
m_outputFile,
" [%d 0 0 %d 0 %d]\n", pix_size.
x, -pix_size.
y , pix_size.
y);
621 fprintf(
m_outputFile,
"{currentfile pix readhexstring pop}\n" );
632 for(
int yy = 0; yy < pix_size.
y; yy ++ )
634 for(
int xx = 0; xx < pix_size.
x; xx++, jj++ )
642 int red, green, blue;
643 red = aImage.GetRed( xx, yy) & 0xFF;
644 green = aImage.GetGreen( xx, yy) & 0xFF;
645 blue = aImage.GetBlue( xx, yy) & 0xFF;
648 if( aImage.HasAlpha() )
650 unsigned char alpha = aImage.GetAlpha( xx, yy ) & 0xFF;
654 float a = 1.0 - ( (float) alpha / 255.0 );
655 red = ( int )(
red + ( a * 0xFF ) ) & 0xFF;
656 green = ( int )( green + ( a * 0xFF ) ) & 0xFF;
657 blue = ( int )( blue + ( a * 0xFF ) ) & 0xFF;
661 if( aImage.HasMask() )
663 if(
red == aImage.GetMaskRed() && green == aImage.GetMaskGreen()
664 && blue == aImage.GetMaskBlue() )
679 unsigned char grey =
KiROUND(
red * 0.2126 + green * 0.7152 + blue * 0.0722 );
717 pos_dev.
x, pos_dev.
y,
718 ( plume==
'D' ) ?
"line" :
"move" );
730 static const char* PSMacro[] =
733 "/line { newpath moveto lineto stroke } bind def\n",
734 "/cir0 { newpath 0 360 arc stroke } bind def\n",
735 "/cir1 { newpath 0 360 arc gsave fill grestore stroke } bind def\n",
736 "/cir2 { newpath 0 360 arc gsave fill grestore stroke } bind def\n",
737 "/arc0 { newpath arc stroke } bind def\n",
738 "/arc1 { newpath 4 index 4 index moveto arc closepath gsave fill\n",
739 " grestore stroke } bind def\n",
740 "/arc2 { newpath 4 index 4 index moveto arc closepath gsave fill\n",
741 " grestore stroke } bind def\n",
742 "/poly0 { stroke } bind def\n",
743 "/poly1 { closepath gsave fill grestore stroke } bind def\n",
744 "/poly2 { closepath gsave fill grestore stroke } bind def\n",
745 "/rect0 { rectstroke } bind def\n",
746 "/rect1 { rectfill } bind def\n",
747 "/rect2 { rectfill } bind def\n",
748 "/linemode0 { 0 setlinecap 0 setlinejoin 0 setlinewidth } bind def\n",
749 "/linemode1 { 1 setlinecap 1 setlinejoin } bind def\n",
750 "/dashedline { [200] 100 setdash } bind def\n",
751 "/solidline { [] 0 setdash } bind def\n",
754 "/phantomshow { moveto\n",
755 " /KicadFont findfont 0.000001 scalefont setfont\n",
756 " show } bind def\n",
759 "/textshow { gsave\n",
760 " findfont exch scalefont setfont concat 1 scale 0 0 moveto show\n",
765 " findfont dup length dict begin\n",
766 " { 1 index /FID ne\n",
768 " { pop pop } ifelse\n",
770 " /Encoding ISOLatin1Encoding def\n",
775 "/KicadFont /Helvetica reencodefont definefont pop\n",
776 "/KicadFont-Bold /Helvetica-Bold reencodefont definefont pop\n",
777 "/KicadFont-Oblique /Helvetica-Oblique reencodefont definefont pop\n",
778 "/KicadFont-BoldOblique /Helvetica-BoldOblique reencodefont definefont pop\n",
783 time_t time1970 = time(
nullptr );
791 fprintf(
m_outputFile,
"%%%%CreationDate: %s", ctime( &time1970 ) );
797 const double BIGPTsPERMIL = 0.072;
811 (
int) ceil( psPaperSize.
x * BIGPTsPERMIL ),
812 (
int) ceil( psPaperSize.
y * BIGPTsPERMIL ) );
831 fprintf(
m_outputFile,
"%%%%DocumentMedia: Custom %d %d 0 () ()\n",
832 KiROUND( psPaperSize.
x * BIGPTsPERMIL ),
833 KiROUND( psPaperSize.
y * BIGPTsPERMIL ) );
837 fprintf(
m_outputFile,
"%%%%DocumentMedia: %s %d %d 0 () ()\n",
839 KiROUND( psPaperSize.
x * BIGPTsPERMIL ),
840 KiROUND( psPaperSize.
y * BIGPTsPERMIL ) );
846 fprintf(
m_outputFile,
"%%%%Orientation: Landscape\n" );
852 for(
int ii = 0; PSMacro[ii] !=
nullptr; ii++ )
862 fprintf(
m_outputFile,
"%%Page: %s 1\n", page_num.c_str() );
864 fputs(
"%%BeginPageSetup\n"
866 "0.0072 0.0072 scale\n"
872 fprintf(
m_outputFile,
"%d 0 translate 90 rotate\n", 10 * psPaperSize.
x );
903 const wxString& aText,
911 bool aMultilineAllowed,
924 fprintf(
m_outputFile,
"%s %g %g phantomshow\n", ps_test.c_str(), pos_dev.
x, pos_dev.
y );
927 PLOTTER::Text( aPos, aColor, aText, aOrient, aSize, aH_justify, aV_justify, aWidth, aItalic,
928 aBold, aMultilineAllowed, aFont, aFontMetrics, aData );
934 const wxString& aText,
948 fprintf(
m_outputFile,
"%s %g %g phantomshow\n", ps_test.c_str(), pos_dev.
x, pos_dev.
y );
951 PLOTTER::PlotText( aPos, aColor, aText, aAttributes, aFont, aFontMetrics, aData );
959 0.278, 0.278, 0.278, 0.278, 0.278, 0.278, 0.278, 0.278,
960 0.278, 0.278, 0.278, 0.278, 0.278, 0.278, 0.278, 0.278,
961 0.278, 0.278, 0.278, 0.278, 0.278, 0.278, 0.278, 0.278,
962 0.278, 0.278, 0.278, 0.278, 0.278, 0.278, 0.278, 0.278,
963 0.278, 0.278, 0.355, 0.556, 0.556, 0.889, 0.667, 0.191,
964 0.333, 0.333, 0.389, 0.584, 0.278, 0.333, 0.278, 0.278,
965 0.556, 0.556, 0.556, 0.556, 0.556, 0.556, 0.556, 0.556,
966 0.556, 0.556, 0.278, 0.278, 0.584, 0.584, 0.584, 0.556,
967 1.015, 0.667, 0.667, 0.722, 0.722, 0.667, 0.611, 0.778,
968 0.722, 0.278, 0.500, 0.667, 0.556, 0.833, 0.722, 0.778,
969 0.667, 0.778, 0.722, 0.667, 0.611, 0.722, 0.667, 0.944,
970 0.667, 0.667, 0.611, 0.278, 0.278, 0.278, 0.469, 0.556,
971 0.333, 0.556, 0.556, 0.500, 0.556, 0.556, 0.278, 0.556,
972 0.556, 0.222, 0.222, 0.500, 0.222, 0.833, 0.556, 0.556,
973 0.556, 0.556, 0.333, 0.500, 0.278, 0.556, 0.500, 0.722,
974 0.500, 0.500, 0.500, 0.334, 0.260, 0.334, 0.584, 0.278,
975 0.278, 0.278, 0.222, 0.556, 0.333, 1.000, 0.556, 0.556,
976 0.333, 1.000, 0.667, 0.333, 1.000, 0.278, 0.278, 0.278,
977 0.278, 0.222, 0.222, 0.333, 0.333, 0.350, 0.556, 1.000,
978 0.333, 1.000, 0.500, 0.333, 0.944, 0.278, 0.278, 0.667,
979 0.278, 0.333, 0.556, 0.556, 0.556, 0.556, 0.260, 0.556,
980 0.333, 0.737, 0.370, 0.556, 0.584, 0.333, 0.737, 0.333,
981 0.400, 0.584, 0.333, 0.333, 0.333, 0.556, 0.537, 0.278,
982 0.333, 0.333, 0.365, 0.556, 0.834, 0.834, 0.834, 0.611,
983 0.667, 0.667, 0.667, 0.667, 0.667, 0.667, 1.000, 0.722,
984 0.667, 0.667, 0.667, 0.667, 0.278, 0.278, 0.278, 0.278,
985 0.722, 0.722, 0.778, 0.778, 0.778, 0.778, 0.778, 0.584,
986 0.778, 0.722, 0.722, 0.722, 0.722, 0.667, 0.667, 0.611,
987 0.556, 0.556, 0.556, 0.556, 0.556, 0.556, 0.889, 0.500,
988 0.556, 0.556, 0.556, 0.556, 0.278, 0.278, 0.278, 0.278,
989 0.556, 0.556, 0.556, 0.556, 0.556, 0.556, 0.556, 0.584,
990 0.611, 0.556, 0.556, 0.556, 0.556, 0.500, 0.556, 0.500
998 0.278, 0.278, 0.278, 0.278, 0.278, 0.278, 0.278, 0.278,
999 0.278, 0.278, 0.278, 0.278, 0.278, 0.278, 0.278, 0.278,
1000 0.278, 0.278, 0.278, 0.278, 0.278, 0.278, 0.278, 0.278,
1001 0.278, 0.278, 0.278, 0.278, 0.278, 0.278, 0.278, 0.278,
1002 0.278, 0.333, 0.474, 0.556, 0.556, 0.889, 0.722, 0.238,
1003 0.333, 0.333, 0.389, 0.584, 0.278, 0.333, 0.278, 0.278,
1004 0.556, 0.556, 0.556, 0.556, 0.556, 0.556, 0.556, 0.556,
1005 0.556, 0.556, 0.333, 0.333, 0.584, 0.584, 0.584, 0.611,
1006 0.975, 0.722, 0.722, 0.722, 0.722, 0.667, 0.611, 0.778,
1007 0.722, 0.278, 0.556, 0.722, 0.611, 0.833, 0.722, 0.778,
1008 0.667, 0.778, 0.722, 0.667, 0.611, 0.722, 0.667, 0.944,
1009 0.667, 0.667, 0.611, 0.333, 0.278, 0.333, 0.584, 0.556,
1010 0.333, 0.556, 0.611, 0.556, 0.611, 0.556, 0.333, 0.611,
1011 0.611, 0.278, 0.278, 0.556, 0.278, 0.889, 0.611, 0.611,
1012 0.611, 0.611, 0.389, 0.556, 0.333, 0.611, 0.556, 0.778,
1013 0.556, 0.556, 0.500, 0.389, 0.280, 0.389, 0.584, 0.278,
1014 0.278, 0.278, 0.278, 0.556, 0.500, 1.000, 0.556, 0.556,
1015 0.333, 1.000, 0.667, 0.333, 1.000, 0.278, 0.278, 0.278,
1016 0.278, 0.278, 0.278, 0.500, 0.500, 0.350, 0.556, 1.000,
1017 0.333, 1.000, 0.556, 0.333, 0.944, 0.278, 0.278, 0.667,
1018 0.278, 0.333, 0.556, 0.556, 0.556, 0.556, 0.280, 0.556,
1019 0.333, 0.737, 0.370, 0.556, 0.584, 0.333, 0.737, 0.333,
1020 0.400, 0.584, 0.333, 0.333, 0.333, 0.611, 0.556, 0.278,
1021 0.333, 0.333, 0.365, 0.556, 0.834, 0.834, 0.834, 0.611,
1022 0.722, 0.722, 0.722, 0.722, 0.722, 0.722, 1.000, 0.722,
1023 0.667, 0.667, 0.667, 0.667, 0.278, 0.278, 0.278, 0.278,
1024 0.722, 0.722, 0.778, 0.778, 0.778, 0.778, 0.778, 0.584,
1025 0.778, 0.722, 0.722, 0.722, 0.722, 0.667, 0.667, 0.611,
1026 0.556, 0.556, 0.556, 0.556, 0.556, 0.556, 0.889, 0.556,
1027 0.556, 0.556, 0.556, 0.556, 0.278, 0.278, 0.278, 0.278,
1028 0.611, 0.611, 0.611, 0.611, 0.611, 0.611, 0.611, 0.584,
1029 0.611, 0.611, 0.611, 0.611, 0.611, 0.556, 0.611, 0.556
1037 0.278, 0.278, 0.278, 0.278, 0.278, 0.278, 0.278, 0.278,
1038 0.278, 0.278, 0.278, 0.278, 0.278, 0.278, 0.278, 0.278,
1039 0.278, 0.278, 0.278, 0.278, 0.278, 0.278, 0.278, 0.278,
1040 0.278, 0.278, 0.278, 0.278, 0.278, 0.278, 0.278, 0.278,
1041 0.278, 0.278, 0.355, 0.556, 0.556, 0.889, 0.667, 0.191,
1042 0.333, 0.333, 0.389, 0.584, 0.278, 0.333, 0.278, 0.278,
1043 0.556, 0.556, 0.556, 0.556, 0.556, 0.556, 0.556, 0.556,
1044 0.556, 0.556, 0.278, 0.278, 0.584, 0.584, 0.584, 0.556,
1045 1.015, 0.667, 0.667, 0.722, 0.722, 0.667, 0.611, 0.778,
1046 0.722, 0.278, 0.500, 0.667, 0.556, 0.833, 0.722, 0.778,
1047 0.667, 0.778, 0.722, 0.667, 0.611, 0.722, 0.667, 0.944,
1048 0.667, 0.667, 0.611, 0.278, 0.278, 0.278, 0.469, 0.556,
1049 0.333, 0.556, 0.556, 0.500, 0.556, 0.556, 0.278, 0.556,
1050 0.556, 0.222, 0.222, 0.500, 0.222, 0.833, 0.556, 0.556,
1051 0.556, 0.556, 0.333, 0.500, 0.278, 0.556, 0.500, 0.722,
1052 0.500, 0.500, 0.500, 0.334, 0.260, 0.334, 0.584, 0.278,
1053 0.278, 0.278, 0.222, 0.556, 0.333, 1.000, 0.556, 0.556,
1054 0.333, 1.000, 0.667, 0.333, 1.000, 0.278, 0.278, 0.278,
1055 0.278, 0.222, 0.222, 0.333, 0.333, 0.350, 0.556, 1.000,
1056 0.333, 1.000, 0.500, 0.333, 0.944, 0.278, 0.278, 0.667,
1057 0.278, 0.333, 0.556, 0.556, 0.556, 0.556, 0.260, 0.556,
1058 0.333, 0.737, 0.370, 0.556, 0.584, 0.333, 0.737, 0.333,
1059 0.400, 0.584, 0.333, 0.333, 0.333, 0.556, 0.537, 0.278,
1060 0.333, 0.333, 0.365, 0.556, 0.834, 0.834, 0.834, 0.611,
1061 0.667, 0.667, 0.667, 0.667, 0.667, 0.667, 1.000, 0.722,
1062 0.667, 0.667, 0.667, 0.667, 0.278, 0.278, 0.278, 0.278,
1063 0.722, 0.722, 0.778, 0.778, 0.778, 0.778, 0.778, 0.584,
1064 0.778, 0.722, 0.722, 0.722, 0.722, 0.667, 0.667, 0.611,
1065 0.556, 0.556, 0.556, 0.556, 0.556, 0.556, 0.889, 0.500,
1066 0.556, 0.556, 0.556, 0.556, 0.278, 0.278, 0.278, 0.278,
1067 0.556, 0.556, 0.556, 0.556, 0.556, 0.556, 0.556, 0.584,
1068 0.611, 0.556, 0.556, 0.556, 0.556, 0.500, 0.556, 0.500
1076 0.278, 0.278, 0.278, 0.278, 0.278, 0.278, 0.278, 0.278,
1077 0.278, 0.278, 0.278, 0.278, 0.278, 0.278, 0.278, 0.278,
1078 0.278, 0.278, 0.278, 0.278, 0.278, 0.278, 0.278, 0.278,
1079 0.278, 0.278, 0.278, 0.278, 0.278, 0.278, 0.278, 0.278,
1080 0.278, 0.333, 0.474, 0.556, 0.556, 0.889, 0.722, 0.238,
1081 0.333, 0.333, 0.389, 0.584, 0.278, 0.333, 0.278, 0.278,
1082 0.556, 0.556, 0.556, 0.556, 0.556, 0.556, 0.556, 0.556,
1083 0.556, 0.556, 0.333, 0.333, 0.584, 0.584, 0.584, 0.611,
1084 0.975, 0.722, 0.722, 0.722, 0.722, 0.667, 0.611, 0.778,
1085 0.722, 0.278, 0.556, 0.722, 0.611, 0.833, 0.722, 0.778,
1086 0.667, 0.778, 0.722, 0.667, 0.611, 0.722, 0.667, 0.944,
1087 0.667, 0.667, 0.611, 0.333, 0.278, 0.333, 0.584, 0.556,
1088 0.333, 0.556, 0.611, 0.556, 0.611, 0.556, 0.333, 0.611,
1089 0.611, 0.278, 0.278, 0.556, 0.278, 0.889, 0.611, 0.611,
1090 0.611, 0.611, 0.389, 0.556, 0.333, 0.611, 0.556, 0.778,
1091 0.556, 0.556, 0.500, 0.389, 0.280, 0.389, 0.584, 0.278,
1092 0.278, 0.278, 0.278, 0.556, 0.500, 1.000, 0.556, 0.556,
1093 0.333, 1.000, 0.667, 0.333, 1.000, 0.278, 0.278, 0.278,
1094 0.278, 0.278, 0.278, 0.500, 0.500, 0.350, 0.556, 1.000,
1095 0.333, 1.000, 0.556, 0.333, 0.944, 0.278, 0.278, 0.667,
1096 0.278, 0.333, 0.556, 0.556, 0.556, 0.556, 0.280, 0.556,
1097 0.333, 0.737, 0.370, 0.556, 0.584, 0.333, 0.737, 0.333,
1098 0.400, 0.584, 0.333, 0.333, 0.333, 0.611, 0.556, 0.278,
1099 0.333, 0.333, 0.365, 0.556, 0.834, 0.834, 0.834, 0.611,
1100 0.722, 0.722, 0.722, 0.722, 0.722, 0.722, 1.000, 0.722,
1101 0.667, 0.667, 0.667, 0.667, 0.278, 0.278, 0.278, 0.278,
1102 0.722, 0.722, 0.778, 0.778, 0.778, 0.778, 0.778, 0.584,
1103 0.778, 0.722, 0.722, 0.722, 0.722, 0.667, 0.667, 0.611,
1104 0.556, 0.556, 0.556, 0.556, 0.556, 0.556, 0.889, 0.556,
1105 0.556, 0.556, 0.556, 0.556, 0.278, 0.278, 0.278, 0.278,
1106 0.611, 0.611, 0.611, 0.611, 0.611, 0.611, 0.611, 0.584,
1107 0.611, 0.611, 0.611, 0.611, 0.611, 0.556, 0.611, 0.556
VECTOR2D mapCoords(const VECTOR2D &aSource)
const double hvbo_widths[256]
Character widths for Helvetica-BoldOblique.
static int getFillId(FILL_T aFill)
const double hvb_widths[256]
Character widths for Helvetica-Bold.
const double hv_widths[256]
Character widths for Helvetica.
const double hvo_widths[256]
Character widths for Helvetica-Oblique.
FONT is an abstract base class for both outline and stroke fonts.
A color representation with 4 components: red, green, blue, alpha.
int GetDefaultPenWidth() const
const VECTOR2D & GetSizeMils() const
double GetHeightMils() const
const wxString & GetType() const
double GetWidthMils() const
double GetDotMarkLenIU(int aLineWidth) const
virtual void ThickSegment(const VECTOR2I &start, const VECTOR2I &end, int width, OUTLINE_MODE tracemode, void *aData)
double GetDashGapLenIU(int aLineWidth) const
virtual void Circle(const VECTOR2I &pos, int diametre, FILL_T fill, int width=USE_DEFAULT_LINE_WIDTH)=0
static const int USE_DEFAULT_LINE_WIDTH
virtual VECTOR2D userToDeviceCoordinates(const VECTOR2I &aCoordinate)
Modify coordinates according to the orientation, scale factor, and offsets trace.
virtual VECTOR2D userToDeviceSize(const VECTOR2I &size)
Modify size according to the plotter scale factors (VECTOR2I version, returns a VECTOR2D).
void sketchOval(const VECTOR2I &aPos, const VECTOR2I &aSize, const EDA_ANGLE &aOrient, int aWidth)
int GetPlotterArcHighDef() const
double m_plotScale
Plot scale - chosen by the user (even implicitly with 'fit in a4')
FILE * m_outputFile
Output file.
virtual void SetCurrentLineWidth(int width, void *aData=nullptr)=0
Set the line width for the next drawing.
virtual void PlotPoly(const std::vector< VECTOR2I > &aCornerList, FILL_T aFill, int aWidth=USE_DEFAULT_LINE_WIDTH, void *aData=nullptr)=0
Draw a polygon ( filled or not ).
static const int DO_NOT_SET_LINE_WIDTH
RENDER_SETTINGS * m_renderSettings
virtual void Text(const VECTOR2I &aPos, const COLOR4D &aColor, const wxString &aText, const EDA_ANGLE &aOrient, const VECTOR2I &aSize, enum GR_TEXT_H_ALIGN_T aH_justify, enum GR_TEXT_V_ALIGN_T aV_justify, int aPenWidth, bool aItalic, bool aBold, bool aMultilineAllowed, KIFONT::FONT *aFont, const KIFONT::METRICS &aFontMetrics, void *aData=nullptr)
Draw text with the plotter.
virtual void PlotText(const VECTOR2I &aPos, const COLOR4D &aColor, const wxString &aText, const TEXT_ATTRIBUTES &aAttributes, KIFONT::FONT *aFont, const KIFONT::METRICS &aFontMetrics, void *aData=nullptr)
virtual int GetCurrentLineWidth() const
double GetDashMarkLenIU(int aLineWidth) const
static const double postscriptTextAscent
Height of the postscript font (from the AFM)
virtual void FlashRegularPolygon(const VECTOR2I &aShapePos, int aDiameter, int aCornerCount, const EDA_ANGLE &aOrient, OUTLINE_MODE aTraceMode, void *aData) override
Flash a regular polygon.
virtual void SetColor(const COLOR4D &color) override
The SetColor implementation is split with the subclasses: the PSLIKE computes the rgb values,...
virtual void FlashPadRoundRect(const VECTOR2I &aPadPos, const VECTOR2I &aSize, int aCornerRadius, const EDA_ANGLE &aOrient, OUTLINE_MODE aTraceMode, void *aData) override
virtual void FlashPadCustom(const VECTOR2I &aPadPos, const VECTOR2I &aSize, const EDA_ANGLE &aOrient, SHAPE_POLY_SET *aPolygons, OUTLINE_MODE aTraceMode, void *aData) override
virtual void FlashPadCircle(const VECTOR2I &aPadPos, int aDiameter, OUTLINE_MODE aTraceMode, void *aData) override
virtual void emitSetRGBColor(double r, double g, double b, double a)=0
Virtual primitive for emitting the setrgbcolor operator.
PLOT_TEXT_MODE m_textMode
How to draw text.
virtual void FlashPadTrapez(const VECTOR2I &aPadPos, const VECTOR2I *aCorners, const EDA_ANGLE &aPadOrient, OUTLINE_MODE aTraceMode, void *aData) override
Flash a trapezoidal pad.
virtual void FlashPadRect(const VECTOR2I &aPadPos, const VECTOR2I &aSize, const EDA_ANGLE &aPadOrient, OUTLINE_MODE aTraceMode, void *aData) override
int returnPostscriptTextWidth(const wxString &aText, int aXSize, bool aItalic, bool aBold)
Sister function for the GRTextWidth in gr_text.cpp Does the same processing (i.e.
double plotScaleAdjX
Fine user scale adjust ( = 1.0 if no correction)
void computeTextParameters(const VECTOR2I &aPos, const wxString &aText, const EDA_ANGLE &aOrient, const VECTOR2I &aSize, bool aMirror, enum GR_TEXT_H_ALIGN_T aH_justify, enum GR_TEXT_V_ALIGN_T aV_justify, int aWidth, bool aItalic, bool aBold, double *wideningFactor, double *ctm_a, double *ctm_b, double *ctm_c, double *ctm_d, double *ctm_e, double *ctm_f, double *heightFactor)
This is the core for postscript/PDF text alignment.
virtual std::string encodeStringForPlotter(const wxString &aUnicode)
convert a wxString unicode string to a char string compatible with the accepted string plotter format...
virtual void FlashPadOval(const VECTOR2I &aPadPos, const VECTOR2I &aSize, const EDA_ANGLE &aPadOrient, OUTLINE_MODE aTraceMode, void *aData) override
virtual bool EndPlot() override
virtual void Text(const VECTOR2I &aPos, const COLOR4D &aColor, const wxString &aText, const EDA_ANGLE &aOrient, const VECTOR2I &aSize, enum GR_TEXT_H_ALIGN_T aH_justify, enum GR_TEXT_V_ALIGN_T aV_justify, int aWidth, bool aItalic, bool aBold, bool aMultilineAllowed, KIFONT::FONT *aFont, const KIFONT::METRICS &aFontMetrics, void *aData=nullptr) override
Draw text with the plotter.
virtual void PlotPoly(const std::vector< VECTOR2I > &aCornerList, FILL_T aFill, int aWidth=USE_DEFAULT_LINE_WIDTH, void *aData=nullptr) override
Draw a polygon ( filled or not ).
virtual void PlotText(const VECTOR2I &aPos, const COLOR4D &aColor, const wxString &aText, const TEXT_ATTRIBUTES &aAttributes, KIFONT::FONT *aFont, const KIFONT::METRICS &aFontMetrics, void *aData=nullptr) override
virtual void PlotImage(const wxImage &aImage, const VECTOR2I &aPos, double aScaleFactor) override
PostScript-likes at the moment are the only plot engines supporting bitmaps.
virtual void SetViewport(const VECTOR2I &aOffset, double aIusPerDecimil, double aScale, bool aMirror) override
Set the plot offset and scaling for the current plot.
virtual void Rect(const VECTOR2I &p1, const VECTOR2I &p2, FILL_T fill, int width=USE_DEFAULT_LINE_WIDTH) override
virtual void Circle(const VECTOR2I &pos, int diametre, FILL_T fill, int width=USE_DEFAULT_LINE_WIDTH) override
virtual void SetDash(int aLineWidth, LINE_STYLE aLineStyle) override
PostScript supports dashed lines.
virtual bool StartPlot(const wxString &aPageNumber) override
The code within this function (and the CloseFilePS function) creates postscript files whose contents ...
virtual void Arc(const VECTOR2D &aCenter, const EDA_ANGLE &aStartAngle, const EDA_ANGLE &aAngle, double aRadius, FILL_T aFill, int aWidth=USE_DEFAULT_LINE_WIDTH) override
virtual void emitSetRGBColor(double r, double g, double b, double a) override
Virtual primitive for emitting the setrgbcolor operator.
virtual void SetCurrentLineWidth(int width, void *aData=nullptr) override
Set the current line width (in IUs) for the next plot.
virtual void PenTo(const VECTOR2I &pos, char plume) override
Moveto/lineto primitive, moves the 'pen' to the specified direction.
Represent a polyline containing arcs as well as line segments: A chain of connected line and/or arc s...
int PointCount() const
Return the number of points (vertices) in this line chain.
const VECTOR2I & CPoint(int aIndex) const
Return a reference to a given point in the line chain.
Represent a set of closed polygons.
SHAPE_LINE_CHAIN & Outline(int aIndex)
Return the reference to aIndex-th outline in the set.
int OutlineCount() const
Return the number of outlines in the set.
void TransformRoundChamferedRectToPolygon(SHAPE_POLY_SET &aBuffer, const VECTOR2I &aPosition, const VECTOR2I &aSize, const EDA_ANGLE &aRotation, int aCornerRadius, double aChamferRatio, int aChamferCorners, int aInflate, int aError, ERROR_LOC aErrorLoc)
Convert a rectangle with rounded corners and/or chamfered corners to a polygon.
static constexpr EDA_ANGLE & ANGLE_90
static constexpr EDA_ANGLE & ANGLE_0
This file contains miscellaneous commonly used macros and functions.
#define KI_FALLTHROUGH
The KI_FALLTHROUGH macro is to be used when switch statement cases should purposely fallthrough from ...
EDA_ANGLE abs(const EDA_ANGLE &aAngle)
Plotting engines similar to ps (PostScript, Gerber, svg)
#define TO_UTF8(wxstring)
Convert a wxString to a UTF8 encoded C string for all wxWidgets build modes.
LINE_STYLE
Dashed line types.
void RotatePoint(int *pX, int *pY, const EDA_ANGLE &aAngle)
Calculate the new point of coord coord pX, pY, for a rotation center 0, 0.
constexpr ret_type KiROUND(fp_type v)
Round a floating point number to an integer using "round halfway cases away from zero".
VECTOR2< double > VECTOR2D