mirror of
https://invent.kde.org/graphics/okular
synced 2024-11-05 18:34:53 +00:00
34b8e28322
- Page: rotation does not switch height and width - Document/Part/Generator: 1. Add API for attaching stuff to the interface: ActionCollection and the Navigation Panel also add possibility to merge an XML .rc file with menu layout. Relevant functions are: QString Generator::getXMLFile(), returns a QString with your .rc file name. void Generator::setupGUI (KActionCollection* , QToolbox* ), add your components to the user interface 2. Supporting backend settings: If during startup, backends which provide a configuration ([X-KDE-oKularHasInternalSettings] set to true) are found, a menu item: configure backends is created, clicking on it results in loading all the generators that have settings, but not those that dont. the Generator::addPages(KConfigDialog *dlg) function should be overloaded by a generator and dlg->addPage should be used to add pages. If a user opens a file that needs an already loaded generator, the already loaded one is used instead of loading another. 3. Error/Warning/Notice sending support, to send a notice/error/warning, add a relevant notice/error/warning(QString& txt ,int duration) to the generator class, and sending a message to the user is as simple as emitting a signal! 4. Intercepting of events generated by the PageView is done by Generator::handleEvent(QEvent*), subclass it, do a switch on QEvent::type(), handle your event and return true if pageview is to proceed with its handling or false if not. 5. Support configuring the KPrinter on the generator side, use Generator::canConfigurePrinter(), return true there, and you get a nonconfigured KPrinter in your Generator::print() 6. PixmapRequest handling update: a.) Generator::canGeneratePixmap is now Generator::canGeneratePixmap(bool async) b.) Document::sendGeneratorRequests is a slot now c.) Old way of sending pixmaps (Document::requestPixmaps(QValueList<PixmapRequest*> checking if we can generate pixmap if not, waiting for receiving) is replaced with: requestPixmaps only queues the pixmap all checking if w can generate is done in sendGeneratorReqest, the sendGeneratorRequest is run in three places: 1. in requestPixmaps when we receive a request 2. in requestDone if pixmapStack is not empty 3. sendGeneratorRequest, apart from removing invalid requests, takes the current request and if generator canGeratePixmap(request->async) it removes the pixmap from stack and sends to generator if not, QTimer::singleshots to itself after 20ms, it ends when stack has no valid pixmap request 7. Added a commented out zoom field to PixmapGenerator, mightcome in handy sometime - TextPage: add instructions that handle simplyfing the RegularAreaRect, no more double painted borders in selection rectangles, this rocks. svn path=/trunk/playground/graphics/oKular/kpdf/; revision=445196
195 lines
5 KiB
C++
195 lines
5 KiB
C++
/***************************************************************************
|
|
* Copyright (C) 2002 by Wilco Greven <greven@kde.org> *
|
|
* Copyright (C) 2003-2004 by Christophe Devriese *
|
|
* <Christophe.Devriese@student.kuleuven.ac.be> *
|
|
* Copyright (C) 2003 by Andy Goossens <andygoossens@telenet.be> *
|
|
* Copyright (C) 2003 by Laurent Montel <montel@kde.org> *
|
|
* Copyright (C) 2004 by Dominique Devriese <devriese@kde.org> *
|
|
* 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_PART_H_
|
|
#define _KPDF_PART_H_
|
|
|
|
#include <kparts/browserextension.h>
|
|
#include <kparts/part.h>
|
|
#include <qguardedptr.h>
|
|
#include "core/observer.h"
|
|
#include "core/document.h"
|
|
#include "dcop.h"
|
|
|
|
class QWidget;
|
|
class QSplitter;
|
|
class QToolBox;
|
|
|
|
class KURL;
|
|
class KAction;
|
|
class KConfig;
|
|
class KDirWatch;
|
|
class KToggleAction;
|
|
class KSelectAction;
|
|
class KAboutData;
|
|
class KPrinter;
|
|
|
|
class KPDFDocument;
|
|
class ThumbnailList;
|
|
class ThumbnailController;
|
|
class PageView;
|
|
class PresentationWidget;
|
|
class SearchWidget;
|
|
|
|
namespace KPDF {
|
|
|
|
class BrowserExtension;
|
|
|
|
/**
|
|
* This is a "Part". It that does all the real work in a KPart
|
|
* application.
|
|
*
|
|
* @short Main Part
|
|
* @author Wilco Greven <greven@kde.org>
|
|
* @version 0.2
|
|
*/
|
|
class Part : public KParts::ReadOnlyPart, public DocumentObserver, virtual public kpdf_dcop
|
|
{
|
|
Q_OBJECT
|
|
|
|
public:
|
|
// Default constructor
|
|
Part(QWidget* parentWidget, const char* widgetName,
|
|
QObject* parent, const char* name, const QStringList& args);
|
|
|
|
// Destructor
|
|
~Part();
|
|
|
|
// inherited from DocumentObserver
|
|
uint observerId() const { return PART_ID; }
|
|
void notifyViewportChanged( bool smoothMove );
|
|
|
|
static KAboutData* createAboutData();
|
|
|
|
ASYNC goToPage(uint page);
|
|
ASYNC openDocument(KURL doc);
|
|
uint pages();
|
|
uint currentPage();
|
|
KURL currentDocument();
|
|
|
|
protected:
|
|
// reimplemented from KParts::ReadOnlyPart
|
|
bool openFile();
|
|
bool openURL(const KURL &url);
|
|
bool closeURL();
|
|
// filter that watches for splitter size changes
|
|
bool eventFilter( QObject * watched, QEvent * e );
|
|
|
|
protected slots:
|
|
// connected to actions
|
|
void slotGoToPage();
|
|
void slotPreviousPage();
|
|
void slotNextPage();
|
|
void slotGotoFirst();
|
|
void slotGotoLast();
|
|
void slotHistoryBack();
|
|
void slotHistoryNext();
|
|
void slotFind();
|
|
void slotFindNext();
|
|
void slotSaveFileAs();
|
|
void slotGetNewStuff();
|
|
void slotPreferences();
|
|
void slotNewConfig();
|
|
void slotPrintPreview();
|
|
void slotShowMenu(const KPDFPage *page, const QPoint &point);
|
|
void slotShowProperties();
|
|
void slotShowLeftPanel();
|
|
void slotShowPresentation();
|
|
void slotHidePresentation();
|
|
bool slotImportPSFile();
|
|
// can be connected to widget elements
|
|
void updateViewActions();
|
|
void enableTOC(bool enable);
|
|
|
|
public slots:
|
|
// connected to Shell action (and browserExtension), not local one
|
|
void slotPrint();
|
|
void restoreDocument(const KURL &url, int page);
|
|
void saveDocumentRestoreInfo(KConfig* config);
|
|
void slotFileDirty( const QString& );
|
|
void slotDoFileDirty();
|
|
void psTransformEnded();
|
|
|
|
private:
|
|
void doPrint( KPrinter& printer );
|
|
void fillGenerators();
|
|
|
|
// the document
|
|
KPDFDocument * m_document;
|
|
QString m_temporaryLocalFile;
|
|
|
|
// main widgets
|
|
QSplitter *m_splitter;
|
|
QWidget *m_leftPanel;
|
|
QToolBox *m_toolBox;
|
|
SearchWidget *m_searchWidget;
|
|
ThumbnailList *m_thumbnailList;
|
|
PageView *m_pageView;
|
|
QGuardedPtr<PresentationWidget> m_presentationWidget;
|
|
|
|
// document watcher (and reloader) variables
|
|
KDirWatch *m_watcher;
|
|
QTimer *m_dirtyHandler;
|
|
DocumentViewport m_viewportDirty;
|
|
|
|
// actions
|
|
KAction *m_gotoPage;
|
|
KAction *m_prevPage;
|
|
KAction *m_nextPage;
|
|
KAction *m_firstPage;
|
|
KAction *m_lastPage;
|
|
KAction *m_historyBack;
|
|
KAction *m_historyNext;
|
|
KAction *m_find;
|
|
KAction *m_findNext;
|
|
KAction *m_saveAs;
|
|
KAction *m_printPreview;
|
|
KAction *m_showProperties;
|
|
KAction *m_showPresentation;
|
|
KToggleAction* m_showMenuBarAction;
|
|
KToggleAction* m_showLeftPanel;
|
|
KToggleAction* m_showFullScreenAction;
|
|
bool m_actionsSearched;
|
|
bool m_searchStarted;
|
|
BrowserExtension *m_bExtension;
|
|
|
|
// QDict: key is the name of the generator
|
|
QDict<Generator> m_loadedGenerators;
|
|
// list of names of the generators that have settings
|
|
QStringList m_generatorsWithSettings;
|
|
KSelectAction * m_confGens;
|
|
|
|
private slots:
|
|
void slotGeneratorPreferences();
|
|
};
|
|
|
|
|
|
class BrowserExtension : public KParts::BrowserExtension
|
|
{
|
|
Q_OBJECT
|
|
|
|
public:
|
|
BrowserExtension(Part*);
|
|
|
|
public slots:
|
|
// Automatically detected by the host.
|
|
void print();
|
|
};
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
// vim:ts=2:sw=2:tw=78:et
|