2010-05-27 21:20:18 +04:00
|
|
|
//
|
2010-05-27 21:50:51 +04:00
|
|
|
// "$Id$"
|
2010-05-27 21:20:18 +04:00
|
|
|
//
|
|
|
|
// Printing support for the Fast Light Tool Kit (FLTK).
|
|
|
|
//
|
|
|
|
// Copyright 2010 by Bill Spitzak and others.
|
|
|
|
//
|
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:
|
|
|
|
//
|
|
|
|
// http://www.fltk.org/COPYING.php
|
2010-05-27 21:20:18 +04:00
|
|
|
//
|
|
|
|
// Please report all bugs and problems on the following page:
|
|
|
|
//
|
|
|
|
// http://www.fltk.org/str.php
|
|
|
|
//
|
|
|
|
|
|
|
|
/** \file Fl_Paged_Device.H
|
|
|
|
\brief declaration of class Fl_Paged_Device.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef Fl_Paged_Device_H
|
|
|
|
#define Fl_Paged_Device_H
|
|
|
|
|
|
|
|
#include <FL/Fl_Device.H>
|
2010-12-28 21:14:59 +03:00
|
|
|
#include <FL/Fl_Window.H>
|
2010-05-27 21:20:18 +04:00
|
|
|
|
2010-12-27 13:33:50 +03:00
|
|
|
/** \brief Number of elements in enum Page_Format */
|
2010-12-12 19:13:55 +03:00
|
|
|
#define NO_PAGE_FORMATS 30 /* MSVC6 compilation fix */
|
|
|
|
|
2010-05-27 21:20:18 +04:00
|
|
|
/**
|
|
|
|
\brief Represents page-structured drawing surfaces.
|
|
|
|
*
|
|
|
|
This class has no public constructor: don't instantiate it; use Fl_Printer
|
|
|
|
or Fl_PostScript_File_Device instead.
|
|
|
|
*/
|
2011-05-20 20:39:06 +04:00
|
|
|
class FL_EXPORT Fl_Paged_Device : public Fl_Surface_Device {
|
2015-11-24 17:26:52 +03:00
|
|
|
#ifndef __APPLE__
|
|
|
|
friend class Fl_Copy_Surface;
|
2016-01-04 16:16:23 +03:00
|
|
|
friend class Fl_Image_Surface;
|
2015-11-24 17:26:52 +03:00
|
|
|
void draw_decorated_window(Fl_Window *win, int x_offset, int y_offset, Fl_Surface_Device *toset);
|
|
|
|
#endif
|
2010-12-12 19:13:55 +03:00
|
|
|
public:
|
|
|
|
/**
|
|
|
|
\brief Possible page formats.
|
|
|
|
|
|
|
|
All paper formats with pre-defined width and height.
|
|
|
|
*/
|
|
|
|
enum Page_Format {
|
|
|
|
A0 = 0, /**< A0 format */
|
|
|
|
A1,
|
|
|
|
A2,
|
|
|
|
A3,
|
|
|
|
A4, /**< A4 format */
|
|
|
|
A5,
|
|
|
|
A6,
|
|
|
|
A7,
|
|
|
|
A8,
|
|
|
|
A9,
|
|
|
|
B0,
|
|
|
|
B1,
|
|
|
|
B2,
|
|
|
|
B3,
|
|
|
|
B4,
|
|
|
|
B5,
|
|
|
|
B6,
|
|
|
|
B7,
|
|
|
|
B8,
|
|
|
|
B9,
|
|
|
|
B10,
|
|
|
|
C5E,
|
|
|
|
DLE,
|
|
|
|
EXECUTIVE,
|
|
|
|
FOLIO,
|
|
|
|
LEDGER,
|
|
|
|
LEGAL,
|
|
|
|
LETTER, /**< Letter format */
|
|
|
|
TABLOID,
|
|
|
|
ENVELOPE,
|
|
|
|
MEDIA = 0x1000
|
|
|
|
};
|
|
|
|
/**
|
|
|
|
\brief Possible page layouts.
|
|
|
|
*/
|
|
|
|
enum Page_Layout {
|
|
|
|
PORTRAIT = 0, /**< Portrait orientation */
|
|
|
|
LANDSCAPE = 0x100, /**< Landscape orientation */
|
|
|
|
REVERSED = 0x200, /**< Reversed orientation */
|
|
|
|
ORIENTATION = 0x300 /**< orientation */
|
|
|
|
};
|
|
|
|
|
|
|
|
/** \brief width, height and name of a page format
|
|
|
|
*/
|
|
|
|
typedef struct {
|
|
|
|
/** \brief width in points */
|
|
|
|
int width;
|
|
|
|
/** \brief height in points */
|
|
|
|
int height;
|
|
|
|
/** \brief format name */
|
|
|
|
const char *name;
|
|
|
|
} page_format;
|
|
|
|
/** \brief width, height and name of all elements of the enum \ref Page_Format.
|
|
|
|
*/
|
|
|
|
static const page_format page_formats[NO_PAGE_FORMATS];
|
2011-01-31 16:02:55 +03:00
|
|
|
private:
|
2010-05-27 21:20:18 +04:00
|
|
|
void traverse(Fl_Widget *widget); // finds subwindows of widget and prints them
|
|
|
|
protected:
|
|
|
|
/** \brief horizontal offset to the origin of graphics coordinates */
|
|
|
|
int x_offset;
|
|
|
|
/** \brief vertical offset to the origin of graphics coordinates */
|
|
|
|
int y_offset;
|
|
|
|
/** \brief The constructor */
|
2012-04-13 20:57:14 +04:00
|
|
|
Fl_Paged_Device() : Fl_Surface_Device(NULL), x_offset(0), y_offset(0) {};
|
2012-11-07 00:46:14 +04:00
|
|
|
#if FLTK_ABI_VERSION >= 10301
|
2012-03-04 22:24:38 +04:00
|
|
|
public:
|
|
|
|
/** \brief The destructor */
|
|
|
|
virtual ~Fl_Paged_Device() {};
|
|
|
|
#else
|
2010-05-27 21:20:18 +04:00
|
|
|
/** \brief The destructor */
|
|
|
|
virtual ~Fl_Paged_Device() {};
|
|
|
|
public:
|
2012-03-04 22:24:38 +04:00
|
|
|
#endif // FLTK_ABI_VERSION
|
2011-01-05 13:21:45 +03:00
|
|
|
static const char *class_id;
|
2011-02-23 17:36:18 +03:00
|
|
|
const char *class_name() {return class_id;};
|
2010-05-27 21:20:18 +04:00
|
|
|
virtual int start_job(int pagecount, int *frompage = NULL, int *topage = NULL);
|
|
|
|
virtual int start_page(void);
|
|
|
|
virtual int printable_rect(int *w, int *h);
|
|
|
|
virtual void margins(int *left, int *top, int *right, int *bottom);
|
|
|
|
virtual void origin(int x, int y);
|
2011-01-31 18:53:23 +03:00
|
|
|
virtual void origin(int *x, int *y);
|
2011-02-04 12:17:45 +03:00
|
|
|
virtual void scale(float scale_x, float scale_y = 0.);
|
2010-05-27 21:20:18 +04:00
|
|
|
virtual void rotate(float angle);
|
|
|
|
virtual void translate(int x, int y);
|
|
|
|
virtual void untranslate(void);
|
2011-01-31 18:53:23 +03:00
|
|
|
virtual void print_widget(Fl_Widget* widget, int delta_x = 0, int delta_y = 0);
|
2011-04-16 01:38:05 +04:00
|
|
|
/** Prints a window with its title bar and frame if any.
|
|
|
|
|
|
|
|
\p x_offset and \p y_offset are optional coordinates of where to position the window top left.
|
|
|
|
Equivalent to print_widget() if \p win is a subwindow or has no border.
|
|
|
|
Use Fl_Window::decorated_w() and Fl_Window::decorated_h() to get the size of the
|
|
|
|
printed window.
|
|
|
|
*/
|
|
|
|
void print_window(Fl_Window *win, int x_offset = 0, int y_offset = 0);
|
2011-01-31 18:53:23 +03:00
|
|
|
virtual void print_window_part(Fl_Window *win, int x, int y, int w, int h, int delta_x = 0, int delta_y = 0);
|
2010-05-27 21:20:18 +04:00
|
|
|
virtual int end_page (void);
|
|
|
|
virtual void end_job (void);
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif // Fl_Paged_Device_H
|
|
|
|
|
|
|
|
//
|
2010-05-27 21:50:51 +04:00
|
|
|
// End of "$Id$"
|
2010-05-27 21:20:18 +04:00
|
|
|
//
|
|
|
|
|