|
|
|
/* This file is part of the KDE libraries
|
|
|
|
Copyright (C) 2000 Kurt Granroth <granroth@kde.org>
|
|
|
|
|
|
|
|
This library is free software; you can redistribute it and/or
|
|
|
|
modify it under the terms of the GNU Library General Public
|
|
|
|
License version 2 as published by the Free Software Foundation.
|
|
|
|
|
|
|
|
This library 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
|
|
|
|
Library General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU Library General Public License
|
|
|
|
along with this library; see the file COPYING.LIB. If not, write to
|
|
|
|
the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
|
|
|
|
Boston, MA 02110-1301, USA.
|
|
|
|
*/
|
|
|
|
#ifndef _KANIMWIDGET_H
|
|
|
|
#define _KANIMWIDGET_H
|
|
|
|
|
|
|
|
#include <tqframe.h>
|
|
|
|
|
|
|
|
#include <tdelibs_export.h>
|
|
|
|
|
|
|
|
class TQStringList;
|
|
|
|
class TQPainter;
|
|
|
|
class TQMouseEvent;
|
|
|
|
|
|
|
|
class KAnimWidgetPrivate;
|
|
|
|
/**
|
|
|
|
* @short Standard "About KDE" dialog box
|
|
|
|
*
|
|
|
|
* This is a widget used to display animation using multiple
|
|
|
|
* individual pixmaps. This widget allows you to deal with variable
|
|
|
|
* size icons (e.g., ones that will change based on a global setting)
|
|
|
|
* as it loads the icons internally. All you need to do is pass along
|
|
|
|
* a list of icon names and their size and everything else is taken
|
|
|
|
* care of.
|
|
|
|
*
|
|
|
|
* This widget also emits a 'clicked()' signal when it received a
|
|
|
|
* mouse press event.
|
|
|
|
*
|
|
|
|
* A quick example:
|
|
|
|
* \code
|
|
|
|
* KAnimWidget *anim = new KAnimWidget("kde", 0, this);
|
|
|
|
* anim->start();
|
|
|
|
* \endcode
|
|
|
|
*
|
|
|
|
* That example will search for the pixmaps "one.png", "two.png", and
|
|
|
|
* "three.png" in the share/icons/small/ directories as well as the
|
|
|
|
* app's pics directory.
|
|
|
|
*
|
|
|
|
* @author Kurt Granroth <granroth@kde.org>
|
|
|
|
*/
|
|
|
|
class TDEUI_EXPORT KAnimWidget : public TQFrame
|
|
|
|
{
|
|
|
|
Q_OBJECT
|
|
|
|
TQ_PROPERTY( int size READ size WRITE setSize )
|
|
|
|
TQ_PROPERTY( TQString icons READ icons WRITE setIcons )
|
|
|
|
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
* This is the most common constructor. Pass along the name of the
|
|
|
|
* animated icons to use (e.g., "kde") for the animation and an
|
|
|
|
* optional size to load and you're set. If you omit the size, the
|
|
|
|
* default size will be used.
|
|
|
|
*
|
|
|
|
* @param icons The icons name (e.g., "kde") to use for the animation
|
|
|
|
* @param size The size to load
|
|
|
|
* You don't have to set it if the parent is a
|
|
|
|
* TDEToolBar; in this case it will use the toolbar's
|
|
|
|
* size.
|
|
|
|
* @param parent The standard parent
|
|
|
|
* @param name The standard internal name
|
|
|
|
*/
|
|
|
|
KAnimWidget( const TQString& icons, int size = 0,
|
|
|
|
TQWidget *parent = 0L, const char *name = 0L );
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Destructor
|
|
|
|
*/
|
|
|
|
virtual ~KAnimWidget();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the size of the icons.
|
|
|
|
*
|
|
|
|
* @param size The size of the icons
|
|
|
|
*/
|
|
|
|
void setSize( int size );
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the current size.
|
|
|
|
* @since 3.4
|
|
|
|
*/
|
|
|
|
int size() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the current icons
|
|
|
|
* since 3.4
|
|
|
|
*/
|
|
|
|
TQString icons() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the name of the animated icons to load. This will use the
|
|
|
|
* TDEIconLoader::loadAnimated method for the actual loading.
|
|
|
|
*
|
|
|
|
* @param icons The name of the icons to use for the animation
|
|
|
|
*/
|
|
|
|
void setIcons( const TQString& icons );
|
|
|
|
|
|
|
|
public slots:
|
|
|
|
/**
|
|
|
|
* Starts the animation from frame 1
|
|
|
|
*/
|
|
|
|
void start();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Stops the animation. This will also reset the widget to frame 1.
|
|
|
|
*/
|
|
|
|
void stop();
|
|
|
|
|
|
|
|
signals:
|
|
|
|
void clicked();
|
|
|
|
|
|
|
|
protected:
|
|
|
|
virtual void drawContents( TQPainter *p );
|
|
|
|
virtual void leaveEvent( TQEvent *e );
|
|
|
|
virtual void enterEvent( TQEvent *e );
|
|
|
|
virtual void hideEvent( TQHideEvent *e);
|
|
|
|
virtual void showEvent( TQShowEvent *e);
|
|
|
|
virtual void mousePressEvent( TQMouseEvent *e );
|
|
|
|
virtual void mouseReleaseEvent( TQMouseEvent *e );
|
|
|
|
|
|
|
|
protected slots:
|
|
|
|
void slotTimerUpdate();
|
|
|
|
void updateIcons();
|
|
|
|
|
|
|
|
protected:
|
|
|
|
virtual void virtual_hook( int id, void* data );
|
|
|
|
private:
|
|
|
|
KAnimWidgetPrivate *d;
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif // _KANIMWIDGET_H
|