summary refs log tree commit diff
path: root/include/SlidingStackWidget.h
diff options
context:
space:
mode:
Diffstat (limited to 'include/SlidingStackWidget.h')
-rw-r--r--include/SlidingStackWidget.h94
1 files changed, 94 insertions, 0 deletions
diff --git a/include/SlidingStackWidget.h b/include/SlidingStackWidget.h
new file mode 100644
index 00000000..7686c6eb
--- /dev/null
+++ b/include/SlidingStackWidget.h
@@ -0,0 +1,94 @@
+/*
+ * nheko Copyright (C) 2017  Konstantinos Sideris <siderisk@auth.gr>
+ *
+ * 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 3 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, see <http://www.gnu.org/licenses/>.
+ */
+
+#ifndef SLIDINGSTACKWIDGET_H
+#define SLIDINGSTACKWIDGET_H
+
+#include <QDebug>
+#include <QEasingCurve>
+#include <QParallelAnimationGroup>
+#include <QPropertyAnimation>
+#include <QStackedWidget>
+#include <QWidget>
+
+/*
+ * SlidingStackWidget allows smooth side shifting of widgets,
+ * in addition to the hard switching from one to another offered
+ * by QStackedWidget.
+ */
+
+class SlidingStackWidget : public QStackedWidget
+{
+	Q_OBJECT
+
+public:
+	// Defines the animation direction.
+	enum AnimationDirection {
+		LEFT_TO_RIGHT,
+		RIGHT_TO_LEFT,
+		AUTOMATIC
+	};
+
+	SlidingStackWidget(QWidget *parent);
+	~SlidingStackWidget();
+
+public slots:
+	// Move to the next widget.
+	void slideInNext();
+
+	// Move to the previous widget.
+	void slideInPrevious();
+
+	// Move to a widget by index.
+	void slideInIndex(int index, enum AnimationDirection direction = AnimationDirection::AUTOMATIC);
+
+	int getWidgetIndex(QWidget *widget);
+signals:
+	// Internal signal to alert the engine for the animation's end.
+	void animationFinished();
+
+protected slots:
+	// Internal slot to handle the end of the animation.
+	void onAnimationFinished();
+
+protected:
+	// The method that does the main work for the widget transition.
+	void slideInWidget(QWidget *widget, enum AnimationDirection direction = AnimationDirection::AUTOMATIC);
+
+	// Indicates whether or not the animation is active.
+	bool active_;
+
+	// The widget currently displayed.
+	QWidget *window_;
+
+	// The speed of the animation in milliseconds.
+	int speed_;
+
+	// The animation type.
+	enum QEasingCurve::Type animation_type_;
+
+	// Current widget's index.
+	int now_;
+
+	// Reference point.
+	QPoint current_position_;
+
+	// Next widget's to show index.
+	int next_;
+};
+
+#endif  // SLIDINGSTACKWIDGET_H