FLTK 1.3.8
|
OS-independent print support. More...
#include <Fl_Printer.H>
Public Member Functions | |
const char * | class_name () |
Returns the name of the class of this object. More... | |
Fl_Graphics_Driver * | driver (void) |
void | end_job (void) |
To be called at the end of a print job. More... | |
int | end_page (void) |
To be called at the end of each page. More... | |
Fl_Printer (void) | |
The constructor. | |
void | margins (int *left, int *top, int *right, int *bottom) |
Computes the dimensions of margins that lie between the printable page area and the full page. More... | |
void | origin (int *x, int *y) |
Computes the page coordinates of the current origin of graphics functions. More... | |
void | origin (int x, int y) |
Sets the position in page coordinates of the origin of graphics functions. More... | |
void | print_widget (Fl_Widget *widget, int delta_x=0, int delta_y=0) |
Draws the widget on the printed page. More... | |
void | print_window_part (Fl_Window *win, int x, int y, int w, int h, int delta_x=0, int delta_y=0) |
Prints a rectangular part of an on-screen window. More... | |
int | printable_rect (int *w, int *h) |
Computes the width and height of the printable area of the page. More... | |
void | rotate (float angle) |
Rotates the graphics operations relatively to paper. More... | |
void | scale (float scale_x, float scale_y=0.) |
Changes the scaling of page coordinates. More... | |
void | set_current (void) |
Make this surface the current drawing surface. More... | |
int | start_job (int pagecount, int *frompage=NULL, int *topage=NULL) |
Starts a print job. More... | |
int | start_page (void) |
Starts a new printed page. More... | |
void | translate (int x, int y) |
Translates the current graphics origin accounting for the current rotation. More... | |
void | untranslate (void) |
Undoes the effect of a previous translate() call. More... | |
~Fl_Printer (void) | |
The destructor. | |
Public Member Functions inherited from Fl_Paged_Device | |
const char * | class_name () |
Returns the name of the class of this object. More... | |
virtual void | end_job (void) |
To be called at the end of a print job. More... | |
virtual int | end_page (void) |
To be called at the end of each page. More... | |
virtual void | margins (int *left, int *top, int *right, int *bottom) |
Computes the dimensions of margins that lie between the printable page area and the full page. More... | |
virtual void | origin (int *x, int *y) |
Computes the page coordinates of the current origin of graphics functions. More... | |
virtual void | origin (int x, int y) |
Sets the position in page coordinates of the origin of graphics functions. More... | |
virtual void | print_widget (Fl_Widget *widget, int delta_x=0, int delta_y=0) |
Draws the widget on the printed page. More... | |
void | print_window (Fl_Window *win, int x_offset=0, int y_offset=0) |
Prints a window with its title bar and frame if any. More... | |
virtual void | print_window_part (Fl_Window *win, int x, int y, int w, int h, int delta_x=0, int delta_y=0) |
Prints a rectangular part of an on-screen window. More... | |
virtual int | printable_rect (int *w, int *h) |
Computes the width and height of the printable area of the page. More... | |
virtual void | rotate (float angle) |
Rotates the graphics operations relatively to paper. More... | |
virtual void | scale (float scale_x, float scale_y=0.) |
Changes the scaling of page coordinates. More... | |
virtual int | start_job (int pagecount, int *frompage=NULL, int *topage=NULL) |
Starts a print job. More... | |
virtual int | start_page (void) |
Starts a new printed page. More... | |
virtual void | translate (int x, int y) |
Translates the current graphics origin accounting for the current rotation. More... | |
virtual void | untranslate (void) |
Undoes the effect of a previous translate() call. More... | |
virtual | ~Fl_Paged_Device () |
The destructor. | |
Public Member Functions inherited from Fl_Surface_Device | |
const char * | class_name () |
Returns the name of the class of this object. More... | |
Fl_Graphics_Driver * | driver () |
Returns the graphics driver of this drawing surface. | |
void | driver (Fl_Graphics_Driver *graphics_driver) |
Sets the graphics driver of this drawing surface. | |
virtual void | set_current (void) |
Make this surface the current drawing surface. More... | |
virtual | ~Fl_Surface_Device () |
The destructor. | |
Public Member Functions inherited from Fl_Device | |
virtual const char * | class_name () |
Returns the name of the class of this object. More... | |
virtual | ~Fl_Device () |
Virtual destructor. More... | |
Static Public Attributes | |
static const char * | class_id = "Fl_Printer" |
These attributes are effective under the Xlib platform only. | |
static const char * | dialog_title = "Print" |
[this text may be customized at run-time] | |
static const char * | dialog_printer = "Printer:" |
[this text may be customized at run-time] | |
static const char * | dialog_range = "Print Range" |
[this text may be customized at run-time] | |
static const char * | dialog_copies = "Copies" |
[this text may be customized at run-time] | |
static const char * | dialog_all = "All" |
[this text may be customized at run-time] | |
static const char * | dialog_pages = "Pages" |
[this text may be customized at run-time] | |
static const char * | dialog_from = "From:" |
[this text may be customized at run-time] | |
static const char * | dialog_to = "To:" |
[this text may be customized at run-time] | |
static const char * | dialog_properties = "Properties..." |
[this text may be customized at run-time] | |
static const char * | dialog_copyNo = "# Copies:" |
[this text may be customized at run-time] | |
static const char * | dialog_print_button = "Print" |
[this text may be customized at run-time] | |
static const char * | dialog_cancel_button = "Cancel" |
[this text may be customized at run-time] | |
static const char * | dialog_print_to_file = "Print To File" |
[this text may be customized at run-time] | |
static const char * | property_title = "Printer Properties" |
[this text may be customized at run-time] | |
static const char * | property_pagesize = "Page Size:" |
[this text may be customized at run-time] | |
static const char * | property_mode = "Output Mode:" |
[this text may be customized at run-time] | |
static const char * | property_use = "Use" |
[this text may be customized at run-time] | |
static const char * | property_save = "Save" |
[this text may be customized at run-time] | |
static const char * | property_cancel = "Cancel" |
[this text may be customized at run-time] | |
Static Public Attributes inherited from Fl_Paged_Device | |
static const char * | class_id = "Fl_Paged_Device" |
static const page_format | page_formats [NO_PAGE_FORMATS] |
width, height and name of all elements of the enum Page_Format. | |
Static Public Attributes inherited from Fl_Surface_Device | |
static const char * | class_id = "Fl_Surface_Device" |
Static Public Attributes inherited from Fl_Device | |
static const char * | class_id = "Fl_Device" |
A string that identifies each subclass of Fl_Device. More... | |
Additional Inherited Members | |
Public Types inherited from Fl_Paged_Device | |
enum | Page_Format { A0 = 0 , A1 , A2 , A3 , A4 , A5 , A6 , A7 , A8 , A9 , B0 , B1 , B2 , B3 , B4 , B5 , B6 , B7 , B8 , B9 , B10 , C5E , DLE , EXECUTIVE , FOLIO , LEDGER , LEGAL , LETTER , TABLOID , ENVELOPE , MEDIA = 0x1000 } |
Possible page formats. More... | |
enum | Page_Layout { PORTRAIT = 0 , LANDSCAPE = 0x100 , REVERSED = 0x200 , ORIENTATION = 0x300 } |
Possible page layouts. More... | |
Static Public Member Functions inherited from Fl_Surface_Device | |
static Fl_Surface_Device * | surface () |
The current drawing surface. More... | |
Protected Member Functions inherited from Fl_Paged_Device | |
Fl_Paged_Device () | |
The constructor. | |
Protected Member Functions inherited from Fl_Surface_Device | |
Fl_Surface_Device (Fl_Graphics_Driver *graphics_driver) | |
Constructor that sets the graphics driver to use for the created surface. | |
Protected Attributes inherited from Fl_Paged_Device | |
int | x_offset |
horizontal offset to the origin of graphics coordinates | |
int | y_offset |
vertical offset to the origin of graphics coordinates | |
OS-independent print support.
Fl_Printer allows to use all drawing, color, text, image, and clip FLTK functions, and to have them operate on printed page(s). There are two main, non exclusive, ways to use it.
In both cases, begin by start_job(), start_page(), printable_rect() and origin() calls and finish by end_page() and end_job() calls.
Example of use: print a widget centered in a page
Platform specifics
|
inlinevirtual |
Returns the name of the class of this object.
Use of the class_name() function is discouraged because it will be removed from future FLTK versions.
The class of an instance of an Fl_Device subclass can be checked with code such as:
Reimplemented from Fl_Paged_Device.
|
virtual |
To be called at the end of a print job.
Reimplemented from Fl_Paged_Device.
|
virtual |
To be called at the end of each page.
Reimplemented from Fl_Paged_Device.
|
virtual |
Computes the dimensions of margins that lie between the printable page area and the full page.
Values are in the same unit as that used by FLTK drawing functions. They are changed by scale() calls.
[out] | left | If non-null, *left is set to the left margin size. |
[out] | top | If non-null, *top is set to the top margin size. |
[out] | right | If non-null, *right is set to the right margin size. |
[out] | bottom | If non-null, *bottom is set to the bottom margin size. |
Reimplemented from Fl_Paged_Device.
|
virtual |
Computes the page coordinates of the current origin of graphics functions.
[out] | x | If non-null, *x is set to the horizontal page offset of graphics origin. |
[out] | y | Same as above, vertically. |
Reimplemented from Fl_Paged_Device.
|
virtual |
Sets the position in page coordinates of the origin of graphics functions.
Arguments should be expressed relatively to the result of a previous printable_rect() call. That is, printable_rect(&w, &h); origin(w/2, 0);
sets the graphics origin at the top center of the page printable area. Origin() calls are not affected by rotate() calls. Successive origin() calls don't combine their effects.
[in] | x | Horizontal position in page coordinates of the desired origin of graphics functions. |
[in] | y | Same as above, vertically. |
Reimplemented from Fl_Paged_Device.
|
virtual |
Draws the widget on the printed page.
The widget's position on the printed page is determined by the last call to origin() and by the optional delta_x and delta_y arguments. Its dimensions are in points unless there was a previous call to scale().
[in] | widget | Any FLTK widget (e.g., standard, custom, window). |
[in] | delta_x | Optional horizontal offset for positioning the widget relatively to the current origin of graphics functions. |
[in] | delta_y | Same as above, vertically. |
Reimplemented from Fl_Paged_Device.
|
virtual |
Prints a rectangular part of an on-screen window.
win | The window from where to capture. |
x | The rectangle left |
y | The rectangle top |
w | The rectangle width |
h | The rectangle height |
delta_x | Optional horizontal offset from current graphics origin where to print the captured rectangle. |
delta_y | As above, vertically. |
Reimplemented from Fl_Paged_Device.
|
virtual |
Computes the width and height of the printable area of the page.
Values are in the same unit as that used by FLTK drawing functions, are unchanged by calls to origin(), but are changed by scale() calls. Values account for the user-selected paper type and print orientation.
Reimplemented from Fl_Paged_Device.
|
virtual |
Rotates the graphics operations relatively to paper.
The rotation is centered on the current graphics origin. Successive rotate() calls don't combine their effects.
angle | Rotation angle in counter-clockwise degrees. |
Reimplemented from Fl_Paged_Device.
|
virtual |
Changes the scaling of page coordinates.
This function also resets the origin of graphics functions at top left of printable page area. After a scale() call, do a printable_rect() call to get the new dimensions of the printable page area. Successive scale() calls don't combine their effects.
scale_x | Horizontal dimensions of plot are multiplied by this quantity. |
scale_y | Same as above, vertically. The value 0. is equivalent to setting scale_y = scale_x . Thus, scale(factor); is equivalent to scale(factor, factor); |
Reimplemented from Fl_Paged_Device.
|
virtual |
Make this surface the current drawing surface.
This surface will receive all future graphics requests.
Reimplemented from Fl_Surface_Device.
|
virtual |
Starts a print job.
Opens a platform-specific dialog window allowing the user to set several options including the desired printer and the page orientation. Optionally, the user can also select a range of pages to be printed. This range is returned to the caller that is in charge of sending only these pages for printing.
[in] | pagecount | the total number of pages of the job (or 0 if you don't know the number of pages) |
[out] | frompage | if non-null, *frompage is set to the first page the user wants printed |
[out] | topage | if non-null, *topage is set to the last page the user wants printed |
Reimplemented from Fl_Paged_Device.
|
virtual |
Starts a new printed page.
The page coordinates are initially in points, i.e., 1/72 inch, and with origin at the top left of the printable page area.
Reimplemented from Fl_Paged_Device.
|
virtual |
Translates the current graphics origin accounting for the current rotation.
This function is only useful after a rotate() call. Each translate() call must be matched by an untranslate() call. Successive translate() calls add up their effects.
Reimplemented from Fl_Paged_Device.
|
virtual |
Undoes the effect of a previous translate() call.
Reimplemented from Fl_Paged_Device.