From 48131a868981b1caa6c91f43c7f4d5285b455be0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E7=9F=B3=E5=8D=9A=E6=96=87?= Date: Wed, 14 Mar 2018 11:24:57 +0800 Subject: [PATCH] optimize timeline settings Change-Id: I38f0b0938e054d9b1201a6871a716131a0b07d1c --- frame/item/appitem.cpp | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/frame/item/appitem.cpp b/frame/item/appitem.cpp index 27f9619ca..7c62255e8 100644 --- a/frame/item/appitem.cpp +++ b/frame/item/appitem.cpp @@ -594,7 +594,13 @@ void AppItem::playSwingEffect() m_itemAnimation.timeLine()->stop(); m_itemAnimation.clear(); } else { - m_itemAnimation.setTimeLine(new QTimeLine); + QTimeLine *tl = new QTimeLine(1200, this); + tl->setFrameRange(0, 60); + tl->setLoopCount(1); + tl->setEasingCurve(QEasingCurve::Linear); + tl->setStartFrame(0); + + m_itemAnimation.setTimeLine(tl); } m_itemScene->clear(); @@ -612,13 +618,6 @@ void AppItem::playSwingEffect() m_swingEffectView->setSceneRect(r); m_swingEffectView->setFixedSize(r.size()); - QTimeLine *tl = m_itemAnimation.timeLine(); - tl->setDuration(1200); - tl->setFrameRange(0, 60); - tl->setLoopCount(1); - tl->setEasingCurve(QEasingCurve::Linear); - tl->setStartFrame(0); - const int px = qreal(-icon.rect().center().x()) / ratio; const int py = qreal(-icon.rect().center().y()) / ratio - 18.; const QPoint pos = r.center() + QPoint(0, 18); @@ -629,6 +628,7 @@ void AppItem::playSwingEffect() m_itemAnimation.setRotationAt(i / 60.0, Frames[i]); } + QTimeLine *tl = m_itemAnimation.timeLine(); connect(tl, &QTimeLine::finished, m_swingEffectView, &QGraphicsView::hide); connect(tl, &QTimeLine::finished, this, &AppItem::checkAttentionEffect);