diff options
author | Konstantinos Sideris <sideris.konstantin@gmail.com> | 2017-09-30 17:05:05 +0300 |
---|---|---|
committer | Konstantinos Sideris <sideris.konstantin@gmail.com> | 2017-09-30 17:05:05 +0300 |
commit | 41a85832b3a2d6ebed0b638027999afcc2f72582 (patch) | |
tree | 925266558c64f4a9b8d29d9f5e75b39a52ba650e /src | |
parent | ff1bc797de845f5af4ce83b4e326bd37869461df (diff) |
Remove unnecessary animations
Diffstat (limited to 'src')
-rw-r--r-- | src/LoginPage.cc | 2 | ||||
-rw-r--r-- | src/MainWindow.cc | 40 | ||||
-rw-r--r-- | src/SlidingStackWidget.cc | 157 | ||||
-rw-r--r-- | src/UserInfoWidget.cc | 8 |
4 files changed, 18 insertions, 189 deletions
diff --git a/src/LoginPage.cc b/src/LoginPage.cc index 6a22fa1b..2f4178dd 100644 --- a/src/LoginPage.cc +++ b/src/LoginPage.cc @@ -78,7 +78,7 @@ LoginPage::LoginPage(QSharedPointer<MatrixClient> client, QWidget *parent) matrixid_input_->setPlaceholderText(tr("e.g @joe:matrix.org")); spinner_ = new LoadingIndicator(this); - spinner_->setColor("#acc7dc"); + spinner_->setColor("#333333"); spinner_->setFixedHeight(40); spinner_->setFixedWidth(40); spinner_->hide(); diff --git a/src/MainWindow.cc b/src/MainWindow.cc index 531bae8b..39fb1d2a 100644 --- a/src/MainWindow.cc +++ b/src/MainWindow.cc @@ -15,8 +15,8 @@ * along with this program. If not, see <http://www.gnu.org/licenses/>. */ -#include "MainWindow.h" #include "Config.h" +#include "MainWindow.h" #include <QApplication> #include <QLayout> @@ -55,13 +55,13 @@ MainWindow::MainWindow(QWidget *parent) chat_page_ = new ChatPage(client_, this); // Initialize sliding widget manager. - sliding_stack_ = new SlidingStackWidget(this); - sliding_stack_->addWidget(welcome_page_); - sliding_stack_->addWidget(login_page_); - sliding_stack_->addWidget(register_page_); - sliding_stack_->addWidget(chat_page_); + pageStack_ = new QStackedWidget(this); + pageStack_->addWidget(welcome_page_); + pageStack_->addWidget(login_page_); + pageStack_->addWidget(register_page_); + pageStack_->addWidget(chat_page_); - setCentralWidget(sliding_stack_); + setCentralWidget(pageStack_); connect(welcome_page_, SIGNAL(userLogin()), this, SLOT(showLoginPage())); 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/user_id", userid); - int index = sliding_stack_->getWidgetIndex(chat_page_); int modalOpacityDuration = 300; // If we go directly from the welcome page don't show an animation. - if (sliding_stack_->currentIndex() == 0) { - sliding_stack_->setCurrentIndex(index); + if (pageStack_->currentIndex() == 0) modalOpacityDuration = 0; - } else { - sliding_stack_->slideInIndex(index, - SlidingStackWidget::AnimationDirection::LEFT_TO_RIGHT); - } + + QTimer::singleShot( + modalOpacityDuration + 100, this, [=]() { pageStack_->setCurrentWidget(chat_page_); }); if (spinner_ == nullptr) { spinner_ = new LoadingIndicator(this); @@ -192,28 +189,19 @@ MainWindow::showChatPage(QString userid, QString homeserver, QString token) void MainWindow::showWelcomePage() { - int index = sliding_stack_->getWidgetIndex(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); + pageStack_->setCurrentWidget(welcome_page_); } void MainWindow::showLoginPage() { - int index = sliding_stack_->getWidgetIndex(login_page_); - sliding_stack_->slideInIndex(index, SlidingStackWidget::AnimationDirection::LEFT_TO_RIGHT); + pageStack_->setCurrentWidget(login_page_); } void MainWindow::showRegisterPage() { - int index = sliding_stack_->getWidgetIndex(register_page_); - sliding_stack_->slideInIndex(index, SlidingStackWidget::AnimationDirection::RIGHT_TO_LEFT); + pageStack_->setCurrentWidget(register_page_); } void diff --git a/src/SlidingStackWidget.cc b/src/SlidingStackWidget.cc deleted file mode 100644 index fd76e993..00000000 --- a/src/SlidingStackWidget.cc +++ /dev/null @@ -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); -} diff --git a/src/UserInfoWidget.cc b/src/UserInfoWidget.cc index b5926c58..463b3c6c 100644 --- a/src/UserInfoWidget.cc +++ b/src/UserInfoWidget.cc @@ -103,7 +103,7 @@ UserInfoWidget::UserInfoWidget(QWidget *parent) if (logoutModal_ == nullptr) { logoutModal_ = new OverlayModal(MainWindow::instance(), logoutDialog_); - logoutModal_->setDuration(100); + logoutModal_->setDuration(0); logoutModal_->setColor(QColor(55, 55, 55, 170)); } @@ -116,10 +116,8 @@ UserInfoWidget::closeLogoutDialog(bool isLoggingOut) { logoutModal_->fadeOut(); - if (isLoggingOut) { - // Waiting for the modal to fade out. - QTimer::singleShot(100, this, [=]() { emit logout(); }); - } + if (isLoggingOut) + emit logout(); } UserInfoWidget::~UserInfoWidget() |