2014-05-04 16:31:24 +08:00
|
|
|
//
|
|
|
|
// UIFocusTest.cpp
|
|
|
|
// cocos2d_tests
|
|
|
|
//
|
|
|
|
// Created by guanghui on 5/4/14.
|
|
|
|
//
|
|
|
|
//
|
|
|
|
|
|
|
|
#include "UIFocusTest.h"
|
|
|
|
|
|
|
|
UIFocusTestBase::UIFocusTestBase()
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
UIFocusTestBase::~UIFocusTestBase()
|
|
|
|
{
|
|
|
|
_eventDispatcher->removeEventListener(_eventListener);
|
|
|
|
}
|
|
|
|
|
|
|
|
bool UIFocusTestBase::init()
|
|
|
|
{
|
|
|
|
if (UIScene::init()) {
|
|
|
|
Layout* root = static_cast<Layout*>(_uiLayer->getChildByTag(81));
|
|
|
|
|
|
|
|
Layout* background = dynamic_cast<Layout*>(root->getChildByName("background_Panel"));
|
|
|
|
background->removeFromParentAndCleanup(true);
|
|
|
|
|
|
|
|
_dpadMenu = Menu::create();
|
|
|
|
|
|
|
|
auto winSize = Director::getInstance()->getVisibleSize();
|
|
|
|
auto leftItem = MenuItemFont::create("Left", CC_CALLBACK_0(UIFocusTestBase::onLeftKeyPressed, this));
|
|
|
|
leftItem->setPosition(Vector2(winSize.width - 100, winSize.height/2));
|
|
|
|
_dpadMenu->addChild(leftItem);
|
|
|
|
|
|
|
|
|
|
|
|
auto rightItem = MenuItemFont::create("Right", CC_CALLBACK_0(UIFocusTestBase::onRightKeyPressed, this));
|
|
|
|
rightItem->setPosition(Vector2(winSize.width - 30, winSize.height/2));
|
|
|
|
_dpadMenu->addChild(rightItem);
|
|
|
|
|
|
|
|
auto upItem = MenuItemFont::create("Up", CC_CALLBACK_0(UIFocusTestBase::onUpKeyPressed, this));
|
|
|
|
upItem->setPosition(Vector2(winSize.width - 60, winSize.height/2 + 50));
|
|
|
|
_dpadMenu->addChild(upItem);
|
|
|
|
|
|
|
|
auto downItem = MenuItemFont::create("Down", CC_CALLBACK_0(UIFocusTestBase::onDownKeyPressed, this));
|
|
|
|
downItem->setPosition(Vector2(winSize.width - 60, winSize.height/2 - 50));
|
|
|
|
_dpadMenu->addChild(downItem);
|
|
|
|
|
|
|
|
_dpadMenu->setPosition(Vector2::ZERO);
|
|
|
|
_uiLayer->addChild(_dpadMenu);
|
|
|
|
|
|
|
|
_eventListener = EventListenerFocus::create();
|
|
|
|
_eventListener->onFocusChanged = CC_CALLBACK_2(UIFocusTestBase::onFocusChanged, this);
|
|
|
|
|
|
|
|
_eventDispatcher->addEventListenerWithFixedPriority(_eventListener, 1);
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2014-05-09 14:30:39 +08:00
|
|
|
void UIFocusTestBase::onImageViewClicked(cocos2d::Ref *ref, Widget::TouchEventType touchType)
|
2014-05-06 14:14:22 +08:00
|
|
|
{
|
2014-05-09 14:30:39 +08:00
|
|
|
if (touchType == Widget::TouchEventType::ENDED) {
|
2014-05-06 14:14:22 +08:00
|
|
|
Widget *w = (Widget*)ref;
|
|
|
|
if (w->isFocusEnabled()) {
|
|
|
|
w->setFocusEnabled(false);
|
2014-05-06 15:11:55 +08:00
|
|
|
w->setColor(Color3B::YELLOW);
|
2014-05-06 14:14:22 +08:00
|
|
|
}else{
|
|
|
|
w->setFocusEnabled(true);
|
2014-05-06 15:11:55 +08:00
|
|
|
w->setColor(Color3B::WHITE);
|
2014-05-06 14:14:22 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-05-06 14:20:01 +08:00
|
|
|
void UIFocusTestBase::onLeftKeyPressed()
|
|
|
|
{
|
|
|
|
if (_firstFocusedWidget) {
|
2014-05-07 10:23:57 +08:00
|
|
|
if (!_firstFocusedWidget->isFocused()) {
|
2014-05-07 18:27:05 +08:00
|
|
|
_firstFocusedWidget = _firstFocusedWidget->getCurrentFocusedWidget(false);
|
2014-05-07 10:23:57 +08:00
|
|
|
}
|
2014-05-08 18:10:21 +08:00
|
|
|
_firstFocusedWidget = _firstFocusedWidget->findNextFocusedWidget(Widget::FocusDirection::LEFT, _firstFocusedWidget);
|
2014-05-06 14:20:01 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void UIFocusTestBase::onRightKeyPressed()
|
|
|
|
{
|
|
|
|
if (_firstFocusedWidget) {
|
2014-05-07 10:23:57 +08:00
|
|
|
if (!_firstFocusedWidget->isFocused()) {
|
2014-05-07 18:27:05 +08:00
|
|
|
_firstFocusedWidget = _firstFocusedWidget->getCurrentFocusedWidget(false);
|
2014-05-07 10:23:57 +08:00
|
|
|
}
|
2014-05-08 18:10:21 +08:00
|
|
|
_firstFocusedWidget = _firstFocusedWidget->findNextFocusedWidget(Widget::FocusDirection::RIGHT, _firstFocusedWidget);
|
2014-05-06 14:20:01 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void UIFocusTestBase::onUpKeyPressed()
|
|
|
|
{
|
|
|
|
if (_firstFocusedWidget) {
|
2014-05-07 10:23:57 +08:00
|
|
|
if (!_firstFocusedWidget->isFocused()) {
|
2014-05-07 18:27:05 +08:00
|
|
|
_firstFocusedWidget = _firstFocusedWidget->getCurrentFocusedWidget(false);
|
2014-05-07 10:23:57 +08:00
|
|
|
}
|
2014-05-08 18:10:21 +08:00
|
|
|
_firstFocusedWidget = _firstFocusedWidget->findNextFocusedWidget(Widget::FocusDirection::UP, _firstFocusedWidget);
|
2014-05-06 14:20:01 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
void UIFocusTestBase::onDownKeyPressed()
|
|
|
|
{
|
|
|
|
if (_firstFocusedWidget) {
|
2014-05-07 10:23:57 +08:00
|
|
|
if (!_firstFocusedWidget->isFocused()) {
|
2014-05-07 18:27:05 +08:00
|
|
|
_firstFocusedWidget = _firstFocusedWidget->getCurrentFocusedWidget(false);
|
2014-05-07 10:23:57 +08:00
|
|
|
}
|
2014-05-08 18:10:21 +08:00
|
|
|
_firstFocusedWidget = _firstFocusedWidget->findNextFocusedWidget(Widget::FocusDirection::DOWN, _firstFocusedWidget);
|
2014-05-06 14:20:01 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
void UIFocusTestBase::onFocusChanged(cocos2d::ui::Widget *widgetLostFocus, cocos2d::ui::Widget *widgetGetFocus)
|
|
|
|
{
|
|
|
|
//only change the widgets' state
|
|
|
|
Layout *getLayout = dynamic_cast<Layout*>(widgetGetFocus);
|
|
|
|
if (!getLayout && widgetGetFocus && widgetGetFocus->isFocusEnabled()) {
|
|
|
|
widgetGetFocus->setColor(Color3B::RED);
|
|
|
|
}
|
|
|
|
|
|
|
|
Layout *loseLayout = dynamic_cast<Layout*>(widgetLostFocus);
|
|
|
|
if (!loseLayout && widgetLostFocus && widgetLostFocus->isFocusEnabled()) {
|
|
|
|
widgetLostFocus->setColor(Color3B::WHITE);
|
|
|
|
}
|
2014-05-07 10:23:57 +08:00
|
|
|
|
|
|
|
if (widgetLostFocus && widgetGetFocus) {
|
|
|
|
CCLOG("on focus change, %d widget get focus, %d widget lose focus", widgetGetFocus->getTag(), widgetLostFocus->getTag());
|
|
|
|
}
|
2014-05-06 14:20:01 +08:00
|
|
|
}
|
|
|
|
|
2014-05-04 16:31:24 +08:00
|
|
|
|
|
|
|
//UIFocusTestHorizontal
|
|
|
|
UIFocusTestHorizontal::UIFocusTestHorizontal()
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
UIFocusTestHorizontal::~UIFocusTestHorizontal()
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
bool UIFocusTestHorizontal::init()
|
|
|
|
{
|
|
|
|
if (UIFocusTestBase::init()) {
|
|
|
|
|
|
|
|
Size winSize = Director::getInstance()->getVisibleSize();
|
|
|
|
|
2014-05-04 18:11:41 +08:00
|
|
|
_horizontalLayout = HBox::create();
|
|
|
|
_horizontalLayout->setPosition(Vector2(20, winSize.height/2 + 40));
|
|
|
|
_uiLayer->addChild(_horizontalLayout);
|
2014-05-05 11:25:30 +08:00
|
|
|
|
2014-05-04 18:11:41 +08:00
|
|
|
_horizontalLayout->setFocused(true);
|
|
|
|
_horizontalLayout->setLoopFocus(true);
|
2014-05-07 10:05:20 +08:00
|
|
|
_horizontalLayout->setTag(100);
|
2014-05-04 18:11:41 +08:00
|
|
|
_firstFocusedWidget = _horizontalLayout;
|
2014-05-04 16:31:24 +08:00
|
|
|
|
|
|
|
int count = 3;
|
|
|
|
for (int i=0; i<count; ++i) {
|
|
|
|
ImageView *w = ImageView::create("cocosui/scrollviewbg.png");
|
2014-05-06 14:14:22 +08:00
|
|
|
w->setTouchEnabled(true);
|
2014-05-06 17:28:12 +08:00
|
|
|
w->setTag(i);
|
2014-05-09 14:30:39 +08:00
|
|
|
w->addTouchEventListener(CC_CALLBACK_2(UIFocusTestHorizontal::onImageViewClicked, this));
|
2014-05-04 18:11:41 +08:00
|
|
|
_horizontalLayout->addChild(w);
|
2014-05-04 16:31:24 +08:00
|
|
|
}
|
|
|
|
|
2014-05-04 18:11:41 +08:00
|
|
|
_loopText = Text::create("loop enabled", "Airal", 20);
|
|
|
|
_loopText->setPosition(Vector2(winSize.width/2, winSize.height - 50));
|
|
|
|
_loopText->setColor(Color3B::GREEN);
|
|
|
|
this->addChild(_loopText);
|
|
|
|
|
|
|
|
auto btn = Button::create("cocosui/switch-mask.png");
|
|
|
|
btn->setTitleText("Toggle Loop");
|
|
|
|
btn->setPosition(Vector2(60, winSize.height - 50));
|
|
|
|
btn->setTitleColor(Color3B::RED);
|
2014-05-09 14:30:39 +08:00
|
|
|
btn->addTouchEventListener(CC_CALLBACK_2(UIFocusTestHorizontal::toggleFocusLoop,this));
|
2014-05-04 18:11:41 +08:00
|
|
|
this->addChild(btn);
|
2014-05-04 16:31:24 +08:00
|
|
|
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2014-05-06 14:14:22 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
2014-05-09 14:30:39 +08:00
|
|
|
void UIFocusTestHorizontal::toggleFocusLoop(cocos2d::Ref * pObjc, Widget::TouchEventType type)
|
2014-05-04 18:11:41 +08:00
|
|
|
{
|
2014-05-09 14:30:39 +08:00
|
|
|
if (type == Widget::TouchEventType::ENDED) {
|
2014-05-07 14:06:44 +08:00
|
|
|
_horizontalLayout->setLoopFocus(!_horizontalLayout->isLoopFocus());
|
|
|
|
if (_horizontalLayout->isLoopFocus()) {
|
2014-05-04 18:11:41 +08:00
|
|
|
_loopText->setText("loop enabled");
|
|
|
|
}else{
|
|
|
|
_loopText->setText("loop disabled");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-05-05 11:25:30 +08:00
|
|
|
|
|
|
|
//UIFocusTestVertical
|
|
|
|
UIFocusTestVertical::UIFocusTestVertical()
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
UIFocusTestVertical::~UIFocusTestVertical()
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
2014-05-04 16:31:24 +08:00
|
|
|
|
2014-05-05 11:25:30 +08:00
|
|
|
bool UIFocusTestVertical::init()
|
|
|
|
{
|
|
|
|
if (UIFocusTestBase::init()) {
|
|
|
|
|
|
|
|
Size winSize = Director::getInstance()->getVisibleSize();
|
|
|
|
|
|
|
|
_verticalLayout = VBox::create();
|
|
|
|
_verticalLayout->setPosition(Vector2(winSize.width/2 - 100, winSize.height - 70));
|
|
|
|
_uiLayer->addChild(_verticalLayout);
|
2014-05-07 10:05:20 +08:00
|
|
|
_verticalLayout->setTag(100);
|
2014-05-08 14:35:45 +08:00
|
|
|
_verticalLayout->setScale(0.5);
|
2014-05-05 11:25:30 +08:00
|
|
|
|
|
|
|
_verticalLayout->setFocused(true);
|
|
|
|
_verticalLayout->setLoopFocus(true);
|
|
|
|
_firstFocusedWidget = _verticalLayout;
|
|
|
|
|
|
|
|
int count = 3;
|
|
|
|
for (int i=0; i<count; ++i) {
|
|
|
|
ImageView *w = ImageView::create("cocosui/scrollviewbg.png");
|
2014-05-06 14:14:22 +08:00
|
|
|
w->setTouchEnabled(true);
|
2014-05-07 10:05:20 +08:00
|
|
|
w->setTag(i);
|
2014-05-09 14:30:39 +08:00
|
|
|
w->addTouchEventListener(CC_CALLBACK_2(UIFocusTestVertical::onImageViewClicked, this));
|
2014-05-05 11:25:30 +08:00
|
|
|
_verticalLayout->addChild(w);
|
2014-05-07 10:23:57 +08:00
|
|
|
if (i == 2) {
|
|
|
|
w->requestFocus();
|
|
|
|
}
|
2014-05-05 11:25:30 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
_loopText = Text::create("loop enabled", "Airal", 20);
|
|
|
|
_loopText->setPosition(Vector2(winSize.width/2, winSize.height - 50));
|
|
|
|
_loopText->setColor(Color3B::GREEN);
|
|
|
|
this->addChild(_loopText);
|
|
|
|
|
|
|
|
auto btn = Button::create("cocosui/switch-mask.png");
|
|
|
|
btn->setTitleText("Toggle Loop");
|
|
|
|
btn->setPosition(Vector2(60, winSize.height - 50));
|
|
|
|
btn->setTitleColor(Color3B::RED);
|
2014-05-09 14:30:39 +08:00
|
|
|
btn->addTouchEventListener(CC_CALLBACK_2(UIFocusTestVertical::toggleFocusLoop, this));
|
2014-05-05 11:25:30 +08:00
|
|
|
this->addChild(btn);
|
|
|
|
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2014-05-06 14:14:22 +08:00
|
|
|
|
2014-05-09 14:30:39 +08:00
|
|
|
void UIFocusTestVertical::toggleFocusLoop(cocos2d::Ref * pObjc, Widget::TouchEventType type)
|
2014-05-05 11:25:30 +08:00
|
|
|
{
|
2014-05-09 14:30:39 +08:00
|
|
|
if (type == Widget::TouchEventType::ENDED) {
|
2014-05-07 14:06:44 +08:00
|
|
|
_verticalLayout->setLoopFocus(!_verticalLayout->isLoopFocus());
|
|
|
|
if (_verticalLayout->isLoopFocus()) {
|
2014-05-05 11:25:30 +08:00
|
|
|
_loopText->setText("loop enabled");
|
|
|
|
}else{
|
|
|
|
_loopText->setText("loop disabled");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-05-06 14:20:01 +08:00
|
|
|
//UIFocusTestNestedLayout1
|
2014-05-06 14:38:45 +08:00
|
|
|
UIFocusTestNestedLayout1::UIFocusTestNestedLayout1()
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
UIFocusTestNestedLayout1::~UIFocusTestNestedLayout1()
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
bool UIFocusTestNestedLayout1::init()
|
|
|
|
{
|
|
|
|
if (UIFocusTestBase::init()) {
|
|
|
|
|
|
|
|
Size winSize = Director::getInstance()->getVisibleSize();
|
|
|
|
|
|
|
|
_verticalLayout = VBox::create();
|
2014-05-08 14:35:45 +08:00
|
|
|
_verticalLayout->setPosition(Vector2(winSize.width/2 - 80, winSize.height - 70));
|
2014-05-06 14:38:45 +08:00
|
|
|
_uiLayer->addChild(_verticalLayout);
|
2014-05-08 14:35:45 +08:00
|
|
|
_verticalLayout->setScale(0.5);
|
2014-05-06 14:38:45 +08:00
|
|
|
|
|
|
|
_verticalLayout->setFocused(true);
|
|
|
|
_verticalLayout->setLoopFocus(true);
|
2014-05-07 10:05:20 +08:00
|
|
|
_verticalLayout->setTag(100);
|
2014-05-06 14:38:45 +08:00
|
|
|
_firstFocusedWidget = _verticalLayout;
|
|
|
|
|
2014-05-07 10:05:20 +08:00
|
|
|
int count1 = 1;
|
|
|
|
for (int i=0; i<count1; ++i) {
|
2014-05-06 14:38:45 +08:00
|
|
|
ImageView *w = ImageView::create("cocosui/scrollviewbg.png");
|
2014-05-06 15:11:55 +08:00
|
|
|
w->setAnchorPoint(Vector2::ZERO);
|
2014-05-06 14:38:45 +08:00
|
|
|
w->setTouchEnabled(true);
|
2014-05-06 15:11:55 +08:00
|
|
|
w->setScaleX(2.5);
|
2014-05-07 10:05:20 +08:00
|
|
|
w->setTag(i+count1);
|
2014-05-09 14:30:39 +08:00
|
|
|
w->addTouchEventListener(CC_CALLBACK_2(UIFocusTestNestedLayout1::onImageViewClicked, this));
|
2014-05-06 14:38:45 +08:00
|
|
|
_verticalLayout->addChild(w);
|
|
|
|
}
|
|
|
|
|
|
|
|
//add HBox into VBox
|
|
|
|
HBox *hbox = HBox::create();
|
|
|
|
hbox->setScale(0.8);
|
2014-05-07 10:05:20 +08:00
|
|
|
hbox->setTag(101);
|
2014-05-06 14:38:45 +08:00
|
|
|
_verticalLayout->addChild(hbox);
|
|
|
|
|
2014-05-07 10:05:20 +08:00
|
|
|
int count2 = 2;
|
|
|
|
for (int i=0; i < count2; ++i) {
|
2014-05-06 14:38:45 +08:00
|
|
|
ImageView *w = ImageView::create("cocosui/scrollviewbg.png");
|
2014-05-06 15:11:55 +08:00
|
|
|
w->setAnchorPoint(Vector2(0,1));
|
|
|
|
w->setScaleY(2.0);
|
2014-05-06 14:38:45 +08:00
|
|
|
w->setTouchEnabled(true);
|
2014-05-07 10:05:20 +08:00
|
|
|
w->setTag(i+count1+count2);
|
2014-05-09 14:30:39 +08:00
|
|
|
w->addTouchEventListener(CC_CALLBACK_2(UIFocusTestNestedLayout1::onImageViewClicked, this));
|
2014-05-06 14:38:45 +08:00
|
|
|
hbox->addChild(w);
|
|
|
|
}
|
|
|
|
|
|
|
|
VBox *innerVBox = VBox::create();
|
|
|
|
hbox->addChild(innerVBox);
|
2014-05-07 10:05:20 +08:00
|
|
|
innerVBox->setTag(102);
|
2014-05-07 10:23:57 +08:00
|
|
|
// innerVBox->setPassFocusToChild(false);
|
2014-05-07 10:05:20 +08:00
|
|
|
// innerVBox->setFocusEnabled(false);
|
|
|
|
|
|
|
|
|
|
|
|
int count3 = 2;
|
|
|
|
for (int i=0; i<count3; ++i) {
|
2014-05-06 14:38:45 +08:00
|
|
|
ImageView *w = ImageView::create("cocosui/scrollviewbg.png");
|
|
|
|
w->setTouchEnabled(true);
|
2014-05-07 10:05:20 +08:00
|
|
|
w->setTag(i+count1+count2+count3);
|
2014-05-09 14:30:39 +08:00
|
|
|
w->addTouchEventListener(CC_CALLBACK_2(UIFocusTestNestedLayout1::onImageViewClicked, this));
|
2014-05-06 14:38:45 +08:00
|
|
|
innerVBox->addChild(w);
|
|
|
|
}
|
|
|
|
|
|
|
|
_loopText = Text::create("loop enabled", "Airal", 20);
|
|
|
|
_loopText->setPosition(Vector2(winSize.width/2, winSize.height - 50));
|
|
|
|
_loopText->setColor(Color3B::GREEN);
|
|
|
|
this->addChild(_loopText);
|
|
|
|
|
|
|
|
auto btn = Button::create("cocosui/switch-mask.png");
|
|
|
|
btn->setTitleText("Toggle Loop");
|
|
|
|
btn->setPosition(Vector2(60, winSize.height - 50));
|
|
|
|
btn->setTitleColor(Color3B::RED);
|
2014-05-09 14:30:39 +08:00
|
|
|
btn->addTouchEventListener(CC_CALLBACK_2(UIFocusTestNestedLayout1::toggleFocusLoop, this));
|
2014-05-06 14:38:45 +08:00
|
|
|
this->addChild(btn);
|
|
|
|
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2014-05-09 14:30:39 +08:00
|
|
|
void UIFocusTestNestedLayout1::toggleFocusLoop(cocos2d::Ref * pObjc, Widget::TouchEventType type)
|
2014-05-06 14:38:45 +08:00
|
|
|
{
|
2014-05-09 14:30:39 +08:00
|
|
|
if (type == Widget::TouchEventType::ENDED) {
|
2014-05-07 14:06:44 +08:00
|
|
|
_verticalLayout->setLoopFocus(!_verticalLayout->isLoopFocus());
|
|
|
|
if (_verticalLayout->isLoopFocus()) {
|
2014-05-06 14:38:45 +08:00
|
|
|
_loopText->setText("loop enabled");
|
|
|
|
}else{
|
|
|
|
_loopText->setText("loop disabled");
|
|
|
|
}
|
|
|
|
}
|
2014-05-07 11:40:01 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
//UIFocusTestNestedLayout2
|
|
|
|
UIFocusTestNestedLayout2::UIFocusTestNestedLayout2()
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
UIFocusTestNestedLayout2::~UIFocusTestNestedLayout2()
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
bool UIFocusTestNestedLayout2::init()
|
|
|
|
{
|
|
|
|
if (UIFocusTestBase::init()) {
|
|
|
|
|
|
|
|
Size winSize = Director::getInstance()->getVisibleSize();
|
|
|
|
|
|
|
|
_horizontalLayout = HBox::create();
|
|
|
|
_horizontalLayout->setPosition(Vector2(winSize.width/2 - 200, winSize.height - 70));
|
|
|
|
_uiLayer->addChild(_horizontalLayout);
|
2014-05-08 14:35:45 +08:00
|
|
|
_horizontalLayout->setScale(0.6);
|
2014-05-07 11:40:01 +08:00
|
|
|
|
|
|
|
_horizontalLayout->setFocused(true);
|
|
|
|
_horizontalLayout->setLoopFocus(true);
|
|
|
|
_horizontalLayout->setTag(100);
|
|
|
|
_firstFocusedWidget = _horizontalLayout;
|
|
|
|
|
|
|
|
int count1 = 2;
|
|
|
|
for (int i=0; i<count1; ++i) {
|
|
|
|
ImageView *w = ImageView::create("cocosui/scrollviewbg.png");
|
|
|
|
w->setAnchorPoint(Vector2(0,1));
|
|
|
|
w->setTouchEnabled(true);
|
|
|
|
w->setTag(i+count1);
|
|
|
|
w->setScaleY(2.4);
|
2014-05-09 14:30:39 +08:00
|
|
|
w->addTouchEventListener(CC_CALLBACK_2(UIFocusTestNestedLayout2::onImageViewClicked, this));
|
2014-05-07 11:40:01 +08:00
|
|
|
_horizontalLayout->addChild(w);
|
|
|
|
}
|
|
|
|
|
|
|
|
//add HBox into VBox
|
|
|
|
VBox *vbox = VBox::create();
|
|
|
|
vbox->setScale(0.8);
|
|
|
|
vbox->setTag(101);
|
|
|
|
_horizontalLayout->addChild(vbox);
|
|
|
|
|
|
|
|
int count2 = 2;
|
|
|
|
for (int i=0; i < count2; ++i) {
|
|
|
|
ImageView *w = ImageView::create("cocosui/scrollviewbg.png");
|
|
|
|
w->setAnchorPoint(Vector2(0,1));
|
|
|
|
w->setScaleX(2.0);
|
|
|
|
w->setTouchEnabled(true);
|
|
|
|
w->setTag(i+count1+count2);
|
2014-05-09 14:30:39 +08:00
|
|
|
w->addTouchEventListener(CC_CALLBACK_2(UIFocusTestNestedLayout2::onImageViewClicked, this));
|
2014-05-07 11:40:01 +08:00
|
|
|
vbox->addChild(w);
|
|
|
|
}
|
|
|
|
|
|
|
|
HBox *innerHBox = HBox::create();
|
|
|
|
vbox->addChild(innerHBox);
|
|
|
|
innerHBox->setTag(102);
|
|
|
|
// innerVBox->setPassFocusToChild(false);
|
|
|
|
// innerVBox->setFocusEnabled(false);
|
|
|
|
|
|
|
|
|
|
|
|
int count3 = 2;
|
|
|
|
for (int i=0; i<count3; ++i) {
|
|
|
|
ImageView *w = ImageView::create("cocosui/scrollviewbg.png");
|
|
|
|
w->setTouchEnabled(true);
|
|
|
|
w->setTag(i+count1+count2+count3);
|
2014-05-09 14:30:39 +08:00
|
|
|
w->addTouchEventListener(CC_CALLBACK_2(UIFocusTestNestedLayout2::onImageViewClicked, this));
|
2014-05-07 11:40:01 +08:00
|
|
|
innerHBox->addChild(w);
|
|
|
|
}
|
|
|
|
|
|
|
|
_loopText = Text::create("loop enabled", "Airal", 20);
|
|
|
|
_loopText->setPosition(Vector2(winSize.width/2, winSize.height - 50));
|
|
|
|
_loopText->setColor(Color3B::GREEN);
|
|
|
|
this->addChild(_loopText);
|
|
|
|
|
|
|
|
auto btn = Button::create("cocosui/switch-mask.png");
|
|
|
|
btn->setTitleText("Toggle Loop");
|
|
|
|
btn->setPosition(Vector2(60, winSize.height - 50));
|
|
|
|
btn->setTitleColor(Color3B::RED);
|
2014-05-09 14:30:39 +08:00
|
|
|
btn->addTouchEventListener(CC_CALLBACK_2(UIFocusTestNestedLayout2::toggleFocusLoop, this));
|
2014-05-07 11:40:01 +08:00
|
|
|
this->addChild(btn);
|
|
|
|
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2014-05-09 14:30:39 +08:00
|
|
|
void UIFocusTestNestedLayout2::toggleFocusLoop(cocos2d::Ref * pObjc, Widget::TouchEventType type)
|
2014-05-07 11:40:01 +08:00
|
|
|
{
|
2014-05-09 14:30:39 +08:00
|
|
|
if (type == Widget::TouchEventType::ENDED) {
|
2014-05-07 14:06:44 +08:00
|
|
|
_horizontalLayout->setLoopFocus(!_horizontalLayout->isLoopFocus());
|
|
|
|
if (_horizontalLayout->isLoopFocus()) {
|
2014-05-07 11:40:01 +08:00
|
|
|
_loopText->setText("loop enabled");
|
|
|
|
}else{
|
|
|
|
_loopText->setText("loop disabled");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2014-05-07 18:27:05 +08:00
|
|
|
|
|
|
|
//UIFocusTestNestedLayout3
|
|
|
|
UIFocusTestNestedLayout3::UIFocusTestNestedLayout3()
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
UIFocusTestNestedLayout3::~UIFocusTestNestedLayout3()
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
bool UIFocusTestNestedLayout3::init()
|
|
|
|
{
|
|
|
|
if (UIFocusTestBase::init()) {
|
|
|
|
|
|
|
|
Size winSize = Director::getInstance()->getVisibleSize();
|
|
|
|
|
|
|
|
_verticalLayout = VBox::create();
|
|
|
|
_verticalLayout->setPosition(Vector2(40, winSize.height - 70));
|
|
|
|
_uiLayer->addChild(_verticalLayout);
|
|
|
|
_verticalLayout->setScale(0.8);
|
|
|
|
|
|
|
|
_verticalLayout->setFocused(true);
|
|
|
|
_verticalLayout->setLoopFocus(true);
|
|
|
|
_verticalLayout->setTag(-1000);
|
|
|
|
_firstFocusedWidget = _verticalLayout;
|
|
|
|
|
|
|
|
|
|
|
|
HBox *upperHBox = HBox::create();
|
|
|
|
upperHBox->setTag(-200);
|
|
|
|
_verticalLayout->addChild(upperHBox);
|
|
|
|
|
|
|
|
LinearLayoutParameter *params = LinearLayoutParameter::create();
|
|
|
|
params->setMargin(Margin(0,0,50,0));
|
|
|
|
|
|
|
|
LinearLayoutParameter *vparams = LinearLayoutParameter::create();
|
|
|
|
vparams->setMargin(Margin(10, 0, 0, 140));
|
|
|
|
upperHBox->setLayoutParameter(vparams);
|
|
|
|
|
|
|
|
int count = 3;
|
|
|
|
for (int i=0; i<count; ++i) {
|
|
|
|
VBox *firstVbox = VBox::create();
|
|
|
|
firstVbox->setScale(0.5);
|
|
|
|
firstVbox->setLayoutParameter(params);
|
|
|
|
firstVbox->setTag((i+1) * 100);
|
|
|
|
|
|
|
|
int count1 = 3;
|
|
|
|
for (int j=0; j<count1; ++j) {
|
|
|
|
ImageView *w = ImageView::create("cocosui/scrollviewbg.png");
|
|
|
|
w->setTouchEnabled(true);
|
|
|
|
w->setTag(j+firstVbox->getTag()+1);
|
2014-05-09 14:30:39 +08:00
|
|
|
w->addTouchEventListener(CC_CALLBACK_2(UIFocusTestBase::onImageViewClicked, this));
|
2014-05-07 18:27:05 +08:00
|
|
|
firstVbox->addChild(w);
|
|
|
|
}
|
|
|
|
|
|
|
|
upperHBox->addChild(firstVbox);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
HBox *bottomHBox = HBox::create();
|
|
|
|
bottomHBox->setScale(0.5);
|
|
|
|
bottomHBox->setTag(600);
|
|
|
|
|
|
|
|
bottomHBox->setLayoutParameter(vparams);
|
|
|
|
count = 3;
|
|
|
|
LinearLayoutParameter *bottomParams = LinearLayoutParameter::create();
|
2014-05-08 10:46:05 +08:00
|
|
|
bottomParams->setMargin(Margin(0, 0, 8, 0));
|
2014-05-07 18:27:05 +08:00
|
|
|
for (int i=0; i < count; ++i) {
|
|
|
|
ImageView *w = ImageView::create("cocosui/scrollviewbg.png");
|
|
|
|
w->setLayoutParameter(bottomParams);
|
|
|
|
w->setTouchEnabled(true);
|
|
|
|
w->setTag(i+601);
|
2014-05-09 14:30:39 +08:00
|
|
|
w->addTouchEventListener(CC_CALLBACK_2(UIFocusTestBase::onImageViewClicked, this));
|
2014-05-07 18:27:05 +08:00
|
|
|
bottomHBox->addChild(w);
|
|
|
|
}
|
|
|
|
_verticalLayout->addChild(bottomHBox);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
_loopText = Text::create("loop enabled", "Airal", 20);
|
|
|
|
_loopText->setPosition(Vector2(winSize.width/2, winSize.height - 50));
|
|
|
|
_loopText->setColor(Color3B::GREEN);
|
|
|
|
this->addChild(_loopText);
|
|
|
|
|
|
|
|
auto btn = Button::create("cocosui/switch-mask.png");
|
|
|
|
btn->setTitleText("Toggle Loop");
|
|
|
|
btn->setPosition(Vector2(60, winSize.height - 50));
|
|
|
|
btn->setTitleColor(Color3B::RED);
|
2014-05-09 14:30:39 +08:00
|
|
|
btn->addTouchEventListener(CC_CALLBACK_2(UIFocusTestNestedLayout3::toggleFocusLoop, this));
|
2014-05-07 18:27:05 +08:00
|
|
|
this->addChild(btn);
|
|
|
|
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2014-05-09 14:30:39 +08:00
|
|
|
void UIFocusTestNestedLayout3::toggleFocusLoop(cocos2d::Ref * pObjc, Widget::TouchEventType type)
|
2014-05-07 18:27:05 +08:00
|
|
|
{
|
2014-05-09 14:30:39 +08:00
|
|
|
if (type == Widget::TouchEventType::ENDED) {
|
2014-05-07 18:27:05 +08:00
|
|
|
_verticalLayout->setLoopFocus(!_verticalLayout->isLoopFocus());
|
|
|
|
if (_verticalLayout->isLoopFocus()) {
|
|
|
|
_loopText->setText("loop enabled");
|
|
|
|
}else{
|
|
|
|
_loopText->setText("loop disabled");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|