Remove unnecessary animations
This commit is contained in:
parent
ff1bc797de
commit
41a85832b3
@ -135,7 +135,6 @@ set(SRC_FILES
|
|||||||
src/RoomState.cc
|
src/RoomState.cc
|
||||||
src/Register.cc
|
src/Register.cc
|
||||||
src/RegisterPage.cc
|
src/RegisterPage.cc
|
||||||
src/SlidingStackWidget.cc
|
|
||||||
src/Splitter.cc
|
src/Splitter.cc
|
||||||
src/Sync.cc
|
src/Sync.cc
|
||||||
src/TextInputWidget.cc
|
src/TextInputWidget.cc
|
||||||
@ -216,7 +215,6 @@ qt5_wrap_cpp(MOC_HEADERS
|
|||||||
include/RoomList.h
|
include/RoomList.h
|
||||||
include/Splitter.h
|
include/Splitter.h
|
||||||
include/UserInfoWidget.h
|
include/UserInfoWidget.h
|
||||||
include/SlidingStackWidget.h
|
|
||||||
include/TopRoomBar.h
|
include/TopRoomBar.h
|
||||||
include/TrayIcon.h
|
include/TrayIcon.h
|
||||||
include/TextInputWidget.h
|
include/TextInputWidget.h
|
||||||
|
@ -26,7 +26,6 @@
|
|||||||
#include "MatrixClient.h"
|
#include "MatrixClient.h"
|
||||||
#include "OverlayModal.h"
|
#include "OverlayModal.h"
|
||||||
#include "RegisterPage.h"
|
#include "RegisterPage.h"
|
||||||
#include "SlidingStackWidget.h"
|
|
||||||
#include "TrayIcon.h"
|
#include "TrayIcon.h"
|
||||||
#include "WelcomePage.h"
|
#include "WelcomePage.h"
|
||||||
|
|
||||||
@ -78,7 +77,7 @@ private:
|
|||||||
RegisterPage *register_page_;
|
RegisterPage *register_page_;
|
||||||
|
|
||||||
// A stacked widget that handles the transitions between widgets.
|
// A stacked widget that handles the transitions between widgets.
|
||||||
SlidingStackWidget *sliding_stack_;
|
QStackedWidget *pageStack_;
|
||||||
|
|
||||||
// The main chat area.
|
// The main chat area.
|
||||||
ChatPage *chat_page_;
|
ChatPage *chat_page_;
|
||||||
|
@ -1,88 +0,0 @@
|
|||||||
/*
|
|
||||||
* 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/>.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#pragma once
|
|
||||||
|
|
||||||
#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 class 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, 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,
|
|
||||||
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.
|
|
||||||
QEasingCurve::Type animation_type_;
|
|
||||||
|
|
||||||
// Current widget's index.
|
|
||||||
int now_;
|
|
||||||
|
|
||||||
// Reference point.
|
|
||||||
QPoint current_position_;
|
|
||||||
|
|
||||||
// Next widget's to show index.
|
|
||||||
int next_;
|
|
||||||
};
|
|
@ -78,7 +78,7 @@ LoginPage::LoginPage(QSharedPointer<MatrixClient> client, QWidget *parent)
|
|||||||
matrixid_input_->setPlaceholderText(tr("e.g @joe:matrix.org"));
|
matrixid_input_->setPlaceholderText(tr("e.g @joe:matrix.org"));
|
||||||
|
|
||||||
spinner_ = new LoadingIndicator(this);
|
spinner_ = new LoadingIndicator(this);
|
||||||
spinner_->setColor("#acc7dc");
|
spinner_->setColor("#333333");
|
||||||
spinner_->setFixedHeight(40);
|
spinner_->setFixedHeight(40);
|
||||||
spinner_->setFixedWidth(40);
|
spinner_->setFixedWidth(40);
|
||||||
spinner_->hide();
|
spinner_->hide();
|
||||||
|
@ -15,8 +15,8 @@
|
|||||||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "MainWindow.h"
|
|
||||||
#include "Config.h"
|
#include "Config.h"
|
||||||
|
#include "MainWindow.h"
|
||||||
|
|
||||||
#include <QApplication>
|
#include <QApplication>
|
||||||
#include <QLayout>
|
#include <QLayout>
|
||||||
@ -55,13 +55,13 @@ MainWindow::MainWindow(QWidget *parent)
|
|||||||
chat_page_ = new ChatPage(client_, this);
|
chat_page_ = new ChatPage(client_, this);
|
||||||
|
|
||||||
// Initialize sliding widget manager.
|
// Initialize sliding widget manager.
|
||||||
sliding_stack_ = new SlidingStackWidget(this);
|
pageStack_ = new QStackedWidget(this);
|
||||||
sliding_stack_->addWidget(welcome_page_);
|
pageStack_->addWidget(welcome_page_);
|
||||||
sliding_stack_->addWidget(login_page_);
|
pageStack_->addWidget(login_page_);
|
||||||
sliding_stack_->addWidget(register_page_);
|
pageStack_->addWidget(register_page_);
|
||||||
sliding_stack_->addWidget(chat_page_);
|
pageStack_->addWidget(chat_page_);
|
||||||
|
|
||||||
setCentralWidget(sliding_stack_);
|
setCentralWidget(pageStack_);
|
||||||
|
|
||||||
connect(welcome_page_, SIGNAL(userLogin()), this, SLOT(showLoginPage()));
|
connect(welcome_page_, SIGNAL(userLogin()), this, SLOT(showLoginPage()));
|
||||||
connect(welcome_page_, SIGNAL(userRegister()), this, SLOT(showRegisterPage()));
|
connect(welcome_page_, SIGNAL(userRegister()), this, SLOT(showRegisterPage()));
|
||||||
@ -157,17 +157,14 @@ MainWindow::showChatPage(QString userid, QString homeserver, QString token)
|
|||||||
settings.setValue("auth/home_server", homeserver);
|
settings.setValue("auth/home_server", homeserver);
|
||||||
settings.setValue("auth/user_id", userid);
|
settings.setValue("auth/user_id", userid);
|
||||||
|
|
||||||
int index = sliding_stack_->getWidgetIndex(chat_page_);
|
|
||||||
int modalOpacityDuration = 300;
|
int modalOpacityDuration = 300;
|
||||||
|
|
||||||
// If we go directly from the welcome page don't show an animation.
|
// If we go directly from the welcome page don't show an animation.
|
||||||
if (sliding_stack_->currentIndex() == 0) {
|
if (pageStack_->currentIndex() == 0)
|
||||||
sliding_stack_->setCurrentIndex(index);
|
|
||||||
modalOpacityDuration = 0;
|
modalOpacityDuration = 0;
|
||||||
} else {
|
|
||||||
sliding_stack_->slideInIndex(index,
|
QTimer::singleShot(
|
||||||
SlidingStackWidget::AnimationDirection::LEFT_TO_RIGHT);
|
modalOpacityDuration + 100, this, [=]() { pageStack_->setCurrentWidget(chat_page_); });
|
||||||
}
|
|
||||||
|
|
||||||
if (spinner_ == nullptr) {
|
if (spinner_ == nullptr) {
|
||||||
spinner_ = new LoadingIndicator(this);
|
spinner_ = new LoadingIndicator(this);
|
||||||
@ -192,28 +189,19 @@ MainWindow::showChatPage(QString userid, QString homeserver, QString token)
|
|||||||
void
|
void
|
||||||
MainWindow::showWelcomePage()
|
MainWindow::showWelcomePage()
|
||||||
{
|
{
|
||||||
int index = sliding_stack_->getWidgetIndex(welcome_page_);
|
pageStack_->setCurrentWidget(welcome_page_);
|
||||||
|
|
||||||
if (sliding_stack_->currentIndex() == sliding_stack_->getWidgetIndex(login_page_))
|
|
||||||
sliding_stack_->slideInIndex(index,
|
|
||||||
SlidingStackWidget::AnimationDirection::RIGHT_TO_LEFT);
|
|
||||||
else
|
|
||||||
sliding_stack_->slideInIndex(index,
|
|
||||||
SlidingStackWidget::AnimationDirection::LEFT_TO_RIGHT);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
MainWindow::showLoginPage()
|
MainWindow::showLoginPage()
|
||||||
{
|
{
|
||||||
int index = sliding_stack_->getWidgetIndex(login_page_);
|
pageStack_->setCurrentWidget(login_page_);
|
||||||
sliding_stack_->slideInIndex(index, SlidingStackWidget::AnimationDirection::LEFT_TO_RIGHT);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
MainWindow::showRegisterPage()
|
MainWindow::showRegisterPage()
|
||||||
{
|
{
|
||||||
int index = sliding_stack_->getWidgetIndex(register_page_);
|
pageStack_->setCurrentWidget(register_page_);
|
||||||
sliding_stack_->slideInIndex(index, SlidingStackWidget::AnimationDirection::RIGHT_TO_LEFT);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -1,157 +0,0 @@
|
|||||||
/*
|
|
||||||
* 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/>.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "SlidingStackWidget.h"
|
|
||||||
|
|
||||||
SlidingStackWidget::SlidingStackWidget(QWidget *parent)
|
|
||||||
: QStackedWidget(parent)
|
|
||||||
{
|
|
||||||
window_ = parent;
|
|
||||||
|
|
||||||
if (parent == Q_NULLPTR) {
|
|
||||||
qDebug() << "Using nullptr for parent";
|
|
||||||
window_ = this;
|
|
||||||
}
|
|
||||||
|
|
||||||
current_position_ = QPoint(0, 0);
|
|
||||||
speed_ = 400;
|
|
||||||
now_ = 0;
|
|
||||||
next_ = 0;
|
|
||||||
active_ = false;
|
|
||||||
animation_type_ = QEasingCurve::InOutCirc;
|
|
||||||
}
|
|
||||||
|
|
||||||
SlidingStackWidget::~SlidingStackWidget()
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
SlidingStackWidget::slideInNext()
|
|
||||||
{
|
|
||||||
int now = currentIndex();
|
|
||||||
|
|
||||||
if (now < count() - 1)
|
|
||||||
slideInIndex(now + 1);
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
SlidingStackWidget::slideInPrevious()
|
|
||||||
{
|
|
||||||
int now = currentIndex();
|
|
||||||
|
|
||||||
if (now > 0)
|
|
||||||
slideInIndex(now - 1);
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
SlidingStackWidget::slideInIndex(int index, AnimationDirection direction)
|
|
||||||
{
|
|
||||||
// Take into consideration possible index overflow/undeflow.
|
|
||||||
if (index > count() - 1) {
|
|
||||||
direction = AnimationDirection::RIGHT_TO_LEFT;
|
|
||||||
index = index % count();
|
|
||||||
} else if (index < 0) {
|
|
||||||
direction = AnimationDirection::LEFT_TO_RIGHT;
|
|
||||||
index = (index + count()) % count();
|
|
||||||
}
|
|
||||||
|
|
||||||
slideInWidget(widget(index), direction);
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
SlidingStackWidget::slideInWidget(QWidget *next_widget, AnimationDirection direction)
|
|
||||||
{
|
|
||||||
// If an animation is currenlty executing we should wait for it to finish before
|
|
||||||
// another transition can start.
|
|
||||||
if (active_)
|
|
||||||
return;
|
|
||||||
|
|
||||||
active_ = true;
|
|
||||||
|
|
||||||
int now = currentIndex();
|
|
||||||
int next = indexOf(next_widget);
|
|
||||||
|
|
||||||
if (now == next) {
|
|
||||||
active_ = false;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
int offset_x = frameRect().width();
|
|
||||||
|
|
||||||
next_widget->setGeometry(0, 0, offset_x, 0);
|
|
||||||
|
|
||||||
if (direction == AnimationDirection::LEFT_TO_RIGHT) {
|
|
||||||
offset_x = -offset_x;
|
|
||||||
}
|
|
||||||
|
|
||||||
QPoint pnext = next_widget->pos();
|
|
||||||
QPoint pnow = widget(now)->pos();
|
|
||||||
current_position_ = pnow;
|
|
||||||
|
|
||||||
// Reposition the next widget outside of the display area.
|
|
||||||
next_widget->move(pnext.x() - offset_x, pnext.y());
|
|
||||||
|
|
||||||
// Make the widget visible.
|
|
||||||
next_widget->show();
|
|
||||||
next_widget->raise();
|
|
||||||
|
|
||||||
// Animate both the next and now widget.
|
|
||||||
QPropertyAnimation *animation_now = new QPropertyAnimation(widget(now), "pos", this);
|
|
||||||
|
|
||||||
animation_now->setDuration(speed_);
|
|
||||||
animation_now->setEasingCurve(animation_type_);
|
|
||||||
animation_now->setStartValue(QPoint(pnow.x(), pnow.y()));
|
|
||||||
animation_now->setEndValue(QPoint(pnow.x() + offset_x, pnow.y()));
|
|
||||||
|
|
||||||
QPropertyAnimation *animation_next = new QPropertyAnimation(next_widget, "pos", this);
|
|
||||||
|
|
||||||
animation_next->setDuration(speed_);
|
|
||||||
animation_next->setEasingCurve(animation_type_);
|
|
||||||
animation_next->setStartValue(QPoint(pnext.x() - offset_x, pnext.y()));
|
|
||||||
animation_next->setEndValue(QPoint(pnext.x(), pnext.y()));
|
|
||||||
|
|
||||||
QParallelAnimationGroup *animation_group = new QParallelAnimationGroup(this);
|
|
||||||
|
|
||||||
animation_group->addAnimation(animation_now);
|
|
||||||
animation_group->addAnimation(animation_next);
|
|
||||||
|
|
||||||
connect(animation_group, SIGNAL(finished()), this, SLOT(onAnimationFinished()));
|
|
||||||
|
|
||||||
next_ = next;
|
|
||||||
now_ = now;
|
|
||||||
animation_group->start();
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
SlidingStackWidget::onAnimationFinished()
|
|
||||||
{
|
|
||||||
setCurrentIndex(next_);
|
|
||||||
|
|
||||||
// The old widget is no longer necessary so we can hide it and
|
|
||||||
// move it back to its original position.
|
|
||||||
widget(now_)->hide();
|
|
||||||
widget(now_)->move(current_position_);
|
|
||||||
|
|
||||||
active_ = false;
|
|
||||||
emit animationFinished();
|
|
||||||
}
|
|
||||||
|
|
||||||
int
|
|
||||||
SlidingStackWidget::getWidgetIndex(QWidget *widget)
|
|
||||||
{
|
|
||||||
return indexOf(widget);
|
|
||||||
}
|
|
@ -103,7 +103,7 @@ UserInfoWidget::UserInfoWidget(QWidget *parent)
|
|||||||
|
|
||||||
if (logoutModal_ == nullptr) {
|
if (logoutModal_ == nullptr) {
|
||||||
logoutModal_ = new OverlayModal(MainWindow::instance(), logoutDialog_);
|
logoutModal_ = new OverlayModal(MainWindow::instance(), logoutDialog_);
|
||||||
logoutModal_->setDuration(100);
|
logoutModal_->setDuration(0);
|
||||||
logoutModal_->setColor(QColor(55, 55, 55, 170));
|
logoutModal_->setColor(QColor(55, 55, 55, 170));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -116,10 +116,8 @@ UserInfoWidget::closeLogoutDialog(bool isLoggingOut)
|
|||||||
{
|
{
|
||||||
logoutModal_->fadeOut();
|
logoutModal_->fadeOut();
|
||||||
|
|
||||||
if (isLoggingOut) {
|
if (isLoggingOut)
|
||||||
// Waiting for the modal to fade out.
|
emit logout();
|
||||||
QTimer::singleShot(100, this, [=]() { emit logout(); });
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
UserInfoWidget::~UserInfoWidget()
|
UserInfoWidget::~UserInfoWidget()
|
||||||
|
Loading…
Reference in New Issue
Block a user