2010-03-18 00:22:10 +03:00
|
|
|
//
|
2010-03-18 13:56:27 +03:00
|
|
|
// Printing support for the Fast Light Tool Kit (FLTK).
|
2010-03-18 00:22:10 +03:00
|
|
|
//
|
2016-02-05 19:34:42 +03:00
|
|
|
// Copyright 2010-2016 by Bill Spitzak and others.
|
2010-03-18 00:22:10 +03:00
|
|
|
//
|
2011-07-19 08:49:30 +04:00
|
|
|
// This library is free software. Distribution and use rights are outlined in
|
|
|
|
// the file "COPYING" which should have been included with this file. If this
|
|
|
|
// file is missing or damaged, see the license at:
|
2010-03-18 00:22:10 +03:00
|
|
|
//
|
2020-07-01 19:03:10 +03:00
|
|
|
// https://www.fltk.org/COPYING.php
|
2010-03-18 00:22:10 +03:00
|
|
|
//
|
2020-07-01 19:03:10 +03:00
|
|
|
// Please see the following page on how to report bugs and issues:
|
2010-03-18 00:22:10 +03:00
|
|
|
//
|
2020-07-01 19:03:10 +03:00
|
|
|
// https://www.fltk.org/bugs.php
|
2010-03-18 00:22:10 +03:00
|
|
|
//
|
2011-07-19 08:49:30 +04:00
|
|
|
|
2020-07-01 19:03:10 +03:00
|
|
|
/** \file Fl_Printer.H
|
2016-03-18 21:20:11 +03:00
|
|
|
\brief declaration of class Fl_Printer.
|
2010-03-25 16:59:00 +03:00
|
|
|
*/
|
2010-03-18 00:22:10 +03:00
|
|
|
|
2010-03-14 21:07:24 +03:00
|
|
|
#ifndef Fl_Printer_H
|
|
|
|
#define Fl_Printer_H
|
|
|
|
|
2010-05-27 21:20:18 +04:00
|
|
|
#include <FL/Fl_Paged_Device.H>
|
2010-04-11 22:42:35 +04:00
|
|
|
|
2010-05-27 21:20:18 +04:00
|
|
|
/**
|
2018-06-23 23:50:22 +03:00
|
|
|
\brief OS-independent print support.
|
2015-02-26 18:38:54 +03:00
|
|
|
Fl_Printer allows to use all drawing, color, text, image, and clip FLTK functions, and to have them operate
|
2010-05-27 21:20:18 +04:00
|
|
|
on printed page(s). There are two main, non exclusive, ways to use it.
|
2020-07-01 19:03:10 +03:00
|
|
|
<ul><li>Print any widget (standard, custom, Fl_Window, Fl_Gl_Window) as it appears
|
|
|
|
on screen, with optional translation, scaling and rotation. This is done by calling print_widget(),
|
2011-06-20 11:53:06 +04:00
|
|
|
print_window() or print_window_part().
|
2010-10-12 13:25:37 +04:00
|
|
|
<li>Use a series of FLTK graphics commands (e.g., font, text, lines, colors, clip, image) to
|
2020-07-01 19:03:10 +03:00
|
|
|
compose a page appropriately shaped for printing.
|
2010-05-27 21:20:18 +04:00
|
|
|
</ul>
|
2018-05-09 17:16:35 +03:00
|
|
|
In both cases, begin by begin_job(), begin_page(), printable_rect() and origin() calls
|
2010-05-27 21:20:18 +04:00
|
|
|
and finish by end_page() and end_job() calls.
|
2015-02-26 18:38:54 +03:00
|
|
|
<p>Example of use: print a widget centered in a page
|
|
|
|
\code
|
|
|
|
#include <FL/Fl_Printer.H>
|
|
|
|
#include <FL/fl_draw.H>
|
|
|
|
int width, height;
|
|
|
|
Fl_Widget *widget = ... // a widget we want printed
|
|
|
|
Fl_Printer *printer = new Fl_Printer();
|
2018-05-09 17:16:35 +03:00
|
|
|
if (printer->begin_job(1) == 0) {
|
|
|
|
printer->begin_page();
|
2015-02-26 18:38:54 +03:00
|
|
|
printer->printable_rect(&width, &height);
|
|
|
|
fl_color(FL_BLACK);
|
|
|
|
fl_line_style(FL_SOLID, 2);
|
|
|
|
fl_rect(0, 0, width, height);
|
|
|
|
fl_font(FL_COURIER, 12);
|
|
|
|
time_t now; time(&now); fl_draw(ctime(&now), 0, fl_height());
|
|
|
|
printer->origin(width/2, height/2);
|
|
|
|
printer->print_widget(widget, -widget->w()/2, -widget->h()/2);
|
|
|
|
printer->end_page();
|
|
|
|
printer->end_job();
|
|
|
|
}
|
|
|
|
delete printer;
|
|
|
|
\endcode
|
2023-07-10 10:18:26 +03:00
|
|
|
<p>Recommended method to refresh GUI while printing :
|
2023-07-09 13:59:54 +03:00
|
|
|
\code
|
|
|
|
printer->begin_job(0);
|
|
|
|
……
|
|
|
|
Fl_Surface_Device::push_current(Fl_Display_Device::display_device());
|
|
|
|
Fl::check(); // or any operation that draws to display
|
|
|
|
Fl_Surface_Device::pop_current();
|
|
|
|
……
|
|
|
|
printer->end_job();
|
|
|
|
\endcode
|
2015-02-26 18:38:54 +03:00
|
|
|
<b>Platform specifics</b>
|
2010-05-27 21:20:18 +04:00
|
|
|
<ul>
|
2022-03-10 17:05:26 +03:00
|
|
|
<li>X11 and Wayland platforms:
|
2019-04-12 12:29:08 +03:00
|
|
|
<ul><li>FLTK expresses all graphics data using (Level 2) PostScript and sends that to the selected printer.
|
2020-11-01 11:26:29 +03:00
|
|
|
See class Fl_PostScript_File_Device for a description of how text and transparent images appear in print.
|
2022-03-10 17:05:26 +03:00
|
|
|
<li>If the GTK library is available at run-time, class Fl_Printer runs GTK's printer dialog which allows to set
|
2020-11-01 11:26:29 +03:00
|
|
|
printer, paper size and orientation.
|
2022-03-10 17:05:26 +03:00
|
|
|
<li>Under the KDE desktop, Fl_Printer runs the <tt>kdialog</tt> command to create KDE-styled file dialogs if
|
|
|
|
that command is available at run-time, unless FLTK was built with CMake and option OPTION_USE_KDIALOG turned off.
|
|
|
|
In that case, Fl_Printer attempts to run the GTK dialog.
|
|
|
|
<li>If the GTK library is not available, or if Fl::option(Fl::OPTION_PRINTER_USES_GTK) has been turned off,
|
|
|
|
class Fl_Printer runs FLTK's print dialog.
|
2020-11-01 11:26:29 +03:00
|
|
|
<ul>
|
2019-04-12 12:29:08 +03:00
|
|
|
<li>Unless it has been previously changed, the default paper size is A4.
|
2015-01-19 17:16:18 +03:00
|
|
|
To change that, press the "Properties" button of the "Print" dialog window
|
2018-05-09 17:16:35 +03:00
|
|
|
opened by an Fl_Printer::begin_job() call. This opens a "Printer Properties" window where it's
|
2015-01-19 17:16:18 +03:00
|
|
|
possible to select the adequate paper size. Finally press the "Save" button therein to assign
|
|
|
|
the chosen paper size to the chosen printer for this and all further print operations.
|
2019-04-12 12:29:08 +03:00
|
|
|
<li>Use the static public attributes of this class to set the print dialog to other languages
|
2010-05-27 21:20:18 +04:00
|
|
|
than English. For example, the "Printer:" dialog item Fl_Printer::dialog_printer can be set to French with:
|
|
|
|
\code
|
|
|
|
Fl_Printer::dialog_printer = "Imprimante:";
|
|
|
|
\endcode
|
2010-07-01 18:41:00 +04:00
|
|
|
before creation of the Fl_Printer object.
|
2019-04-12 12:29:08 +03:00
|
|
|
<li>Use Fl_PostScript_File_Device::file_chooser_title to customize the title of the file chooser dialog that opens
|
|
|
|
when using the "Print To File" option of the print dialog.
|
|
|
|
</ul>
|
2020-11-01 11:26:29 +03:00
|
|
|
</ul>
|
2018-02-09 17:39:42 +03:00
|
|
|
<li>Windows platform: Transparent Fl_RGB_Image 's don't print with exact transparency on most printers
|
2016-03-18 21:20:11 +03:00
|
|
|
(a workaround is to use print_window_part() ).
|
2010-05-27 21:20:18 +04:00
|
|
|
Fl_RGB_Image 's don't rotate() well.
|
2016-03-18 21:20:11 +03:00
|
|
|
<li>Mac OS X platform: all graphics requests print as on display and accept rotation and scaling.
|
2010-05-27 21:20:18 +04:00
|
|
|
</ul>
|
|
|
|
*/
|
2011-05-20 20:39:06 +04:00
|
|
|
class FL_EXPORT Fl_Printer : public Fl_Paged_Device {
|
2016-03-11 23:32:48 +03:00
|
|
|
private:
|
2016-03-18 21:20:11 +03:00
|
|
|
Fl_Paged_Device *printer;
|
2018-05-25 09:54:03 +03:00
|
|
|
/** Each platform implements this function its own way */
|
|
|
|
static Fl_Paged_Device* newPrinterDriver(void);
|
2010-05-27 21:20:18 +04:00
|
|
|
public:
|
2016-03-18 21:20:11 +03:00
|
|
|
/** The constructor */
|
2010-05-27 21:20:18 +04:00
|
|
|
Fl_Printer(void);
|
2022-12-30 21:14:36 +03:00
|
|
|
int begin_job(int pagecount = 0, int *frompage = NULL, int *topage = NULL, char **perr_message = NULL) FL_OVERRIDE;
|
|
|
|
int begin_page(void) FL_OVERRIDE;
|
|
|
|
int printable_rect(int *w, int *h) FL_OVERRIDE;
|
|
|
|
void margins(int *left, int *top, int *right, int *bottom) FL_OVERRIDE;
|
|
|
|
void origin(int *x, int *y) FL_OVERRIDE;
|
|
|
|
void origin(int x, int y) FL_OVERRIDE;
|
|
|
|
void scale(float scale_x, float scale_y = 0.) FL_OVERRIDE;
|
|
|
|
void rotate(float angle) FL_OVERRIDE;
|
|
|
|
void translate(int x, int y) FL_OVERRIDE;
|
|
|
|
void untranslate(void) FL_OVERRIDE;
|
|
|
|
int end_page (void) FL_OVERRIDE;
|
|
|
|
void end_job (void) FL_OVERRIDE;
|
|
|
|
void set_current(void) FL_OVERRIDE;
|
|
|
|
bool is_current() FL_OVERRIDE;
|
2018-05-25 09:54:03 +03:00
|
|
|
|
2016-03-18 21:20:11 +03:00
|
|
|
/** \name These attributes are useful for the Linux/Unix platform only.
|
2010-03-28 18:03:40 +04:00
|
|
|
\{
|
2020-07-01 19:03:10 +03:00
|
|
|
*/
|
|
|
|
static const char *dialog_title;
|
|
|
|
static const char *dialog_printer;
|
|
|
|
static const char *dialog_range;
|
|
|
|
static const char *dialog_copies;
|
|
|
|
static const char *dialog_all;
|
2010-03-28 18:03:40 +04:00
|
|
|
static const char *dialog_pages;
|
|
|
|
static const char *dialog_from;
|
|
|
|
static const char *dialog_to;
|
|
|
|
static const char *dialog_properties;
|
|
|
|
static const char *dialog_copyNo;
|
|
|
|
static const char *dialog_print_button;
|
|
|
|
static const char *dialog_cancel_button;
|
2010-03-29 16:15:22 +04:00
|
|
|
static const char *dialog_print_to_file;
|
2010-03-28 18:03:40 +04:00
|
|
|
static const char *property_title;
|
|
|
|
static const char *property_pagesize;
|
|
|
|
static const char *property_mode;
|
|
|
|
static const char *property_use;
|
|
|
|
static const char *property_save;
|
|
|
|
static const char *property_cancel;
|
2020-07-01 19:03:10 +03:00
|
|
|
/** \} */
|
2016-03-18 21:20:11 +03:00
|
|
|
/** The destructor */
|
2016-02-05 19:34:42 +03:00
|
|
|
~Fl_Printer(void);
|
2016-03-11 23:32:48 +03:00
|
|
|
};
|
|
|
|
|
2010-03-14 21:07:24 +03:00
|
|
|
#endif // Fl_Printer_H
|