git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@808
c3d73ce0-8a6f-49c7-b76d-
6d57e0e08775
#endif
#if !USE_SHARED_LIBRARY
#endif
#if !USE_SHARED_LIBRARY
+IMPLEMENT_DYNAMIC_CLASS(wxPostScriptModule, wxModule)
IMPLEMENT_DYNAMIC_CLASS(wxPostScriptDC, wxDC)
IMPLEMENT_DYNAMIC_CLASS(wxPrintSetupData, wxObject)
IMPLEMENT_DYNAMIC_CLASS(wxPrintPaperType, wxObject)
IMPLEMENT_DYNAMIC_CLASS(wxPostScriptDC, wxDC)
IMPLEMENT_DYNAMIC_CLASS(wxPrintSetupData, wxObject)
IMPLEMENT_DYNAMIC_CLASS(wxPrintPaperType, wxObject)
"newpath\n" <<
(x+w/2) << " " << YSCALE (y+h/2) << " " <<
w/2 << " " << (h/2) << " " <<
"newpath\n" <<
(x+w/2) << " " << YSCALE (y+h/2) << " " <<
w/2 << " " << (h/2) << " " <<
"newpath\n" <<
(x+w/2) << " " << YSCALE (y+h/2) << " " <<
(w/2) << " " << (h/2) << " " <<
"newpath\n" <<
(x+w/2) << " " << YSCALE (y+h/2) << " " <<
(w/2) << " " << (h/2) << " " <<
<< (x + w) << " " << YSCALE (y + size - UnderlinePosition)
<< " lineto stroke grestore\n";
}
<< (x + w) << " " << YSCALE (y + size - UnderlinePosition)
<< " lineto stroke grestore\n";
}
CalcBoundingBox (x, (long)YSCALE (y + size));
CalcBoundingBox (x + size * strlen ((char *)(const char *)text), (long)YSCALE (y));
}
CalcBoundingBox (x, (long)YSCALE (y + size));
CalcBoundingBox (x + size * strlen ((char *)(const char *)text), (long)YSCALE (y));
}
// VMS is sh*t!
m_pstream = new ofstream;
if(fileBuffer) delete[] fileBuffer;
// VMS is sh*t!
m_pstream = new ofstream;
if(fileBuffer) delete[] fileBuffer;
- fileBuffer = new char[VMS_BUFSIZ];
+ fileBuffer = new char[VMS_BUFSIZ];
m_pstream->setbuf(fileBuffer,VMS_BUFSIZ);
m_pstream->open(wxThePrintSetupData->GetPrinterFile());
#else
m_pstream->setbuf(fileBuffer,VMS_BUFSIZ);
m_pstream->open(wxThePrintSetupData->GetPrinterFile());
#else
if (wxThePrintSetupData->GetPrinterOrientation() == PS_LANDSCAPE)
{
real_translate_y -= m_maxY;
if (wxThePrintSetupData->GetPrinterOrientation() == PS_LANDSCAPE)
{
real_translate_y -= m_maxY;
- // The following line can be used instead of the adjustment to
+ // The following line can be used instead of the adjustment to
// llx and urx above.
// real_translate_y -= m_minX;
*m_pstream << "90 rotate\n";
// llx and urx above.
// real_translate_y -= m_minX;
*m_pstream << "90 rotate\n";
* We should rationalise the scaling code to one place. JACS, October 1995
* Do we take the next 2 lines out or not?
*/
* We should rationalise the scaling code to one place. JACS, October 1995
* Do we take the next 2 lines out or not?
*/
*m_pstream << wx_printer_scale_x << " " << wx_printer_scale_y << " scale\n";
*m_pstream << wx_printer_translate_x << " " << real_translate_y << " translate\n";
#endif
*m_pstream << wx_printer_scale_x << " " << wx_printer_scale_y << " scale\n";
*m_pstream << wx_printer_translate_x << " " << real_translate_y << " translate\n";
#endif
char * opts = wxThePrintSetupData->GetPrinterOptions();
if (opts && *opts)
argv[argc++] = opts;
char * opts = wxThePrintSetupData->GetPrinterOptions();
if (opts && *opts)
argv[argc++] = opts;
argv[argc++] = wxThePrintSetupData->GetPrinterFile();
argv[argc++] = (char *) NULL;
wxExecute (argv, TRUE);
argv[argc++] = wxThePrintSetupData->GetPrinterFile();
argv[argc++] = (char *) NULL;
wxExecute (argv, TRUE);
XImage *image;
long j, i;
char s[3];
XImage *image;
long j, i;
char s[3];
#ifdef __WXGTK__
d = gdk_display;
#ifdef __WXGTK__
d = gdk_display;
GdkWindow *gwin = ((wxClientDC*)source)->GetWindow();
image = XGetImage(d, ((GdkWindowPrivate*)gwin)->xwindow, x, y, width, height, AllPlanes, ZPixmap);
GdkWindow *gwin = ((wxClientDC*)source)->GetWindow();
image = XGetImage(d, ((GdkWindowPrivate*)gwin)->xwindow, x, y, width, height, AllPlanes, ZPixmap);
#ifdef __WXMOTIF__
// TODO. for now, use global display
#ifdef __WXMOTIF__
// TODO. for now, use global display
cm = (Colormap) wxTheApp->GetMainColormap((WXDisplay*) d);
// TODO - implement GetPixmap() and uncomment this line
// image = XGetImage(d, source->GetPixmap(), x, y, width, height, AllPlanes, ZPixmap);
cm = (Colormap) wxTheApp->GetMainColormap((WXDisplay*) d);
// TODO - implement GetPixmap() and uncomment this line
// image = XGetImage(d, source->GetPixmap(), x, y, width, height, AllPlanes, ZPixmap);
pixel = cachedest[k];
goto install;
}
pixel = cachedest[k];
goto install;
}
cachesrc[cache_pos] = xcol.pixel = spixel;
XQueryColor(d, cm, &xcol);
cachesrc[cache_pos] = xcol.pixel = spixel;
XQueryColor(d, cm, &xcol);
long r, g, b;
r = (long)((double)(xcol.red) / MAX_COLOR);
long r, g, b;
r = (long)((double)(xcol.red) / MAX_COLOR);
pixel = (int)(255 * sqrt(((r * r) + (g * g) + (b * b)) / 3));
cachedest[cache_pos] = pixel;
pixel = (int)(255 * sqrt(((r * r) + (g * g) + (b * b)) / 3));
cachedest[cache_pos] = pixel;
if (++cache_pos >= CM_CACHE_SIZE) {
cache_pos = 0;
all_cache = TRUE;
}
if (++cache_pos >= CM_CACHE_SIZE) {
cache_pos = 0;
all_cache = TRUE;
}
int h, l;
h = (pixel >> 4) & 0xF;
int h, l;
h = (pixel >> 4) & 0xF;
s[1] = '0' + l;
else
s[1] = 'a' + (l - 10);
s[1] = '0' + l;
else
s[1] = 'a' + (l - 10);
*m_pstream << s;
}
*m_pstream << "\n";
*m_pstream << s;
}
*m_pstream << "\n";
*externalLeading = 0;
#else
// +++++ start of contributed code +++++
*externalLeading = 0;
#else
// +++++ start of contributed code +++++
// ************************************************************
// method for calculating string widths in postscript:
// read in the AFM (adobe font metrics) file for the
// ************************************************************
// method for calculating string widths in postscript:
// read in the AFM (adobe font metrics) file for the
//
// C 63 ; WX 444 ; N question ; B 49 -14 395 676 ;
//
//
// C 63 ; WX 444 ; N question ; B 49 -14 395 676 ;
//
- // that means, we have a character with ascii code 63, and width
+ // that means, we have a character with ascii code 63, and width
// (444/1000 * fontSize) points.
// the other data is ignored for now!
//
// when the font has changed, we read in the right AFM file and store the
// character widths in an array, which is processed below (see point 3.).
// (444/1000 * fontSize) points.
// the other data is ignored for now!
//
// when the font has changed, we read in the right AFM file and store the
// character widths in an array, which is processed below (see point 3.).
// new elements JC Sun Aug 25 23:21:44 MET DST 1996
// new elements JC Sun Aug 25 23:21:44 MET DST 1996
strcat(afmName,name);
strcat(afmName,".afm");
FILE *afmFile = fopen(afmName,"r");
strcat(afmName,name);
strcat(afmName,".afm");
FILE *afmFile = fopen(afmName,"r");
if(lastDescender!=INT_MIN){
height += (long)(((-lastDescender)/1000.0F) * Size); /* MATTHEW: forgot scale */
}
if(lastDescender!=INT_MIN){
height += (long)(((-lastDescender)/1000.0F) * Size); /* MATTHEW: forgot scale */
}
// return size values
*x = widthSum;
*y = height;
// return size values
*x = widthSum;
*y = height;
CalcBoundingBox( (long)x3, (long)(GetYOrigin() - y3));
}
/*
CalcBoundingBox( (long)x3, (long)(GetYOrigin() - y3));
}
/*
- * At this point, (x2,y2) and (c,d) are the position of the
+ * At this point, (x2,y2) and (c,d) are the position of the
* next-to-last and last point respectively, in the point list
*/
*(GetStream()) << c << " " << (GetYOrigin() - d) << " lineto stroke\n";
* next-to-last and last point respectively, in the point list
*/
*(GetStream()) << c << " " << (GetYOrigin() - d) << " lineto stroke\n";
int yPos = 40;
#if defined(__WXGTK__) || defined (__WXMOTIF__)
int yPos = 40;
#if defined(__WXGTK__) || defined (__WXMOTIF__)
- (void) new wxStaticText( this, -1, _("Printer Command: "),
+ (void) new wxStaticText( this, -1, _("Printer Command: "),
- (void) new wxTextCtrl( this, wxID_PRINTER_COMMAND, wxThePrintSetupData->GetPrinterCommand(),
+ (void) new wxTextCtrl( this, wxID_PRINTER_COMMAND, wxThePrintSetupData->GetPrinterCommand(),
wxPoint(100, yPos), wxSize(100, -1) );
wxPoint(100, yPos), wxSize(100, -1) );
-
- (void) new wxStaticText( this, -1, _("Printer Options: "),
+
+ (void) new wxStaticText( this, -1, _("Printer Options: "),
- (void) new wxTextCtrl( this, wxID_PRINTER_OPTIONS, wxThePrintSetupData->GetPrinterOptions(),
+ (void) new wxTextCtrl( this, wxID_PRINTER_OPTIONS, wxThePrintSetupData->GetPrinterOptions(),
wxPoint(305, yPos), wxSize(150, -1) );
yPos += 40;
wxPoint(305, yPos), wxSize(150, -1) );
yPos += 40;
#endif
radio1->SetSelection((int)wxThePrintSetupData->GetPrinterMode());
#endif
radio1->SetSelection((int)wxThePrintSetupData->GetPrinterMode());
long wx_printer_translate_x, wx_printer_translate_y;
double wx_printer_scale_x, wx_printer_scale_y;
wxThePrintSetupData->GetPrinterTranslation(&wx_printer_translate_x, &wx_printer_translate_y);
long wx_printer_translate_x, wx_printer_translate_y;
double wx_printer_scale_x, wx_printer_scale_y;
wxThePrintSetupData->GetPrinterTranslation(&wx_printer_translate_x, &wx_printer_translate_y);
{
if (cmd == previewCommand)
return;
{
if (cmd == previewCommand)
return;
if (previewCommand)
delete[] previewCommand;
if (cmd)
if (previewCommand)
delete[] previewCommand;
if (cmd)
{
if (printerFlags == flags)
return;
{
if (printerFlags == flags)
return;
if (printerFlags)
delete[] printerFlags;
if (flags)
if (printerFlags)
delete[] printerFlags;
if (flags)
{
if (f == printerFile)
return;
{
if (f == printerFile)
return;
if (printerFile)
delete[] printerFile;
if (f)
if (printerFile)
delete[] printerFile;
if (f)
{
if (f == afmPath)
return;
{
if (f == afmPath)
return;
if (afmPath)
delete[] afmPath;
if (f)
if (afmPath)
delete[] afmPath;
if (f)
// Can't remember where the PostScript origin is by default.
// Heck, someone will know how to make it hunky-dory...
// JACS 25/5/95
// Can't remember where the PostScript origin is by default.
// Heck, someone will know how to make it hunky-dory...
// JACS 25/5/95
AddPaperType(_("A4 210 x 297 mm"), 210, 297, 595, 842);
AddPaperType(_("A3 297 x 420 mm"), 297, 420, 842, 1191);
AddPaperType(_("Letter 8 1/2 x 11 in"), 216, 279, 612, 791);
AddPaperType(_("A4 210 x 297 mm"), 210, 297, 595, 842);
AddPaperType(_("A3 297 x 420 mm"), 297, 420, 842, 1191);
AddPaperType(_("Letter 8 1/2 x 11 in"), 216, 279, 612, 791);