1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
|
// This module defines interface to the QextScintillaPrinter class.
//
// Copyright (c) 2006
// Riverbank Computing Limited <[email protected]>
//
// This file is part of QScintilla.
//
// This copy of QScintilla is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License as published by
// the Free Software Foundation; either version 2, or (at your option) any
// later version.
//
// QScintilla is supplied in the hope that it will be useful, but WITHOUT ANY
// WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
// FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
// details.
//
// You should have received a copy of the GNU General Public License along with
// QScintilla; see the file LICENSE. If not, write to the Free Software
// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
#ifndef QEXTSCINTILLAPRINTER_H
#define QEXTSCINTILLAPRINTER_H
#include <qprinter.h>
#include <qextscintillaglobal.h>
#include <qextscintilla.h>
class QRect;
class QPainter;
class QextScintillaBase;
//! \brief The QextScintillaPrinter class is a sub-class of the Qt QPrinter
//! class that is able to print the text of a Scintilla document.
//!
//! The class can be further sub-classed to alter to layout of the text, adding
//! headers and footers for example.
class QEXTSCINTILLA_EXPORT QextScintillaPrinter : public QPrinter
{
public:
//! Constructs a printer paint device with mode \a mode.
QextScintillaPrinter(PrinterMode mode = ScreenResolution);
//! Destroys the QextScintillaPrinter instance.
~QextScintillaPrinter();
//! Format a page, by adding headers and footers for example, before
//! the document text is drawn on it. \a painter is the painter to be
//! used to add customised text and graphics. \a drawing is TRUE if
//! the page is actually being drawn rather than being sized.
//! \a painter drawing methods must only be called when \a drawing is
//! TRUE. \a area is the area of the page that will be used to draw
//! the text. This should be modified if it is necessary to reserve
//! space for any customised text or graphics. By default the area is
//! relative to the printable area of the page. Use
//! QPrinter::setFullPage() because calling printRange() if you want to
//! try and print over the whole page. \a pagenr is the number of the
//! page. The first page is numbered 1.
virtual void formatPage(QPainter &painter,bool drawing,QRect &area,
int pagenr);
//! Return the number of points to add to each font when printing.
//!
//! \sa setMagnification()
int magnification() const {return mag;}
//! Sets the number of points to add to each font when printing to
//! \a magnification.
//!
//! \sa magnification()
virtual void setMagnification(int magnification);
//! Print a range of lines from the Scintilla instance \a qsb. \a from
//! is the first line to print and a negative value signifies the first
//! line of text. \a to is the last line to print and a negative value
//! signifies the last line of text. TRUE is returned if there was no
//! error.
virtual int printRange(QextScintillaBase *qsb,int from = -1,
int to = -1);
//! Return the line wrap mode used when printing. The default is
//! QextScintilla::WrapWord.
//!
//! \sa setWrapMode()
QextScintilla::WrapMode wrapMode() const {return wrap;}
//! Sets the line wrap mode used when printing to \a wmode.
//!
//! \sa wrapMode()
virtual void setWrapMode(QextScintilla::WrapMode wmode);
private:
int mag;
QextScintilla::WrapMode wrap;
#if defined(Q_DISABLE_COPY)
QextScintillaPrinter(const QextScintillaPrinter &);
QextScintillaPrinter &operator=(const QextScintillaPrinter &);
#endif
};
#endif
|