mirror of
https://bitbucket.org/smil3y/kde-extraapps.git
synced 2025-02-23 18:32:53 +00:00
206 lines
5.5 KiB
C++
206 lines
5.5 KiB
C++
/*
|
|
Gwenview: an image viewer
|
|
Copyright 2007 Aurélien Gâteau <agateau@kde.org>
|
|
|
|
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.
|
|
|
|
This program 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 General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program; if not, write to the Free Software
|
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
*/
|
|
#ifndef THUMBNAILVIEW_H
|
|
#define THUMBNAILVIEW_H
|
|
|
|
#include <lib/gwenviewlib_export.h>
|
|
|
|
// Qt
|
|
#include <QListView>
|
|
|
|
// KDE
|
|
#include <KUrl>
|
|
|
|
class KFileItem;
|
|
#include <QDragEnterEvent>
|
|
#include <QDragMoveEvent>
|
|
#include <QDropEvent>
|
|
#include <QPixmap>
|
|
|
|
namespace Gwenview
|
|
{
|
|
|
|
class AbstractDocumentInfoProvider;
|
|
class AbstractThumbnailViewHelper;
|
|
|
|
struct ThumbnailViewPrivate;
|
|
class GWENVIEWLIB_EXPORT ThumbnailView : public QListView
|
|
{
|
|
Q_OBJECT
|
|
public:
|
|
enum {
|
|
MinThumbnailSize = 48,
|
|
MaxThumbnailSize = 256
|
|
};
|
|
|
|
enum ThumbnailScaleMode {
|
|
ScaleToSquare,
|
|
ScaleToHeight,
|
|
ScaleToWidth,
|
|
ScaleToFit
|
|
};
|
|
ThumbnailView(QWidget* parent);
|
|
~ThumbnailView();
|
|
|
|
void setThumbnailViewHelper(AbstractThumbnailViewHelper* helper);
|
|
|
|
AbstractThumbnailViewHelper* thumbnailViewHelper() const;
|
|
|
|
void setDocumentInfoProvider(AbstractDocumentInfoProvider* provider);
|
|
|
|
AbstractDocumentInfoProvider* documentInfoProvider() const;
|
|
|
|
ThumbnailScaleMode thumbnailScaleMode() const;
|
|
|
|
void setThumbnailScaleMode(ThumbnailScaleMode);
|
|
|
|
/**
|
|
* Returns the thumbnail size.
|
|
*/
|
|
QSize thumbnailSize() const;
|
|
|
|
/**
|
|
* Returns the aspect ratio of the thumbnail.
|
|
*/
|
|
qreal thumbnailAspectRatio() const;
|
|
|
|
QPixmap thumbnailForIndex(const QModelIndex&, QSize* fullSize = 0);
|
|
|
|
/**
|
|
* Returns true if the document pointed by the index has been modified
|
|
* inside Gwenview.
|
|
*/
|
|
bool isModified(const QModelIndex&) const;
|
|
|
|
/**
|
|
* Returns true if the document pointed by the index is currently busy
|
|
* (loading, saving, rotating...)
|
|
*/
|
|
bool isBusy(const QModelIndex& index) const;
|
|
|
|
virtual void setModel(QAbstractItemModel* model);
|
|
|
|
/**
|
|
* Publish this method so that delegates can call it.
|
|
*/
|
|
using QListView::scheduleDelayedItemsLayout;
|
|
|
|
/**
|
|
* Returns the current pixmap to paint when drawing a busy index.
|
|
*/
|
|
QPixmap busySequenceCurrentPixmap() const;
|
|
|
|
void reloadThumbnail(const QModelIndex&);
|
|
|
|
void updateThumbnailSize();
|
|
|
|
void setCreateThumbnailsForRemoteUrls(bool createRemoteThumbs);
|
|
|
|
Q_SIGNALS:
|
|
/**
|
|
* It seems we can't use the 'activated()' signal for now because it does
|
|
* not know about KDE single vs doubleclick settings. The indexActivated()
|
|
* signal replaces it.
|
|
*/
|
|
void indexActivated(const QModelIndex&);
|
|
void urlListDropped(const KUrl::List& lst, const KUrl& destination);
|
|
|
|
void thumbnailSizeChanged(const QSize&);
|
|
void thumbnailWidthChanged(int);
|
|
|
|
/**
|
|
* Emitted whenever selectionChanged() is called.
|
|
* This signal is suffixed with "Signal" because
|
|
* QAbstractItemView::selectionChanged() is a slot.
|
|
*/
|
|
void selectionChangedSignal(const QItemSelection&, const QItemSelection&);
|
|
|
|
/**
|
|
* Forward some signals from model, so that the delegate can use them
|
|
*/
|
|
void rowsRemovedSignal(const QModelIndex& parent, int start, int end);
|
|
|
|
void rowsInsertedSignal(const QModelIndex& parent, int start, int end);
|
|
|
|
public Q_SLOTS:
|
|
/**
|
|
* Sets the thumbnail's width, in pixels. Keeps aspect ratio unchanged.
|
|
*/
|
|
void setThumbnailWidth(int width);
|
|
|
|
/**
|
|
* Sets the thumbnail's aspect ratio. Keeps width unchanged.
|
|
*/
|
|
void setThumbnailAspectRatio(qreal ratio);
|
|
|
|
void scrollToSelectedIndex();
|
|
|
|
void generateThumbnailsForItems();
|
|
|
|
protected:
|
|
virtual void dragEnterEvent(QDragEnterEvent*);
|
|
|
|
virtual void dragMoveEvent(QDragMoveEvent*);
|
|
|
|
virtual void dropEvent(QDropEvent*);
|
|
|
|
virtual void keyPressEvent(QKeyEvent*);
|
|
|
|
virtual void showEvent(QShowEvent*);
|
|
|
|
virtual void wheelEvent(QWheelEvent*);
|
|
|
|
virtual void startDrag(Qt::DropActions);
|
|
|
|
protected Q_SLOTS:
|
|
virtual void rowsAboutToBeRemoved(const QModelIndex& parent, int start, int end);
|
|
virtual void rowsInserted(const QModelIndex& parent, int start, int end);
|
|
virtual void selectionChanged(const QItemSelection& selected, const QItemSelection& deselected);
|
|
virtual void dataChanged(const QModelIndex& topLeft, const QModelIndex& bottomRight);
|
|
|
|
private Q_SLOTS:
|
|
void showContextMenu();
|
|
void emitIndexActivatedIfNoModifiers(const QModelIndex&);
|
|
void setThumbnail(const KFileItem&, const QPixmap&);
|
|
void setBrokenThumbnail(const KFileItem&);
|
|
|
|
/**
|
|
* Generate thumbnail for @a index.
|
|
*/
|
|
void updateThumbnail(const QModelIndex& index);
|
|
|
|
/**
|
|
* Tells the view the busy state of the document pointed by the index has changed.
|
|
*/
|
|
void updateThumbnailBusyState(const QModelIndex& index, bool);
|
|
|
|
/*
|
|
* Cause a repaint of all busy indexes
|
|
*/
|
|
void updateBusyIndexes();
|
|
|
|
private:
|
|
friend struct ThumbnailViewPrivate;
|
|
ThumbnailViewPrivate * const d;
|
|
};
|
|
|
|
} // namespace
|
|
|
|
#endif /* THUMBNAILVIEW_H */
|