source: trunk/src/gui/dialogs/qabstractprintdialog.cpp@ 1073

Last change on this file since 1073 was 846, checked in by Dmitry A. Kuminov, 14 years ago

trunk: Merged in qt 4.7.2 sources from branches/vendor/nokia/qt.

File size: 13.8 KB
Line 
1/****************************************************************************
2**
3** Copyright (C) 2011 Nokia Corporation and/or its subsidiary(-ies).
4** All rights reserved.
5** Contact: Nokia Corporation (qt-info@nokia.com)
6**
7** This file is part of the QtGui module of the Qt Toolkit.
8**
9** $QT_BEGIN_LICENSE:LGPL$
10** Commercial Usage
11** Licensees holding valid Qt Commercial licenses may use this file in
12** accordance with the Qt Commercial License Agreement provided with the
13** Software or, alternatively, in accordance with the terms contained in
14** a written agreement between you and Nokia.
15**
16** GNU Lesser General Public License Usage
17** Alternatively, this file may be used under the terms of the GNU Lesser
18** General Public License version 2.1 as published by the Free Software
19** Foundation and appearing in the file LICENSE.LGPL included in the
20** packaging of this file. Please review the following information to
21** ensure the GNU Lesser General Public License version 2.1 requirements
22** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
23**
24** In addition, as a special exception, Nokia gives you certain additional
25** rights. These rights are described in the Nokia Qt LGPL Exception
26** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
27**
28** GNU General Public License Usage
29** Alternatively, this file may be used under the terms of the GNU
30** General Public License version 3.0 as published by the Free Software
31** Foundation and appearing in the file LICENSE.GPL included in the
32** packaging of this file. Please review the following information to
33** ensure the GNU General Public License version 3.0 requirements will be
34** met: http://www.gnu.org/copyleft/gpl.html.
35**
36** If you have questions regarding the use of this file, please contact
37** Nokia at qt-info@nokia.com.
38** $QT_END_LICENSE$
39**
40****************************************************************************/
41
42#include "qabstractprintdialog_p.h"
43#include "qcoreapplication.h"
44#include "qprintdialog.h"
45#include "qprinter.h"
46#include "private/qprinter_p.h"
47
48#ifndef QT_NO_PRINTDIALOG
49
50QT_BEGIN_NAMESPACE
51
52// hack
53class QPrintDialogPrivate : public QAbstractPrintDialogPrivate
54{
55};
56
57/*!
58 \class QAbstractPrintDialog
59 \brief The QAbstractPrintDialog class provides a base implementation for
60 print dialogs used to configure printers.
61
62 \ingroup printing
63
64 This class implements getter and setter functions that are used to
65 customize settings shown in print dialogs, but it is not used directly.
66 Use QPrintDialog to display a print dialog in your application.
67
68 In Symbian, there is no support for printing. Hence, this dialog should not
69 be used in Symbian.
70
71 \sa QPrintDialog, QPrinter, {Printing with Qt}
72*/
73
74/*!
75 \enum QAbstractPrintDialog::PrintRange
76
77 Used to specify the print range selection option.
78
79 \value AllPages All pages should be printed.
80 \value Selection Only the selection should be printed.
81 \value PageRange The specified page range should be printed.
82 \value CurrentPage Only the currently visible page should be printed.
83
84 \sa QPrinter::PrintRange
85*/
86
87/*!
88 \enum QAbstractPrintDialog::PrintDialogOption
89
90 Used to specify which parts of the print dialog should be visible.
91
92 \value None None of the options are enabled.
93 \value PrintToFile The print to file option is enabled.
94 \value PrintSelection The print selection option is enabled.
95 \value PrintPageRange The page range selection option is enabled.
96 \value PrintShowPageSize Show the page size + margins page only if this is enabled.
97 \value PrintCollateCopies The collate copies option is enabled
98 \value PrintCurrentPage The print current page option is enabled
99
100 This value is obsolete and does nothing since Qt 4.5:
101
102 \value DontUseSheet In previous versions of Qt, exec() the print dialog
103 would create a sheet by default the dialog was given a parent.
104 This is no longer supported in Qt 4.5. If you want to use sheets, use
105 QPrintDialog::open() instead.
106*/
107
108/*!
109 Constructs an abstract print dialog for \a printer with \a parent
110 as parent widget.
111*/
112QAbstractPrintDialog::QAbstractPrintDialog(QPrinter *printer, QWidget *parent)
113 : QDialog(*(new QAbstractPrintDialogPrivate), parent)
114{
115 Q_D(QAbstractPrintDialog);
116 setWindowTitle(QCoreApplication::translate("QPrintDialog", "Print"));
117 d->setPrinter(printer);
118}
119
120/*!
121 \internal
122*/
123QAbstractPrintDialog::QAbstractPrintDialog(QAbstractPrintDialogPrivate &ptr,
124 QPrinter *printer,
125 QWidget *parent)
126 : QDialog(ptr, parent)
127{
128 Q_D(QAbstractPrintDialog);
129 setWindowTitle(QCoreApplication::translate("QPrintDialog", "Print"));
130 d->setPrinter(printer);
131}
132
133/*!
134 \internal
135*/
136QAbstractPrintDialog::~QAbstractPrintDialog()
137{
138 Q_D(QAbstractPrintDialog);
139 if (d->ownsPrinter)
140 delete d->printer;
141}
142
143/*!
144 Sets the given \a option to be enabled if \a on is true;
145 otherwise, clears the given \a option.
146
147 \sa options, testOption()
148*/
149void QPrintDialog::setOption(PrintDialogOption option, bool on)
150{
151 Q_D(QPrintDialog);
152 if (!(d->pd->options & option) != !on)
153 setOptions(d->pd->options ^ option);
154}
155
156/*!
157 Returns true if the given \a option is enabled; otherwise, returns
158 false.
159
160 \sa options, setOption()
161*/
162bool QPrintDialog::testOption(PrintDialogOption option) const
163{
164 Q_D(const QPrintDialog);
165 return (d->pd->options & option) != 0;
166}
167
168/*!
169 \property QPrintDialog::options
170 \brief the various options that affect the look and feel of the dialog
171 \since 4.5
172
173 By default, all options are disabled.
174
175 Options should be set before showing the dialog. Setting them while the
176 dialog is visible is not guaranteed to have an immediate effect on the
177 dialog (depending on the option and on the platform).
178
179 \sa setOption(), testOption()
180*/
181void QPrintDialog::setOptions(PrintDialogOptions options)
182{
183 Q_D(QPrintDialog);
184
185 PrintDialogOptions changed = (options ^ d->pd->options);
186 if (!changed)
187 return;
188
189 d->pd->options = options;
190}
191
192QPrintDialog::PrintDialogOptions QPrintDialog::options() const
193{
194 Q_D(const QPrintDialog);
195 return d->pd->options;
196}
197
198/*!
199 \obsolete
200
201 Use QPrintDialog::setOptions() instead.
202*/
203void QAbstractPrintDialog::setEnabledOptions(PrintDialogOptions options)
204{
205 Q_D(QAbstractPrintDialog);
206 d->pd->options = options;
207}
208
209/*!
210 \obsolete
211
212 Use QPrintDialog::setOption(\a option, true) instead.
213*/
214void QAbstractPrintDialog::addEnabledOption(PrintDialogOption option)
215{
216 Q_D(QAbstractPrintDialog);
217 d->pd->options |= option;
218}
219
220/*!
221 \obsolete
222
223 Use QPrintDialog::options() instead.
224*/
225QAbstractPrintDialog::PrintDialogOptions QAbstractPrintDialog::enabledOptions() const
226{
227 Q_D(const QAbstractPrintDialog);
228 return d->pd->options;
229}
230
231/*!
232 \obsolete
233
234 Use QPrintDialog::testOption(\a option) instead.
235*/
236bool QAbstractPrintDialog::isOptionEnabled(PrintDialogOption option) const
237{
238 Q_D(const QAbstractPrintDialog);
239 return d->pd->options & option;
240}
241
242/*!
243 Sets the print range option in to be \a range.
244 */
245void QAbstractPrintDialog::setPrintRange(PrintRange range)
246{
247 Q_D(QAbstractPrintDialog);
248 d->pd->printRange = range;
249}
250
251/*!
252 Returns the print range.
253*/
254QAbstractPrintDialog::PrintRange QAbstractPrintDialog::printRange() const
255{
256 Q_D(const QAbstractPrintDialog);
257 return d->pd->printRange;
258}
259
260/*!
261 Sets the page range in this dialog to be from \a min to \a max. This also
262 enables the PrintPageRange option.
263*/
264void QAbstractPrintDialog::setMinMax(int min, int max)
265{
266 Q_D(QAbstractPrintDialog);
267 Q_ASSERT_X(min <= max, "QAbstractPrintDialog::setMinMax",
268 "'min' must be less than or equal to 'max'");
269 d->pd->minPage = min;
270 d->pd->maxPage = max;
271 d->pd->options |= PrintPageRange;
272}
273
274/*!
275 Returns the minimum page in the page range.
276 By default, this value is set to 1.
277*/
278int QAbstractPrintDialog::minPage() const
279{
280 Q_D(const QAbstractPrintDialog);
281 return d->pd->minPage;
282}
283
284/*!
285 Returns the maximum page in the page range. As of Qt 4.4, this
286 function returns INT_MAX by default. Previous versions returned 1
287 by default.
288*/
289int QAbstractPrintDialog::maxPage() const
290{
291 Q_D(const QAbstractPrintDialog);
292 return d->pd->maxPage;
293}
294
295/*!
296 Sets the range in the print dialog to be from \a from to \a to.
297*/
298void QAbstractPrintDialog::setFromTo(int from, int to)
299{
300 Q_D(QAbstractPrintDialog);
301 Q_ASSERT_X(from <= to, "QAbstractPrintDialog::setFromTo",
302 "'from' must be less than or equal to 'to'");
303 d->pd->fromPage = from;
304 d->pd->toPage = to;
305
306 if (d->pd->minPage == 0 && d->pd->maxPage == 0)
307 setMinMax(1, to);
308}
309
310/*!
311 Returns the first page to be printed
312 By default, this value is set to 0.
313*/
314int QAbstractPrintDialog::fromPage() const
315{
316 Q_D(const QAbstractPrintDialog);
317 return d->pd->fromPage;
318}
319
320/*!
321 Returns the last page to be printed.
322 By default, this value is set to 0.
323*/
324int QAbstractPrintDialog::toPage() const
325{
326 Q_D(const QAbstractPrintDialog);
327 return d->pd->toPage;
328}
329
330
331/*!
332 Returns the printer that this printer dialog operates
333 on.
334*/
335QPrinter *QAbstractPrintDialog::printer() const
336{
337 Q_D(const QAbstractPrintDialog);
338 return d->printer;
339}
340
341void QAbstractPrintDialogPrivate::setPrinter(QPrinter *newPrinter)
342{
343 if (newPrinter) {
344 printer = newPrinter;
345 ownsPrinter = false;
346 } else {
347 printer = new QPrinter;
348 ownsPrinter = true;
349 }
350 pd = printer->d_func();
351}
352
353/*!
354 \fn int QAbstractPrintDialog::exec()
355
356 This virtual function is called to pop up the dialog. It must be
357 reimplemented in subclasses.
358*/
359
360/*!
361 \class QPrintDialog
362
363 \brief The QPrintDialog class provides a dialog for specifying
364 the printer's configuration.
365
366 \ingroup standard-dialogs
367 \ingroup printing
368
369 The dialog allows users to change document-related settings, such
370 as the paper size and orientation, type of print (color or
371 grayscale), range of pages, and number of copies to print.
372
373 Controls are also provided to enable users to choose from the
374 printers available, including any configured network printers.
375
376 Typically, QPrintDialog objects are constructed with a QPrinter
377 object, and executed using the exec() function.
378
379 \snippet doc/src/snippets/code/src_gui_dialogs_qabstractprintdialog.cpp 0
380
381 If the dialog is accepted by the user, the QPrinter object is
382 correctly configured for printing.
383
384 \raw HTML
385 <table align="center">
386 <tr><td>
387 \endraw
388 \inlineimage plastique-printdialog.png
389 \raw HTML
390 </td><td>
391 \endraw
392 \inlineimage plastique-printdialog-properties.png
393 \raw HTML
394 </td></tr>
395 </table>
396 \endraw
397
398 The printer dialog (shown above in Plastique style) enables access to common
399 printing properties. On X11 and OS/2 platforms that use the CUPS printing
400 system, the settings for each available printer can be modified via the
401 dialog's \gui{Properties} push button.
402
403 On Windows and Mac OS X, the native print dialog is used, which means that
404 some QWidget and QDialog properties set on the dialog won't be respected.
405 The native print dialog on Mac OS X does not support setting printer options,
406 i.e. setOptions() and setOption() have no effect.
407
408 In Qt 4.4, it was possible to use the static functions to show a sheet on
409 Mac OS X. This is no longer supported in Qt 4.5. If you want this
410 functionality, use QPrintDialog::open().
411
412 \sa QPageSetupDialog, QPrinter, {Pixelator Example}, {Order Form Example},
413 {Image Viewer Example}, {Scribble Example}
414*/
415
416/*!
417 \fn QPrintDialog::QPrintDialog(QPrinter *printer, QWidget *parent)
418
419 Constructs a new modal printer dialog for the given \a printer
420 with the given \a parent.
421*/
422
423/*!
424 \fn QPrintDialog::~QPrintDialog()
425
426 Destroys the print dialog.
427*/
428
429/*!
430 \fn int QPrintDialog::exec()
431 \reimp
432*/
433
434/*!
435 \since 4.4
436
437 Set a list of widgets as \a tabs to be shown on the print dialog, if supported.
438
439 Currently this option is only supported on X11.
440
441 Setting the option tabs will transfer their ownership to the print dialog.
442*/
443void QAbstractPrintDialog::setOptionTabs(const QList<QWidget*> &tabs)
444{
445 Q_D(QAbstractPrintDialog);
446 d->setTabs(tabs);
447}
448
449/*!
450
451 \fn void QPrintDialog::accepted(QPrinter *printer)
452
453 This signal is emitted when the user accepts the values set in the print dialog.
454 The \a printer parameter includes the printer that the settings were applied to.
455*/
456
457/*!
458 \fn QPrinter *QPrintDialog::printer()
459
460 Returns the printer that this printer dialog operates
461 on. This can be useful when using the QPrintDialog::open() method.
462*/
463
464/*!
465 Closes the dialog and sets its result code to \a result. If this dialog
466 is shown with exec(), done() causes the local event loop to finish,
467 and exec() to return \a result.
468
469 \sa QDialog::done()
470*/
471void QPrintDialog::done(int result)
472{
473 Q_D(QPrintDialog);
474 QDialog::done(result);
475 if (result == Accepted)
476 emit accepted(printer());
477 if (d->receiverToDisconnectOnClose) {
478 disconnect(this, SIGNAL(accepted(QPrinter*)),
479 d->receiverToDisconnectOnClose, d->memberToDisconnectOnClose);
480 d->receiverToDisconnectOnClose = 0;
481 }
482 d->memberToDisconnectOnClose.clear();
483}
484
485/*!
486 \since 4.5
487 \overload
488
489 Opens the dialog and connects its accepted() signal to the slot specified
490 by \a receiver and \a member.
491
492 The signal will be disconnected from the slot when the dialog is closed.
493*/
494void QPrintDialog::open(QObject *receiver, const char *member)
495{
496 Q_D(QPrintDialog);
497 connect(this, SIGNAL(accepted(QPrinter*)), receiver, member);
498 d->receiverToDisconnectOnClose = receiver;
499 d->memberToDisconnectOnClose = member;
500 QDialog::open();
501}
502
503QT_END_NAMESPACE
504
505#endif // QT_NO_PRINTDIALOG
Note: See TracBrowser for help on using the repository browser.