|
|
|
/***************************************************************************
|
|
|
|
* Copyright (C) 2006 by Peter Penz *
|
|
|
|
* peter.penz@gmx.at *
|
|
|
|
* *
|
|
|
|
* 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 DOLPHINICONSVIEW_H
|
|
|
|
#define DOLPHINICONSVIEW_H
|
|
|
|
|
|
|
|
#include <tdefileiconview.h>
|
|
|
|
#include <tqpixmap.h>
|
|
|
|
#include <kurl.h>
|
|
|
|
#include <itemeffectsmanager.h>
|
|
|
|
|
|
|
|
class DolphinView;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Represents the view, where each item is shown as an icon.
|
|
|
|
*
|
|
|
|
* It is also possible that instead of the icon a preview of the item
|
|
|
|
* content is shown.
|
|
|
|
*
|
|
|
|
* @author Peter Penz
|
|
|
|
*/
|
|
|
|
class DolphinIconsView : public KFileIconView, public ItemEffectsManager
|
|
|
|
{
|
|
|
|
Q_OBJECT
|
|
|
|
|
|
|
|
|
|
|
|
public:
|
|
|
|
enum LayoutMode {
|
|
|
|
Icons,
|
|
|
|
Previews
|
|
|
|
};
|
|
|
|
|
|
|
|
DolphinIconsView(DolphinView *parent, LayoutMode layoutMode);
|
|
|
|
|
|
|
|
virtual ~DolphinIconsView();
|
|
|
|
|
|
|
|
void setLayoutMode(LayoutMode mode);
|
|
|
|
LayoutMode layoutMode() const { return m_layoutMode; }
|
|
|
|
|
|
|
|
/** @see ItemEffectsManager::updateItems */
|
|
|
|
virtual void beginItemUpdates();
|
|
|
|
|
|
|
|
/** @see ItemEffectsManager::updateItems */
|
|
|
|
virtual void endItemUpdates();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Reads out the dolphin settings for the icons view and refreshs
|
|
|
|
* the details view.
|
|
|
|
*/
|
|
|
|
// TODO: Other view implementations use a similar interface. When using
|
|
|
|
// Interview in TQt4 this method should be moved to a base class (currently
|
|
|
|
// not possible due to having different base classes for the views).
|
|
|
|
void refreshSettings();
|
|
|
|
|
|
|
|
/** @see ItemEffectsManager::zoomIn() */
|
|
|
|
virtual void zoomIn();
|
|
|
|
|
|
|
|
/** @see ItemEffectsManager::zoomOut() */
|
|
|
|
virtual void zoomOut();
|
|
|
|
|
|
|
|
/** @see ItemEffectsManager::isZoomInPossible() */
|
|
|
|
virtual bool isZoomInPossible() const;
|
|
|
|
|
|
|
|
/** @see ItemEffectsManager::isZoomOutPossible() */
|
|
|
|
virtual bool isZoomOutPossible() const;
|
|
|
|
|
|
|
|
public slots:
|
|
|
|
/**
|
|
|
|
* Bypass a layout issue in KFileIconView in combination with previews.
|
|
|
|
* @see KFileIconView::arrangeItemsInGrid
|
|
|
|
*/
|
|
|
|
virtual void arrangeItemsInGrid(bool updated = true);
|
|
|
|
|
|
|
|
signals:
|
|
|
|
/**
|
|
|
|
* Is send, if the details view should be activated. Usually an activation
|
|
|
|
* is triggered by a mouse click.
|
|
|
|
*/
|
|
|
|
void signalRequestActivation();
|
|
|
|
|
|
|
|
protected:
|
|
|
|
/** @see ItemEffectsManager::setContextPixmap */
|
|
|
|
virtual void setContextPixmap(void* context,
|
|
|
|
const TQPixmap& pixmap);
|
|
|
|
|
|
|
|
/** @see ItemEffectsManager::contextPixmap */
|
|
|
|
virtual const TQPixmap* contextPixmap(void* context);
|
|
|
|
|
|
|
|
/** @see ItemEffectsManager::firstContext */
|
|
|
|
virtual void* firstContext();
|
|
|
|
|
|
|
|
/** @see ItemEffectsManager::nextContext */
|
|
|
|
virtual void* nextContext(void* context);
|
|
|
|
|
|
|
|
/** @see ItemEffectsManager::contextFileInfo */
|
|
|
|
virtual KFileItem* contextFileInfo(void* context);
|
|
|
|
|
|
|
|
/** @see KFileIconView::contentsMousePressEvent */
|
|
|
|
virtual void contentsMousePressEvent(TQMouseEvent* event);
|
|
|
|
|
|
|
|
/** @see KFileIconView::contentsMouseReleaseEvent */
|
|
|
|
virtual void contentsMouseReleaseEvent(TQMouseEvent* event);
|
|
|
|
|
|
|
|
/** @see KFileIconView::drawBackground */
|
|
|
|
virtual void drawBackground(TQPainter* painter, const TQRect& rect);
|
|
|
|
|
|
|
|
/** @see KFileIconView::dragObject */
|
|
|
|
virtual TQDragObject* dragObject();
|
|
|
|
|
|
|
|
/** @see KFileIconView::contentsDragEnterEvent */
|
|
|
|
virtual void contentsDragEnterEvent(TQDragEnterEvent* event);
|
|
|
|
|
|
|
|
/** @see KFileIconView::contentsDragMoveEvent */
|
|
|
|
virtual void contentsDragMoveEvent(TQDragMoveEvent* event);
|
|
|
|
|
|
|
|
/** @see KFileIconView::contentsDropEvent */
|
|
|
|
virtual void contentsDropEvent(TQDropEvent* event);
|
|
|
|
|
|
|
|
private slots:
|
|
|
|
/** Is connected to the onItem-signal from KFileIconView. */
|
|
|
|
void slotOnItem(TQIconViewItem* item);
|
|
|
|
|
|
|
|
/** Is connected to the onViewport-signal from KFileIconView. */
|
|
|
|
void slotOnViewport();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Opens the context menu for the item \a item on the given
|
|
|
|
* position \a pos.
|
|
|
|
*/
|
|
|
|
void slotContextMenuRequested(TQIconViewItem* item,
|
|
|
|
const TQPoint& pos);
|
|
|
|
|
|
|
|
/** Renames the item \a item to the name \a name. */
|
|
|
|
void slotItemRenamed(TQIconViewItem* item,
|
|
|
|
const TQString& name);
|
|
|
|
|
|
|
|
void slotActivationUpdate();
|
|
|
|
void slotUpdateDisabledItems();
|
|
|
|
|
|
|
|
private:
|
|
|
|
int m_previewIconSize;
|
|
|
|
LayoutMode m_layoutMode;
|
|
|
|
DolphinView* m_dolphinView;
|
|
|
|
|
|
|
|
/** Returns the increased icon size for the size \a size. */
|
|
|
|
int increasedIconSize(int size) const;
|
|
|
|
|
|
|
|
/** Returns the decreased icon size for the size \a size. */
|
|
|
|
int decreasedIconSize(int size) const;
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|