You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
163 lines
5.3 KiB
163 lines
5.3 KiB
/*************************************************************************** |
|
* Copyright (C) 2004 by Enrico Ros <eros.kde@email.it> * |
|
* Copyright (C) 2004 by Albert Astals Cid <tsdgeos@terra.es> * |
|
* * |
|
* This program 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 of the License, or * |
|
* (at your option) any later version. * |
|
***************************************************************************/ |
|
|
|
#ifndef _KPDF_DOCUMENT_H_ |
|
#define _KPDF_DOCUMENT_H_ |
|
|
|
#include <qvaluevector.h> |
|
#include <qstring.h> |
|
#include <qdom.h> |
|
|
|
class KPDFPage; |
|
class KPDFLink; |
|
class KPDFDocumentObserver; |
|
class DocumentInfo; |
|
class DocumentSynopsis; |
|
class Generator; |
|
class PixmapRequest; |
|
class KPrinter; |
|
|
|
/** |
|
* @short The Document. Heart of everything. Actions take place here. |
|
* |
|
* The Document is the main object in KPDF. All views query the Document to |
|
* get data/properties or even for accessing pages (in a 'const' way). |
|
* |
|
* It is designed to keep it detached from the document type (pdf, ps, you |
|
* name it..) so whenever you want to get some data, it asks its internals |
|
* generator to do the job and return results in a format-indepedent way. |
|
* |
|
* Apart from the generator (the currently running one) the document stores |
|
* all the Pages ('KPDFPage' class) of the current document in a vector and |
|
* notifies all the registered DocumentObservers when some content changes. |
|
* |
|
* For a better understanding of hieracies @see README.internals.png |
|
* @see KPDFDocumentObserver, KPDFPage |
|
*/ |
|
class KPDFDocument : public QObject // only for a private slot.. |
|
{ |
|
Q_OBJECT |
|
public: |
|
KPDFDocument(); |
|
~KPDFDocument(); |
|
|
|
// document handling |
|
bool openDocument( const QString & docFile ); |
|
void closeDocument(); |
|
|
|
// misc methods |
|
void addObserver( KPDFDocumentObserver * pObserver ); |
|
void removeObserver( KPDFDocumentObserver * pObserver ); |
|
void reparseConfig(); |
|
|
|
// query methods (const ones) |
|
const DocumentInfo * documentInfo() const; |
|
const DocumentSynopsis * documentSynopsis() const; |
|
const KPDFPage * page( uint page ) const; |
|
uint currentPage() const; |
|
uint pages() const; |
|
bool okToPrint() const; |
|
QString getMetaData( const QString &key ) const; |
|
|
|
// perform actions on document / pages |
|
void requestPixmaps( const QValueList< PixmapRequest * > & requests, bool asyncronous ); |
|
void requestTextPage( uint page ); |
|
void setCurrentPage( int page, const QRect & viewport = QRect() ); |
|
void findText( const QString & text = "", bool caseSensitive = false ); |
|
void findTextAll( const QString & pattern, bool caseSensitive ); |
|
void toggleBookmark( int page ); |
|
void processLink( const KPDFLink * link ); |
|
bool print( KPrinter &printer ); |
|
|
|
signals: |
|
void linkFind(); |
|
void linkGoToPage(); |
|
|
|
private: |
|
// memory management related functions |
|
void mCleanupMemory( int observerId ); |
|
int mTotalMemory(); |
|
int mFreeMemory(); |
|
// more private functions |
|
void loadDocumentInfo(); |
|
QString giveAbsolutePath( const QString & fileName ); |
|
bool openRelativeFile( const QString & fileName ); |
|
void processPageList( bool documentChanged ); |
|
void unHilightPages(); |
|
|
|
Generator * generator; |
|
QString documentFileName; |
|
QValueVector< KPDFPage * > pages_vector; |
|
class KPDFDocumentPrivate * d; |
|
|
|
private slots: |
|
void saveDocumentInfo() const; |
|
void slotCheckMemory(); |
|
void slotGeneratedContents( int id, int pageNumber ); |
|
}; |
|
|
|
/** |
|
* @short A window on the document. |
|
* |
|
* TODO HACK OVER ME AND FIXME WITH A CHAINSAW |
|
*/ |
|
struct DocumentViewport |
|
{ |
|
int lastPage; |
|
}; |
|
|
|
|
|
/** |
|
* @short Metadata that describes the document. |
|
* |
|
* The Info structure can be filled in by generators to display metadata |
|
* about the currently opened file. |
|
*/ |
|
class DocumentInfo : public QDomDocument |
|
{ |
|
public: |
|
DocumentInfo(); |
|
|
|
/** |
|
* Sets a value for a special key. The title should be an i18n'ed |
|
* string, since it's used in the document information dialog. |
|
*/ |
|
void set( const QString &key, const QString &value, |
|
const QString &title = QString() ); |
|
|
|
/** |
|
* Returns the value for a given key or an empty string when the |
|
* key doesn't exist. |
|
*/ |
|
QString get( const QString &key ) const; |
|
}; |
|
|
|
/** |
|
* @short A Dom tree that describes the Table of Contents. |
|
* |
|
* The Synopsis (TOC or Table Of Contents for friends) is represented via |
|
* a dom tree where each nod has an internal name (displayed in the listview) |
|
* and one or more attributes. |
|
* |
|
* To fill in a valid synopsis tree just add domElements where the tag name |
|
* is the screen name of the entry. |
|
* |
|
* The following attributes are valid [more may be added in future]: |
|
* - Page: The page to which the node refers. |
|
* - Position: The position inside the page, where 0 means top and 100 is |
|
* the bottom. |
|
*/ |
|
class DocumentSynopsis : public QDomDocument |
|
{ |
|
public: |
|
DocumentSynopsis(); |
|
}; |
|
|
|
#endif
|
|
|