Merge pull request #14964 from zilongshanren/fix14909

fix pageview page turning event issue
This commit is contained in:
zilongshanren 2016-01-27 20:53:48 +08:00
commit b0d0a7a064
11 changed files with 225 additions and 89 deletions

View File

@ -1,3 +1,5 @@
/*global ccui */
/*
* Copyright (c) 2013-2014 Chukong Technologies Inc.
*
@ -25,15 +27,69 @@
var cc = cc || {};
(function() {
var logW = function(oldName, newName) {
cc.log("\n********** \n"+oldName +" was deprecated, please use "+ newName +" instead.\n**********");
};
ccui.Text.prototype.setText = function(text){
ccui.Text.prototype.setText = function(text) {
logW("ccui.Text.setText", "ccui.Text.setString");
this.setString(text);
};
ccui.Text.prototype.getStringValue = function(){
ccui.Text.prototype.getStringValue = function() {
logW("ccui.Text.getStringValue", "ccui.Text.getString");
return this.getString();
};
ccui.PageView.prototype.getCurPageIndex = function() {
logW("ccui.PageView.getCurPageIndex", "ccui.PageView.getCurrentPageIndex");
return this.getCurrentPageIndex();
};
ccui.PageView.prototype.addWidgetToPage = function(widget, pageIndx) {
logW("ccui.PageView.addWidgetToPage", "ccui.PageView.insertPage");
return this.insertPage(widget, pageIndx);
};
ccui.PageView.prototype.setCurPageIndex = function(index) {
logW("ccui.PageView.setCurPageIndex", "ccui.PageView.setCurrentPageIndex");
return this.setCurrentPageIndex(index);
};
ccui.PageView.prototype.getPages = function() {
logW("ccui.PageView.getPages", "ccui.PageView.getItems");
return this.getItems();
};
ccui.PageView.prototype.getPage = function(index) {
logW("ccui.PageView.getPage", "ccui.PageView.getItem");
return this.getItem(index);
};
ccui.PageView.prototype.setCustomScrollThreshold = function() {
cc.log("Since v3.9, this method has no effect.");
};
ccui.PageView.prototype.getCustomScrollThreshold = function() {
cc.log("Since v3.9, this method has no effect.");
};
ccui.PageView.prototype.setUsingCustomScrollThreshold = function() {
cc.log("Since v3.9, this method has no effect.");
};
ccui.PageView.prototype.isUsingCustomScrollThreshold = function() {
cc.log("Since v3.9, this method has no effect.");
};
ccui.ListView.prototype.requestRefreshView = function() {
logW("ccui.ListView.requestRefreshView", "ccui.ListView.forceDoLayout");
this.forceDoLayout();
};
ccui.ListView.prototype.refreshView = function() {
logW("ccui.ListView.refreshView", "ccui.ListView.forceDoLayout");
this.forceDoLayout();
};
})();

View File

@ -524,10 +524,10 @@ static int lua_cocos2dx_PageView_addEventListener(lua_State* L)
}
#endif
LUA_FUNCTION handler = ( toluafix_ref_function(L,2,0));
self->addEventListener([=](cocos2d::Ref* ref,PageView::EventType eventType){
auto pageViewHandler = [=](cocos2d::Ref* ref,PageView::EventType eventType){
handleUIEvent(handler, ref, (int)eventType);
});
};
self->addEventListener((PageView::ccPageViewCallback)pageViewHandler);
ScriptHandlerMgr::getInstance()->addCustomHandler((void*)self, handler);
return 0;

View File

@ -162,6 +162,56 @@ function UIPageViewDeprecated.addEventListenerPageView(self,handler)
return self:addEventListener(handler)
end
ccui.PageView.addEventListenerPageView = UIPageViewDeprecated.addEventListenerPageView
function UIPageViewDeprecated.addWidgetToPage(self, widget, pageIdx)
deprecatedTip("ccui.PageView:addWidgetToPage","ccui.PageView:insertPage")
return self:insertPage(widget, pageIdx)
end
ccui.PageView.addWidgetToPage = UIPageViewDeprecated.addWidgetToPage
function UIPageViewDeprecated.getCurPageIndex(self)
deprecatedTip("ccui.PageView:getCurPageIndex","ccui.PageView:getCurrentPageIndex")
return self:getCurrentPageIndex()
end
ccui.PageView.getCurPageIndex = UIPageViewDeprecated.getCurPageIndex
function UIPageViewDeprecated.setCurPageIndex(self, index)
deprecatedTip("ccui.PageView:setCurPageIndex","ccui.PageView:setCurrentPageIndex")
return self:setCurrentPageIndex(index)
end
ccui.PageView.setCurPageIndex = UIPageViewDeprecated.setCurPageIndex
function UIPageViewDeprecated.getPages(self)
deprecatedTip("ccui.PageView:getPages","ccui.PageView:getItems")
return self:getItems()
end
ccui.PageView.getPages = UIPageViewDeprecated.getPages
function UIPageViewDeprecated.getPage(self, index)
deprecatedTip("ccui.PageView:getPage","ccui.PageView:getItem")
return self:getItem(index)
end
ccui.PageView.getPage = UIPageViewDeprecated.getPage
function UIPageViewDeprecated.setCustomScrollThreshold(self)
print("Since v3.9, this method has no effect.")
end
ccui.PageView.setCustomScrollThreshold = UIPageViewDeprecated.setCustomScrollThreshold
function UIPageViewDeprecated.getCustomScrollThreshold(self)
print("Since v3.9, this method has no effect.")
end
ccui.PageView.getCustomScrollThreshold = UIPageViewDeprecated.getCustomScrollThreshold
function UIPageViewDeprecated.isUsingCustomScrollThreshold(self)
print("Since v3.9, this method has no effect.")
end
ccui.PageView.isUsingCustomScrollThreshold = UIPageViewDeprecated.isUsingCustomScrollThreshold
function UIPageViewDeprecated.setUsingCustomScrollThreshold(self)
print("Since v3.9, this method has no effect.")
end
ccui.PageView.setUsingCustomScrollThreshold = UIPageViewDeprecated.setUsingCustomScrollThreshold
--functions of ccui.PageView will be deprecated end
--functions of ccui.ScrollView will be deprecated begin
@ -180,4 +230,16 @@ function UIListViewDeprecated.addEventListenerListView(self,handler)
return self:addEventListener(handler)
end
ccui.ListView.addEventListenerListView = UIListViewDeprecated.addEventListenerListView
function UIListViewDeprecated.requestRefreshView(self)
deprecatedTip("ccui.ListView:requestRefreshView","ccui.ListView:forceDoLayout")
return self:forceDoLayout()
end
ccui.ListView.requestRefreshView = UIListViewDeprecated.requestRefreshView
function UIListViewDeprecated.refreshView(self)
deprecatedTip("ccui.ListView:refreshView","ccui.ListView:refreshView")
return self:forceDoLayout()
end
ccui.ListView.refreshView = UIListViewDeprecated.refreshView
--functions of ccui.ListView will be deprecated end

View File

@ -1,5 +1,5 @@
/****************************************************************************
Copyright (c) 2013-2014 Chukong Technologies Inc.
Copyright (c) 2013-2016 Chukong Technologies Inc.
http://www.cocos2d-x.org
@ -254,7 +254,7 @@ void PageView::handleReleaseLogic(Touch *touch)
{
--_currentPageIndex;
}
_currentPageIndex = MIN(_currentPageIndex, _items.size());
_currentPageIndex = MIN(_currentPageIndex, _items.size() - 1);
_currentPageIndex = MAX(_currentPageIndex, 0);
scrollToItem(_currentPageIndex);
}
@ -288,6 +288,12 @@ void PageView::addEventListenerPageView(Ref *target, SEL_PageViewEvent selector)
void PageView::addEventListener(const ccPageViewCallback& callback)
{
_eventCallback = callback;
ccScrollViewCallback scrollViewCallback = [=](Ref* ref, ScrollView::EventType type) -> void{
if (type == ScrollView::EventType::AUTOSCROLL_ENDED) {
callback(ref, PageView::EventType::TURNING);
}
};
this->addEventListener(scrollViewCallback);
}
ssize_t PageView::getCurPageIndex() const

View File

@ -1,5 +1,5 @@
/****************************************************************************
Copyright (c) 2013-2014 Chukong Technologies Inc.
Copyright (c) 2013-2016 Chukong Technologies Inc.
http://www.cocos2d-x.org
@ -238,7 +238,7 @@ public:
* @param callback A page turning callback.
*/
void addEventListener(const ccPageViewCallback& callback);
using ScrollView::addEventListener;
//override methods
virtual std::string getDescription() const override;

View File

@ -535,6 +535,7 @@ void ScrollView::processAutoScrolling(float deltaTime)
if(reachedEnd)
{
_autoScrolling = false;
dispatchEvent(SCROLLVIEW_EVENT_AUTOSCROLL_ENDED, EventType::AUTOSCROLL_ENDED);
}
moveInnerContainer(newPosition - getInnerContainerPosition(), reachedEnd);

View File

@ -55,7 +55,8 @@ typedef enum
SCROLLVIEW_EVENT_BOUNCE_TOP,
SCROLLVIEW_EVENT_BOUNCE_BOTTOM,
SCROLLVIEW_EVENT_BOUNCE_LEFT,
SCROLLVIEW_EVENT_BOUNCE_RIGHT
SCROLLVIEW_EVENT_BOUNCE_RIGHT,
SCROLLVIEW_EVENT_AUTOSCROLL_ENDED
}ScrollviewEventType;
/**
@ -100,7 +101,8 @@ public:
BOUNCE_BOTTOM,
BOUNCE_LEFT,
BOUNCE_RIGHT,
CONTAINER_MOVED
CONTAINER_MOVED,
AUTOSCROLL_ENDED
};
/**

View File

@ -83,7 +83,7 @@ bool UIPageViewTest::init()
pageView->removeItem(0);
pageView->scrollToItem(pageCount - 2);
pageView->addEventListener(CC_CALLBACK_2(UIPageViewTest::pageViewEvent, this));
pageView->addEventListener((PageView::ccPageViewCallback)CC_CALLBACK_2(UIPageViewTest::pageViewEvent, this));
_uiLayer->addChild(pageView);
@ -187,7 +187,7 @@ bool UIPageViewButtonTest::init()
pageView->removeItem(0);
pageView->addEventListener(CC_CALLBACK_2(UIPageViewButtonTest::pageViewEvent, this));
pageView->addEventListener((PageView::ccPageViewCallback)CC_CALLBACK_2(UIPageViewButtonTest::pageViewEvent, this));
_uiLayer->addChild(pageView);
@ -293,7 +293,7 @@ bool UIPageViewTouchPropagationTest::init()
pageView->insertCustomItem(outerBox, i);
}
pageView->addEventListener(CC_CALLBACK_2(UIPageViewTouchPropagationTest::pageViewEvent, this));
pageView->addEventListener((PageView::ccPageViewCallback)CC_CALLBACK_2(UIPageViewTouchPropagationTest::pageViewEvent, this));
pageView->setName("pageView");
pageView->addTouchEventListener([](Ref* sender, Widget::TouchEventType type){
if (type == Widget::TouchEventType::BEGAN)
@ -493,7 +493,7 @@ bool UIPageViewDynamicAddAndRemoveTest::init()
pageView->insertCustomItem(outerBox, i);
}
pageView->addEventListener(CC_CALLBACK_2(UIPageViewDynamicAddAndRemoveTest::pageViewEvent, this));
pageView->addEventListener((PageView::ccPageViewCallback)CC_CALLBACK_2(UIPageViewDynamicAddAndRemoveTest::pageViewEvent, this));
pageView->setName("pageView");
_uiLayer->addChild(pageView);
@ -777,7 +777,7 @@ bool UIPageViewVerticalTest::init()
pageView->insertCustomItem(layout, i);
}
pageView->addEventListener(CC_CALLBACK_2(UIPageViewVerticalTest::pageViewEvent, this));
pageView->addEventListener((PageView::ccPageViewCallback)CC_CALLBACK_2(UIPageViewVerticalTest::pageViewEvent, this));
_uiLayer->addChild(pageView);
@ -936,7 +936,7 @@ bool UIPageViewChildSizeTest::init()
pageView->insertCustomItem(imageView, i);
}
pageView->addEventListener(CC_CALLBACK_2(UIPageViewChildSizeTest::pageViewEvent, this));
pageView->addEventListener((PageView::ccPageViewCallback)CC_CALLBACK_2(UIPageViewChildSizeTest::pageViewEvent, this));
_uiLayer->addChild(pageView);

View File

@ -136,6 +136,7 @@ var UIListViewTest_Vertical = UIMainLayer.extend({
// set all items layout gravity
listView.setGravity(ccui.ListView.GRAVITY_CENTER_VERTICAL);
listView.requestRefreshView();
return true;
}

View File

@ -66,9 +66,14 @@ var UIPageViewTest = UIMainLayer.extend({
text.y = layoutRect.height / 2;
layout.addChild(text);
pageView.addPage(layout);
pageView.addWidgetToPage(layout, i);
}
pageView.setCurPageIndex(1);
pageView.addEventListener(this.pageViewEvent, this);
//for test purpose only
cc.log(pageView.getPages());
cc.log(pageView.getPage(0));
this._mainNode.addChild(pageView);
return true;

View File

@ -1748,13 +1748,16 @@ add_new_testcase(function()
label:setPosition(cc.p(layout:getContentSize().width / 2, layout:getContentSize().height / 2))
layout:addChild(label)
pageView:addPage(layout)
pageView:addWidgetToPage(layout, i-1)
end
pageView:setCurPageIndex(1)
local function pageViewEvent(sender, eventType)
if eventType == ccui.PageViewEventType.turning then
local pageInfo = string.format("page %d " , pageView:getCurPageIndex() + 1)
local pages = pageView:getPages()
print("total items " .. table.getn(pages))
self._displayValueLabel:setString(pageInfo)
end
end