mirror of https://github.com/axmolengine/axmol.git
issue #5176, refactor AutoScrollDirection in UIPageView
This commit is contained in:
parent
0c065b4be0
commit
2344928945
|
@ -43,7 +43,7 @@ _rightBoundary(0.0f),
|
|||
_isAutoScrolling(false),
|
||||
_autoScrollDistance(0.0f),
|
||||
_autoScrollSpeed(0.0f),
|
||||
_autoScrollDir(0),
|
||||
_autoScrollDirection(AutoScrollDirection::LEFT),
|
||||
_childFocusCancelOffset(5.0f),
|
||||
_pageViewEventListener(nullptr),
|
||||
_pageViewEventSelector(nullptr),
|
||||
|
@ -262,7 +262,7 @@ void PageView::scrollToPage(ssize_t idx)
|
|||
Layout* curPage = _pages.at(idx);
|
||||
_autoScrollDistance = -(curPage->getPosition().x);
|
||||
_autoScrollSpeed = fabs(_autoScrollDistance)/0.2f;
|
||||
_autoScrollDir = _autoScrollDistance > 0 ? 1 : 0;
|
||||
_autoScrollDirection = _autoScrollDistance > 0 ? AutoScrollDirection::RIGHT : AutoScrollDirection::LEFT;
|
||||
_isAutoScrolling = true;
|
||||
}
|
||||
|
||||
|
@ -270,9 +270,15 @@ void PageView::update(float dt)
|
|||
{
|
||||
if (_isAutoScrolling)
|
||||
{
|
||||
switch (_autoScrollDir)
|
||||
this->autoScroll(dt);
|
||||
}
|
||||
}
|
||||
|
||||
void PageView::autoScroll(float dt)
|
||||
{
|
||||
case 0:
|
||||
switch (_autoScrollDirection)
|
||||
{
|
||||
case AutoScrollDirection::LEFT:
|
||||
{
|
||||
float step = _autoScrollSpeed*dt;
|
||||
if (_autoScrollDistance + step >= 0.0f)
|
||||
|
@ -293,7 +299,7 @@ void PageView::update(float dt)
|
|||
break;
|
||||
}
|
||||
break;
|
||||
case 1:
|
||||
case AutoScrollDirection::RIGHT:
|
||||
{
|
||||
float step = _autoScrollSpeed*dt;
|
||||
if (_autoScrollDistance - step <= 0.0f)
|
||||
|
@ -307,16 +313,18 @@ void PageView::update(float dt)
|
|||
_autoScrollDistance -= step;
|
||||
}
|
||||
scrollPages(step);
|
||||
|
||||
if (!_isAutoScrolling)
|
||||
{
|
||||
pageTurningEvent();
|
||||
}
|
||||
|
||||
break;
|
||||
}
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
bool PageView::onTouchBegan(Touch *touch, Event *unusedEvent)
|
||||
|
@ -576,7 +584,7 @@ void PageView::copyClonedWidgetChildren(Widget* model)
|
|||
auto modelPages = static_cast<PageView*>(model)->getPages();
|
||||
for (auto& page : modelPages)
|
||||
{
|
||||
addPage(dynamic_cast<Layout*>(page->clone()));
|
||||
addPage(static_cast<Layout*>(page->clone()));
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -187,6 +187,7 @@ protected:
|
|||
void pageTurningEvent();
|
||||
void updateAllPagesSize();
|
||||
void updateAllPagesPosition();
|
||||
void autoScroll(float dt);
|
||||
|
||||
virtual void handlePressLogic(const Vec2 &touchPoint);
|
||||
virtual void handleMoveLogic(const Vec2 &touchPoint) ;
|
||||
|
@ -203,6 +204,16 @@ protected:
|
|||
virtual void doLayout() override;
|
||||
|
||||
protected:
|
||||
enum class AutoScrollDirection
|
||||
{
|
||||
LEFT,
|
||||
RIGHT
|
||||
};
|
||||
bool _isAutoScrolling;
|
||||
float _autoScrollDistance;
|
||||
float _autoScrollSpeed;
|
||||
AutoScrollDirection _autoScrollDirection;
|
||||
|
||||
ssize_t _curPageIdx;
|
||||
Vector<Layout*> _pages;
|
||||
|
||||
|
@ -215,10 +226,7 @@ protected:
|
|||
Widget* _rightBoundaryChild;
|
||||
float _leftBoundary;
|
||||
float _rightBoundary;
|
||||
bool _isAutoScrolling;
|
||||
float _autoScrollDistance;
|
||||
float _autoScrollSpeed;
|
||||
int _autoScrollDir;
|
||||
|
||||
float _childFocusCancelOffset;
|
||||
|
||||
|
||||
|
|
Loading…
Reference in New Issue