123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244 |
- /*
- @class: PictureFlow
- @descprition: This class extends an additional feature to
- PictureFlow (http://pictureflow.googlecode.com). It also displays a caption whenever
- a slide is displayed.
- @author: Mirko Perkusich
- Taciana Rached
- */
- /*
- Copyright (c) 2010 Embedded Systems and Pervasive Laboratory, Federal
- University of Campina Grande, Brazil, Angelo Perkusich, Mirko Perkusich,
- Taciana Rached
- Permission is hereby granted, free of charge, to any person obtaining a
- copy of this software and associated documentation files (the
- "Software"), to deal in the Software without restriction, including
- without limitation the rights to use, copy, modify, merge, publish,
- distribute, sublicense, and/or sell copies of the Software, and to
- permit persons to whom the Software is furnished to do so, subject to
- the following conditions:
- The above copyright notice and this permission notice shall be included
- in all copies or substantial portions of the Software.
- THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
- OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
- MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
- IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
- CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
- TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
- SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
- */
- /*
- PictureFlow - animated image show widget
- http://pictureflow.googlecode.com
- Copyright (C) 2008 Ariya Hidayat (ariya@kde.org)
- Copyright (C) 2007 Ariya Hidayat (ariya@kde.org)
- Permission is hereby granted, free of charge, to any person obtaining a copy
- of this software and associated documentation files (the "Software"), to deal
- in the Software without restriction, including without limitation the rights
- to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
- copies of the Software, and to permit persons to whom the Software is
- furnished to do so, subject to the following conditions:
- The above copyright notice and this permission notice shall be included in
- all copies or substantial portions of the Software.
- THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
- OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
- THE SOFTWARE.
- */
- #ifndef PICTUREFLOW_H
- #define PICTUREFLOW_H
- #include <qwidget.h>
- #include <QDebug>
- class PictureFlowPrivate;
- /*!
- Class PictureFlow implements an image show widget with animation effect
- like Apple's CoverFlow (in iTunes and iPod). Images are arranged in form
- of slides, one main slide is shown at the center with few slides on
- the left and right sides of the center slide. When the next or previous
- slide is brought to the front, the whole slides flow to the right or
- the right with smooth animation effect; until the new slide is finally
- placed at the center.
- */
- class PictureFlow : public QWidget
- {
- Q_OBJECT
- Q_PROPERTY(QColor backgroundColor READ backgroundColor WRITE setBackgroundColor)
- Q_PROPERTY(QSize slideSize READ slideSize WRITE setSlideSize)
- Q_PROPERTY(int slideCount READ slideCount)
- Q_PROPERTY(int centerIndex READ centerIndex WRITE setCenterIndex)
- public:
- enum ReflectionEffect
- {
- NoReflection,
- PlainReflection,
- BlurredReflection
- };
- /*!
- Creates a new PictureFlow widget.
- */
- PictureFlow(QWidget* parent = 0);
- /*!
- Destroys the widget.
- */
- ~PictureFlow();
- /*!
- Returns the background color.
- */
- QColor backgroundColor() const;
- /*!
- Sets the background color. By default it is black.
- */
- void setBackgroundColor(const QColor& c);
- /*!
- Returns the dimension of each slide (in pixels).
- */
- QSize slideSize() const;
- /*!
- Sets the dimension of each slide (in pixels).
- */
- void setSlideSize(QSize size);
- /*!
- Returns the total number of slides.
- */
- int slideCount() const;
- /*!
- Returns QImage of specified slide.
- */
- QImage slide(int index) const;
- /*!
- Returns the index of slide currently shown in the middle of the viewport.
- */
- int centerIndex() const;
- /*!
- Returns the effect applied to the reflection.
- */
- ReflectionEffect reflectionEffect() const;
- /*!
- Sets the effect applied to the reflection. The default is PlainReflection.
- */
- void setReflectionEffect(ReflectionEffect effect);
- public slots:
- /*!
- Adds a new slide.
- */
- void addSlide(const QImage& image);
- /*!
- Adds a new slide.
- */
- void addSlide(const QPixmap& pixmap);
- /*!
- Adds a new caption
- */
- void addSlideCaption(QString caption);
- /*!
- Sets an image for specified slide. If the slide already exists,
- it will be replaced.
- */
- void setSlide(int index, const QImage& image);
- /*!
- Sets a caption for the specified slide.
- */
- void setSlideCaption(int index, QString caption);
- /*!
- Sets a pixmap for specified slide. If the slide already exists,
- it will be replaced.
- */
- void setSlide(int index, const QPixmap& pixmap);
- /*!
- Sets slide to be shown in the middle of the viewport. No animation
- effect will be produced, unlike using showSlide.
- */
- void setCenterIndex(int index);
- /*!
- Clears all slides.
- */
- void clear();
- /*!
- Shows previous slide using animation effect.
- */
- void showPrevious();
- /*!
- Shows next slide using animation effect.
- */
- void showNext();
- /*!
- Go to specified slide using animation effect.
- */
- void showSlide(int index);
- /*!
- Rerender the widget. Normally this function will be automatically invoked
- whenever necessary, e.g. during the transition animation.
- */
- void render();
- /*!
- Schedules a rendering update. Unlike render(), this function does not cause
- immediate rendering.
- */
- void triggerRender();
- signals:
- void centerIndexChanged(int index);
- void mouseClicked();
- protected:
- void paintEvent(QPaintEvent *event);
- void keyPressEvent(QKeyEvent* event);
- void mousePressEvent(QMouseEvent* event);
- void resizeEvent(QResizeEvent* event);
- private slots:
- void updateAnimation();
- private:
- PictureFlowPrivate* d;
- };
- #endif // PICTUREFLOW_H
|