/*************************************************************************** * Copyright (C) 2004 by Albert Astals Cid * * * * 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 _OKULAR_THUMBNAILLIST_H_ #define _OKULAR_THUMBNAILLIST_H_ #include #include #include #include "core/observer.h" class ThumbnailListPrivate; namespace Okular { class Document; } /** * @short A scrollview that displays page pixmap previews (aka thumbnails). * * ... */ class ThumbnailList : public QScrollArea, public Okular::DocumentObserver { Q_OBJECT public: ThumbnailList(QWidget *parent, Okular::Document *document); ~ThumbnailList(); // inherited: create thumbnails ( inherited as a DocumentObserver ) void notifySetup( const QVector< Okular::Page * > & pages, int setupFlags ); // inherited: hilihght current thumbnail ( inherited as DocumentObserver ) void notifyCurrentPageChanged( int previous, int current ); // inherited: redraw thumbnail ( inherited as DocumentObserver ) void notifyPageChanged( int pageNumber, int changedFlags ); // inherited: request all visible pixmap (due to a global shange or so..) void notifyContentsCleared( int changedFlags ); // inherited: the visible areas of the page have changed void notifyVisibleRectsChanged(); // inherited: tell if pixmap is hidden and can be unloaded bool canUnloadPixmap( int pageNumber ) const; // redraw visible widgets (useful for refreshing contents...) void updateWidgets(); public slots: // these are connected to ThumbnailController buttons void slotFilterBookmarks( bool filterOn ); protected: // scroll up/down the view void keyPressEvent( QKeyEvent * e ); // catch the viewport event and filter them if necessary bool viewportEvent( QEvent * ); signals: void rightClick( const Okular::Page *, const QPoint & ); private: friend class ThumbnailListPrivate; ThumbnailListPrivate *d; Q_PRIVATE_SLOT( d, void slotRequestVisiblePixmaps( int newContentsY = -1 ) ) Q_PRIVATE_SLOT( d, void slotDelayTimeout() ) }; /** * @short A vertical boxed container with zero size hint (for insertion on left toolbox) */ class ThumbnailsBox : public KVBox { public: ThumbnailsBox( QWidget * parent ) : KVBox( parent ) {} QSize sizeHint() const { return QSize(); } }; /** * @short A toolbar that sets ThumbnailList properties when clicking on items * * This class is the small toolbar that resides in the bottom of the * ThumbnailsBox container (below ThumbnailList and the SearchLine) and * emits signals whenever a button is pressed. A click action results * in invoking some method (or slot) in ThumbnailList. */ class ThumbnailController : public QToolBar { public: ThumbnailController( QWidget * parent, ThumbnailList * thumbnailList ); }; #endif