FLTK 1.4.0
|
Represents page-structured drawing surfaces. More...
#include <Fl_Paged_Device.H>
Classes | |
struct | page_format |
width, height and name of a page format More... | |
Public Types | |
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... | |
Public Member Functions | |
virtual int | begin_job (int pagecount=0, int *frompage=NULL, int *topage=NULL, char **perr_message=NULL) |
Begins a print job. More... | |
virtual int | begin_page (void) |
Begins a new printed page. 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... | |
void | print_widget (Fl_Widget *widget, int delta_x=0, int delta_y=0) |
Synonym of draw(Fl_Widget*, int, int) | |
void | print_window (Fl_Window *win, int x_off=0, int y_off=0) |
Synonym of draw_decorated_window(Fl_Window*, int, int) | |
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... | |
int | start_job (int pagecount=0, int *frompage=NULL, int *topage=NULL, char **perr_message=NULL) |
Synonym of begin_job(int pagecount, int *frompage, int *topage, char **perr_message). More... | |
int | start_page () |
Synonym of begin_page(). More... | |
virtual | ~Fl_Paged_Device () |
The destructor. | |
Public Member Functions inherited from Fl_Widget_Surface | |
void | draw (Fl_Widget *widget, int delta_x=0, int delta_y=0) |
Draws the widget on the drawing surface. More... | |
void | draw_decorated_window (Fl_Window *win, int x_offset=0, int y_offset=0) |
Draws a window with its title bar and frame if any. More... | |
virtual void | origin (int *x, int *y) |
Computes the coordinates of the current origin of graphics functions. More... | |
virtual void | origin (int x, int y) |
Sets the position of the origin of graphics in the drawable part of the drawing surface. More... | |
void | print_window_part (Fl_Window *win, int x, int y, int w, int h, int delta_x=0, int delta_y=0) |
Draws a rectangular part of an on-screen window. More... | |
virtual int | printable_rect (int *w, int *h) |
Computes the width and height of the drawable area of the drawing surface. More... | |
virtual void | translate (int x, int y) |
Translates the current graphics origin accounting for the current rotation. More... | |
virtual void | untranslate () |
Undoes the effect of a previous translate() call. More... | |
Public Member Functions inherited from Fl_Surface_Device | |
Fl_Graphics_Driver * | driver () |
Returns the graphics driver of this drawing surface. | |
virtual bool | is_current () |
Is this surface the current drawing surface? More... | |
virtual void | set_current (void) |
Make this surface the current drawing surface. More... | |
virtual | ~Fl_Surface_Device () |
The destructor. | |
Static Public Attributes | |
static const page_format | page_formats [NO_PAGE_FORMATS] |
width, height and name of all elements of the enum Page_Format. | |
Protected Member Functions | |
Fl_Paged_Device () | |
The constructor. | |
Protected Member Functions inherited from Fl_Widget_Surface | |
Fl_Widget_Surface (Fl_Graphics_Driver *d) | |
The constructor. More... | |
Protected Member Functions inherited from Fl_Surface_Device | |
void | driver (Fl_Graphics_Driver *graphics_driver) |
Sets the graphics driver of this drawing surface. | |
virtual void | end_current () |
FLTK calls this each time a surface ceases to be the current drawing surface. More... | |
Fl_Surface_Device (Fl_Graphics_Driver *graphics_driver) | |
Constructor that sets the graphics driver to use for the created surface. | |
Additional Inherited Members | |
Static Public Member Functions inherited from Fl_Surface_Device | |
static Fl_Surface_Device * | pop_current () |
Removes the top element from the current drawing surface stack, and makes the new top element current. More... | |
static void | push_current (Fl_Surface_Device *new_current) |
Pushes new_current on top of the stack of current drawing surfaces, and makes it current. More... | |
static Fl_Surface_Device * | surface () |
The current drawing surface. More... | |
Protected Attributes inherited from Fl_Widget_Surface | |
int | x_offset |
horizontal offset to the origin of graphics coordinates | |
int | y_offset |
vertical offset to the origin of graphics coordinates | |
Represents page-structured drawing surfaces.
This class has no public constructor: don't instantiate it; use Fl_Printer or Fl_PostScript_File_Device instead.
Possible page formats.
All paper formats with pre-defined width and height. The Fl_Paged_Device::page_formats array gives these widths and heights.
|
virtual |
Begins a print job.
[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 |
[out] | perr_message | if non-null and if the returned value is ≥ 2, *perr_message is set to a string describing the error. That string can be delete[]'d after use. |
Reimplemented in Fl_PostScript_File_Device, Fl_Printer, and Fl_PDF_File_Surface.
|
virtual |
Begins 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. This function also makes this surface the current drawing surface with Fl_Surface_Device::push_current().
Reimplemented in Fl_PDF_File_Surface, Fl_PostScript_File_Device, and Fl_Printer.
|
virtual |
To be called at the end of a print job.
Reimplemented in Fl_PDF_File_Surface, Fl_PostScript_File_Device, and Fl_Printer.
|
virtual |
To be called at the end of each page.
This function also stops this surface from being the current drawing surface with Fl_Surface_Device::pop_current().
Reimplemented in Fl_PDF_File_Surface, Fl_PostScript_File_Device, and Fl_Printer.
|
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 in Fl_PDF_File_Surface, Fl_PostScript_File_Device, and Fl_Printer.
|
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 in Fl_PDF_File_Surface, Fl_PostScript_File_Device, and Fl_Printer.
|
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 in Fl_PDF_File_Surface, Fl_PostScript_File_Device, and Fl_Printer.
|
inline |
Synonym of begin_job(int pagecount, int *frompage, int *topage, char **perr_message).
For API compatibility with FLTK 1.3.x
|
inline |
Synonym of begin_page().
For API compatibility with FLTK 1.3.x