/* * This file is part of the KDE libraries * Copyright (c) 2001 Michael Goffioul <tdeprint@swing.be> * * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Library General Public * License version 2 as published by the Free Software Foundation. * * This library is distributed 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 * Library General Public License for more details. * * You should have received a copy of the GNU Library General Public License * along with this library; see the file COPYING.LIB. If not, write to * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, * Boston, MA 02110-1301, USA. **/ #ifndef KPRINTER_H #define KPRINTER_H #include <tqpaintdevice.h> #include <tqprinter.h> #include <tqmap.h> #include <tqstring.h> #include <tqstringlist.h> #include <tqvaluelist.h> #include <kdemacros.h> #include <tdelibs_export.h> #include <tdeprint/kpreloadobject.h> class KPrinterImpl; class KPrintDialogPage; class KPrinterPrivate; class DrPageSize; /** * This class is the main interface to access the KDE print framework. It allows KDE * applications to easily access the print system, through an interface that is compatible * with TQPrinter. So that the porting of an existing application should be as easy as * replacing any occurrence of TQPrinter by KPrinter. However applications that explicitly * used the TQPrintDialog class must be changed to the standard KPrinter way of accessing * the print dialog. * * Basically, a KDE application will use the KPrinter object as a paint device, and will draw * on it using TQPainter. In a standard application, the use of the KPrinter class will * look like this: * \code * #include <kprinter.h> * #include <tqpainter.h> * * void MyClass::doPrint() * { * KPrinter printer; * * // do some printer initialization * printer.setFullPage( true ); * * // initialize the printer using the print dialog * if ( printer.setup( this ) ) * { * // create a painter to paint on the printer object * TQPainter painter; * * // start painting * painter.begin( &printer ); * <do something> * // stop painting, this will automatically send the print data to the printer * painter.end(); * } * } * \endcode * * The KPrinter interface also allows some more advanced possibilities, like the customization * of the print dialog to integrate application specific print options. This is done by subclassing * KPrintDialogPage and adding the page using addDialogPage(). * * When compiling an application that uses KPrinter, you must link to -ltdeprint, which when * using the standard KDE build framework can be done by adding $(LIB_TDEPRINT) to _LDADD. * * @short The central interface class to access the KDE print system. * @author Michael Goffioul * @see TQPrinter, KPrintDialogPage */ class TDEPRINT_EXPORT KPrinter : public TQPaintDevice, public KPReloadObject { friend class KPrinterWrapper; friend class KPrinterImpl; public: // Print global settings (set via static functions) /** * Defines the standard pages available for the print dialog: * @li @p CopiesPage: page and copies selection (included by default) * @li @p FilesPage: file selection (only used by kprinter utility) * @li @p Custom: unused * * @see addStandardPage(), removeStandardPage() */ enum StandardPageType { CopiesPage = 0x01, FilesPage = 0x02, Custom = 0x10 }; /** * Defines whether the application can perform page selection itself or not. * Some print systems (like CUPS) can do page selection, in this case the * page selection will be enabled in the print dialog, otherwise it will be * disabled. However some applications (word processor) can do page selection * themselves, then it will be enabled in the print dialog, whatever the * print system used. But such an application has to tell tdeprint about its * feature: * @li @p ApplicationSide: the application will do page selection * @li @p SystemSide: page selection will be left to the print system, if available (default) * * @see setPageSelection(), pageSelection() */ enum PageSelectionType { ApplicationSide = 0x01, SystemSide = 0x02 }; /** * Defines the type of the application, this affects the GUI of the print dialog: * @li @p Dialog: print dialog used in an application (default) * @li @p StandAlone: print dialog used as a standalone widget * @li @p StandAlonePersistent: print dialog used as standalone widget, but persistent (do not use) * * @internal * @see setApplicationType(), applicationType() */ enum ApplicationType { Dialog = 0x00, StandAlone = 0x01, StandAlonePersistent = 0x02 }; // TQPrinter extension /** * Defines the page set to print: * @li @p AllPages: all pages * @li @p OddPages: only odd pages * @li @p EvenPages: only even pages * * @see pageSet() */ enum PageSetType { AllPages = 0x00, OddPages = 0x01, EvenPages = 0x02 }; /** * Defines the collate property of the printer (if supported by the print system): * @li @p Collate: copies collated (1-2-3-..., 1-2-3-...) * @li @p Uncollate: copies uncollated (1-1-..., 2-2-..., 3-3-...) * * @see setCollate(), collate() */ enum CollateType { Collate = 0x00, Uncollate = 0x01 }; // from TQPrinter class /** * Defines the color mode of the printer * @see TQPrinter::ColorMode */ enum ColorMode { GrayScale = TQPrinter::GrayScale, Color = TQPrinter::Color }; /** * Defines the orientation of the paper * @see TQPrinter::Orientation */ enum Orientation { Portrait = TQPrinter::Portrait, Landscape = TQPrinter::Landscape }; /** * Defines the page order of the print job * @see TQPrinter::PageOrder */ enum PageOrder { FirstPageFirst = TQPrinter::FirstPageFirst, LastPageFirst = TQPrinter::LastPageFirst }; /** * Defines the paper size to use * @see TQPrinter::PageSize */ enum PageSize { A4 = TQPrinter::A4, B5 = TQPrinter::B5, Letter = TQPrinter::Letter, Legal = TQPrinter::Legal, Executive = TQPrinter::Executive, A0 = TQPrinter::A0, A1 = TQPrinter::A1, A2 = TQPrinter::A2, A3 = TQPrinter::A3, A5 = TQPrinter::A5, A6 = TQPrinter::A6, A7 = TQPrinter::A7, A8 = TQPrinter::A8, A9 = TQPrinter::A9, B0 = TQPrinter::B0, B1 = TQPrinter::B1, B10 = TQPrinter::B10, B2 = TQPrinter::B2, B3 = TQPrinter::B3, B4 = TQPrinter::B4, B6 = TQPrinter::B6, B7 = TQPrinter::B7, B8 = TQPrinter::B8, B9 = TQPrinter::B9, C5E = TQPrinter::C5E, Comm10E = TQPrinter::Comm10E, DLE = TQPrinter::DLE, Folio = TQPrinter::Folio, Ledger = TQPrinter::Ledger, Tabloid = TQPrinter::Tabloid, NPageSize = TQPrinter::NPageSize }; // constructors / destructor /** * Constructor. This also restores/saves the state from a previous KPrinter object created within * the same application run, if @p restore is true. Setting @p restore to false may * be useful if you want an independent/clean KPrinter object. * @param restore if true, options will be restored/saved between successive KPrinter objects * @param m the mode to establish the KPrinter in (see TQPrinter::PrinterMode) */ KPrinter(bool restore = true, TQPrinter::PrinterMode m = TQPrinter::ScreenResolution ); /** * Destructor. This also saves the current KPrinter state for future printing. */ ~KPrinter(); // TQPrinter interface (+ some extensions) /** * See TQPrinter::newPage(). */ bool newPage(); /** * See TQPrinter::abort(). */ bool abort(); /** * See TQPrinter::aborted(.) */ bool aborted() const; /** * See TQPrinter::outputToFile(). */ bool outputToFile() const; /** * See TQPrinter::setOutputToFile(). */ void setOutputToFile(bool); /** * See TQPrinter::outputFileName(). */ TQString outputFileName() const; /** * See TQPrinter::setOutputFileName(). */ void setOutputFileName(const TQString&); /** * See TQPrinter::docName(). */ TQString docName() const; /** * See TQPrinter::setDocName(). */ void setDocName(const TQString&); /** * See TQPrinter::creator(). */ TQString creator() const; /** * See TQPrinter::setCreator(). */ void setCreator(const TQString&); /** * See TQPrinter::fullPage(). */ bool fullPage() const; /** * See TQPrinter::setFullPage(). */ void setFullPage(bool); /** * See TQPrinter::colorMode(). */ ColorMode colorMode() const; /** * See TQPrinter::setColorMode(). */ void setColorMode(ColorMode); /** * See TQPrinter::numCopies(). */ int numCopies() const; /** * See TQPrinter::setNumCopies(). */ void setNumCopies(int n); /** * See TQPrinter::orientation(). */ Orientation orientation() const; /** * See TQPrinter::setOrientation(). */ void setOrientation(Orientation); /** * See TQPrinter::pageOrder(). */ PageOrder pageOrder() const; /** * See TQPrinter::setPageOrder(). */ void setPageOrder(PageOrder); /** * Returns the collate status of the current KPrinter. */ CollateType collate() const; /** * Sets the collate status for the current KPrinter to @p type. */ void setCollate(CollateType type); /** * See TQPrinter::minPage(). */ int minPage() const; /** * See TQPrinter::maxPage(). */ int maxPage() const; /** * See TQPrinter::setMinMax(). */ void setMinMax(int, int); /** * Returns the first page to be printed. * @deprecated Applications * should use pageList() instead, which takes into account all options: collate, * page order, ranges, page set, ... * * @see pageList() */ int fromPage() const KDE_DEPRECATED; /** * Returns the last page to be printed. * @deprecated Applications * should use pageList() instead, which takes into account all options: collate, * page order, ranges, page set, ... * * @see pageList() */ int toPage() const; /** * Sets the first and last page to be printed. See TQPrinter::setFromTo(). */ void setFromTo(int, int); /** * See TQPrinter::pageSize(). */ PageSize pageSize() const; /** * See TQPrinter::setPageSize(). */ void setPageSize(PageSize); /** * See TQPrinter::printerName(). */ TQString printerName() const; /** * See TQPrinter::setPrinterName(). */ void setPrinterName(const TQString&); /** * Returns the print program as set by setPrintProgram() or by the print dialog * if a special printer has been selected. * @return the print command line * @see setPrintProgram() */ TQString printProgram() const; /** * Sets the command line to use when printing. This function is useful * when using a KPrinter object without the print dialog, to control what * to print and how to do it. The command line may contain the following * tags: * @li %in : the input file to the print program. It is required and automatically * appended at the end of the command line if not present. * @li %out : the output file. Use this tag in conjunction with setOutputToFile() * and setOutputFileName() * @li %psl : the page size in lower case. This may be useful with some * programs like gs. * \code * void createPNGOutputFile(const TQString& filename) * { * // use a clean KPrinter object * KPrinter prt(false); * * prt.setOutputToFile( true ); * prt.setOutputFileName( filename ); * prt.setPrintProgram( "gs -sDEVICE=png256 -sPAPERSIZE=%psl -sOutputFile=%out %in" ); * * TQPainter painter( &prt ); * doPaint( &painter ); * } * \endcode * @param cmd the print command line (containing at least the @p %in tag) * @see printProgram() */ void setPrintProgram(const TQString& cmd); /** * See TQPrinter::printerSelectionOption(). Unused. */ TQString printerSelectionOption() const; /** * See TQPrinter::setPrinterSelectionOption(). Unused */ void setPrinterSelectionOption(const TQString&); /** * Returns the current page number. * @see setCurrentPage() */ int currentPage() const; /** * Sets the current page number. This page number will be used if the user * selected "current page" in the print dialog. This option will only be * enabled if the application does page selection itself and the application * has called setCurrentPage() before opening the print dialog: * \code * MyClass::MyClass() * { * // declares my application able to do page selection * KPrinter::setPageSelection( KPrinter::ApplicationSide ); * } * * void MyClass::doPrint() * { * KPrinter printer; * * printer.setCurrentPage( mycurrentpage ); * if ( printer.setup( this ) ) * { * TQValueList<int> pages = printer.pageList(); * // print the pages * ... * } * } * \endcode * @param p the current page number (starting from 1) */ void setCurrentPage(int p = 0); /** * Returns the page set of the current KPrinter object. */ PageSetType pageSet() const; /** * Sets up the KPrinter object using the print dialog, returns true if the user clicked OK. * @param parent the parent widget to use for the print dialog * @param caption the caption to use in the print dialog * @param forceExpand force the expansion of the dialog (the show/hide button will be hidden) * @returns boolean value corresponding to the button clicked by the user */ bool setup(TQWidget *parent = 0, const TQString& caption = TQString::null, bool forceExpand = false); /** * See TQPrinter::margins(). */ TQSize margins() const; /** * Not used yet. */ void setMargins(TQSize m); /** * Returns the page size in dot unit ( 1 dot = 1/72th in ). This method is intended for * internal use, if you want to access actual page size, use a TQPaintDeviceMetrics object * instead. Note that the size returned by this method does not take resolution into * account, and that it can returns invalid size if no page metric was found in the printer * driver. DO NOT USE, WILL BE REMOVED. * @see setRealPageSize * @obsolete */ TQSize realPageSize() const; /** * DO NOT USE, WILL BE REMOVED. * @obsolete */ void setRealPageSize( TQSize p ); /** * DO NOT USE, WILL BE REMOVED. * @obsolete */ void setRealDrawableArea( const TQRect& r ); /** * DO NOT USE, WILL BE REMOVED. * @obsolete */ TQRect realDrawableArea() const; void margins( uint *top, uint *left, uint *bottom, uint *right ) const; void setMargins( uint top, uint left, uint bottom, uint right ); /** * Returns the page list to be printed, correpsonding to the options selected by the user. This * takes into account collate, page order, page set, ranges, ... This is useful when the * application does page selection itself. * @see setCurrentPage() */ TQValueList<int> pageList() const; /** * Sets the KPrinter object to preview mode if @p on is true. In this mode, nothing will be * printed but only a preview dialog will be popped up with the single "Close" action. Using * this mode, any application can easily implement a preview action: * \code * void MyClass:doPreview() * { * // use a "clean" KPrinter object (independent from previous print jobs), * // this is not necessary, it depends on the application * KPrinter prt( false ); * prt.setPreviewOnly( true ); * * TQPainter painter( &prt ); * doPrint( &painter ); * } * \endcode * @param on the preview-only state * @see previewOnly() */ void setPreviewOnly(bool on); /** * Returns the preview-only state for this KPrinter object. * @see setPreviewOnly() */ bool previewOnly() const; /** * Set the resolution of the current KPrinter object. The resolution is given in DPI. This * resolution mainly affects the accuracy for object positionning on the paint device, and * does not influence the real resolution that will be used by the printer (this should be * set in the driver settings). The resolution is usually defined in the constructor. * @param dpi the resolution in DPI * @see KPrinter(), resolution() */ void setResolution(int dpi); /** * Resturns the resolution of the current KPrinter object. The resolution is given in DPI. * @returns resolution in DPI * @see setResolution(), KPrinter() */ int resolution() const; /** * Define the KPrinter object to use the actual printer resolution. Under some print systems * (CUPS, Foomatic, PostScript printers), it is possible to know the actual resolution that * is used by the printer, as selected by the user in the driver settings. If @p on is true, * this KPrinter object will use the actual printer resolution if it is able to extract it. * If nothing can be found, the default resolution will be the one defined by the PrinterMode * argument used in the KPrinter constructor, or set explicitly by setResolution(). * @param on true if the KPrinter object should use the actual printer resolution * @see resolution(), setResolution() */ void setUsePrinterResolution( bool on ); /** * For internal use only. */ KPrinterImpl* implementation() const; /** * Prints the files given in argument. This will first filter the files accorsing to the filtering * options selected by the user in the print dialog, then send the filtered files to the printer * with the print options selected. This function is called automatically when calling * TQPainter::end() for a painter object constructed on KPrinter. In normal use, you don't need * this use this function explicitly. */ bool printFiles(const TQStringList& files, bool removeafter = false, bool startviewer = true); /** * Adds a customized page to the print dialog. The pages will appear in a tab widget in the * bottom half of the dialog, along with the standard "Copies" page. The page must be created * and added each time you want open a print dialog with setup(). If you correctly * reimplemented KPrintDialogPage::setOptions(), the settings will be restored from call * to call, you don't have to worry about state saving/restoration. * @param _page the page to add * @see KPrintDialogPage::setOptions() */ static void addDialogPage(KPrintDialogPage* _page); /** * Sets the page selection mode of the application. If needed, call this method somewhere at * the beginning of your code. The default value is @p SystemSide. * @param _mode the mode for the application * @see pageSelection() */ static void setPageSelection(PageSelectionType _mode); /** * Returns the page selection mode of the current application. * @returns the page selection mode * @see setPageSelection() */ static PageSelectionType pageSelection(); /** * Sets the application type concerning the print dialog. You probably don't want to use it. * For internal use only. * @param type the type for this application * @see applicationType() */ static void setApplicationType(ApplicationType type); /** * Returns the application type concerning the print dialog. For internal use only. * @returns the type for the current application * @see setApplicationType() */ static ApplicationType applicationType(); /** * Adds a standard page to the print dialog. This is not useful yet as there's only one * standard page defines @p CopiesPage. * @param p the page identifier * @see StandardPageType */ static void addStandardPage(int p); /** * Removes a standard page from the print dialog. If your application doesn't want a * standard page in the dialog, simply call this method with the correct identifier. * By default, the print dialog includes the @p CopiesPage page. * @param p the page identifier * @see StandardPageType */ static void removeStandardPage(int p); /** * Starts the add printer wizard. This utility function allows any application for * adding a printer using the KDEPrint powerful wizard. * @param parent the parent widget for the wizard * @returns 1: success, 0: cancel, -1: error */ //static int addPrinterWizard(TQWidget *parent = 0); /** * The KPrinter object stores all its settings in an internal TQMap structure on * TQString. This allows to store any property. This method allows an application to access * any print option from the KPrinter object, using the option name. For example if your * application add a customized page to the print dialog, this page will saves its settings * into the KPrinter object using this TQMap<TQString,TQString> structure. After showing the * print dialog, your application can then access these options using this method. The * custom option name should follow the form "kde-appname-optionname". * \code * void MyClass::doPrint() * { * KPrinter prt; * * // add my custom page * prt.addDialogPage( new MyDialogPage() ); * * // open print dialog * if ( prt.setup( this ) ) * { * TQString fntname = prt.option( "kde-myapp-fontname" ); * ... * do_something; * ... * } * } * \endcode * @param key the option name (key) * @returns the option value correponding to the key, or TQString::null * @see KPrintDialogPage, setOption, options(), setOptions() */ const TQString& option(const TQString& key) const; /** * Adds or modifies an option in the KPrinter object. You probably don't need to use this function * explicitly. This will be done implicitely for example when reimplementing * KPrintDialogPage::getOptions(). * @param key the option name * @param value the option value * @see option(), KPrintDialogPage */ void setOption(const TQString& key, const TQString& value); /** * Returns the complete set of print options from the KPrinter object. For internal use. * @returns the option set as a TQMap object */ const TQMap<TQString,TQString>& options() const; /** * Sets the option set in one operation. This method has some side effects like merging * the internal map with the one given in argument, but only for option in the form * "kde-...". For internal use only. * @param opts the option set to be merged in the KPrinter object */ void setOptions(const TQMap<TQString,TQString>& opts); /** * For internal use only. Does a similar job as setOption(), except that all possible * internal printers are initialized with the option if it has the form "kde-...". * @param opts the option set * @see setOptions() */ void initOptions(const TQMap<TQString,TQString>& opts); /** * Returns the search name of the printer selected by the user. Each printer is identified by * a unique name. This method is mainly used for state restoration. For internal use. * @returns the unique printer search name * @see setSearchName */ TQString searchName() const; /** * Sets the search name of the KPrinter object. For internal use. * @param n the unique printer search name * @see searchName() */ void setSearchName(const TQString& n); /** * Returns the last error message issued by the print system. Unimplemented yet. * @returns the last error message */ TQString errorMessage() const; /** * Sets the last error message. For internal use. * @param msg the error message */ void setErrorMessage(const TQString& msg); /** * Configure the KPrinter object to be used with the printer named * @p prname. After the call, the KPrinter object can be used without * the need to call the print dialog. If @p prname is empty, then the * KPrinter object is configured for the default printer. If @p prname * corresponds to a pseudo-printer which needs an output file, a file * dialog will be used. In that case, providing a parent widget for * that dialog in @p parent may be useful. * @param prname the name of the printer for which the KPrinter object * has to be configured * @param parent a parent widget, used a parent for a file dialog * @returns boolean flag: if false, the KPrinter has not been correctly * set up, and the application shouldn't use it to print. This may * happen if the printer named @p prname has not been found or if the * user clicked "Cancel" in the file dialog. * @see setup() */ bool autoConfigure(const TQString& prname = TQString::null, TQWidget *parent = 0); /** * Set the default document filename. This filename will be used as the * default basename for the output file, instead of the default "print". * For example, by using setDocFileName("my_document"), the default * output file will be $HOME/my_document.ps. * @param filename the default document basename to use * @see docFileName() */ void setDocFileName(const TQString& filename); /** * Get the default document filename, that is the default basename used for * the output file. * @returns the default document basename * @see setDocFileName() */ TQString docFileName() const; /** * Set the default document directory. This directory will be used as * the default location for any output file. If not set, $HOME directory * is used instead. * @param dir the new default output directory * @see docDirectory() */ void setDocDirectory( const TQString& dir ); /** * Get the default document directory, that is the directory used for * any output file. By default, it is the $HOME directory. * @returns the default output directory * @see setDocDirectory */ TQString docDirectory() const; protected: virtual bool cmd(int, TQPainter*, TQPDevCmdParam*); virtual int metric(int) const; void translateQtOptions(); void loadSettings(); void saveSettings(); void preparePrinting(); void finishPrinting(); void reload(); void init(bool restore = true, TQPrinter::PrinterMode m = TQPrinter::ScreenResolution); bool doPreview(const TQString& file); void setRealPageSize(DrPageSize* p); void setOption( const TQString& key, const TQString& value, bool broadcast ); protected: KPrinterPrivate *d; }; //************************************************************************************** // Utility functions TDEPRINT_EXPORT KPrinter::PageSize pageNameToPageSize(const TQString& name); TDEPRINT_EXPORT const char* pageSizeToPageName(KPrinter::PageSize s); /** * DO NOT USE, WILL BE REMOVED. * @obsolete */ TQSize rangeToSize( const TQString& ); #endif