mirror of https://github.com/axmolengine/axmol.git
Merge branch 'develop' of https://github.com/cocos2d/cocos2d-x into developCheck
This commit is contained in:
commit
e6fd1fece1
|
@ -1 +1 @@
|
|||
695569fbf5580abb74dbc9b9d9fc7ad8d21db805
|
||||
30ca6c02884f9bc20405b3e657b444c0153bead7
|
|
@ -1 +1 @@
|
|||
13f41d81e48285159fafa45159fdd1c081b4bb06
|
||||
3ff18018375c71f683a484652678740cc6395eaf
|
|
@ -159,7 +159,7 @@ void ActionNode::initActionNodeFromRoot(Object* root)
|
|||
UIWidget* rootWidget = dynamic_cast<UIWidget*>(root);
|
||||
if (rootWidget != NULL)
|
||||
{
|
||||
UIWidget* widget = UIHelper::instance()->seekActionWidgetByActionTag(rootWidget, getActionTag());
|
||||
UIWidget* widget = UIHelper::seekActionWidgetByActionTag(rootWidget, getActionTag());
|
||||
if (widget != NULL)
|
||||
{
|
||||
setObject(widget);
|
||||
|
|
|
@ -152,7 +152,7 @@ UIWidget* CCSGUIReader::widgetFromJsonDictionary(JsonDictionary* data)
|
|||
}
|
||||
else if (classname && strcmp(classname, "Panel") == 0)
|
||||
{
|
||||
widget = Layout::create();
|
||||
widget = UILayout::create();
|
||||
setPropsForPanelFromJsonDictionary(widget, uiOptions);
|
||||
}
|
||||
else if (classname && strcmp(classname, "Slider") == 0)
|
||||
|
@ -162,8 +162,8 @@ UIWidget* CCSGUIReader::widgetFromJsonDictionary(JsonDictionary* data)
|
|||
}
|
||||
else if (classname && strcmp(classname, "ListView") == 0)
|
||||
{
|
||||
// widget = UIListView::create();
|
||||
// setPropsForListViewFromJsonDictionary(widget, uiOptions);
|
||||
widget = UIListView::create();
|
||||
setPropsForListViewFromJsonDictionary(widget, uiOptions);
|
||||
}
|
||||
else if (classname && strcmp(classname, "PageView") == 0)
|
||||
{
|
||||
|
@ -177,7 +177,7 @@ UIWidget* CCSGUIReader::widgetFromJsonDictionary(JsonDictionary* data)
|
|||
}
|
||||
else if (classname && strcmp(classname, "DragPanel") == 0)
|
||||
{
|
||||
widget = UIDragPanel::create();
|
||||
widget = UIScrollView::create();
|
||||
setPropsForDragPanelFromJsonDictionary(widget, uiOptions);
|
||||
}
|
||||
|
||||
|
@ -232,20 +232,20 @@ UIWidget* CCSGUIReader::widgetFromJsonFile(const char *fileName)
|
|||
const char* file = DICTOOL->getStringValueFromArray_json(jsonDict, "textures", i);
|
||||
std::string tp = m_strFilePath;
|
||||
tp.append(file);
|
||||
CCUIHELPER->addSpriteFrame(tp.c_str());
|
||||
SpriteFrameCache::getInstance()->addSpriteFramesWithFile(tp.c_str());
|
||||
}
|
||||
float fileDesignWidth = DICTOOL->getFloatValue_json(jsonDict, "designWidth");
|
||||
float fileDesignHeight = DICTOOL->getFloatValue_json(jsonDict, "designHeight");
|
||||
if (fileDesignWidth <= 0 || fileDesignHeight <= 0) {
|
||||
printf("Read design size error!\n");
|
||||
Size winSize = Director::getInstance()->getWinSize();
|
||||
CCUIHELPER->setFileDesignWidth(winSize.width);
|
||||
CCUIHELPER->setFileDesignHeight(winSize.height);
|
||||
// CCUIHELPER->setFileDesignWidth(winSize.width);
|
||||
// CCUIHELPER->setFileDesignHeight(winSize.height);
|
||||
}
|
||||
else
|
||||
{
|
||||
CCUIHELPER->setFileDesignWidth(fileDesignWidth);
|
||||
CCUIHELPER->setFileDesignHeight(fileDesignHeight);
|
||||
// CCUIHELPER->setFileDesignWidth(fileDesignWidth);
|
||||
// CCUIHELPER->setFileDesignHeight(fileDesignHeight);
|
||||
}
|
||||
JsonDictionary* widgetTree = DICTOOL->getSubDictionary_json(jsonDict, "widgetTree");
|
||||
UIWidget* widget = widgetFromJsonDictionary(widgetTree);
|
||||
|
@ -253,7 +253,7 @@ UIWidget* CCSGUIReader::widgetFromJsonFile(const char *fileName)
|
|||
/* *********temp********* */
|
||||
if (widget->getContentSize().equals(Size::ZERO))
|
||||
{
|
||||
Layout* rootWidget = dynamic_cast<Layout*>(widget);
|
||||
UILayout* rootWidget = dynamic_cast<UILayout*>(widget);
|
||||
rootWidget->setSize(Size(fileDesignWidth, fileDesignHeight));
|
||||
}
|
||||
/* ********************** */
|
||||
|
@ -792,7 +792,7 @@ void CCSGUIReader::setPropsForLabelFromJsonDictionary(UIWidget*widget,JsonDictio
|
|||
setPropsForWidgetFromJsonDictionary(widget, options);
|
||||
UILabel* label = (UILabel*)widget;
|
||||
bool touchScaleChangeAble = DICTOOL->getBooleanValue_json(options, "touchScaleEnable");
|
||||
label->setTouchScaleChangeAble(touchScaleChangeAble);
|
||||
label->setTouchScaleChangeEnabled(touchScaleChangeAble);
|
||||
const char* text = DICTOOL->getStringValue_json(options, "text");
|
||||
label->setText(text);
|
||||
bool fs = DICTOOL->checkObjectExist_json(options, "fontSize");
|
||||
|
@ -877,10 +877,9 @@ void CCSGUIReader::setPropsForLabelAtlasFromJsonDictionary(UIWidget*widget,JsonD
|
|||
void CCSGUIReader::setPropsForContainerWidgetFromJsonDictionary(UIWidget *widget, JsonDictionary *options)
|
||||
{
|
||||
setPropsForWidgetFromJsonDictionary(widget, options);
|
||||
Layout* containerWidget = (Layout*)widget;
|
||||
UILayout* containerWidget = (UILayout*)widget;
|
||||
if (!dynamic_cast<UIScrollView*>(containerWidget)
|
||||
&& !dynamic_cast<UIListView*>(containerWidget)
|
||||
&& !dynamic_cast<UIDragPanel*>(containerWidget))
|
||||
&& !dynamic_cast<UIListView*>(containerWidget))
|
||||
{
|
||||
containerWidget->setClippingEnabled(DICTOOL->getBooleanValue_json(options, "clipAble"));
|
||||
}
|
||||
|
@ -892,7 +891,7 @@ void CCSGUIReader::setPropsForPanelFromJsonDictionary(UIWidget*widget,JsonDictio
|
|||
if (m_bOlderVersion)
|
||||
{
|
||||
setPropsForContainerWidgetFromJsonDictionary(widget, options);
|
||||
Layout* panel = (Layout*)widget;
|
||||
UILayout* panel = (UILayout*)widget;
|
||||
bool backGroundScale9Enable = DICTOOL->getBooleanValue_json(options, "backGroundScale9Enable");
|
||||
panel->setBackGroundImageScale9Enabled(backGroundScale9Enable);
|
||||
int cr = DICTOOL->getIntValue_json(options, "bgColorR");
|
||||
|
@ -959,7 +958,7 @@ void CCSGUIReader::setPropsForPanelFromJsonDictionary(UIWidget*widget,JsonDictio
|
|||
else
|
||||
{
|
||||
setPropsForContainerWidgetFromJsonDictionary(widget, options);
|
||||
Layout* panel = (Layout*)widget;
|
||||
UILayout* panel = (UILayout*)widget;
|
||||
bool backGroundScale9Enable = DICTOOL->getBooleanValue_json(options, "backGroundScale9Enable");
|
||||
panel->setBackGroundImageScale9Enabled(backGroundScale9Enable);
|
||||
int cr = DICTOOL->getIntValue_json(options, "bgColorR");
|
||||
|
@ -1394,7 +1393,7 @@ void CCSGUIReader::setPropsForTextFieldFromJsonDictionary(UIWidget*widget,JsonDi
|
|||
//textField->setSize(CCSizeMake(dw, dh));
|
||||
}
|
||||
bool maxLengthEnable = DICTOOL->getBooleanValue_json(options, "maxLengthEnable");
|
||||
textField->setMaxLengthEnable(maxLengthEnable);
|
||||
textField->setMaxLengthEnabled(maxLengthEnable);
|
||||
|
||||
if (maxLengthEnable)
|
||||
{
|
||||
|
@ -1402,7 +1401,7 @@ void CCSGUIReader::setPropsForTextFieldFromJsonDictionary(UIWidget*widget,JsonDi
|
|||
textField->setMaxLength(maxLength);
|
||||
}
|
||||
bool passwordEnable = DICTOOL->getBooleanValue_json(options, "passwordEnable");
|
||||
textField->setPasswordEnable(passwordEnable);
|
||||
textField->setPasswordEnabled(passwordEnable);
|
||||
if (passwordEnable)
|
||||
{
|
||||
textField->setPasswordStyleText(DICTOOL->getStringValue_json(options, "passwordStyleText"));
|
||||
|
@ -1557,10 +1556,10 @@ void CCSGUIReader::setPropsForDragPanelFromJsonDictionary(UIWidget *widget, Json
|
|||
{
|
||||
setPropsForPanelFromJsonDictionary(widget, options);
|
||||
|
||||
UIDragPanel* dragPanel = (UIDragPanel*)widget;
|
||||
UIScrollView* dragPanel = (UIScrollView*)widget;
|
||||
|
||||
bool bounceEnable = DICTOOL->getBooleanValue_json(options, "bounceEnable");
|
||||
dragPanel->setBounceEnable(bounceEnable);
|
||||
dragPanel->setBounceEnabled(bounceEnable);
|
||||
|
||||
float innerWidth = DICTOOL->getFloatValue_json(options, "innerWidth");
|
||||
float innerHeight = DICTOOL->getFloatValue_json(options, "innerHeight");
|
||||
|
|
|
@ -320,8 +320,8 @@ namespace cocostudio {
|
|||
{
|
||||
gui::UILayer *pLayer = gui::UILayer::create();
|
||||
pLayer->scheduleUpdate();
|
||||
UIWidget* widget= gui::UIHelper::instance()->createWidgetFromJsonFile(pPath.c_str());
|
||||
pLayer->addWidget(widget);
|
||||
// UIWidget* widget= gui::UIHelper::instance()->createWidgetFromJsonFile(pPath.c_str());
|
||||
// pLayer->addWidget(widget);
|
||||
ComRender *pRender = ComRender::create(pLayer, "GUIComponent");
|
||||
if (pComName != NULL)
|
||||
{
|
||||
|
|
|
@ -7,14 +7,13 @@ LOCAL_MODULE_FILENAME := libgui
|
|||
|
||||
LOCAL_SRC_FILES := UIRootWidget.cpp \
|
||||
UIWidget.cpp \
|
||||
Layout.cpp \
|
||||
LayoutParameter.cpp \
|
||||
UILayout.cpp \
|
||||
UILayoutParameter.cpp \
|
||||
UILayoutDefine.cpp \
|
||||
CocosGUI.cpp \
|
||||
UIHelper.cpp \
|
||||
UIInputManager.cpp \
|
||||
UILayer.cpp \
|
||||
UIDragPanel.cpp \
|
||||
UIListView.cpp \
|
||||
UIPageView.cpp \
|
||||
UIScrollView.cpp \
|
||||
|
|
|
@ -1,14 +1,13 @@
|
|||
set(GUI_SRC
|
||||
UIRootWidget.cpp
|
||||
UIWidget.cpp
|
||||
Layout.cpp
|
||||
LayoutParameter.cpp
|
||||
UILayout.cpp
|
||||
UILayoutParameter.cpp
|
||||
UILayoutDefine.cpp
|
||||
CocosGUI.cpp
|
||||
UIHelper.cpp
|
||||
UIInputManager.cpp
|
||||
UILayer.cpp
|
||||
UIDragPanel.cpp
|
||||
UIListView.cpp
|
||||
UIPageView.cpp
|
||||
UIScrollView.cpp
|
||||
|
|
|
@ -27,7 +27,7 @@
|
|||
|
||||
|
||||
#include "gui/UIWidget.h"
|
||||
#include "gui/Layout.h"
|
||||
#include "gui/UILayout.h"
|
||||
#include "gui/UIRootWidget.h"
|
||||
#include "gui/UIButton.h"
|
||||
#include "gui/UICheckBox.h"
|
||||
|
@ -36,10 +36,9 @@
|
|||
#include "gui/UILabelAtlas.h"
|
||||
#include "gui/UILoadingBar.h"
|
||||
#include "gui/UIScrollView.h"
|
||||
#include "gui/UIListView.h"
|
||||
#include "gui/UISlider.h"
|
||||
#include "gui/UITextField.h"
|
||||
#include "gui/UIListView.h"
|
||||
#include "gui/UIDragPanel.h"
|
||||
#include "gui/UILabelBMFont.h"
|
||||
#include "gui/UIPageView.h"
|
||||
#include "gui/UIHelper.h"
|
||||
|
|
|
@ -1,785 +0,0 @@
|
|||
/****************************************************************************
|
||||
Copyright (c) 2013 cocos2d-x.org
|
||||
|
||||
http://www.cocos2d-x.org
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
of this software and associated documentation files (the "Software"), to deal
|
||||
in the Software without restriction, including without limitation the rights
|
||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
copies of the Software, and to permit persons to whom the Software is
|
||||
furnished to do so, subject to the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be included in
|
||||
all copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||
THE SOFTWARE.
|
||||
****************************************************************************/
|
||||
|
||||
#include "gui/Layout.h"
|
||||
#include "gui/UILayer.h"
|
||||
#include "gui/UIHelper.h"
|
||||
#include "extensions/GUI/CCControlExtension/CCScale9Sprite.h"
|
||||
|
||||
using namespace cocos2d;
|
||||
using namespace cocos2d::extension;
|
||||
|
||||
namespace gui {
|
||||
|
||||
#define DYNAMIC_CAST_CLIPPINGLAYER dynamic_cast<RectClippingNode*>(_renderer)
|
||||
|
||||
Layout::Layout():
|
||||
_clippingEnabled(false),
|
||||
_backGroundScale9Enabled(false),
|
||||
_backGroundImage(NULL),
|
||||
_backGroundImageFileName(""),
|
||||
_backGroundImageCapInsets(Rect::ZERO),
|
||||
_colorType(LAYOUT_COLOR_NONE),
|
||||
_bgImageTexType(UI_TEX_TYPE_LOCAL),
|
||||
_colorRender(NULL),
|
||||
_gradientRender(NULL),
|
||||
_cColor(Color3B::WHITE),
|
||||
_gStartColor(Color3B::WHITE),
|
||||
_gEndColor(Color3B::WHITE),
|
||||
_alongVector(Point(0.0f, -1.0f)),
|
||||
_cOpacity(255),
|
||||
_backGroundImageTextureSize(Size::ZERO),
|
||||
_layoutType(LAYOUT_ABSOLUTE)
|
||||
{
|
||||
_widgetType = WidgetTypeContainer;
|
||||
}
|
||||
|
||||
Layout::~Layout()
|
||||
{
|
||||
}
|
||||
|
||||
Layout* Layout::create()
|
||||
{
|
||||
Layout* layout = new Layout();
|
||||
if (layout && layout->init())
|
||||
{
|
||||
layout->autorelease();
|
||||
return layout;
|
||||
}
|
||||
CC_SAFE_DELETE(layout);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
bool Layout::init()
|
||||
{
|
||||
_children = CCArray::create();
|
||||
_children->retain();
|
||||
initRenderer();
|
||||
_renderer->retain();
|
||||
_renderer->setZOrder(_widgetZOrder);
|
||||
RGBAProtocol* renderRGBA = dynamic_cast<RGBAProtocol*>(_renderer);
|
||||
if (renderRGBA)
|
||||
{
|
||||
renderRGBA->setCascadeColorEnabled(false);
|
||||
renderRGBA->setCascadeOpacityEnabled(false);
|
||||
}
|
||||
ignoreContentAdaptWithSize(false);
|
||||
setSize(Size::ZERO);
|
||||
setBright(true);
|
||||
setAnchorPoint(Point(0, 0));
|
||||
_scheduler = Director::getInstance()->getScheduler();
|
||||
CC_SAFE_RETAIN(_scheduler);
|
||||
return true;
|
||||
}
|
||||
|
||||
void Layout::initRenderer()
|
||||
{
|
||||
_renderer = RectClippingNode::create();
|
||||
}
|
||||
|
||||
bool Layout::isClippingEnabled()
|
||||
{
|
||||
return _clippingEnabled;
|
||||
}
|
||||
|
||||
bool Layout::hitTest(const Point &pt)
|
||||
{
|
||||
Point nsp = _renderer->convertToNodeSpace(pt);
|
||||
Rect bb = Rect(0.0f, 0.0f, _size.width, _size.height);
|
||||
if (nsp.x >= bb.origin.x && nsp.x <= bb.origin.x + bb.size.width && nsp.y >= bb.origin.y && nsp.y <= bb.origin.y + bb.size.height)
|
||||
{
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
void Layout::setClippingEnabled(bool able)
|
||||
{
|
||||
_clippingEnabled = able;
|
||||
DYNAMIC_CAST_CLIPPINGLAYER->setClippingEnabled(able);
|
||||
}
|
||||
|
||||
void Layout::onSizeChanged()
|
||||
{
|
||||
DYNAMIC_CAST_CLIPPINGLAYER->setClippingSize(_size);
|
||||
doLayout();
|
||||
if (_backGroundImage)
|
||||
{
|
||||
_backGroundImage->setPosition(Point(_size.width/2.0f, _size.height/2.0f));
|
||||
if (_backGroundScale9Enabled)
|
||||
{
|
||||
dynamic_cast<Scale9Sprite*>(_backGroundImage)->setPreferredSize(_size);
|
||||
}
|
||||
}
|
||||
if (_colorRender)
|
||||
{
|
||||
_colorRender->setContentSize(_size);
|
||||
}
|
||||
if (_gradientRender)
|
||||
{
|
||||
_gradientRender->setContentSize(_size);
|
||||
}
|
||||
}
|
||||
|
||||
void Layout::setBackGroundImageScale9Enabled(bool able)
|
||||
{
|
||||
if (_backGroundScale9Enabled == able)
|
||||
{
|
||||
return;
|
||||
}
|
||||
_renderer->removeChild(_backGroundImage, true);
|
||||
_backGroundImage = NULL;
|
||||
_backGroundScale9Enabled = able;
|
||||
if (_backGroundScale9Enabled)
|
||||
{
|
||||
_backGroundImage = Scale9Sprite::create();
|
||||
_renderer->addChild(_backGroundImage);
|
||||
}
|
||||
else
|
||||
{
|
||||
_backGroundImage = Sprite::create();
|
||||
_renderer->addChild(_backGroundImage);
|
||||
}
|
||||
_backGroundImage->setZOrder(-1);
|
||||
setBackGroundImage(_backGroundImageFileName.c_str(),_bgImageTexType);
|
||||
setBackGroundImageCapInsets(_backGroundImageCapInsets);
|
||||
}
|
||||
|
||||
void Layout::setBackGroundImage(const char* fileName,TextureResType texType)
|
||||
{
|
||||
if (!fileName || strcmp(fileName, "") == 0)
|
||||
{
|
||||
return;
|
||||
}
|
||||
if (_backGroundImage == NULL)
|
||||
{
|
||||
addBackGroundImage();
|
||||
}
|
||||
_backGroundImageFileName = fileName;
|
||||
_bgImageTexType = texType;
|
||||
if (_backGroundScale9Enabled)
|
||||
{
|
||||
switch (_bgImageTexType)
|
||||
{
|
||||
case UI_TEX_TYPE_LOCAL:
|
||||
dynamic_cast<Scale9Sprite*>(_backGroundImage)->initWithFile(fileName);
|
||||
break;
|
||||
case UI_TEX_TYPE_PLIST:
|
||||
dynamic_cast<Scale9Sprite*>(_backGroundImage)->initWithSpriteFrameName(fileName);
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
dynamic_cast<Scale9Sprite*>(_backGroundImage)->setPreferredSize(_size);
|
||||
}
|
||||
else
|
||||
{
|
||||
switch (_bgImageTexType)
|
||||
{
|
||||
case UI_TEX_TYPE_LOCAL:
|
||||
dynamic_cast<Sprite*>(_backGroundImage)->initWithFile(fileName);
|
||||
break;
|
||||
case UI_TEX_TYPE_PLIST:
|
||||
dynamic_cast<Sprite*>(_backGroundImage)->initWithSpriteFrameName(fileName);
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
if (_backGroundScale9Enabled)
|
||||
{
|
||||
dynamic_cast<Scale9Sprite*>(_backGroundImage)->setColor(getColor());
|
||||
dynamic_cast<Scale9Sprite*>(_backGroundImage)->setOpacity(getOpacity());
|
||||
}
|
||||
else
|
||||
{
|
||||
dynamic_cast<Sprite*>(_backGroundImage)->setColor(getColor());
|
||||
dynamic_cast<Sprite*>(_backGroundImage)->setOpacity(getOpacity());
|
||||
}
|
||||
_backGroundImageTextureSize = _backGroundImage->getContentSize();
|
||||
_backGroundImage->setPosition(Point(_size.width/2.0f, _size.height/2.0f));
|
||||
}
|
||||
|
||||
void Layout::setBackGroundImageCapInsets(const Rect &capInsets)
|
||||
{
|
||||
_backGroundImageCapInsets = capInsets;
|
||||
if (_backGroundScale9Enabled)
|
||||
{
|
||||
dynamic_cast<Scale9Sprite*>(_backGroundImage)->setCapInsets(capInsets);
|
||||
}
|
||||
}
|
||||
|
||||
void Layout::addBackGroundImage()
|
||||
{
|
||||
if (_backGroundScale9Enabled)
|
||||
{
|
||||
_backGroundImage = Scale9Sprite::create();
|
||||
_backGroundImage->setZOrder(-1);
|
||||
_renderer->addChild(_backGroundImage);
|
||||
dynamic_cast<Scale9Sprite*>(_backGroundImage)->setPreferredSize(_size);
|
||||
}
|
||||
else
|
||||
{
|
||||
_backGroundImage = CCSprite::create();
|
||||
_backGroundImage->setZOrder(-1);
|
||||
_renderer->addChild(_backGroundImage);
|
||||
}
|
||||
_backGroundImage->setPosition(Point(_size.width/2.0f, _size.height/2.0f));
|
||||
}
|
||||
|
||||
void Layout::removeBackGroundImage()
|
||||
{
|
||||
if (!_backGroundImage)
|
||||
{
|
||||
return;
|
||||
}
|
||||
_renderer->removeChild(_backGroundImage, true);
|
||||
_backGroundImage = NULL;
|
||||
_backGroundImageFileName = "";
|
||||
_backGroundImageTextureSize = Size::ZERO;
|
||||
}
|
||||
|
||||
void Layout::setBackGroundColorType(LayoutBackGroundColorType type)
|
||||
{
|
||||
if (_colorType == type)
|
||||
{
|
||||
return;
|
||||
}
|
||||
switch (_colorType)
|
||||
{
|
||||
case LAYOUT_COLOR_NONE:
|
||||
if (_colorRender)
|
||||
{
|
||||
_renderer->removeChild(_colorRender, true);
|
||||
_colorRender = NULL;
|
||||
}
|
||||
if (_gradientRender)
|
||||
{
|
||||
_renderer->removeChild(_gradientRender, true);
|
||||
_gradientRender = NULL;
|
||||
}
|
||||
break;
|
||||
case LAYOUT_COLOR_SOLID:
|
||||
if (_colorRender)
|
||||
{
|
||||
_renderer->removeChild(_colorRender, true);
|
||||
_colorRender = NULL;
|
||||
}
|
||||
break;
|
||||
case LAYOUT_COLOR_GRADIENT:
|
||||
if (_gradientRender)
|
||||
{
|
||||
_renderer->removeChild(_gradientRender, true);
|
||||
_gradientRender = NULL;
|
||||
}
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
_colorType = type;
|
||||
switch (_colorType)
|
||||
{
|
||||
case LAYOUT_COLOR_NONE:
|
||||
break;
|
||||
case LAYOUT_COLOR_SOLID:
|
||||
_colorRender = CCLayerColor::create();
|
||||
_colorRender->setContentSize(_size);
|
||||
_colorRender->setOpacity(_cOpacity);
|
||||
_colorRender->setColor(_cColor);
|
||||
_renderer->addChild(_colorRender,-2);
|
||||
break;
|
||||
case LAYOUT_COLOR_GRADIENT:
|
||||
_gradientRender = CCLayerGradient::create();
|
||||
_gradientRender->setContentSize(_size);
|
||||
_gradientRender->setOpacity(_cOpacity);
|
||||
_gradientRender->setStartColor(_gStartColor);
|
||||
_gradientRender->setEndColor(_gEndColor);
|
||||
_gradientRender->setVector(_alongVector);
|
||||
_renderer->addChild(_gradientRender,-2);
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
void Layout::setBackGroundColor(const Color3B &color)
|
||||
{
|
||||
_cColor = color;
|
||||
if (_colorRender)
|
||||
{
|
||||
_colorRender->setColor(color);
|
||||
}
|
||||
}
|
||||
|
||||
void Layout::setBackGroundColor(const Color3B &startColor, const Color3B &endColor)
|
||||
{
|
||||
_gStartColor = startColor;
|
||||
if (_gradientRender)
|
||||
{
|
||||
_gradientRender->setStartColor(startColor);
|
||||
}
|
||||
_gEndColor = endColor;
|
||||
if (_gradientRender)
|
||||
{
|
||||
_gradientRender->setEndColor(endColor);
|
||||
}
|
||||
}
|
||||
|
||||
void Layout::setBackGroundColorOpacity(int opacity)
|
||||
{
|
||||
_cOpacity = opacity;
|
||||
switch (_colorType)
|
||||
{
|
||||
case LAYOUT_COLOR_NONE:
|
||||
break;
|
||||
case LAYOUT_COLOR_SOLID:
|
||||
_colorRender->setOpacity(opacity);
|
||||
break;
|
||||
case LAYOUT_COLOR_GRADIENT:
|
||||
_gradientRender->setOpacity(opacity);
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
void Layout::setBackGroundColorVector(const Point &vector)
|
||||
{
|
||||
_alongVector = vector;
|
||||
if (_gradientRender)
|
||||
{
|
||||
_gradientRender->setVector(vector);
|
||||
}
|
||||
}
|
||||
|
||||
void Layout::setColor(const Color3B &color)
|
||||
{
|
||||
UIWidget::setColor(color);
|
||||
if (_backGroundImage)
|
||||
{
|
||||
RGBAProtocol* rgbap = dynamic_cast<RGBAProtocol*>(_backGroundImage);
|
||||
if (rgbap)
|
||||
{
|
||||
rgbap->setColor(color);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void Layout::setOpacity(int opacity)
|
||||
{
|
||||
UIWidget::setOpacity(opacity);
|
||||
if (_backGroundImage)
|
||||
{
|
||||
RGBAProtocol* rgbap = dynamic_cast<RGBAProtocol*>(_backGroundImage);
|
||||
if (rgbap)
|
||||
{
|
||||
rgbap->setOpacity(opacity);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
const Size& Layout::getBackGroundImageTextureSize() const
|
||||
{
|
||||
return _backGroundImageTextureSize;
|
||||
}
|
||||
|
||||
const Size& Layout::getContentSize() const
|
||||
{
|
||||
return _renderer->getContentSize();
|
||||
}
|
||||
|
||||
void Layout::setLayoutType(LayoutType type)
|
||||
{
|
||||
_layoutType = type;
|
||||
}
|
||||
|
||||
LayoutType Layout::getLayoutType() const
|
||||
{
|
||||
return _layoutType;
|
||||
}
|
||||
|
||||
void Layout::doLayout()
|
||||
{
|
||||
switch (_layoutType)
|
||||
{
|
||||
case LAYOUT_ABSOLUTE:
|
||||
break;
|
||||
case LAYOUT_LINEAR_VERTICAL:
|
||||
{
|
||||
ccArray* layoutChildrenArray = getChildren()->data;
|
||||
int length = layoutChildrenArray->num;
|
||||
Size layoutSize = getSize();
|
||||
float topBoundary = layoutSize.height;
|
||||
for (int i=0; i<length; ++i)
|
||||
{
|
||||
UIWidget* child = dynamic_cast<UIWidget*>(layoutChildrenArray->arr[i]);
|
||||
LinearLayoutParameter* layoutParameter = dynamic_cast<LinearLayoutParameter*>(child->getLayoutParameter());
|
||||
|
||||
if (layoutParameter)
|
||||
{
|
||||
WidgetType childType = child->getWidgetType();
|
||||
UILinearGravity childGravity = layoutParameter->getGravity();
|
||||
Point ap = child->getAnchorPoint();
|
||||
Size cs = child->getSize();
|
||||
float finalPosX = childType == WidgetTypeWidget ? ap.x * cs.width : 0.0f;
|
||||
float finalPosY = childType == WidgetTypeWidget ? topBoundary - ((1.0f-ap.y) * cs.height) : topBoundary - cs.height;
|
||||
switch (childGravity)
|
||||
{
|
||||
case LINEAR_GRAVITY_NONE:
|
||||
case LINEAR_GRAVITY_LEFT:
|
||||
break;
|
||||
case LINEAR_GRAVITY_RIGHT:
|
||||
finalPosX = childType == WidgetTypeWidget ? layoutSize.width - ((1.0f - ap.x) * cs.width) : layoutSize.width - cs.width;
|
||||
break;
|
||||
case LINEAR_GRAVITY_CENTER_HORIZONTAL:
|
||||
finalPosX = childType == WidgetTypeWidget ? layoutSize.width / 2.0f - cs.width * (0.5f-ap.x) : (layoutSize.width - cs.width) * 0.5f;
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
UIMargin mg = layoutParameter->getMargin();
|
||||
finalPosX += mg.left;
|
||||
finalPosY -= mg.top;
|
||||
child->setPosition(Point(finalPosX, finalPosY));
|
||||
topBoundary = child->getBottomInParent() - mg.bottom;
|
||||
}
|
||||
}
|
||||
break;
|
||||
}
|
||||
case LAYOUT_LINEAR_HORIZONTAL:
|
||||
{
|
||||
ccArray* layoutChildrenArray = getChildren()->data;
|
||||
int length = layoutChildrenArray->num;
|
||||
Size layoutSize = getSize();
|
||||
float leftBoundary = 0.0f;
|
||||
for (int i=0; i<length; ++i)
|
||||
{
|
||||
UIWidget* child = dynamic_cast<UIWidget*>(layoutChildrenArray->arr[i]);
|
||||
LinearLayoutParameter* layoutParameter = dynamic_cast<LinearLayoutParameter*>(child->getLayoutParameter());
|
||||
|
||||
if (layoutParameter)
|
||||
{
|
||||
WidgetType childType = child->getWidgetType();
|
||||
UILinearGravity childGravity = layoutParameter->getGravity();
|
||||
Point ap = child->getAnchorPoint();
|
||||
Size cs = child->getSize();
|
||||
float finalPosX = childType == WidgetTypeWidget ? leftBoundary + (ap.x * cs.width) : leftBoundary;
|
||||
float finalPosY = childType == WidgetTypeWidget ? layoutSize.height - (1.0f - ap.y) * cs.height : layoutSize.height - cs.height;
|
||||
switch (childGravity)
|
||||
{
|
||||
case LINEAR_GRAVITY_NONE:
|
||||
case LINEAR_GRAVITY_TOP:
|
||||
break;
|
||||
case LINEAR_GRAVITY_BOTTOM:
|
||||
finalPosY = childType == WidgetTypeWidget ? ap.y * cs.height : 0.0f;
|
||||
break;
|
||||
case LINEAR_GRAVITY_CENTER_VERTICAL:
|
||||
finalPosY = childType == WidgetTypeWidget ? layoutSize.height/2.0f - cs.height * (0.5f - ap.y) : (layoutSize.height - cs.height) * 0.5f;
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
UIMargin mg = layoutParameter->getMargin();
|
||||
finalPosX += mg.left;
|
||||
finalPosY -= mg.top;
|
||||
child->setPosition(Point(finalPosX, finalPosY));
|
||||
leftBoundary = child->getRightInParent() + mg.right;
|
||||
}
|
||||
}
|
||||
break;
|
||||
}
|
||||
case LAYOUT_RELATIVE:
|
||||
{
|
||||
ccArray* layoutChildrenArray = getChildren()->data;
|
||||
int length = layoutChildrenArray->num;
|
||||
Size layoutSize = getSize();
|
||||
for (int i=0; i<length; i++)
|
||||
{
|
||||
UIWidget* child = dynamic_cast<UIWidget*>(layoutChildrenArray->arr[i]);
|
||||
WidgetType childType = child->getWidgetType();
|
||||
Point ap = child->getAnchorPoint();
|
||||
Size cs = child->getSize();
|
||||
RelativeLayoutParameter* layoutParameter = dynamic_cast<RelativeLayoutParameter*>(child->getLayoutParameter());
|
||||
if (layoutParameter)
|
||||
{
|
||||
float finalPosX = childType == WidgetTypeWidget ? ap.x * cs.width : 0.0f;
|
||||
float finalPosY = childType == WidgetTypeWidget ? layoutSize.height - ((1.0f - ap.y) * cs.height) : layoutSize.height - cs.height;
|
||||
UIRelativeAlign align = layoutParameter->getAlign();
|
||||
const char* relativeName = layoutParameter->getRelativeToWidgetName();
|
||||
UIWidget* relativeWidget = NULL;
|
||||
if (relativeName && strcmp(relativeName, ""))
|
||||
{
|
||||
relativeWidget = CCUIHELPER->seekWidgetByRelativeName(this, relativeName);
|
||||
}
|
||||
switch (align)
|
||||
{
|
||||
case RELATIVE_ALIGN_NONE:
|
||||
break;
|
||||
case RELATIVE_ALIGN_PARENT_LEFT:
|
||||
break;
|
||||
case RELATIVE_ALIGN_PARENT_TOP:
|
||||
break;
|
||||
case RELATIVE_ALIGN_PARENT_RIGHT:
|
||||
finalPosX = childType == WidgetTypeWidget ? layoutSize.width - ((1.0f - ap.x) * cs.width) : layoutSize.width - cs.width;
|
||||
break;
|
||||
case RELATIVE_ALIGN_PARENT_BOTTOM:
|
||||
finalPosY = childType == WidgetTypeWidget ? ap.y * cs.height : 0.0f;
|
||||
break;
|
||||
case RELATIVE_CENTER_IN_PARENT:
|
||||
finalPosX = childType == WidgetTypeWidget ? layoutSize.width * 0.5f - cs.width * (0.5f - ap.x) : (layoutSize.width - cs.width) * 0.5f;
|
||||
finalPosY = childType == WidgetTypeWidget ? layoutSize.height * 0.5f - cs.height * (0.5f - ap.y) : (layoutSize.height - cs.height) * 0.5f;
|
||||
break;
|
||||
case RELATIVE_CENTER_HORIZONTAL:
|
||||
finalPosX = childType == WidgetTypeWidget ? layoutSize.width * 0.5f - cs.width * (0.5f - ap.x) : (layoutSize.width - cs.width) * 0.5f;
|
||||
break;
|
||||
case RELATIVE_CENTER_VERTICAL:
|
||||
finalPosY = childType == WidgetTypeWidget ? layoutSize.height * 0.5f - cs.height * (0.5f - ap.y) : (layoutSize.height - cs.height) * 0.5f;
|
||||
break;
|
||||
case RELATIVE_LOCATION_LEFT_OF_TOPALIGN:
|
||||
if (relativeWidget)
|
||||
{
|
||||
float locationTop = relativeWidget->getTopInParent();
|
||||
float locationRight = relativeWidget->getLeftInParent();
|
||||
finalPosY = childType == WidgetTypeWidget ? locationTop - ap.y * cs.height : locationTop - cs.height;
|
||||
finalPosX = childType == WidgetTypeWidget ? locationRight - (1.0f - ap.x) * cs.width : locationRight - cs.width;
|
||||
}
|
||||
break;
|
||||
case RELATIVE_LOCATION_LEFT_OF_CENTER:
|
||||
break;
|
||||
case RELATIVE_LOCATION_LEFT_OF_BOTTOMALIGN:
|
||||
if (relativeWidget)
|
||||
{
|
||||
float locationRight = relativeWidget->getLeftInParent();
|
||||
float locationBottom = relativeWidget->getBottomInParent();
|
||||
finalPosY = childType == WidgetTypeWidget ? locationBottom + ap.y * cs.height : locationBottom;
|
||||
finalPosX = childType == WidgetTypeWidget ? locationRight - (1.0f - ap.x) * cs.width : locationRight - cs.width;
|
||||
}
|
||||
break;
|
||||
case RELATIVE_LOCATION_RIGHT_OF_TOPALIGN:
|
||||
if (relativeWidget)
|
||||
{
|
||||
float locationTop = relativeWidget->getTopInParent();
|
||||
float locationLeft = relativeWidget->getRightInParent();
|
||||
finalPosY = childType == WidgetTypeWidget ? locationTop - ap.y * cs.height : locationTop - cs.height;
|
||||
finalPosX = childType == WidgetTypeWidget ? locationLeft + ap.x * cs.width : locationLeft;
|
||||
}
|
||||
break;
|
||||
case RELATIVE_LOCATION_RIGHT_OF_CENTER:
|
||||
break;
|
||||
case RELATIVE_LOCATION_RIGHT_OF_BOTTOMALIGN:
|
||||
if (relativeWidget)
|
||||
{
|
||||
float locationLeft = relativeWidget->getRightInParent();
|
||||
float locationBottom = relativeWidget->getBottomInParent();
|
||||
finalPosY = childType == WidgetTypeWidget ? locationBottom + ap.y * cs.height : locationBottom;
|
||||
finalPosX = childType == WidgetTypeWidget ? locationLeft + ap.x * cs.width : locationLeft;
|
||||
}
|
||||
break;
|
||||
case RELATIVE_LOCATION_ABOVE_LEFTALIGN:
|
||||
if (relativeWidget)
|
||||
{
|
||||
float locationBottom = relativeWidget->getTopInParent();
|
||||
float locationLeft = relativeWidget->getLeftInParent();
|
||||
finalPosY = childType == WidgetTypeWidget ? locationBottom + ap.y * cs.height : locationBottom;
|
||||
finalPosX = childType == WidgetTypeWidget ? locationLeft + ap.x * cs.width : locationLeft;
|
||||
}
|
||||
break;
|
||||
case RELATIVE_LOCATION_ABOVE_CENTER:
|
||||
break;
|
||||
case RELATIVE_LOCATION_ABOVE_RIGHTALIGN:
|
||||
if (relativeWidget)
|
||||
{
|
||||
float locationBottom = relativeWidget->getTopInParent();
|
||||
float locationRight = relativeWidget->getRightInParent();
|
||||
finalPosY = childType == WidgetTypeWidget ? locationBottom + ap.y * cs.height : locationBottom;
|
||||
finalPosX = childType == WidgetTypeWidget ? locationRight - (1.0f - ap.x) * cs.width : locationRight - cs.width;
|
||||
}
|
||||
break;
|
||||
case RELATIVE_LOCATION_BELOW_LEFTALIGN:
|
||||
if (relativeWidget)
|
||||
{
|
||||
float locationTop = relativeWidget->getBottomInParent();
|
||||
float locationLeft = relativeWidget->getLeftInParent();
|
||||
finalPosY = childType == WidgetTypeWidget ? locationTop - (1.0f - ap.y) * cs.height : locationTop - cs.height;
|
||||
finalPosX = childType == WidgetTypeWidget ? locationLeft + ap.x * cs.width : locationLeft;
|
||||
}
|
||||
break;
|
||||
case RELATIVE_LOCATION_BELOW_CENTER:
|
||||
break;
|
||||
case RELATIVE_LOCATION_BELOW_RIGHTALIGN:
|
||||
if (relativeWidget)
|
||||
{
|
||||
float locationTop = relativeWidget->getBottomInParent();
|
||||
float locationRight = relativeWidget->getRightInParent();
|
||||
finalPosY = childType == WidgetTypeWidget ? locationTop - (1.0f - ap.y) * cs.height : locationTop - cs.height;
|
||||
finalPosX = childType == WidgetTypeWidget ? locationRight - (1.0f - ap.x) * cs.width : locationRight - cs.width;
|
||||
}
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
UIMargin relativeWidgetMargin;
|
||||
UIMargin mg;
|
||||
if (relativeWidget)
|
||||
{
|
||||
relativeWidgetMargin = relativeWidget->getLayoutParameter()->getMargin();
|
||||
mg = child->getLayoutParameter()->getMargin();
|
||||
}
|
||||
//handle margin
|
||||
switch (align)
|
||||
{
|
||||
case RELATIVE_LOCATION_ABOVE_LEFTALIGN:
|
||||
case RELATIVE_LOCATION_ABOVE_RIGHTALIGN:
|
||||
case RELATIVE_LOCATION_ABOVE_CENTER:
|
||||
finalPosY += relativeWidgetMargin.top;
|
||||
finalPosY += mg.bottom;
|
||||
break;
|
||||
case RELATIVE_LOCATION_BELOW_LEFTALIGN:
|
||||
case RELATIVE_LOCATION_BELOW_RIGHTALIGN:
|
||||
case RELATIVE_LOCATION_BELOW_CENTER:
|
||||
finalPosY -= relativeWidgetMargin.bottom;
|
||||
finalPosY -= mg.top;
|
||||
break;
|
||||
case RELATIVE_LOCATION_LEFT_OF_TOPALIGN:
|
||||
case RELATIVE_LOCATION_LEFT_OF_BOTTOMALIGN:
|
||||
case RELATIVE_LOCATION_LEFT_OF_CENTER:
|
||||
finalPosX -= relativeWidgetMargin.left;
|
||||
finalPosX -= mg.right;
|
||||
break;
|
||||
case RELATIVE_LOCATION_RIGHT_OF_TOPALIGN:
|
||||
case RELATIVE_LOCATION_RIGHT_OF_BOTTOMALIGN:
|
||||
case RELATIVE_LOCATION_RIGHT_OF_CENTER:
|
||||
finalPosX += relativeWidgetMargin.right;
|
||||
finalPosX += mg.left;
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
child->setPosition(Point(finalPosX, finalPosY));
|
||||
}
|
||||
}
|
||||
break;
|
||||
}
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
const char* Layout::getDescription() const
|
||||
{
|
||||
return "Layout";
|
||||
}
|
||||
|
||||
RectClippingNode::RectClippingNode():
|
||||
m_pInnerStencil(NULL),
|
||||
_enabled(true),
|
||||
_clippingSize(Size(50.0f, 50.0f)),
|
||||
_clippingEnabled(false)
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
RectClippingNode::~RectClippingNode()
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
RectClippingNode* RectClippingNode::create()
|
||||
{
|
||||
RectClippingNode *pRet = new RectClippingNode();
|
||||
if (pRet && pRet->init())
|
||||
{
|
||||
pRet->autorelease();
|
||||
}
|
||||
else
|
||||
{
|
||||
CC_SAFE_DELETE(pRet);
|
||||
}
|
||||
|
||||
return pRet;
|
||||
}
|
||||
|
||||
bool RectClippingNode::init()
|
||||
{
|
||||
m_pInnerStencil = CCDrawNode::create();
|
||||
rect[0] = Point(0, 0);
|
||||
rect[1] = Point(_clippingSize.width, 0);
|
||||
rect[2] = Point(_clippingSize.width, _clippingSize.height);
|
||||
rect[3] = Point(0, _clippingSize.height);
|
||||
|
||||
Color4F green(0, 1, 0, 1);
|
||||
m_pInnerStencil->drawPolygon(rect, 4, green, 0, green);
|
||||
if (CCClippingNode::init(m_pInnerStencil))
|
||||
{
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
|
||||
void RectClippingNode::setClippingSize(const Size &size)
|
||||
{
|
||||
setContentSize(size);
|
||||
_clippingSize = size;
|
||||
rect[0] = Point(0, 0);
|
||||
rect[1] = Point(_clippingSize.width, 0);
|
||||
rect[2] = Point(_clippingSize.width, _clippingSize.height);
|
||||
rect[3] = Point(0, _clippingSize.height);
|
||||
Color4F green(0, 1, 0, 1);
|
||||
m_pInnerStencil->clear();
|
||||
m_pInnerStencil->drawPolygon(rect, 4, green, 0, green);
|
||||
}
|
||||
|
||||
void RectClippingNode::setClippingEnabled(bool enabled)
|
||||
{
|
||||
_clippingEnabled = enabled;
|
||||
}
|
||||
|
||||
void RectClippingNode::visit()
|
||||
{
|
||||
if (!_enabled)
|
||||
{
|
||||
return;
|
||||
}
|
||||
if (_clippingEnabled)
|
||||
{
|
||||
CCClippingNode::visit();
|
||||
}
|
||||
else
|
||||
{
|
||||
CCNode::visit();
|
||||
}
|
||||
}
|
||||
|
||||
void RectClippingNode::setEnabled(bool enabled)
|
||||
{
|
||||
_enabled = enabled;
|
||||
}
|
||||
|
||||
bool RectClippingNode::isEnabled() const
|
||||
{
|
||||
return _enabled;
|
||||
}
|
||||
|
||||
}
|
|
@ -6,14 +6,13 @@ INCLUDES = -I../ \
|
|||
|
||||
SOURCES = UIRootWidget.cpp \
|
||||
UIWidget.cpp \
|
||||
Layout.cpp \
|
||||
LayoutParameter.cpp \
|
||||
UILayout.cpp \
|
||||
UILayoutParameter.cpp \
|
||||
UILayoutDefine.cpp \
|
||||
CocosGUI.cpp \
|
||||
UIHelper.cpp \
|
||||
UIInputManager.cpp \
|
||||
UILayer.cpp \
|
||||
UIDragPanel.cpp \
|
||||
UIListView.cpp \
|
||||
UIPageView.cpp \
|
||||
UIScrollView.cpp \
|
||||
|
|
|
@ -25,9 +25,6 @@
|
|||
#include "gui/UIButton.h"
|
||||
#include "extensions/GUI/CCControlExtension/CCScale9Sprite.h"
|
||||
|
||||
using namespace cocos2d;
|
||||
using namespace cocos2d::extension;
|
||||
|
||||
namespace gui {
|
||||
|
||||
#define NORMALRENDERERZ (0)
|
||||
|
@ -45,9 +42,9 @@ _clickedFileName(""),
|
|||
_disabledFileName(""),
|
||||
_prevIgnoreSize(true),
|
||||
_scale9Enabled(false),
|
||||
_capInsetsNormal(Rect::ZERO),
|
||||
_capInsetsPressed(Rect::ZERO),
|
||||
_capInsetsDisabled(Rect::ZERO),
|
||||
_capInsetsNormal(cocos2d::Rect::ZERO),
|
||||
_capInsetsPressed(cocos2d::Rect::ZERO),
|
||||
_capInsetsDisabled(cocos2d::Rect::ZERO),
|
||||
_normalTexType(UI_TEX_TYPE_LOCAL),
|
||||
_pressedTexType(UI_TEX_TYPE_LOCAL),
|
||||
_disabledTexType(UI_TEX_TYPE_LOCAL),
|
||||
|
@ -55,7 +52,7 @@ _normalTextureSize(_size),
|
|||
_pressedTextureSize(_size),
|
||||
_disabledTextureSize(_size),
|
||||
_pressedActionEnabled(false),
|
||||
_titleColor(Color3B::WHITE)
|
||||
_titleColor(cocos2d::Color3B::WHITE)
|
||||
{
|
||||
|
||||
}
|
||||
|
@ -88,10 +85,10 @@ bool UIButton::init()
|
|||
void UIButton::initRenderer()
|
||||
{
|
||||
UIWidget::initRenderer();
|
||||
_buttonNormalRenderer = Sprite::create();
|
||||
_buttonClickedRenderer = Sprite::create();
|
||||
_buttonDisableRenderer = Sprite::create();
|
||||
_titleRenderer = LabelTTF::create();
|
||||
_buttonNormalRenderer = cocos2d::Sprite::create();
|
||||
_buttonClickedRenderer = cocos2d::Sprite::create();
|
||||
_buttonDisableRenderer = cocos2d::Sprite::create();
|
||||
_titleRenderer = cocos2d::LabelTTF::create();
|
||||
_renderer->addChild(_buttonNormalRenderer,NORMALRENDERERZ);
|
||||
_renderer->addChild(_buttonClickedRenderer,PRESSEDRENDERERZ);
|
||||
_renderer->addChild(_buttonDisableRenderer,DISABLEDRENDERERZ);
|
||||
|
@ -117,15 +114,15 @@ void UIButton::setScale9Enabled(bool able)
|
|||
_buttonDisableRenderer = NULL;
|
||||
if (_scale9Enabled)
|
||||
{
|
||||
_buttonNormalRenderer = Scale9Sprite::create();
|
||||
_buttonClickedRenderer = Scale9Sprite::create();
|
||||
_buttonDisableRenderer = Scale9Sprite::create();
|
||||
_buttonNormalRenderer = cocos2d::extension::Scale9Sprite::create();
|
||||
_buttonClickedRenderer = cocos2d::extension::Scale9Sprite::create();
|
||||
_buttonDisableRenderer = cocos2d::extension::Scale9Sprite::create();
|
||||
}
|
||||
else
|
||||
{
|
||||
_buttonNormalRenderer = CCSprite::create();
|
||||
_buttonClickedRenderer = CCSprite::create();
|
||||
_buttonDisableRenderer = CCSprite::create();
|
||||
_buttonNormalRenderer = cocos2d::Sprite::create();
|
||||
_buttonClickedRenderer = cocos2d::Sprite::create();
|
||||
_buttonDisableRenderer = cocos2d::Sprite::create();
|
||||
}
|
||||
|
||||
loadTextureNormal(_normalFileName.c_str(), _normalTexType);
|
||||
|
@ -179,32 +176,33 @@ void UIButton::loadTextureNormal(const char* normal,TextureResType texType)
|
|||
switch (_normalTexType)
|
||||
{
|
||||
case UI_TEX_TYPE_LOCAL:
|
||||
dynamic_cast<Scale9Sprite*>(_buttonNormalRenderer)->initWithFile(normal);
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_buttonNormalRenderer)->initWithFile(normal);
|
||||
break;
|
||||
case UI_TEX_TYPE_PLIST:
|
||||
dynamic_cast<Scale9Sprite*>(_buttonNormalRenderer)->initWithSpriteFrameName(normal);
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_buttonNormalRenderer)->initWithSpriteFrameName(normal);
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
dynamic_cast<Scale9Sprite*>(_buttonNormalRenderer)->setColor(getColor());
|
||||
dynamic_cast<Scale9Sprite*>(_buttonNormalRenderer)->setOpacity(getOpacity());
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_buttonNormalRenderer)->setColor(getColor());
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_buttonNormalRenderer)->setOpacity(getOpacity());
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_buttonNormalRenderer)->setCapInsets(_capInsetsNormal);
|
||||
}
|
||||
else
|
||||
{
|
||||
switch (_normalTexType)
|
||||
{
|
||||
case UI_TEX_TYPE_LOCAL:
|
||||
dynamic_cast<Sprite*>(_buttonNormalRenderer)->initWithFile(normal);
|
||||
dynamic_cast<cocos2d::Sprite*>(_buttonNormalRenderer)->initWithFile(normal);
|
||||
break;
|
||||
case UI_TEX_TYPE_PLIST:
|
||||
dynamic_cast<Sprite*>(_buttonNormalRenderer)->initWithSpriteFrameName(normal);
|
||||
dynamic_cast<cocos2d::Sprite*>(_buttonNormalRenderer)->initWithSpriteFrameName(normal);
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
dynamic_cast<Sprite*>(_buttonNormalRenderer)->setColor(getColor());
|
||||
dynamic_cast<Sprite*>(_buttonNormalRenderer)->setOpacity(getOpacity());
|
||||
dynamic_cast<cocos2d::Sprite*>(_buttonNormalRenderer)->setColor(getColor());
|
||||
dynamic_cast<cocos2d::Sprite*>(_buttonNormalRenderer)->setOpacity(getOpacity());
|
||||
}
|
||||
_normalTextureSize = _buttonNormalRenderer->getContentSize();
|
||||
updateAnchorPoint();
|
||||
|
@ -224,32 +222,33 @@ void UIButton::loadTexturePressed(const char* selected,TextureResType texType)
|
|||
switch (_pressedTexType)
|
||||
{
|
||||
case UI_TEX_TYPE_LOCAL:
|
||||
dynamic_cast<Scale9Sprite*>(_buttonClickedRenderer)->initWithFile(selected);
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_buttonClickedRenderer)->initWithFile(selected);
|
||||
break;
|
||||
case UI_TEX_TYPE_PLIST:
|
||||
dynamic_cast<Scale9Sprite*>(_buttonClickedRenderer)->initWithSpriteFrameName(selected);
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_buttonClickedRenderer)->initWithSpriteFrameName(selected);
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
dynamic_cast<Scale9Sprite*>(_buttonClickedRenderer)->setColor(getColor());
|
||||
dynamic_cast<Scale9Sprite*>(_buttonClickedRenderer)->setOpacity(getOpacity());
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_buttonClickedRenderer)->setColor(getColor());
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_buttonClickedRenderer)->setOpacity(getOpacity());
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_buttonClickedRenderer)->setCapInsets(_capInsetsPressed);
|
||||
}
|
||||
else
|
||||
{
|
||||
switch (_pressedTexType)
|
||||
{
|
||||
case UI_TEX_TYPE_LOCAL:
|
||||
dynamic_cast<Sprite*>(_buttonClickedRenderer)->initWithFile(selected);
|
||||
dynamic_cast<cocos2d::Sprite*>(_buttonClickedRenderer)->initWithFile(selected);
|
||||
break;
|
||||
case UI_TEX_TYPE_PLIST:
|
||||
dynamic_cast<Sprite*>(_buttonClickedRenderer)->initWithSpriteFrameName(selected);
|
||||
dynamic_cast<cocos2d::Sprite*>(_buttonClickedRenderer)->initWithSpriteFrameName(selected);
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
dynamic_cast<Sprite*>(_buttonClickedRenderer)->setColor(getColor());
|
||||
dynamic_cast<Sprite*>(_buttonClickedRenderer)->setOpacity(getOpacity());
|
||||
dynamic_cast<cocos2d::Sprite*>(_buttonClickedRenderer)->setColor(getColor());
|
||||
dynamic_cast<cocos2d::Sprite*>(_buttonClickedRenderer)->setOpacity(getOpacity());
|
||||
}
|
||||
_pressedTextureSize = _buttonClickedRenderer->getContentSize();
|
||||
updateAnchorPoint();
|
||||
|
@ -269,73 +268,74 @@ void UIButton::loadTextureDisabled(const char* disabled,TextureResType texType)
|
|||
switch (_disabledTexType)
|
||||
{
|
||||
case UI_TEX_TYPE_LOCAL:
|
||||
dynamic_cast<Scale9Sprite*>(_buttonDisableRenderer)->initWithFile(disabled);
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_buttonDisableRenderer)->initWithFile(disabled);
|
||||
break;
|
||||
case UI_TEX_TYPE_PLIST:
|
||||
dynamic_cast<Scale9Sprite*>(_buttonDisableRenderer)->initWithSpriteFrameName(disabled);
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_buttonDisableRenderer)->initWithSpriteFrameName(disabled);
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
dynamic_cast<Scale9Sprite*>(_buttonDisableRenderer)->setColor(getColor());
|
||||
dynamic_cast<Scale9Sprite*>(_buttonDisableRenderer)->setOpacity(getOpacity());
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_buttonDisableRenderer)->setColor(getColor());
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_buttonDisableRenderer)->setOpacity(getOpacity());
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_buttonDisableRenderer)->setCapInsets(_capInsetsDisabled);
|
||||
}
|
||||
else
|
||||
{
|
||||
switch (_disabledTexType)
|
||||
{
|
||||
case UI_TEX_TYPE_LOCAL:
|
||||
dynamic_cast<Sprite*>(_buttonDisableRenderer)->initWithFile(disabled);
|
||||
dynamic_cast<cocos2d::Sprite*>(_buttonDisableRenderer)->initWithFile(disabled);
|
||||
break;
|
||||
case UI_TEX_TYPE_PLIST:
|
||||
dynamic_cast<Sprite*>(_buttonDisableRenderer)->initWithSpriteFrameName(disabled);
|
||||
dynamic_cast<cocos2d::Sprite*>(_buttonDisableRenderer)->initWithSpriteFrameName(disabled);
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
dynamic_cast<Sprite*>(_buttonDisableRenderer)->setColor(getColor());
|
||||
dynamic_cast<Sprite*>(_buttonDisableRenderer)->setOpacity(getOpacity());
|
||||
dynamic_cast<cocos2d::Sprite*>(_buttonDisableRenderer)->setColor(getColor());
|
||||
dynamic_cast<cocos2d::Sprite*>(_buttonDisableRenderer)->setOpacity(getOpacity());
|
||||
}
|
||||
_disabledTextureSize = _buttonDisableRenderer->getContentSize();
|
||||
updateAnchorPoint();
|
||||
disabledTextureScaleChangedWithSize();
|
||||
}
|
||||
|
||||
void UIButton::setCapInsets(const Rect &capInsets)
|
||||
void UIButton::setCapInsets(const cocos2d::Rect &capInsets)
|
||||
{
|
||||
setCapInsetsNormalRenderer(capInsets);
|
||||
setCapInsetsPressedRenderer(capInsets);
|
||||
setCapInsetsDisabledRenderer(capInsets);
|
||||
}
|
||||
|
||||
void UIButton::setCapInsetsNormalRenderer(const Rect &capInsets)
|
||||
void UIButton::setCapInsetsNormalRenderer(const cocos2d::Rect &capInsets)
|
||||
{
|
||||
_capInsetsNormal = capInsets;
|
||||
if (!_scale9Enabled)
|
||||
{
|
||||
return;
|
||||
}
|
||||
dynamic_cast<Scale9Sprite*>(_buttonNormalRenderer)->setCapInsets(capInsets);
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_buttonNormalRenderer)->setCapInsets(capInsets);
|
||||
}
|
||||
|
||||
void UIButton::setCapInsetsPressedRenderer(const Rect &capInsets)
|
||||
void UIButton::setCapInsetsPressedRenderer(const cocos2d::Rect &capInsets)
|
||||
{
|
||||
_capInsetsPressed = capInsets;
|
||||
if (!_scale9Enabled)
|
||||
{
|
||||
return;
|
||||
}
|
||||
dynamic_cast<Scale9Sprite*>(_buttonClickedRenderer)->setCapInsets(capInsets);
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_buttonClickedRenderer)->setCapInsets(capInsets);
|
||||
}
|
||||
|
||||
void UIButton::setCapInsetsDisabledRenderer(const Rect &capInsets)
|
||||
void UIButton::setCapInsetsDisabledRenderer(const cocos2d::Rect &capInsets)
|
||||
{
|
||||
_capInsetsDisabled = capInsets;
|
||||
if (!_scale9Enabled)
|
||||
{
|
||||
return;
|
||||
}
|
||||
dynamic_cast<Scale9Sprite*>(_buttonDisableRenderer)->setCapInsets(capInsets);
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_buttonDisableRenderer)->setCapInsets(capInsets);
|
||||
}
|
||||
|
||||
void UIButton::onPressStateChangedToNormal()
|
||||
|
@ -348,9 +348,9 @@ void UIButton::onPressStateChangedToNormal()
|
|||
_buttonNormalRenderer->stopAllActions();
|
||||
_buttonClickedRenderer->stopAllActions();
|
||||
_buttonDisableRenderer->stopAllActions();
|
||||
Action *zoomAction = ScaleTo::create(0.05f, 1.0f);
|
||||
Action *zoomAction1 = ScaleTo::create(0.05f, 1.0f);
|
||||
Action *zoomAction2 = ScaleTo::create(0.05f, 1.0f);
|
||||
cocos2d::Action *zoomAction = cocos2d::ScaleTo::create(0.05f, 1.0f);
|
||||
cocos2d::Action *zoomAction1 = cocos2d::ScaleTo::create(0.05f, 1.0f);
|
||||
cocos2d::Action *zoomAction2 = cocos2d::ScaleTo::create(0.05f, 1.0f);
|
||||
_buttonNormalRenderer->runAction(zoomAction);
|
||||
_buttonClickedRenderer->runAction(zoomAction1);
|
||||
_buttonDisableRenderer->runAction(zoomAction2);
|
||||
|
@ -367,9 +367,9 @@ void UIButton::onPressStateChangedToPressed()
|
|||
_buttonNormalRenderer->stopAllActions();
|
||||
_buttonClickedRenderer->stopAllActions();
|
||||
_buttonDisableRenderer->stopAllActions();
|
||||
Action *zoomAction = ScaleTo::create(0.05f, 1.1f);
|
||||
Action *zoomAction1 = ScaleTo::create(0.05f, 1.1f);
|
||||
Action *zoomAction2 = ScaleTo::create(0.05f, 1.1f);
|
||||
cocos2d::Action *zoomAction = cocos2d::ScaleTo::create(0.05f, 1.1f);
|
||||
cocos2d::Action *zoomAction1 = cocos2d::ScaleTo::create(0.05f, 1.1f);
|
||||
cocos2d::Action *zoomAction2 = cocos2d::ScaleTo::create(0.05f, 1.1f);
|
||||
_buttonNormalRenderer->runAction(zoomAction);
|
||||
_buttonClickedRenderer->runAction(zoomAction1);
|
||||
_buttonDisableRenderer->runAction(zoomAction2);
|
||||
|
@ -390,9 +390,9 @@ void UIButton::setFlipX(bool flipX)
|
|||
{
|
||||
return;
|
||||
}
|
||||
dynamic_cast<Sprite*>(_buttonNormalRenderer)->setFlippedX(flipX);
|
||||
dynamic_cast<Sprite*>(_buttonClickedRenderer)->setFlippedX(flipX);
|
||||
dynamic_cast<Sprite*>(_buttonDisableRenderer)->setFlippedX(flipX);
|
||||
dynamic_cast<cocos2d::Sprite*>(_buttonNormalRenderer)->setFlippedX(flipX);
|
||||
dynamic_cast<cocos2d::Sprite*>(_buttonClickedRenderer)->setFlippedX(flipX);
|
||||
dynamic_cast<cocos2d::Sprite*>(_buttonDisableRenderer)->setFlippedX(flipX);
|
||||
}
|
||||
|
||||
void UIButton::setFlipY(bool flipY)
|
||||
|
@ -402,9 +402,9 @@ void UIButton::setFlipY(bool flipY)
|
|||
{
|
||||
return;
|
||||
}
|
||||
dynamic_cast<Sprite*>(_buttonNormalRenderer)->setFlippedY(flipY);
|
||||
dynamic_cast<Sprite*>(_buttonClickedRenderer)->setFlippedY(flipY);
|
||||
dynamic_cast<Sprite*>(_buttonDisableRenderer)->setFlippedY(flipY);
|
||||
dynamic_cast<cocos2d::Sprite*>(_buttonNormalRenderer)->setFlippedY(flipY);
|
||||
dynamic_cast<cocos2d::Sprite*>(_buttonClickedRenderer)->setFlippedY(flipY);
|
||||
dynamic_cast<cocos2d::Sprite*>(_buttonDisableRenderer)->setFlippedY(flipY);
|
||||
}
|
||||
|
||||
bool UIButton::isFlipX()
|
||||
|
@ -413,7 +413,7 @@ bool UIButton::isFlipX()
|
|||
{
|
||||
return false;
|
||||
}
|
||||
return dynamic_cast<Sprite*>(_buttonNormalRenderer)->isFlippedX();
|
||||
return dynamic_cast<cocos2d::Sprite*>(_buttonNormalRenderer)->isFlippedX();
|
||||
}
|
||||
|
||||
bool UIButton::isFlipY()
|
||||
|
@ -422,16 +422,16 @@ bool UIButton::isFlipY()
|
|||
{
|
||||
return false;
|
||||
}
|
||||
return dynamic_cast<Sprite*>(_buttonNormalRenderer)->isFlippedY();
|
||||
return dynamic_cast<cocos2d::Sprite*>(_buttonNormalRenderer)->isFlippedY();
|
||||
}
|
||||
|
||||
void UIButton::setAnchorPoint(const Point &pt)
|
||||
void UIButton::setAnchorPoint(const cocos2d::Point &pt)
|
||||
{
|
||||
UIWidget::setAnchorPoint(pt);
|
||||
_buttonNormalRenderer->setAnchorPoint(pt);
|
||||
_buttonClickedRenderer->setAnchorPoint(pt);
|
||||
_buttonDisableRenderer->setAnchorPoint(pt);
|
||||
_titleRenderer->setPosition(Point(_size.width*(0.5f-_anchorPoint.x), _size.height*(0.5f-_anchorPoint.y)));
|
||||
_titleRenderer->setPosition(cocos2d::Point(_size.width*(0.5f-_anchorPoint.x), _size.height*(0.5f-_anchorPoint.y)));
|
||||
}
|
||||
|
||||
void UIButton::onSizeChanged()
|
||||
|
@ -441,12 +441,12 @@ void UIButton::onSizeChanged()
|
|||
disabledTextureScaleChangedWithSize();
|
||||
}
|
||||
|
||||
const Size& UIButton::getContentSize() const
|
||||
const cocos2d::Size& UIButton::getContentSize() const
|
||||
{
|
||||
return _normalTextureSize;
|
||||
}
|
||||
|
||||
Node* UIButton::getVirtualRenderer()
|
||||
cocos2d::Node* UIButton::getVirtualRenderer()
|
||||
{
|
||||
if (_bright)
|
||||
{
|
||||
|
@ -480,11 +480,11 @@ void UIButton::normalTextureScaleChangedWithSize()
|
|||
{
|
||||
if (_scale9Enabled)
|
||||
{
|
||||
dynamic_cast<Scale9Sprite*>(_buttonNormalRenderer)->setPreferredSize(_size);
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_buttonNormalRenderer)->setPreferredSize(_size);
|
||||
}
|
||||
else
|
||||
{
|
||||
Size textureSize = _normalTextureSize;
|
||||
cocos2d::Size textureSize = _normalTextureSize;
|
||||
if (textureSize.width <= 0.0f || textureSize.height <= 0.0f)
|
||||
{
|
||||
_buttonNormalRenderer->setScale(1.0f);
|
||||
|
@ -511,11 +511,11 @@ void UIButton::pressedTextureScaleChangedWithSize()
|
|||
{
|
||||
if (_scale9Enabled)
|
||||
{
|
||||
dynamic_cast<Scale9Sprite*>(_buttonClickedRenderer)->setPreferredSize(_size);
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_buttonClickedRenderer)->setPreferredSize(_size);
|
||||
}
|
||||
else
|
||||
{
|
||||
Size textureSize = _pressedTextureSize;
|
||||
cocos2d::Size textureSize = _pressedTextureSize;
|
||||
if (textureSize.width <= 0.0f || textureSize.height <= 0.0f)
|
||||
{
|
||||
_buttonClickedRenderer->setScale(1.0f);
|
||||
|
@ -542,11 +542,11 @@ void UIButton::disabledTextureScaleChangedWithSize()
|
|||
{
|
||||
if (_scale9Enabled)
|
||||
{
|
||||
dynamic_cast<Scale9Sprite*>(_buttonDisableRenderer)->setPreferredSize(_size);
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_buttonDisableRenderer)->setPreferredSize(_size);
|
||||
}
|
||||
else
|
||||
{
|
||||
Size textureSize = _disabledTextureSize;
|
||||
cocos2d::Size textureSize = _disabledTextureSize;
|
||||
if (textureSize.width <= 0.0f || textureSize.height <= 0.0f)
|
||||
{
|
||||
_buttonDisableRenderer->setScale(1.0f);
|
||||
|
@ -575,13 +575,13 @@ const char* UIButton::getTitleText() const
|
|||
return _titleRenderer->getString();
|
||||
}
|
||||
|
||||
void UIButton::setTitleColor(const Color3B& color)
|
||||
void UIButton::setTitleColor(const cocos2d::Color3B& color)
|
||||
{
|
||||
_titleColor = color;
|
||||
_titleRenderer->setColor(color);
|
||||
}
|
||||
|
||||
const Color3B& UIButton::getTitleColor() const
|
||||
const cocos2d::Color3B& UIButton::getTitleColor() const
|
||||
{
|
||||
return _titleRenderer->getColor();
|
||||
}
|
||||
|
@ -606,7 +606,7 @@ const char* UIButton::getTitleFontName() const
|
|||
return _titleRenderer->getFontName().c_str();
|
||||
}
|
||||
|
||||
void UIButton::setColor(const Color3B &color)
|
||||
void UIButton::setColor(const cocos2d::Color3B &color)
|
||||
{
|
||||
UIWidget::setColor(color);
|
||||
setTitleColor(_titleColor);
|
||||
|
@ -617,4 +617,30 @@ const char* UIButton::getDescription() const
|
|||
return "Button";
|
||||
}
|
||||
|
||||
UIWidget* UIButton::createCloneInstance()
|
||||
{
|
||||
return UIButton::create();
|
||||
}
|
||||
|
||||
void UIButton::copySpecialProperties(UIWidget *widget)
|
||||
{
|
||||
UIButton* button = dynamic_cast<UIButton*>(widget);
|
||||
if (button)
|
||||
{
|
||||
_prevIgnoreSize = button->_prevIgnoreSize;
|
||||
setScale9Enabled(button->_scale9Enabled);
|
||||
loadTextureNormal(button->_normalFileName.c_str(), button->_normalTexType);
|
||||
loadTexturePressed(button->_clickedFileName.c_str(), button->_pressedTexType);
|
||||
loadTextureDisabled(button->_disabledFileName.c_str(), button->_disabledTexType);
|
||||
setCapInsetsNormalRenderer(button->_capInsetsNormal);
|
||||
setCapInsetsPressedRenderer(button->_capInsetsPressed);
|
||||
setCapInsetsDisabledRenderer(button->_capInsetsDisabled);
|
||||
setTitleText(button->getTitleText());
|
||||
setTitleFontName(button->getTitleFontName());
|
||||
setTitleFontSize(button->getTitleFontSize());
|
||||
setTitleColor(button->getTitleColor());
|
||||
setPressedActionEnabled(button->_pressedActionEnabled);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
|
@ -27,8 +27,12 @@
|
|||
|
||||
#include "gui/UIWidget.h"
|
||||
|
||||
namespace gui {
|
||||
namespace gui{
|
||||
|
||||
/**
|
||||
* @js NA
|
||||
* @lua NA
|
||||
*/
|
||||
class UIButton : public UIWidget
|
||||
{
|
||||
public:
|
||||
|
@ -162,6 +166,11 @@ public:
|
|||
*/
|
||||
virtual void setColor(const cocos2d::Color3B &color);
|
||||
|
||||
/**
|
||||
* Returns the "class name" of widget.
|
||||
*/
|
||||
virtual const char* getDescription() const;
|
||||
|
||||
void setTitleText(const char* text);
|
||||
const char* getTitleText() const;
|
||||
void setTitleColor(const cocos2d::Color3B& color);
|
||||
|
@ -170,11 +179,7 @@ public:
|
|||
float getTitleFontSize() const;
|
||||
void setTitleFontName(const char* fontName);
|
||||
const char* getTitleFontName() const;
|
||||
|
||||
/**
|
||||
* Returns the "class name" of widget.
|
||||
*/
|
||||
virtual const char* getDescription() const;
|
||||
|
||||
protected:
|
||||
virtual bool init();
|
||||
virtual void initRenderer();
|
||||
|
@ -186,6 +191,8 @@ protected:
|
|||
void normalTextureScaleChangedWithSize();
|
||||
void pressedTextureScaleChangedWithSize();
|
||||
void disabledTextureScaleChangedWithSize();
|
||||
virtual UIWidget* createCloneInstance();
|
||||
virtual void copySpecialProperties(UIWidget* model);
|
||||
protected:
|
||||
cocos2d::Node* _buttonNormalRenderer;
|
||||
cocos2d::Node* _buttonClickedRenderer;
|
||||
|
|
|
@ -24,10 +24,9 @@
|
|||
|
||||
#include "gui/UICheckBox.h"
|
||||
|
||||
using namespace cocos2d;
|
||||
|
||||
namespace gui {
|
||||
|
||||
|
||||
UICheckBox::UICheckBox():
|
||||
_backGroundBoxRenderer(NULL),
|
||||
_backGroundSelectedBoxRenderer(NULL),
|
||||
|
@ -41,7 +40,12 @@ _backGroundTexType(UI_TEX_TYPE_LOCAL),
|
|||
_backGroundSelectedTexType(UI_TEX_TYPE_LOCAL),
|
||||
_frontCrossTexType(UI_TEX_TYPE_LOCAL),
|
||||
_backGroundDisabledTexType(UI_TEX_TYPE_LOCAL),
|
||||
_frontCrossDisabledTexType(UI_TEX_TYPE_LOCAL)
|
||||
_frontCrossDisabledTexType(UI_TEX_TYPE_LOCAL),
|
||||
_backGroundFileName(""),
|
||||
_backGroundSelectedFileName(""),
|
||||
_frontCrossFileName(""),
|
||||
_backGroundDisabledFileName(""),
|
||||
_frontCrossDisabledFileName("")
|
||||
{
|
||||
}
|
||||
|
||||
|
@ -75,11 +79,11 @@ bool UICheckBox::init()
|
|||
void UICheckBox::initRenderer()
|
||||
{
|
||||
UIWidget::initRenderer();
|
||||
_backGroundBoxRenderer = Sprite::create();
|
||||
_backGroundSelectedBoxRenderer = Sprite::create();
|
||||
_frontCrossRenderer = Sprite::create();
|
||||
_backGroundBoxDisabledRenderer = Sprite::create();
|
||||
_frontCrossDisabledRenderer = Sprite::create();
|
||||
_backGroundBoxRenderer = cocos2d::Sprite::create();
|
||||
_backGroundSelectedBoxRenderer = cocos2d::Sprite::create();
|
||||
_frontCrossRenderer = cocos2d::Sprite::create();
|
||||
_backGroundBoxDisabledRenderer = cocos2d::Sprite::create();
|
||||
_frontCrossDisabledRenderer = cocos2d::Sprite::create();
|
||||
_renderer->addChild(_backGroundBoxRenderer);
|
||||
_renderer->addChild(_backGroundSelectedBoxRenderer);
|
||||
_renderer->addChild(_frontCrossRenderer);
|
||||
|
@ -102,6 +106,7 @@ void UICheckBox::loadTextureBackGround(const char *backGround,TextureResType tex
|
|||
{
|
||||
return;
|
||||
}
|
||||
_backGroundFileName = backGround;
|
||||
_backGroundTexType = texType;
|
||||
switch (_backGroundTexType)
|
||||
{
|
||||
|
@ -125,6 +130,7 @@ void UICheckBox::loadTextureBackGroundSelected(const char *backGroundSelected,Te
|
|||
{
|
||||
return;
|
||||
}
|
||||
_backGroundSelectedFileName = backGroundSelected;
|
||||
_backGroundSelectedTexType = texType;
|
||||
switch (_backGroundSelectedTexType)
|
||||
{
|
||||
|
@ -148,6 +154,7 @@ void UICheckBox::loadTextureFrontCross(const char *cross,TextureResType texType)
|
|||
{
|
||||
return;
|
||||
}
|
||||
_frontCrossFileName = cross;
|
||||
_frontCrossTexType = texType;
|
||||
switch (_frontCrossTexType)
|
||||
{
|
||||
|
@ -171,6 +178,7 @@ void UICheckBox::loadTextureBackGroundDisabled(const char *backGroundDisabled,Te
|
|||
{
|
||||
return;
|
||||
}
|
||||
_backGroundDisabledFileName = backGroundDisabled;
|
||||
_backGroundDisabledTexType = texType;
|
||||
switch (_backGroundDisabledTexType)
|
||||
{
|
||||
|
@ -194,6 +202,7 @@ void UICheckBox::loadTextureFrontCrossDisabled(const char *frontCrossDisabled,Te
|
|||
{
|
||||
return;
|
||||
}
|
||||
_frontCrossDisabledFileName = frontCrossDisabled;
|
||||
_frontCrossDisabledTexType = texType;
|
||||
switch (_frontCrossDisabledTexType)
|
||||
{
|
||||
|
@ -211,7 +220,7 @@ void UICheckBox::loadTextureFrontCrossDisabled(const char *frontCrossDisabled,Te
|
|||
frontCrossDisabledTextureScaleChangedWithSize();
|
||||
}
|
||||
|
||||
void UICheckBox::onTouchEnded(const Point &touchPoint)
|
||||
void UICheckBox::onTouchEnded(const cocos2d::Point &touchPoint)
|
||||
{
|
||||
if (_focus)
|
||||
{
|
||||
|
@ -289,7 +298,7 @@ void UICheckBox::unSelectedEvent()
|
|||
}
|
||||
}
|
||||
|
||||
void UICheckBox::addEventListener(Object *target, SEL_SelectedStateEvent selector)
|
||||
void UICheckBox::addEventListener(cocos2d::Object *target, SEL_SelectedStateEvent selector)
|
||||
{
|
||||
_selectedStateEventListener = target;
|
||||
_selectedStateEventSelector = selector;
|
||||
|
@ -323,7 +332,7 @@ bool UICheckBox::isFlipY()
|
|||
return _backGroundBoxRenderer->isFlippedY();
|
||||
}
|
||||
|
||||
void UICheckBox::setAnchorPoint(const Point &pt)
|
||||
void UICheckBox::setAnchorPoint(const cocos2d::Point &pt)
|
||||
{
|
||||
UIWidget::setAnchorPoint(pt);
|
||||
_backGroundBoxRenderer->setAnchorPoint(pt);
|
||||
|
@ -342,12 +351,12 @@ void UICheckBox::onSizeChanged()
|
|||
frontCrossDisabledTextureScaleChangedWithSize();
|
||||
}
|
||||
|
||||
const Size& UICheckBox::getContentSize() const
|
||||
const cocos2d::Size& UICheckBox::getContentSize() const
|
||||
{
|
||||
return _backGroundBoxRenderer->getContentSize();
|
||||
}
|
||||
|
||||
Node* UICheckBox::getVirtualRenderer()
|
||||
cocos2d::Node* UICheckBox::getVirtualRenderer()
|
||||
{
|
||||
return _backGroundBoxRenderer;
|
||||
}
|
||||
|
@ -361,7 +370,7 @@ void UICheckBox::backGroundTextureScaleChangedWithSize()
|
|||
}
|
||||
else
|
||||
{
|
||||
Size textureSize = _backGroundBoxRenderer->getContentSize();
|
||||
cocos2d::Size textureSize = _backGroundBoxRenderer->getContentSize();
|
||||
if (textureSize.width <= 0.0f || textureSize.height <= 0.0f)
|
||||
{
|
||||
_backGroundBoxRenderer->setScale(1.0f);
|
||||
|
@ -382,7 +391,7 @@ void UICheckBox::backGroundSelectedTextureScaleChangedWithSize()
|
|||
}
|
||||
else
|
||||
{
|
||||
Size textureSize = _backGroundSelectedBoxRenderer->getContentSize();
|
||||
cocos2d::Size textureSize = _backGroundSelectedBoxRenderer->getContentSize();
|
||||
if (textureSize.width <= 0.0f || textureSize.height <= 0.0f)
|
||||
{
|
||||
_backGroundSelectedBoxRenderer->setScale(1.0f);
|
||||
|
@ -403,7 +412,7 @@ void UICheckBox::frontCrossTextureScaleChangedWithSize()
|
|||
}
|
||||
else
|
||||
{
|
||||
Size textureSize = _frontCrossRenderer->getContentSize();
|
||||
cocos2d::Size textureSize = _frontCrossRenderer->getContentSize();
|
||||
if (textureSize.width <= 0.0f || textureSize.height <= 0.0f)
|
||||
{
|
||||
_frontCrossRenderer->setScale(1.0f);
|
||||
|
@ -424,7 +433,7 @@ void UICheckBox::backGroundDisabledTextureScaleChangedWithSize()
|
|||
}
|
||||
else
|
||||
{
|
||||
Size textureSize = _backGroundBoxDisabledRenderer->getContentSize();
|
||||
cocos2d::Size textureSize = _backGroundBoxDisabledRenderer->getContentSize();
|
||||
if (textureSize.width <= 0.0f || textureSize.height <= 0.0f)
|
||||
{
|
||||
_backGroundBoxDisabledRenderer->setScale(1.0f);
|
||||
|
@ -445,7 +454,7 @@ void UICheckBox::frontCrossDisabledTextureScaleChangedWithSize()
|
|||
}
|
||||
else
|
||||
{
|
||||
Size textureSize = _frontCrossDisabledRenderer->getContentSize();
|
||||
cocos2d::Size textureSize = _frontCrossDisabledRenderer->getContentSize();
|
||||
if (textureSize.width <= 0.0f || textureSize.height <= 0.0f)
|
||||
{
|
||||
_frontCrossDisabledRenderer->setScale(1.0f);
|
||||
|
@ -463,4 +472,23 @@ const char* UICheckBox::getDescription() const
|
|||
return "CheckBox";
|
||||
}
|
||||
|
||||
UIWidget* UICheckBox::createCloneInstance()
|
||||
{
|
||||
return UICheckBox::create();
|
||||
}
|
||||
|
||||
void UICheckBox::copySpecialProperties(UIWidget *widget)
|
||||
{
|
||||
UICheckBox* checkBox = dynamic_cast<UICheckBox*>(widget);
|
||||
if (checkBox)
|
||||
{
|
||||
loadTextureBackGround(checkBox->_backGroundFileName.c_str(), checkBox->_backGroundTexType);
|
||||
loadTextureBackGroundSelected(checkBox->_backGroundSelectedFileName.c_str(), checkBox->_backGroundSelectedTexType);
|
||||
loadTextureFrontCross(checkBox->_frontCrossFileName.c_str(), checkBox->_frontCrossTexType);
|
||||
loadTextureBackGroundDisabled(checkBox->_backGroundDisabledFileName.c_str(), checkBox->_backGroundDisabledTexType);
|
||||
loadTextureFrontCrossDisabled(checkBox->_frontCrossDisabledFileName.c_str(), checkBox->_frontCrossDisabledTexType);
|
||||
setSelectedState(checkBox->_isSelected);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
|
@ -35,9 +35,13 @@ typedef enum
|
|||
CHECKBOX_STATE_EVENT_UNSELECTED
|
||||
}CheckBoxEventType;
|
||||
|
||||
typedef void (cocos2d::CCObject::*SEL_SelectedStateEvent)(cocos2d::Object*,CheckBoxEventType);
|
||||
typedef void (cocos2d::Object::*SEL_SelectedStateEvent)(cocos2d::Object*,CheckBoxEventType);
|
||||
#define checkboxselectedeventselector(_SELECTOR) (SEL_SelectedStateEvent)(&_SELECTOR)
|
||||
|
||||
/**
|
||||
* @js NA
|
||||
* @lua NA
|
||||
*/
|
||||
class UICheckBox : public UIWidget
|
||||
{
|
||||
public:
|
||||
|
@ -156,11 +160,12 @@ public:
|
|||
|
||||
//override "getVirtualRenderer" method of widget.
|
||||
virtual cocos2d::Node* getVirtualRenderer();
|
||||
|
||||
|
||||
/**
|
||||
* Returns the "class name" of widget.
|
||||
*/
|
||||
virtual const char* getDescription() const;
|
||||
|
||||
protected:
|
||||
virtual bool init();
|
||||
virtual void initRenderer();
|
||||
|
@ -175,6 +180,8 @@ protected:
|
|||
void frontCrossTextureScaleChangedWithSize();
|
||||
void backGroundDisabledTextureScaleChangedWithSize();
|
||||
void frontCrossDisabledTextureScaleChangedWithSize();
|
||||
virtual UIWidget* createCloneInstance();
|
||||
virtual void copySpecialProperties(UIWidget* model);
|
||||
protected:
|
||||
cocos2d::Sprite* _backGroundBoxRenderer;
|
||||
cocos2d::Sprite* _backGroundSelectedBoxRenderer;
|
||||
|
@ -191,6 +198,12 @@ protected:
|
|||
TextureResType _frontCrossTexType;
|
||||
TextureResType _backGroundDisabledTexType;
|
||||
TextureResType _frontCrossDisabledTexType;
|
||||
|
||||
std::string _backGroundFileName;
|
||||
std::string _backGroundSelectedFileName;
|
||||
std::string _frontCrossFileName;
|
||||
std::string _backGroundDisabledFileName;
|
||||
std::string _frontCrossDisabledFileName;
|
||||
};
|
||||
|
||||
}
|
||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -1,367 +0,0 @@
|
|||
/****************************************************************************
|
||||
Copyright (c) 2013 cocos2d-x.org
|
||||
|
||||
http://www.cocos2d-x.org
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
of this software and associated documentation files (the "Software"), to deal
|
||||
in the Software without restriction, including without limitation the rights
|
||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
copies of the Software, and to permit persons to whom the Software is
|
||||
furnished to do so, subject to the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be included in
|
||||
all copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||
THE SOFTWARE.
|
||||
****************************************************************************/
|
||||
|
||||
#ifndef __UIDRAGPANEL_H__
|
||||
#define __UIDRAGPANEL_H__
|
||||
|
||||
#include "gui/Layout.h"
|
||||
#include "gui/UIScrollInterface.h"
|
||||
|
||||
namespace gui {
|
||||
|
||||
/**
|
||||
* drag panel move type
|
||||
*/
|
||||
enum DRAGPANEL_MOVE_TYPE
|
||||
{
|
||||
DRAGPANEL_MOVE_TYPE_NONE,
|
||||
DRAGPANEL_MOVE_TYPE_AUTOMOVE,
|
||||
DRAGPANEL_MOVE_TYPE_BOUNCE,
|
||||
};
|
||||
|
||||
/**
|
||||
* dragpanel berth direction
|
||||
*/
|
||||
enum DRAGPANEL_BERTH_DIR
|
||||
{
|
||||
DRAGPANEL_BERTH_DIR_NONE,
|
||||
DRAGPANEL_BERTH_DIR_LEFTBOTTOM,
|
||||
DRAGPANEL_BERTH_DIR_LFETTOP,
|
||||
DRAGPANEL_BERTH_DIR_RIGHTBOTTOM,
|
||||
DRAGPANEL_BERTH_DIR_RIGHTTOP,
|
||||
DRAGPANEL_BERTH_DIR_LEFT,
|
||||
DRAGPANEL_BERTH_DIR_TOP,
|
||||
DRAGPANEL_BERTH_DIR_RIGHT,
|
||||
DRAGPANEL_BERTH_DIR_BOTTOM,
|
||||
};
|
||||
|
||||
/**
|
||||
* dragpanel bounce direction
|
||||
*/
|
||||
enum DRAGPANEL_BOUNCE_DIR
|
||||
{
|
||||
DRAGPANEL_BOUNCE_DIR_NONE,
|
||||
DRAGPANEL_BOUNCE_DIR_LEFTBOTTOM,
|
||||
DRAGPANEL_BOUNCE_DIR_LEFTTOP,
|
||||
DRAGPANEL_BOUNCE_DIR_RIGHTBOTTOM,
|
||||
DRAGPANEL_BOUNCE_DIR_RIGHTTOP,
|
||||
DRAGPANEL_BOUNCE_DIR_LEFT,
|
||||
DRAGPANEL_BOUNCE_DIR_TOP,
|
||||
DRAGPANEL_BOUNCE_DIR_RIGHT,
|
||||
DRAGPANEL_BOUNCE_DIR_BOTTOM,
|
||||
};
|
||||
|
||||
typedef enum
|
||||
{
|
||||
DRAGPANEL_EVENT_BERTH_LEFTBOTTOM,
|
||||
DRAGPANEL_EVENT_BERTH_LFETTOP,
|
||||
DRAGPANEL_EVENT_BERTH_RIGHTBOTTOM,
|
||||
DRAGPANEL_EVENT_BERTH_RIGHTTOP,
|
||||
DRAGPANEL_EVENT_BERTH_LEFT,
|
||||
DRAGPANEL_EVENT_BERTH_TOP,
|
||||
DRAGPANEL_EVENT_BERTH_RIGHT,
|
||||
DRAGPANEL_EVENT_BERTH_BOTTOM,
|
||||
DRAGPANEL_EVENT_BOUNCE_LEFTBOTTOM,
|
||||
DRAGPANEL_EVENT_BOUNCE_LEFTTOP,
|
||||
DRAGPANEL_EVENT_BOUNCE_RIGHTBOTTOM,
|
||||
DRAGPANEL_EVENT_BOUNCE_RIGHTTOP,
|
||||
DRAGPANEL_EVENT_BOUNCE_LEFT,
|
||||
DRAGPANEL_EVENT_BOUNCE_TOP,
|
||||
DRAGPANEL_EVENT_BOUNCE_RIGHT,
|
||||
DRAGPANEL_EVENT_BOUNCE_BOTTOM,
|
||||
}DragPanelEventType;
|
||||
|
||||
/**
|
||||
* dragpanel event
|
||||
*/
|
||||
typedef void (cocos2d::Object::*SEL_DragPanelEvent)(cocos2d::Object*, DragPanelEventType);
|
||||
#define dragpaneleventselector(_SELECTOR)(SEL_DragPanelEvent)(&_SELECTOR)
|
||||
|
||||
class UIDragPanel : public Layout, public UIScrollInterface
|
||||
{
|
||||
public:
|
||||
UIDragPanel();
|
||||
virtual ~UIDragPanel();
|
||||
|
||||
static UIDragPanel* create();
|
||||
|
||||
virtual bool onTouchBegan(const cocos2d::Point &touchPoint);
|
||||
virtual void onTouchMoved(const cocos2d::Point &touchPoint);
|
||||
virtual void onTouchEnded(const cocos2d::Point &touchPoint);
|
||||
virtual void onTouchCancelled(const cocos2d::Point &touchPoint);
|
||||
virtual void onTouchLongClicked(const cocos2d::Point &touchPoint);
|
||||
|
||||
virtual void update(float dt);
|
||||
|
||||
/**
|
||||
* add widget child override
|
||||
*/
|
||||
virtual bool addChild(UIWidget* widget);
|
||||
/**
|
||||
* remove widget child override
|
||||
*/
|
||||
virtual bool removeChild(UIWidget* child);
|
||||
/**
|
||||
* remove all widget children override
|
||||
*/
|
||||
virtual void removeAllChildren();
|
||||
/**
|
||||
* get widget children of inner container
|
||||
*/
|
||||
virtual cocos2d::Array* getChildren();
|
||||
/* gui mark */
|
||||
/**
|
||||
* get and set inner container size
|
||||
*/
|
||||
const cocos2d::Size& getInnerContainerSize() const;
|
||||
void setInnerContainerSize(const cocos2d::Size &size);
|
||||
/**
|
||||
* get and set inner container position
|
||||
*/
|
||||
const cocos2d::Point& getInnerContainerPosition() const;
|
||||
void setInnerContainerPosition(const cocos2d::Point& point, bool animated);
|
||||
/**
|
||||
* set inner container offset
|
||||
*/
|
||||
void setInnerContainerOffset(const cocos2d::Point& offset, bool animated);
|
||||
/**/
|
||||
|
||||
// auto move
|
||||
/**
|
||||
* set auto move duration
|
||||
*/
|
||||
void setAutoMoveDuration(float duration);
|
||||
/**
|
||||
* set auto move ease rate
|
||||
*/
|
||||
void setAutoMoveEaseRate(float rate);
|
||||
|
||||
// berth
|
||||
/**
|
||||
* get berth or not
|
||||
*/
|
||||
bool isBerth();
|
||||
|
||||
/**
|
||||
* event
|
||||
*/
|
||||
void addEventListener(cocos2d::Object* target, SEL_DragPanelEvent selector);
|
||||
|
||||
/**
|
||||
* get and set bounce enable
|
||||
*/
|
||||
bool isBounceEnable();
|
||||
void setBounceEnable(bool bounce);
|
||||
/**
|
||||
* set bounce duration
|
||||
*/
|
||||
void setBounceDuratoin(float duration);
|
||||
/**
|
||||
* set bounce ease rate
|
||||
*/
|
||||
void setBounceEaseRate(float rate);
|
||||
|
||||
/**
|
||||
* Gets inner container of dragpanel.
|
||||
*
|
||||
* Inner container is the container of dragpanel's children.
|
||||
*
|
||||
* @return inner container.
|
||||
*/
|
||||
Layout* getInnerContainer();
|
||||
|
||||
/**
|
||||
* Sets LayoutType.
|
||||
*
|
||||
* @see LayoutType
|
||||
*
|
||||
* @param LayoutType
|
||||
*/
|
||||
virtual void setLayoutType(LayoutType type);
|
||||
|
||||
/**
|
||||
* Gets LayoutType.
|
||||
*
|
||||
* @see LayoutType
|
||||
*
|
||||
* @return LayoutType
|
||||
*/
|
||||
virtual LayoutType getLayoutType() const;
|
||||
|
||||
virtual void doLayout();
|
||||
|
||||
/**
|
||||
* Returns the "class name" of widget.
|
||||
*/
|
||||
virtual const char* getDescription() const;
|
||||
|
||||
protected:
|
||||
virtual bool init();
|
||||
virtual void initRenderer();
|
||||
virtual void releaseResoures();
|
||||
|
||||
virtual void handlePressLogic(const cocos2d::Point &touchPoint);
|
||||
virtual void handleMoveLogic(const cocos2d::Point &touchPoint);
|
||||
virtual void handleReleaseLogic(const cocos2d::Point &touchPoint);
|
||||
virtual void interceptTouchEvent(int handleState,UIWidget* sender, const cocos2d::Point &touchPoint);
|
||||
/* gui mark */
|
||||
// virtual bool isInScrollDegreeRange(UIWidget* widget);
|
||||
/**/
|
||||
virtual void checkChildInfo(int handleState, UIWidget *sender, const cocos2d::Point &touchPoint);
|
||||
// void updateWidthAndHeight();
|
||||
void recordSlidTime(float dt);
|
||||
|
||||
/* gui mark */
|
||||
void setInnerContainerOffset(const cocos2d::Point& offset);
|
||||
/**/
|
||||
|
||||
// check if dragpanel rect contain inner rect
|
||||
bool checkContainInnerRect();
|
||||
|
||||
// move
|
||||
void moveWithDelta(const cocos2d::Point& delta);
|
||||
|
||||
// auto move
|
||||
void autoMove();
|
||||
void autoMoveOver();
|
||||
void startAutoMove();
|
||||
void stopAutoMove();
|
||||
|
||||
// berth
|
||||
// check if move to boundary with update
|
||||
bool checkToBoundaryWithDeltaPosition(const cocos2d::Point& delta);
|
||||
|
||||
// calculate to boundary delta
|
||||
cocos2d::Point calculateToBoundaryDeltaPosition(const cocos2d::Point& paramDelta);
|
||||
|
||||
// check berth
|
||||
bool checkBerth();
|
||||
|
||||
// berth event
|
||||
void berthEvent();
|
||||
void berthToLeftEvent();
|
||||
void berthToRightEvent();
|
||||
void berthToTopEvent();
|
||||
void berthToBottomEvent();
|
||||
void berthToLeftBottomEvent();
|
||||
void berthToLeftTopEvent();
|
||||
void berthToRightBottomEvent();
|
||||
void berthToRightTopEvent();
|
||||
|
||||
// bounce
|
||||
bool checkNeedBounce();
|
||||
void startBounce();
|
||||
void stopBounce();
|
||||
void bounceToCorner();
|
||||
void bounceOver();
|
||||
// bounce event
|
||||
void bounceToLeftBottomEvent();
|
||||
void bounceToRightBottomEvent();
|
||||
void bounceToLeftTopEvent();
|
||||
void bounceToRightTopEvent();
|
||||
void bounceToLeftEvent();
|
||||
void bounceToTopEvent();
|
||||
void bounceToRightEvent();
|
||||
void bounceToBottomEvent();
|
||||
|
||||
void actionWithDuration(float duration);
|
||||
bool actionIsDone();
|
||||
void actionStartWithWidget(UIWidget* widget);
|
||||
void actionStep(float dt);
|
||||
void actionUpdate(float dt);
|
||||
void actionStop();
|
||||
void actionDone();
|
||||
void moveByWithDuration(float duration, const cocos2d::Point& deltaPosition);
|
||||
void moveByInit();
|
||||
void moveByUpdate(float t);
|
||||
void moveToWithDuration(float duration, const cocos2d::Point& position);
|
||||
void moveToInit();
|
||||
void moveToUpdate(float t);
|
||||
virtual void onSizeChanged();
|
||||
/*compatible*/
|
||||
/**
|
||||
* These methods will be removed
|
||||
*/
|
||||
virtual void setClippingEnable(bool is){setClippingEnabled(is);};
|
||||
/************/
|
||||
virtual void setClippingEnabled(bool able){Layout::setClippingEnabled(able);};
|
||||
protected:
|
||||
Layout* _innerContainer;
|
||||
|
||||
/*
|
||||
DRAGPANEL_DIR m_eDirection;
|
||||
DRAGPANEL_MOVE_DIR m_eMoveDirection;
|
||||
*/
|
||||
|
||||
bool _touchPressed;
|
||||
bool _touchMoved;
|
||||
bool _touchReleased;
|
||||
bool _touchCanceld; // check touch out of drag panel boundary
|
||||
|
||||
cocos2d::Point _touchStartNodeSpace;
|
||||
cocos2d::Point _touchStartWorldSpace;
|
||||
cocos2d::Point _touchEndWorldSpace;
|
||||
|
||||
float _slidTime;
|
||||
|
||||
// move type
|
||||
DRAGPANEL_MOVE_TYPE _moveType;
|
||||
|
||||
// auto move
|
||||
float _autoMoveDuration;
|
||||
float _autoMoveEaseRate;
|
||||
|
||||
// event
|
||||
cocos2d::Object* _eventLister;
|
||||
SEL_DragPanelEvent _eventSelector;
|
||||
|
||||
// berth
|
||||
DRAGPANEL_BERTH_DIR _berthDirection;
|
||||
|
||||
// bounce
|
||||
bool _bounceEnable;
|
||||
DRAGPANEL_BOUNCE_DIR _bounceDirection;
|
||||
float _bounceDuration;
|
||||
float _bounceEaseRate;
|
||||
|
||||
|
||||
float _runningAction;
|
||||
int _actionType;
|
||||
|
||||
UIWidget* _actionWidget;
|
||||
|
||||
float _duration;
|
||||
float _elapsed;
|
||||
bool _firstTick;
|
||||
|
||||
cocos2d::Point _positionDelta;
|
||||
cocos2d::Point _startPosition;
|
||||
cocos2d::Point _previousPosition;
|
||||
|
||||
cocos2d::Point _endPosition;
|
||||
};
|
||||
|
||||
}
|
||||
|
||||
#endif /* defined(__TestCpp__UIDragPanel__) */
|
|
@ -22,111 +22,9 @@
|
|||
THE SOFTWARE.
|
||||
****************************************************************************/
|
||||
|
||||
#include "gui/UIHelper.h"
|
||||
#include "cocos2d.h"
|
||||
#include "cocostudio/DictionaryHelper.h"
|
||||
#include "cocostudio/CCSGUIReader.h"
|
||||
|
||||
|
||||
using namespace cocos2d;
|
||||
using namespace cocostudio;
|
||||
#include "CocosGUI.h"
|
||||
|
||||
namespace gui {
|
||||
|
||||
static UIHelper* helperInstance = NULL;
|
||||
|
||||
UIHelper* UIHelper::instance()
|
||||
{
|
||||
if (!helperInstance)
|
||||
{
|
||||
helperInstance = new UIHelper();
|
||||
}
|
||||
return helperInstance;
|
||||
}
|
||||
|
||||
void UIHelper::purgeUIHelper()
|
||||
{
|
||||
CC_SAFE_DELETE(helperInstance);
|
||||
}
|
||||
|
||||
UIHelper::UIHelper():
|
||||
_textureFiles(NULL),
|
||||
_fileDesignHeight(0.0f),
|
||||
_fileDesignWidth(0.0f)
|
||||
{
|
||||
Size winSize = Director::getInstance()->getWinSize();
|
||||
_fileDesignWidth = winSize.width;
|
||||
_fileDesignHeight = winSize.height;
|
||||
init();
|
||||
}
|
||||
|
||||
UIHelper::~UIHelper()
|
||||
{
|
||||
cocostudio::CCSGUIReader::purgeCCSGUIReader();
|
||||
}
|
||||
|
||||
void UIHelper::init()
|
||||
{
|
||||
_textureFiles = CCArray::create();
|
||||
_textureFiles->retain();
|
||||
}
|
||||
|
||||
UIWidget* UIHelper::createWidgetFromJsonFile(const char *fileName)
|
||||
{
|
||||
return CCSGUIReader::shareReader()->widgetFromJsonFile(fileName);
|
||||
}
|
||||
|
||||
void UIHelper::addSpriteFrame(const char *fileName)
|
||||
{
|
||||
if (!fileName || strcmp(fileName, "") == 0)
|
||||
{
|
||||
return;
|
||||
}
|
||||
ccArray* arrayTextures = _textureFiles->data;
|
||||
int length = arrayTextures->num;
|
||||
for (int i=0;i<length;i++)
|
||||
{
|
||||
String* file = (String*)(arrayTextures->arr[i]);
|
||||
if (strcmp(file->_string.c_str(), fileName) == 0)
|
||||
{
|
||||
return;
|
||||
}
|
||||
}
|
||||
_textureFiles->addObject(CCString::create(fileName));
|
||||
SpriteFrameCache::getInstance()->addSpriteFramesWithFile(fileName);
|
||||
}
|
||||
|
||||
void UIHelper::removeSpriteFrame(const char *fileName)
|
||||
{
|
||||
if (!fileName || strcmp(fileName, "") == 0)
|
||||
{
|
||||
return;
|
||||
}
|
||||
ccArray* arrayTextures = _textureFiles->data;
|
||||
int length = arrayTextures->num;
|
||||
for (int i=0;i<length;i++)
|
||||
{
|
||||
String* file = (String*)(arrayTextures->arr[i]);
|
||||
if (strcmp(file->_string.c_str(), fileName) == 0)
|
||||
{
|
||||
SpriteFrameCache::getInstance()->removeSpriteFrameByName(fileName);
|
||||
_textureFiles->removeObject(file);
|
||||
return;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void UIHelper::removeAllSpriteFrame()
|
||||
{
|
||||
ccArray* arrayTextures = _textureFiles->data;
|
||||
int length = arrayTextures->num;
|
||||
for (int i=0;i<length;i++)
|
||||
{
|
||||
String* file = (String*)(arrayTextures->arr[i]);
|
||||
SpriteFrameCache::getInstance()->removeSpriteFrameByName(file->_string.c_str());
|
||||
}
|
||||
_textureFiles->removeAllObjects();
|
||||
}
|
||||
|
||||
UIWidget* UIHelper::seekWidgetByTag(UIWidget* root, int tag)
|
||||
{
|
||||
|
@ -138,7 +36,7 @@ UIWidget* UIHelper::seekWidgetByTag(UIWidget* root, int tag)
|
|||
{
|
||||
return root;
|
||||
}
|
||||
ccArray* arrayRootChildren = root->getChildren()->data;
|
||||
cocos2d::ccArray* arrayRootChildren = root->getChildren()->data;
|
||||
int length = arrayRootChildren->num;
|
||||
for (int i=0;i<length;i++)
|
||||
{
|
||||
|
@ -162,7 +60,7 @@ UIWidget* UIHelper::seekWidgetByName(UIWidget* root, const char *name)
|
|||
{
|
||||
return root;
|
||||
}
|
||||
ccArray* arrayRootChildren = root->getChildren()->data;
|
||||
cocos2d::ccArray* arrayRootChildren = root->getChildren()->data;
|
||||
int length = arrayRootChildren->num;
|
||||
for (int i=0;i<length;i++)
|
||||
{
|
||||
|
@ -182,12 +80,12 @@ UIWidget* UIHelper::seekWidgetByRelativeName(UIWidget *root, const char *name)
|
|||
{
|
||||
return NULL;
|
||||
}
|
||||
ccArray* arrayRootChildren = root->getChildren()->data;
|
||||
cocos2d::ccArray* arrayRootChildren = root->getChildren()->data;
|
||||
int length = arrayRootChildren->num;
|
||||
for (int i=0;i<length;i++)
|
||||
{
|
||||
UIWidget* child = (UIWidget*)(arrayRootChildren->arr[i]);
|
||||
RelativeLayoutParameter* layoutParameter = dynamic_cast<RelativeLayoutParameter*>(child->getLayoutParameter());
|
||||
UIRelativeLayoutParameter* layoutParameter = dynamic_cast<UIRelativeLayoutParameter*>(child->getLayoutParameter(LAYOUT_PARAMETER_RELATIVE));
|
||||
if (layoutParameter && strcmp(layoutParameter->getRelativeName(), name) == 0)
|
||||
{
|
||||
return child;
|
||||
|
@ -196,26 +94,6 @@ UIWidget* UIHelper::seekWidgetByRelativeName(UIWidget *root, const char *name)
|
|||
return NULL;
|
||||
}
|
||||
|
||||
void UIHelper::setFileDesignWidth(float width)
|
||||
{
|
||||
_fileDesignWidth = width;
|
||||
}
|
||||
|
||||
float UIHelper::getFileDesignWidth()
|
||||
{
|
||||
return _fileDesignWidth;
|
||||
}
|
||||
|
||||
void UIHelper::setFileDesignHeight(float height)
|
||||
{
|
||||
_fileDesignHeight = height;
|
||||
}
|
||||
|
||||
float UIHelper::getFileDesignHeight()
|
||||
{
|
||||
return _fileDesignHeight;
|
||||
}
|
||||
|
||||
/*temp action*/
|
||||
UIWidget* UIHelper::seekActionWidgetByActionTag(UIWidget* root, int tag)
|
||||
{
|
||||
|
@ -227,7 +105,7 @@ UIWidget* UIHelper::seekActionWidgetByActionTag(UIWidget* root, int tag)
|
|||
{
|
||||
return root;
|
||||
}
|
||||
ccArray* arrayRootChildren = root->getChildren()->data;
|
||||
cocos2d::ccArray* arrayRootChildren = root->getChildren()->data;
|
||||
int length = arrayRootChildren->num;
|
||||
for (int i=0;i<length;i++)
|
||||
{
|
||||
|
|
|
@ -25,52 +25,15 @@
|
|||
#ifndef __UIHELPER_H__
|
||||
#define __UIHELPER_H__
|
||||
|
||||
#include "gui/UIInputManager.h"
|
||||
#include "cocostudio/CSContentJsonDictionary.h"
|
||||
|
||||
|
||||
#define CCUIHELPER gui::UIHelper::instance()
|
||||
|
||||
namespace gui {
|
||||
|
||||
/**
|
||||
* @js NA
|
||||
* @lua NA
|
||||
*/
|
||||
class UIHelper
|
||||
{
|
||||
public:
|
||||
/**
|
||||
* Default constructor
|
||||
*/
|
||||
UIHelper();
|
||||
|
||||
/**
|
||||
* Default destructor
|
||||
*/
|
||||
virtual ~UIHelper();
|
||||
|
||||
//initializes state of UIHelper.
|
||||
void init();
|
||||
|
||||
/**
|
||||
* Load a widget with json file.
|
||||
*
|
||||
* @return a widget created with json file.
|
||||
*/
|
||||
UIWidget* createWidgetFromJsonFile(const char* fileName);
|
||||
|
||||
//get instance
|
||||
static UIHelper* instance();
|
||||
|
||||
//release instance
|
||||
static void purgeUIHelper();
|
||||
|
||||
//add a plist file for loading widget's texture.
|
||||
void addSpriteFrame(const char* fileName);
|
||||
|
||||
//remove a plist file for loading widget's texture.
|
||||
void removeSpriteFrame(const char* fileName);
|
||||
|
||||
//remove all plist files for loading widget's texture.
|
||||
void removeAllSpriteFrame();
|
||||
|
||||
/**
|
||||
* Finds a widget whose tag equals to param tag from root widget.
|
||||
*
|
||||
|
@ -80,7 +43,7 @@ public:
|
|||
*
|
||||
* @return finded result.
|
||||
*/
|
||||
UIWidget* seekWidgetByTag(UIWidget* root, int tag);
|
||||
static UIWidget* seekWidgetByTag(UIWidget* root, int tag);
|
||||
|
||||
/**
|
||||
* Finds a widget whose name equals to param name from root widget.
|
||||
|
@ -91,7 +54,7 @@ public:
|
|||
*
|
||||
* @return finded result.
|
||||
*/
|
||||
UIWidget* seekWidgetByName(UIWidget* root, const char* name);
|
||||
static UIWidget* seekWidgetByName(UIWidget* root, const char* name);
|
||||
|
||||
/**
|
||||
* Finds a widget whose name equals to param name from root widget.
|
||||
|
@ -104,19 +67,10 @@ public:
|
|||
*
|
||||
* @return finded result.
|
||||
*/
|
||||
UIWidget* seekWidgetByRelativeName(UIWidget* root, const char* name);
|
||||
void setFileDesignWidth(float width);
|
||||
float getFileDesignWidth();
|
||||
void setFileDesignHeight(float height);
|
||||
float getFileDesignHeight();
|
||||
/*temp action*/
|
||||
UIWidget* seekActionWidgetByActionTag(UIWidget* root, int tag);
|
||||
protected:
|
||||
static UIWidget* seekWidgetByRelativeName(UIWidget* root, const char* name);
|
||||
|
||||
float _fileDesignWidth;
|
||||
float _fileDesignHeight;
|
||||
//texture
|
||||
cocos2d::Array* _textureFiles;
|
||||
/*temp action*/
|
||||
static UIWidget* seekActionWidgetByActionTag(UIWidget* root, int tag);
|
||||
};
|
||||
|
||||
}
|
||||
|
|
|
@ -25,11 +25,9 @@
|
|||
#include "gui/UIImageView.h"
|
||||
#include "extensions/GUI/CCControlExtension/CCScale9Sprite.h"
|
||||
|
||||
using namespace cocos2d;
|
||||
using namespace cocos2d::extension;
|
||||
|
||||
namespace gui {
|
||||
|
||||
|
||||
#define DYNAMIC_CAST_CCSPRITE dynamic_cast<cocos2d::Sprite*>(_imageRenderer)
|
||||
#define DYNAMIC_CAST_SCALE9SPRITE dynamic_cast<cocos2d::extension::Scale9Sprite*>(_imageRenderer)
|
||||
|
||||
|
@ -41,7 +39,7 @@ _touchRelease(false),
|
|||
_doubleClickEnabled(false),
|
||||
_scale9Enabled(false),
|
||||
_prevIgnoreSize(true),
|
||||
_capInsets(Rect::ZERO),
|
||||
_capInsets(cocos2d::Rect::ZERO),
|
||||
_imageRenderer(NULL),
|
||||
_textureFile(""),
|
||||
_imageTexType(UI_TEX_TYPE_LOCAL),
|
||||
|
@ -70,7 +68,7 @@ UIImageView* UIImageView::create()
|
|||
void UIImageView::initRenderer()
|
||||
{
|
||||
UIWidget::initRenderer();
|
||||
_imageRenderer = Sprite::create();
|
||||
_imageRenderer = cocos2d::Sprite::create();
|
||||
_renderer->addChild(_imageRenderer);
|
||||
}
|
||||
|
||||
|
@ -90,6 +88,7 @@ void UIImageView::loadTexture(const char *fileName, TextureResType texType)
|
|||
DYNAMIC_CAST_SCALE9SPRITE->initWithFile(fileName);
|
||||
DYNAMIC_CAST_SCALE9SPRITE->setColor(getColor());
|
||||
DYNAMIC_CAST_SCALE9SPRITE->setOpacity(getOpacity());
|
||||
DYNAMIC_CAST_SCALE9SPRITE->setCapInsets(_capInsets);
|
||||
}
|
||||
else
|
||||
{
|
||||
|
@ -104,6 +103,7 @@ void UIImageView::loadTexture(const char *fileName, TextureResType texType)
|
|||
DYNAMIC_CAST_SCALE9SPRITE->initWithSpriteFrameName(fileName);
|
||||
DYNAMIC_CAST_SCALE9SPRITE->setColor(getColor());
|
||||
DYNAMIC_CAST_SCALE9SPRITE->setOpacity(getOpacity());
|
||||
DYNAMIC_CAST_SCALE9SPRITE->setCapInsets(_capInsets);
|
||||
}
|
||||
else
|
||||
{
|
||||
|
@ -120,7 +120,7 @@ void UIImageView::loadTexture(const char *fileName, TextureResType texType)
|
|||
imageTextureScaleChangedWithSize();
|
||||
}
|
||||
|
||||
void UIImageView::setTextureRect(const Rect &rect)
|
||||
void UIImageView::setTextureRect(const cocos2d::Rect &rect)
|
||||
{
|
||||
if (_scale9Enabled)
|
||||
{
|
||||
|
@ -131,7 +131,7 @@ void UIImageView::setTextureRect(const Rect &rect)
|
|||
}
|
||||
}
|
||||
|
||||
bool UIImageView::onTouchBegan(const Point &touchPoint)
|
||||
bool UIImageView::onTouchBegan(const cocos2d::Point &touchPoint)
|
||||
{
|
||||
setFocused(true);
|
||||
_touchStartPos.x = touchPoint.x;
|
||||
|
@ -149,7 +149,7 @@ bool UIImageView::onTouchBegan(const Point &touchPoint)
|
|||
return _touchPassedEnabled;
|
||||
}
|
||||
|
||||
void UIImageView::onTouchEnded(const Point &touchPoint)
|
||||
void UIImageView::onTouchEnded(const cocos2d::Point &touchPoint)
|
||||
{
|
||||
if (_doubleClickEnabled)
|
||||
{
|
||||
|
@ -278,11 +278,11 @@ void UIImageView::setScale9Enabled(bool able)
|
|||
_imageRenderer = NULL;
|
||||
if (_scale9Enabled)
|
||||
{
|
||||
_imageRenderer = extension::Scale9Sprite::create();
|
||||
_imageRenderer = cocos2d::extension::Scale9Sprite::create();
|
||||
}
|
||||
else
|
||||
{
|
||||
_imageRenderer = CCSprite::create();
|
||||
_imageRenderer = cocos2d::Sprite::create();
|
||||
}
|
||||
loadTexture(_textureFile.c_str(),_imageTexType);
|
||||
_renderer->addChild(_imageRenderer);
|
||||
|
@ -308,7 +308,7 @@ void UIImageView::ignoreContentAdaptWithSize(bool ignore)
|
|||
}
|
||||
}
|
||||
|
||||
void UIImageView::setCapInsets(const Rect &capInsets)
|
||||
void UIImageView::setCapInsets(const cocos2d::Rect &capInsets)
|
||||
{
|
||||
_capInsets = capInsets;
|
||||
if (!_scale9Enabled)
|
||||
|
@ -318,7 +318,7 @@ void UIImageView::setCapInsets(const Rect &capInsets)
|
|||
DYNAMIC_CAST_SCALE9SPRITE->setCapInsets(capInsets);
|
||||
}
|
||||
|
||||
void UIImageView::setAnchorPoint(const Point &pt)
|
||||
void UIImageView::setAnchorPoint(const cocos2d::Point &pt)
|
||||
{
|
||||
UIWidget::setAnchorPoint(pt);
|
||||
_imageRenderer->setAnchorPoint(pt);
|
||||
|
@ -329,12 +329,12 @@ void UIImageView::onSizeChanged()
|
|||
imageTextureScaleChangedWithSize();
|
||||
}
|
||||
|
||||
const Size& UIImageView::getContentSize() const
|
||||
const cocos2d::Size& UIImageView::getContentSize() const
|
||||
{
|
||||
return _imageTextureSize;
|
||||
}
|
||||
|
||||
Node* UIImageView::getVirtualRenderer()
|
||||
cocos2d::Node* UIImageView::getVirtualRenderer()
|
||||
{
|
||||
return _imageRenderer;
|
||||
}
|
||||
|
@ -353,11 +353,11 @@ void UIImageView::imageTextureScaleChangedWithSize()
|
|||
{
|
||||
if (_scale9Enabled)
|
||||
{
|
||||
dynamic_cast<Scale9Sprite*>(_imageRenderer)->setPreferredSize(_size);
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_imageRenderer)->setPreferredSize(_size);
|
||||
}
|
||||
else
|
||||
{
|
||||
Size textureSize = _imageRenderer->getContentSize();
|
||||
cocos2d::Size textureSize = _imageRenderer->getContentSize();
|
||||
if (textureSize.width <= 0.0f || textureSize.height <= 0.0f)
|
||||
{
|
||||
_imageRenderer->setScale(1.0f);
|
||||
|
@ -376,4 +376,21 @@ const char* UIImageView::getDescription() const
|
|||
return "ImageView";
|
||||
}
|
||||
|
||||
UIWidget* UIImageView::createCloneInstance()
|
||||
{
|
||||
return UIImageView::create();
|
||||
}
|
||||
|
||||
void UIImageView::copySpecialProperties(UIWidget *widget)
|
||||
{
|
||||
UIImageView* imageView = dynamic_cast<UIImageView*>(widget);
|
||||
if (imageView)
|
||||
{
|
||||
_prevIgnoreSize = imageView->_prevIgnoreSize;
|
||||
setScale9Enabled(imageView->_scale9Enabled);
|
||||
loadTexture(imageView->_textureFile.c_str(), imageView->_imageTexType);
|
||||
setCapInsets(imageView->_capInsets);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
|
@ -29,6 +29,10 @@
|
|||
|
||||
namespace gui {
|
||||
|
||||
/**
|
||||
* @js NA
|
||||
* @lua NA
|
||||
*/
|
||||
class UIImageView : public UIWidget
|
||||
{
|
||||
public:
|
||||
|
@ -100,22 +104,22 @@ public:
|
|||
//override "ignoreContentAdaptWithSize" method of widget.
|
||||
virtual void ignoreContentAdaptWithSize(bool ignore);
|
||||
|
||||
|
||||
/**
|
||||
* Returns the "class name" of widget.
|
||||
*/
|
||||
virtual const char* getDescription() const;
|
||||
|
||||
void setDoubleClickEnabled(bool able);
|
||||
void doubleClickEvent();
|
||||
void checkDoubleClick(float dt);
|
||||
virtual const cocos2d::Size& getContentSize() const;
|
||||
virtual cocos2d::Node* getVirtualRenderer();
|
||||
|
||||
/**
|
||||
* Returns the "class name" of widget.
|
||||
*/
|
||||
virtual const char* getDescription() const;
|
||||
protected:
|
||||
virtual void initRenderer();
|
||||
virtual void onSizeChanged();
|
||||
void imageTextureScaleChangedWithSize();
|
||||
virtual UIWidget* createCloneInstance();
|
||||
virtual void copySpecialProperties(UIWidget* model);
|
||||
protected:
|
||||
int _clickCount;
|
||||
float _clickTimeInterval;
|
||||
|
|
|
@ -37,11 +37,11 @@ _longClickRecordTime(0.0),
|
|||
_checkedDoubleClickWidget(NULL),
|
||||
_rootWidget(NULL)
|
||||
{
|
||||
_manageredWidget = CCArray::create();
|
||||
_manageredWidget = Array::create();
|
||||
_manageredWidget->retain();
|
||||
_checkedDoubleClickWidget = CCArray::create();
|
||||
_checkedDoubleClickWidget = Array::create();
|
||||
_checkedDoubleClickWidget->retain();
|
||||
_selectedWidgets = CCArray::create();
|
||||
_selectedWidgets = Array::create();
|
||||
_selectedWidgets->retain();
|
||||
}
|
||||
|
||||
|
|
|
@ -26,7 +26,7 @@
|
|||
#define __UIINPUTMANAGER_H__
|
||||
|
||||
#include "cocos2d.h"
|
||||
#include "gui/Layout.h"
|
||||
#include "gui/UILayout.h"
|
||||
|
||||
namespace gui {
|
||||
|
||||
|
@ -41,7 +41,7 @@ public:
|
|||
/**
|
||||
* Default destructor
|
||||
*/
|
||||
~UIInputManager();
|
||||
virtual ~UIInputManager();
|
||||
|
||||
/**
|
||||
* Regist a widget to input manager.
|
||||
|
|
|
@ -24,10 +24,9 @@
|
|||
|
||||
#include "gui/UILabel.h"
|
||||
|
||||
using namespace cocos2d;
|
||||
|
||||
namespace gui {
|
||||
|
||||
|
||||
UILabel::UILabel():
|
||||
_touchScaleChangeEnabled(false),
|
||||
_normalScaleValue(1.0f),
|
||||
|
@ -67,7 +66,7 @@ bool UILabel::init()
|
|||
void UILabel::initRenderer()
|
||||
{
|
||||
UIWidget::initRenderer();
|
||||
_labelRenderer = CCLabelTTF::create();
|
||||
_labelRenderer = cocos2d::LabelTTF::create();
|
||||
_renderer->addChild(_labelRenderer);
|
||||
}
|
||||
|
||||
|
@ -95,29 +94,31 @@ int UILabel::getStringLength()
|
|||
|
||||
void UILabel::setFontSize(int size)
|
||||
{
|
||||
_fontSize = size;
|
||||
_labelRenderer->setFontSize(size);
|
||||
labelScaleChangedWithSize();
|
||||
}
|
||||
|
||||
void UILabel::setFontName(const char* name)
|
||||
{
|
||||
_fontName = name;
|
||||
_labelRenderer->setFontName(name);
|
||||
labelScaleChangedWithSize();
|
||||
}
|
||||
|
||||
void UILabel::setTextAreaSize(const Size &size)
|
||||
void UILabel::setTextAreaSize(const cocos2d::Size &size)
|
||||
{
|
||||
_labelRenderer->setDimensions(size);
|
||||
labelScaleChangedWithSize();
|
||||
}
|
||||
|
||||
void UILabel::setTextHorizontalAlignment(TextHAlignment alignment)
|
||||
void UILabel::setTextHorizontalAlignment(cocos2d::TextHAlignment alignment)
|
||||
{
|
||||
_labelRenderer->setHorizontalAlignment(alignment);
|
||||
labelScaleChangedWithSize();
|
||||
}
|
||||
|
||||
void UILabel::setTextVerticalAlignment(TextVAlignment alignment)
|
||||
void UILabel::setTextVerticalAlignment(cocos2d::TextVAlignment alignment)
|
||||
{
|
||||
_labelRenderer->setVerticalAlignment(alignment);
|
||||
labelScaleChangedWithSize();
|
||||
|
@ -182,7 +183,7 @@ bool UILabel::isFlipY()
|
|||
return _labelRenderer->isFlippedY();
|
||||
}
|
||||
|
||||
void UILabel::setAnchorPoint(const Point &pt)
|
||||
void UILabel::setAnchorPoint(const cocos2d::Point &pt)
|
||||
{
|
||||
UIWidget::setAnchorPoint(pt);
|
||||
_labelRenderer->setAnchorPoint(pt);
|
||||
|
@ -193,12 +194,12 @@ void UILabel::onSizeChanged()
|
|||
labelScaleChangedWithSize();
|
||||
}
|
||||
|
||||
const Size& UILabel::getContentSize() const
|
||||
const cocos2d::Size& UILabel::getContentSize() const
|
||||
{
|
||||
return _labelRenderer->getContentSize();
|
||||
}
|
||||
|
||||
Node* UILabel::getVirtualRenderer()
|
||||
cocos2d::Node* UILabel::getVirtualRenderer()
|
||||
{
|
||||
return _labelRenderer;
|
||||
}
|
||||
|
@ -212,7 +213,7 @@ void UILabel::labelScaleChangedWithSize()
|
|||
}
|
||||
else
|
||||
{
|
||||
Size textureSize = _labelRenderer->getContentSize();
|
||||
cocos2d::Size textureSize = _labelRenderer->getContentSize();
|
||||
if (textureSize.width <= 0.0f || textureSize.height <= 0.0f)
|
||||
{
|
||||
_labelRenderer->setScale(1.0f);
|
||||
|
@ -223,6 +224,7 @@ void UILabel::labelScaleChangedWithSize()
|
|||
_labelRenderer->setScaleX(scaleX);
|
||||
_labelRenderer->setScaleY(scaleY);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
const char* UILabel::getDescription() const
|
||||
|
@ -230,4 +232,21 @@ const char* UILabel::getDescription() const
|
|||
return "Label";
|
||||
}
|
||||
|
||||
UIWidget* UILabel::createCloneInstance()
|
||||
{
|
||||
return UILabel::create();
|
||||
}
|
||||
|
||||
void UILabel::copySpecialProperties(UIWidget *widget)
|
||||
{
|
||||
UILabel* label = dynamic_cast<UILabel*>(widget);
|
||||
if (label)
|
||||
{
|
||||
setFontName(label->_fontName.c_str());
|
||||
setFontSize(label->_labelRenderer->getFontSize());
|
||||
setText(label->getStringValue());
|
||||
setTouchScaleChangeEnabled(label->_touchScaleChangeEnabled);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
|
@ -27,8 +27,13 @@
|
|||
|
||||
#include "gui/UIWidget.h"
|
||||
|
||||
|
||||
namespace gui {
|
||||
|
||||
/**
|
||||
* @js NA
|
||||
* @lua NA
|
||||
*/
|
||||
class UILabel : public UIWidget
|
||||
{
|
||||
public:
|
||||
|
@ -124,11 +129,7 @@ public:
|
|||
|
||||
void setTextAreaSize(const cocos2d::Size &size);
|
||||
void setTextHorizontalAlignment(cocos2d::TextHAlignment alignment);
|
||||
void setTextVerticalAlignment(cocos2d::TextVAlignment alignment);
|
||||
|
||||
|
||||
void setTouchScaleChangeAble(bool able){setTouchScaleChangeEnabled(able);};
|
||||
bool getTouchScaleChangeAble(){return isTouchScaleChangeEnabled();};
|
||||
void setTextVerticalAlignment(cocos2d::TextVAlignment alignment);
|
||||
protected:
|
||||
virtual bool init();
|
||||
virtual void initRenderer();
|
||||
|
@ -138,6 +139,8 @@ protected:
|
|||
virtual void onSizeChanged();
|
||||
void clickScale(float scale);
|
||||
void labelScaleChangedWithSize();
|
||||
virtual UIWidget* createCloneInstance();
|
||||
virtual void copySpecialProperties(UIWidget* model);
|
||||
protected:
|
||||
bool _touchScaleChangeEnabled;
|
||||
float _normalScaleValue;
|
||||
|
|
|
@ -24,10 +24,9 @@
|
|||
|
||||
#include "gui/UILabelAtlas.h"
|
||||
|
||||
using namespace cocos2d;
|
||||
|
||||
namespace gui {
|
||||
|
||||
|
||||
UICCLabelAtlas::UICCLabelAtlas()
|
||||
{
|
||||
|
||||
|
@ -56,7 +55,7 @@ void UICCLabelAtlas::setProperty(const char *string, const char *charMapFile, un
|
|||
initWithString(string, charMapFile, itemWidth, itemHeight, startCharMap);
|
||||
}
|
||||
|
||||
void UICCLabelAtlas::setProperty(const char *string, Texture2D *texture, unsigned int itemWidth, unsigned int itemHeight, unsigned int startCharMap)
|
||||
void UICCLabelAtlas::setProperty(const char *string, cocos2d::Texture2D *texture, unsigned int itemWidth, unsigned int itemHeight, unsigned int startCharMap)
|
||||
{
|
||||
initWithString(string, texture, itemWidth, itemHeight, startCharMap);
|
||||
}
|
||||
|
@ -68,20 +67,26 @@ void UICCLabelAtlas::draw()
|
|||
return;
|
||||
}
|
||||
|
||||
CCAtlasNode::draw();
|
||||
cocos2d::AtlasNode::draw();
|
||||
}
|
||||
|
||||
void UICCLabelAtlas::updateDisplayedOpacity(GLubyte opacity)
|
||||
{
|
||||
CCAtlasNode::setOpacity(opacity);
|
||||
cocos2d::AtlasNode::setOpacity(opacity);
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
UILabelAtlas::UILabelAtlas():
|
||||
_laberAtlasRenderer(NULL)
|
||||
_laberAtlasRenderer(NULL),
|
||||
_stringValue(""),
|
||||
_charMapFileName(""),
|
||||
_itemWidth(0),
|
||||
_itemHeight(0),
|
||||
_startCharMap("")
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
UILabelAtlas::~UILabelAtlas()
|
||||
|
@ -108,8 +113,13 @@ void UILabelAtlas::initRenderer()
|
|||
_renderer->addChild(_laberAtlasRenderer);
|
||||
}
|
||||
|
||||
void UILabelAtlas::setProperty(const char *stringValue, const char *charMapFile, int itemWidth, int itemHeight, const char *startCharMap,bool useSpriteFrame)
|
||||
void UILabelAtlas::setProperty(const char *stringValue, const char *charMapFile, int itemWidth, int itemHeight, const char *startCharMap)
|
||||
{
|
||||
_stringValue = stringValue;
|
||||
_charMapFileName = charMapFile;
|
||||
_itemWidth = itemWidth;
|
||||
_itemHeight = itemHeight;
|
||||
_startCharMap = startCharMap;
|
||||
_laberAtlasRenderer->setProperty(stringValue, charMapFile, itemWidth, itemHeight, (int)(startCharMap[0]));
|
||||
updateAnchorPoint();
|
||||
labelAtlasScaleChangedWithSize();
|
||||
|
@ -117,6 +127,7 @@ void UILabelAtlas::setProperty(const char *stringValue, const char *charMapFile,
|
|||
|
||||
void UILabelAtlas::setStringValue(const char *value)
|
||||
{
|
||||
_stringValue = value;
|
||||
_laberAtlasRenderer->setString(value);
|
||||
labelAtlasScaleChangedWithSize();
|
||||
}
|
||||
|
@ -126,10 +137,10 @@ const char* UILabelAtlas::getStringValue()
|
|||
return _laberAtlasRenderer->getString();
|
||||
}
|
||||
|
||||
void UILabelAtlas::setAnchorPoint(const Point &pt)
|
||||
void UILabelAtlas::setAnchorPoint(const cocos2d::Point &pt)
|
||||
{
|
||||
UIWidget::setAnchorPoint(pt);
|
||||
_laberAtlasRenderer->setAnchorPoint(Point(pt.x, pt.y));
|
||||
_laberAtlasRenderer->setAnchorPoint(cocos2d::Point(pt.x, pt.y));
|
||||
}
|
||||
|
||||
void UILabelAtlas::onSizeChanged()
|
||||
|
@ -137,12 +148,12 @@ void UILabelAtlas::onSizeChanged()
|
|||
labelAtlasScaleChangedWithSize();
|
||||
}
|
||||
|
||||
const Size& UILabelAtlas::getContentSize() const
|
||||
const cocos2d::Size& UILabelAtlas::getContentSize() const
|
||||
{
|
||||
return _laberAtlasRenderer->getContentSize();
|
||||
}
|
||||
|
||||
Node* UILabelAtlas::getVirtualRenderer()
|
||||
cocos2d::Node* UILabelAtlas::getVirtualRenderer()
|
||||
{
|
||||
return _laberAtlasRenderer;
|
||||
}
|
||||
|
@ -156,7 +167,7 @@ void UILabelAtlas::labelAtlasScaleChangedWithSize()
|
|||
}
|
||||
else
|
||||
{
|
||||
Size textureSize = _laberAtlasRenderer->getContentSize();
|
||||
cocos2d::Size textureSize = _laberAtlasRenderer->getContentSize();
|
||||
if (textureSize.width <= 0.0f || textureSize.height <= 0.0f)
|
||||
{
|
||||
_laberAtlasRenderer->setScale(1.0f);
|
||||
|
@ -171,7 +182,21 @@ void UILabelAtlas::labelAtlasScaleChangedWithSize()
|
|||
|
||||
const char* UILabelAtlas::getDescription() const
|
||||
{
|
||||
return "LabelAtlase";
|
||||
return "LabelAtlas";
|
||||
}
|
||||
|
||||
UIWidget* UILabelAtlas::createCloneInstance()
|
||||
{
|
||||
return UILabelAtlas::create();
|
||||
}
|
||||
|
||||
void UILabelAtlas::copySpecialProperties(UIWidget *widget)
|
||||
{
|
||||
UILabelAtlas* labelAtlas = dynamic_cast<UILabelAtlas*>(widget);
|
||||
if (labelAtlas)
|
||||
{
|
||||
setProperty(labelAtlas->_stringValue.c_str(), labelAtlas->_charMapFileName.c_str(), labelAtlas->_itemWidth, labelAtlas->_itemHeight, labelAtlas->_startCharMap.c_str());
|
||||
}
|
||||
}
|
||||
|
||||
}
|
|
@ -29,6 +29,10 @@
|
|||
|
||||
namespace gui {
|
||||
|
||||
/**
|
||||
* @js NA
|
||||
* @lua NA
|
||||
*/
|
||||
class UICCLabelAtlas : public cocos2d::LabelAtlas
|
||||
{
|
||||
public:
|
||||
|
@ -51,7 +55,10 @@ public:
|
|||
virtual void updateDisplayedOpacity(GLubyte opacity);
|
||||
virtual void draw(void);
|
||||
};
|
||||
|
||||
/**
|
||||
* @js NA
|
||||
* @lua NA
|
||||
*/
|
||||
class UILabelAtlas : public UIWidget
|
||||
{
|
||||
public:
|
||||
|
@ -71,7 +78,7 @@ public:
|
|||
static UILabelAtlas* create();
|
||||
|
||||
/** initializes the UILabelAtlas with a string, a char map file(the atlas), the width and height of each element and the starting char of the atlas */
|
||||
void setProperty(const char* stringValue,const char* charMapFile, int itemWidth, int itemHeight, const char* startCharMap,bool useSpriteFrame = false);
|
||||
void setProperty(const char* stringValue,const char* charMapFile, int itemWidth, int itemHeight, const char* startCharMap);
|
||||
|
||||
//set string value for labelatlas.
|
||||
void setStringValue(const char* value);
|
||||
|
@ -92,12 +99,20 @@ public:
|
|||
* Returns the "class name" of widget.
|
||||
*/
|
||||
virtual const char* getDescription() const;
|
||||
|
||||
protected:
|
||||
virtual void initRenderer();
|
||||
virtual void onSizeChanged();
|
||||
void labelAtlasScaleChangedWithSize();
|
||||
virtual UIWidget* createCloneInstance();
|
||||
virtual void copySpecialProperties(UIWidget* model);
|
||||
protected:
|
||||
UICCLabelAtlas* _laberAtlasRenderer;
|
||||
std::string _stringValue;
|
||||
std::string _charMapFileName;
|
||||
int _itemWidth;
|
||||
int _itemHeight;
|
||||
std::string _startCharMap;
|
||||
};
|
||||
|
||||
}
|
||||
|
|
|
@ -24,13 +24,13 @@
|
|||
|
||||
#include "gui/UILabelBMFont.h"
|
||||
|
||||
using namespace cocos2d;
|
||||
|
||||
namespace gui {
|
||||
|
||||
UILabelBMFont::UILabelBMFont():
|
||||
_labelBMFontRenderer(NULL),
|
||||
_fntFileHasInit(false)
|
||||
_fntFileHasInit(false),
|
||||
_fntFileName(""),
|
||||
_stringValue("")
|
||||
{
|
||||
}
|
||||
|
||||
|
@ -54,7 +54,7 @@ UILabelBMFont* UILabelBMFont::create()
|
|||
void UILabelBMFont::initRenderer()
|
||||
{
|
||||
UIWidget::initRenderer();
|
||||
_labelBMFontRenderer = CCLabelBMFont::create();
|
||||
_labelBMFontRenderer = cocos2d::LabelBMFont::create();
|
||||
_renderer->addChild(_labelBMFontRenderer);
|
||||
}
|
||||
|
||||
|
@ -64,28 +64,35 @@ void UILabelBMFont::setFntFile(const char *fileName)
|
|||
{
|
||||
return;
|
||||
}
|
||||
_fntFileName = fileName;
|
||||
_labelBMFontRenderer->initWithString("", fileName);
|
||||
updateAnchorPoint();
|
||||
labelBMFontScaleChangedWithSize();
|
||||
_fntFileHasInit = true;
|
||||
setText(_stringValue.c_str());
|
||||
}
|
||||
|
||||
void UILabelBMFont::setText(const char* value)
|
||||
{
|
||||
if (!value || !_fntFileHasInit)
|
||||
if (!value)
|
||||
{
|
||||
return;
|
||||
}
|
||||
_labelBMFontRenderer->setString(value);
|
||||
_stringValue = value;
|
||||
if (!_fntFileHasInit)
|
||||
{
|
||||
return;
|
||||
}
|
||||
_labelBMFontRenderer->setString(value);
|
||||
labelBMFontScaleChangedWithSize();
|
||||
}
|
||||
|
||||
const char* UILabelBMFont::getStringValue()
|
||||
{
|
||||
return _labelBMFontRenderer->getString();
|
||||
return _stringValue.c_str();
|
||||
}
|
||||
|
||||
void UILabelBMFont::setAnchorPoint(const Point &pt)
|
||||
void UILabelBMFont::setAnchorPoint(const cocos2d::Point &pt)
|
||||
{
|
||||
UIWidget::setAnchorPoint(pt);
|
||||
_labelBMFontRenderer->setAnchorPoint(pt);
|
||||
|
@ -96,12 +103,12 @@ void UILabelBMFont::onSizeChanged()
|
|||
labelBMFontScaleChangedWithSize();
|
||||
}
|
||||
|
||||
const Size& UILabelBMFont::getContentSize() const
|
||||
const cocos2d::Size& UILabelBMFont::getContentSize() const
|
||||
{
|
||||
return _labelBMFontRenderer->getContentSize();
|
||||
}
|
||||
|
||||
Node* UILabelBMFont::getVirtualRenderer()
|
||||
cocos2d::Node* UILabelBMFont::getVirtualRenderer()
|
||||
{
|
||||
return _labelBMFontRenderer;
|
||||
}
|
||||
|
@ -115,7 +122,7 @@ void UILabelBMFont::labelBMFontScaleChangedWithSize()
|
|||
}
|
||||
else
|
||||
{
|
||||
Size textureSize = _labelBMFontRenderer->getContentSize();
|
||||
cocos2d::Size textureSize = _labelBMFontRenderer->getContentSize();
|
||||
if (textureSize.width <= 0.0f || textureSize.height <= 0.0f)
|
||||
{
|
||||
_labelBMFontRenderer->setScale(1.0f);
|
||||
|
@ -133,5 +140,19 @@ const char* UILabelBMFont::getDescription() const
|
|||
return "LabelBMFont";
|
||||
}
|
||||
|
||||
UIWidget* UILabelBMFont::createCloneInstance()
|
||||
{
|
||||
return UILabelBMFont::create();
|
||||
}
|
||||
|
||||
void UILabelBMFont::copySpecialProperties(UIWidget *widget)
|
||||
{
|
||||
UILabelBMFont* labelBMFont = dynamic_cast<UILabelBMFont*>(widget);
|
||||
if (labelBMFont)
|
||||
{
|
||||
setFntFile(labelBMFont->_fntFileName.c_str());
|
||||
setText(labelBMFont->_stringValue.c_str());
|
||||
}
|
||||
}
|
||||
|
||||
}
|
|
@ -29,6 +29,10 @@
|
|||
|
||||
namespace gui {
|
||||
|
||||
/**
|
||||
* @js NA
|
||||
* @lua NA
|
||||
*/
|
||||
class UILabelBMFont : public UIWidget
|
||||
{
|
||||
public:
|
||||
|
@ -58,7 +62,6 @@ public:
|
|||
virtual void setAnchorPoint(const cocos2d::Point &pt);
|
||||
virtual const cocos2d::Size& getContentSize() const;
|
||||
virtual cocos2d::Node* getVirtualRenderer();
|
||||
|
||||
/**
|
||||
* Returns the "class name" of widget.
|
||||
*/
|
||||
|
@ -67,9 +70,13 @@ protected:
|
|||
virtual void initRenderer();
|
||||
virtual void onSizeChanged();
|
||||
void labelBMFontScaleChangedWithSize();
|
||||
virtual UIWidget* createCloneInstance();
|
||||
virtual void copySpecialProperties(UIWidget* model);
|
||||
protected:
|
||||
cocos2d::LabelBMFont* _labelBMFontRenderer;
|
||||
bool _fntFileHasInit;
|
||||
std::string _fntFileName;
|
||||
std::string _stringValue;
|
||||
};
|
||||
|
||||
}
|
||||
|
|
|
@ -119,7 +119,7 @@ UIWidget* UILayer::getWidgetByTag(int tag)
|
|||
{
|
||||
return NULL;
|
||||
}
|
||||
return CCUIHELPER->seekWidgetByTag(_rootWidget, tag);
|
||||
return UIHelper::seekWidgetByTag(_rootWidget, tag);
|
||||
}
|
||||
|
||||
UIWidget* UILayer::getWidgetByName(const char* name)
|
||||
|
@ -128,7 +128,7 @@ UIWidget* UILayer::getWidgetByName(const char* name)
|
|||
{
|
||||
return NULL;
|
||||
}
|
||||
return CCUIHELPER->seekWidgetByName(_rootWidget, name);
|
||||
return UIHelper::seekWidgetByName(_rootWidget, name);
|
||||
}
|
||||
|
||||
UIRootWidget* UILayer::getRootWidget()
|
||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -44,23 +44,28 @@ typedef enum
|
|||
LAYOUT_RELATIVE
|
||||
}LayoutType;
|
||||
|
||||
class Layout : public UIWidget
|
||||
|
||||
/**
|
||||
* @js NA
|
||||
* @lua NA
|
||||
*/
|
||||
class UILayout : public UIWidget
|
||||
{
|
||||
public:
|
||||
/**
|
||||
* Default constructor
|
||||
*/
|
||||
Layout();
|
||||
UILayout();
|
||||
|
||||
/**
|
||||
* Default destructor
|
||||
*/
|
||||
virtual ~Layout();
|
||||
virtual ~UILayout();
|
||||
|
||||
/**
|
||||
* Allocates and initializes a layout.
|
||||
*/
|
||||
static Layout* create();
|
||||
static UILayout* create();
|
||||
|
||||
//override "hitTest" method of widget.
|
||||
virtual bool hitTest(const cocos2d::Point &pt);
|
||||
|
@ -168,6 +173,11 @@ public:
|
|||
*/
|
||||
virtual const cocos2d::Size& getContentSize() const;
|
||||
|
||||
/**
|
||||
* Returns the "class name" of widget.
|
||||
*/
|
||||
virtual const char* getDescription() const;
|
||||
|
||||
/**
|
||||
* Sets LayoutType.
|
||||
*
|
||||
|
@ -187,11 +197,14 @@ public:
|
|||
virtual LayoutType getLayoutType() const;
|
||||
|
||||
virtual void doLayout();
|
||||
|
||||
|
||||
/**
|
||||
* Returns the "class name" of widget.
|
||||
* Adds a child to the container.
|
||||
*
|
||||
* @param child A child widget
|
||||
*/
|
||||
virtual const char* getDescription() const;
|
||||
virtual bool addChild(UIWidget* child);
|
||||
|
||||
protected:
|
||||
//override "init" method of widget.
|
||||
virtual bool init();
|
||||
|
@ -204,6 +217,11 @@ protected:
|
|||
|
||||
//init background image renderer.
|
||||
void addBackGroundImage();
|
||||
|
||||
void supplyTheLayoutParameterLackToChild(UIWidget* child);
|
||||
virtual UIWidget* createCloneInstance();
|
||||
virtual void copySpecialProperties(UIWidget* model);
|
||||
virtual void copyClonedWidgetChildren(UIWidget* model);
|
||||
protected:
|
||||
bool _clippingEnabled;
|
||||
|
||||
|
@ -224,23 +242,26 @@ protected:
|
|||
cocos2d::Size _backGroundImageTextureSize;
|
||||
LayoutType _layoutType;
|
||||
};
|
||||
|
||||
class RectClippingNode : public cocos2d::ClippingNode
|
||||
/**
|
||||
* @js NA
|
||||
* @lua NA
|
||||
*/
|
||||
class UIRectClippingNode : public cocos2d::ClippingNode
|
||||
{
|
||||
public:
|
||||
virtual ~RectClippingNode();
|
||||
virtual ~UIRectClippingNode();
|
||||
virtual bool init();
|
||||
static RectClippingNode* create();
|
||||
static UIRectClippingNode* create();
|
||||
void setClippingSize(const cocos2d::Size& size);
|
||||
void setClippingEnabled(bool enabled);
|
||||
virtual void visit();
|
||||
void setEnabled(bool enabled);
|
||||
bool isEnabled() const;
|
||||
protected:
|
||||
cocos2d::DrawNode* m_pInnerStencil;
|
||||
cocos2d::DrawNode* _innerStencil;
|
||||
bool _enabled;
|
||||
private:
|
||||
RectClippingNode();
|
||||
UIRectClippingNode();
|
||||
cocos2d::Point rect[4];
|
||||
cocos2d::Size _clippingSize;
|
||||
bool _clippingEnabled;
|
|
@ -21,7 +21,7 @@
|
|||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||
THE SOFTWARE.
|
||||
****************************************************************************/
|
||||
#include "gui/UILayoutDefine.h"
|
||||
#include "UILayoutDefine.h"
|
||||
|
||||
namespace gui {
|
||||
|
||||
|
|
|
@ -26,9 +26,13 @@
|
|||
#define __UILAYOUTDEFINE_H__
|
||||
|
||||
#include "cocos2d.h"
|
||||
#include "ExtensionMacros.h"
|
||||
|
||||
namespace gui {
|
||||
|
||||
/**
|
||||
* @js NA
|
||||
* @lua NA
|
||||
*/
|
||||
class UIMargin
|
||||
{
|
||||
public:
|
||||
|
@ -46,6 +50,7 @@ public:
|
|||
bool equals(const UIMargin& target) const;
|
||||
};
|
||||
|
||||
const UIMargin UIMarginZero = UIMargin();
|
||||
|
||||
typedef enum
|
||||
{
|
||||
|
@ -61,22 +66,25 @@ typedef enum
|
|||
typedef enum
|
||||
{
|
||||
RELATIVE_ALIGN_NONE,
|
||||
RELATIVE_ALIGN_PARENT_LEFT,
|
||||
RELATIVE_ALIGN_PARENT_TOP,
|
||||
RELATIVE_ALIGN_PARENT_RIGHT,
|
||||
RELATIVE_ALIGN_PARENT_BOTTOM,
|
||||
RELATIVE_ALIGN_PARENT_TOP_LEFT,
|
||||
RELATIVE_ALIGN_PARENT_TOP_CENTER_HORIZONTAL,
|
||||
RELATIVE_ALIGN_PARENT_TOP_RIGHT,
|
||||
RELATIVE_ALIGN_PARENT_LEFT_CENTER_VERTICAL,
|
||||
RELATIVE_CENTER_IN_PARENT,
|
||||
RELATIVE_CENTER_HORIZONTAL,
|
||||
RELATIVE_CENTER_VERTICAL,
|
||||
RELATIVE_ALIGN_PARENT_RIGHT_CENTER_VERTICAL,
|
||||
RELATIVE_ALIGN_PARENT_LEFT_BOTTOM,
|
||||
RELATIVE_ALIGN_PARENT_BOTTOM_CENTER_HORIZONTAL,
|
||||
RELATIVE_ALIGN_PARENT_RIGHT_BOTTOM,
|
||||
|
||||
RELATIVE_LOCATION_ABOVE_LEFTALIGN,
|
||||
RELATIVE_LOCATION_ABOVE_CENTER,
|
||||
RELATIVE_LOCATION_ABOVE_RIGHTALIGN,
|
||||
RELATIVE_LOCATION_LEFT_OF_TOPALIGN,
|
||||
RELATIVE_LOCATION_LEFT_OF_CENTER,
|
||||
RELATIVE_LOCATION_LEFT_OF_BOTTOMALIGN,
|
||||
RELATIVE_LOCATION_RIGHT_OF_TOPALIGN,
|
||||
RELATIVE_LOCATION_RIGHT_OF_CENTER,
|
||||
RELATIVE_LOCATION_RIGHT_OF_BOTTOMALIGN,
|
||||
RELATIVE_LOCATION_ABOVE_LEFTALIGN,
|
||||
RELATIVE_LOCATION_ABOVE_CENTER,
|
||||
RELATIVE_LOCATION_ABOVE_RIGHTALIGN,
|
||||
RELATIVE_LOCATION_BELOW_LEFTALIGN,
|
||||
RELATIVE_LOCATION_BELOW_CENTER,
|
||||
RELATIVE_LOCATION_BELOW_RIGHTALIGN
|
||||
|
|
|
@ -22,14 +22,15 @@
|
|||
THE SOFTWARE.
|
||||
****************************************************************************/
|
||||
|
||||
#include "gui/LayoutParameter.h"
|
||||
#include "gui/Layout.h"
|
||||
#include "gui/UILayoutParameter.h"
|
||||
#include "gui/UILayout.h"
|
||||
|
||||
namespace gui {
|
||||
|
||||
LayoutParameter* LayoutParameter::create()
|
||||
|
||||
UILayoutParameter* UILayoutParameter::create()
|
||||
{
|
||||
LayoutParameter* parameter = new LayoutParameter();
|
||||
UILayoutParameter* parameter = new UILayoutParameter();
|
||||
if (parameter)
|
||||
{
|
||||
parameter->autorelease();
|
||||
|
@ -39,24 +40,24 @@ LayoutParameter* LayoutParameter::create()
|
|||
return NULL;
|
||||
}
|
||||
|
||||
void LayoutParameter::setMargin(const UIMargin &margin)
|
||||
void UILayoutParameter::setMargin(const UIMargin &margin)
|
||||
{
|
||||
_margin = margin;
|
||||
}
|
||||
|
||||
const UIMargin& LayoutParameter::getMargin() const
|
||||
const UIMargin& UILayoutParameter::getMargin() const
|
||||
{
|
||||
return _margin;
|
||||
}
|
||||
|
||||
LayoutParameterType LayoutParameter::getLayoutType() const
|
||||
LayoutParameterType UILayoutParameter::getLayoutType() const
|
||||
{
|
||||
return _layoutParameterType;
|
||||
}
|
||||
|
||||
LinearLayoutParameter* LinearLayoutParameter::create()
|
||||
UILinearLayoutParameter* UILinearLayoutParameter::create()
|
||||
{
|
||||
LinearLayoutParameter* parameter = new LinearLayoutParameter();
|
||||
UILinearLayoutParameter* parameter = new UILinearLayoutParameter();
|
||||
if (parameter)
|
||||
{
|
||||
parameter->autorelease();
|
||||
|
@ -66,19 +67,19 @@ LinearLayoutParameter* LinearLayoutParameter::create()
|
|||
return NULL;
|
||||
}
|
||||
|
||||
void LinearLayoutParameter::setGravity(UILinearGravity gravity)
|
||||
void UILinearLayoutParameter::setGravity(UILinearGravity gravity)
|
||||
{
|
||||
_linearGravity = gravity;
|
||||
}
|
||||
|
||||
UILinearGravity LinearLayoutParameter::getGravity() const
|
||||
UILinearGravity UILinearLayoutParameter::getGravity() const
|
||||
{
|
||||
return _linearGravity;
|
||||
}
|
||||
|
||||
RelativeLayoutParameter* RelativeLayoutParameter::create()
|
||||
UIRelativeLayoutParameter* UIRelativeLayoutParameter::create()
|
||||
{
|
||||
RelativeLayoutParameter* parameter = new RelativeLayoutParameter();
|
||||
UIRelativeLayoutParameter* parameter = new UIRelativeLayoutParameter();
|
||||
if (parameter)
|
||||
{
|
||||
parameter->autorelease();
|
||||
|
@ -88,32 +89,32 @@ RelativeLayoutParameter* RelativeLayoutParameter::create()
|
|||
return NULL;
|
||||
}
|
||||
|
||||
void RelativeLayoutParameter::setAlign(UIRelativeAlign align)
|
||||
void UIRelativeLayoutParameter::setAlign(UIRelativeAlign align)
|
||||
{
|
||||
_relativeAlign = align;
|
||||
}
|
||||
|
||||
UIRelativeAlign RelativeLayoutParameter::getAlign() const
|
||||
UIRelativeAlign UIRelativeLayoutParameter::getAlign() const
|
||||
{
|
||||
return _relativeAlign;
|
||||
}
|
||||
|
||||
void RelativeLayoutParameter::setRelativeToWidgetName(const char *name)
|
||||
void UIRelativeLayoutParameter::setRelativeToWidgetName(const char *name)
|
||||
{
|
||||
_relativeWidgetName = name;
|
||||
}
|
||||
|
||||
const char* RelativeLayoutParameter::getRelativeToWidgetName() const
|
||||
const char* UIRelativeLayoutParameter::getRelativeToWidgetName() const
|
||||
{
|
||||
return _relativeWidgetName.c_str();
|
||||
}
|
||||
|
||||
void RelativeLayoutParameter::setRelativeName(const char* name)
|
||||
void UIRelativeLayoutParameter::setRelativeName(const char* name)
|
||||
{
|
||||
_relativeLayoutName = name;
|
||||
}
|
||||
|
||||
const char* RelativeLayoutParameter::getRelativeName() const
|
||||
const char* UIRelativeLayoutParameter::getRelativeName() const
|
||||
{
|
||||
return _relativeLayoutName.c_str();
|
||||
}
|
|
@ -35,25 +35,28 @@ typedef enum
|
|||
LAYOUT_PARAMETER_LINEAR,
|
||||
LAYOUT_PARAMETER_RELATIVE
|
||||
}LayoutParameterType;
|
||||
|
||||
class LayoutParameter : public cocos2d::Object
|
||||
/**
|
||||
* @js NA
|
||||
* @lua NA
|
||||
*/
|
||||
class UILayoutParameter : public cocos2d::Object
|
||||
{
|
||||
public:
|
||||
/**
|
||||
* Default constructor
|
||||
*/
|
||||
LayoutParameter() : _margin(UIMargin()){_layoutParameterType = LAYOUT_PARAMETER_NONE;};
|
||||
UILayoutParameter() : _margin(UIMargin()){_layoutParameterType = LAYOUT_PARAMETER_NONE;};
|
||||
|
||||
/**
|
||||
* Default destructor
|
||||
*/
|
||||
virtual ~LayoutParameter(){};
|
||||
virtual ~UILayoutParameter(){};
|
||||
|
||||
/**
|
||||
* Allocates and initializes.
|
||||
* @return A initialized LayoutParameter which is marked as "autorelease".
|
||||
*/
|
||||
static LayoutParameter* create();
|
||||
static UILayoutParameter* create();
|
||||
|
||||
/**
|
||||
* Sets Margin parameter for LayoutParameter.
|
||||
|
@ -85,25 +88,28 @@ protected:
|
|||
UIMargin _margin;
|
||||
LayoutParameterType _layoutParameterType;
|
||||
};
|
||||
|
||||
class LinearLayoutParameter : public LayoutParameter
|
||||
/**
|
||||
* @js NA
|
||||
* @lua NA
|
||||
*/
|
||||
class UILinearLayoutParameter : public UILayoutParameter
|
||||
{
|
||||
public:
|
||||
/**
|
||||
* Default constructor
|
||||
*/
|
||||
LinearLayoutParameter() : _linearGravity(LINEAR_GRAVITY_NONE){_layoutParameterType = LAYOUT_PARAMETER_LINEAR;};
|
||||
UILinearLayoutParameter() : _linearGravity(LINEAR_GRAVITY_NONE){_layoutParameterType = LAYOUT_PARAMETER_LINEAR;};
|
||||
|
||||
/**
|
||||
* Default destructor
|
||||
*/
|
||||
virtual ~LinearLayoutParameter(){};
|
||||
virtual ~UILinearLayoutParameter(){};
|
||||
|
||||
/**
|
||||
* Allocates and initializes.
|
||||
* @return A initialized LayoutParameter which is marked as "autorelease".
|
||||
*/
|
||||
static LinearLayoutParameter* create();
|
||||
static UILinearLayoutParameter* create();
|
||||
|
||||
/**
|
||||
* Sets UILinearGravity parameter for LayoutParameter.
|
||||
|
@ -125,25 +131,31 @@ public:
|
|||
protected:
|
||||
UILinearGravity _linearGravity;
|
||||
};
|
||||
/**
|
||||
* @js NA
|
||||
* @lua NA
|
||||
*/
|
||||
|
||||
class RelativeLayoutParameter : public LayoutParameter
|
||||
class UILayout;
|
||||
|
||||
class UIRelativeLayoutParameter : public UILayoutParameter
|
||||
{
|
||||
public:
|
||||
/**
|
||||
* Default constructor
|
||||
*/
|
||||
RelativeLayoutParameter() : _relativeAlign(RELATIVE_ALIGN_NONE),_relativeWidgetName(""),_relativeLayoutName(""){_layoutParameterType = LAYOUT_PARAMETER_RELATIVE;};
|
||||
UIRelativeLayoutParameter() : _relativeAlign(RELATIVE_ALIGN_NONE),_relativeWidgetName(""),_relativeLayoutName(""),_put(false){_layoutParameterType = LAYOUT_PARAMETER_RELATIVE;};
|
||||
|
||||
/**
|
||||
* Default destructor
|
||||
*/
|
||||
virtual ~RelativeLayoutParameter(){};
|
||||
virtual ~UIRelativeLayoutParameter(){};
|
||||
|
||||
/**
|
||||
* Allocates and initializes.
|
||||
* @return A initialized LayoutParameter which is marked as "autorelease".
|
||||
*/
|
||||
static RelativeLayoutParameter* create();
|
||||
static UIRelativeLayoutParameter* create();
|
||||
|
||||
/**
|
||||
* Sets UIRelativeAlign parameter for LayoutParameter.
|
||||
|
@ -194,6 +206,8 @@ protected:
|
|||
UIRelativeAlign _relativeAlign;
|
||||
std::string _relativeWidgetName;
|
||||
std::string _relativeLayoutName;
|
||||
bool _put;
|
||||
friend class UILayout;
|
||||
};
|
||||
|
||||
}
|
File diff suppressed because it is too large
Load Diff
|
@ -22,226 +22,156 @@
|
|||
THE SOFTWARE.
|
||||
****************************************************************************/
|
||||
|
||||
|
||||
#ifndef __UILISTVIEW_H__
|
||||
#define __UILISTVIEW_H__
|
||||
|
||||
/* gui mark */
|
||||
#include "gui/Layout.h"
|
||||
/**/
|
||||
#include "gui/UIScrollView.h"
|
||||
|
||||
namespace gui {
|
||||
|
||||
/**
|
||||
* list view direction
|
||||
*/
|
||||
typedef enum LISTVIEW_DIR
|
||||
{
|
||||
LISTVIEW_DIR_NONE,
|
||||
LISTVIEW_DIR_VERTICAL,
|
||||
LISTVIEW_DIR_HORIZONTAL
|
||||
}ListViewDirection;
|
||||
|
||||
/**
|
||||
* list view scroll direction
|
||||
*/
|
||||
typedef enum LISTVIEW_MOVE_DIR
|
||||
{
|
||||
LISTVIEW_MOVE_DIR_NONE,
|
||||
LISTVIEW_MOVE_DIR_UP,
|
||||
LISTVIEW_MOVE_DIR_DOWN,
|
||||
LISTVIEW_MOVE_DIR_LEFT,
|
||||
LISTVIEW_MOVE_DIR_RIGHT,
|
||||
}ListViewMoveDirection;
|
||||
namespace gui{
|
||||
|
||||
typedef enum
|
||||
{
|
||||
LISTVIEW_EVENT_INIT_CHILD,
|
||||
LISTVIEW_EVENT_UPDATE_CHILD,
|
||||
}ListViewEventType;
|
||||
LISTVIEW_GRAVITY_LEFT,
|
||||
LISTVIEW_GRAVITY_RIGHT,
|
||||
LISTVIEW_GRAVITY_CENTER_HORIZONTAL,
|
||||
|
||||
LISTVIEW_GRAVITY_TOP,
|
||||
LISTVIEW_GRAVITY_BOTTOM,
|
||||
LISTVIEW_GRAVITY_CENTER_VERTICAL,
|
||||
}ListViewGravity;
|
||||
|
||||
/**
|
||||
* list view event
|
||||
*/
|
||||
typedef void (cocos2d::Object::*SEL_ListViewEvent)(cocos2d::Object*, ListViewEventType);
|
||||
#define listvieweventselector(_SELECTOR)(SEL_ListViewEvent)(&_SELECTOR)
|
||||
|
||||
class UIListView : public Layout
|
||||
class UIListView : public UIScrollView
|
||||
{
|
||||
|
||||
public:
|
||||
|
||||
/**
|
||||
* Default constructor
|
||||
*/
|
||||
UIListView();
|
||||
|
||||
/**
|
||||
* Default destructor
|
||||
*/
|
||||
virtual ~UIListView();
|
||||
|
||||
/**
|
||||
* Allocates and initializes.
|
||||
*/
|
||||
static UIListView* create();
|
||||
|
||||
/**
|
||||
* add widget child override
|
||||
* Sets a item model for listview
|
||||
*
|
||||
* A model will be cloned for adding default item.
|
||||
*
|
||||
* @param model item model for listview
|
||||
*/
|
||||
virtual bool addChild(UIWidget* widget);
|
||||
/**
|
||||
* remove all widget children override
|
||||
*/
|
||||
virtual void removeAllChildren();
|
||||
/**
|
||||
* remove widget child override
|
||||
*/
|
||||
virtual bool removeChild(UIWidget* child);
|
||||
|
||||
virtual bool onTouchBegan(const cocos2d::Point &touchPoint);
|
||||
virtual void onTouchMoved(const cocos2d::Point &touchPoint);
|
||||
virtual void onTouchEnded(const cocos2d::Point &touchPoint);
|
||||
virtual void onTouchCancelled(const cocos2d::Point &touchPoint);
|
||||
virtual void onTouchLongClicked(const cocos2d::Point &touchPoint);
|
||||
void setItemModel(UIWidget* model);
|
||||
|
||||
/**
|
||||
* set and get direction
|
||||
* Push back a default item(create by a cloned model) into listview.
|
||||
*/
|
||||
void setDirection(ListViewDirection dir);
|
||||
ListViewDirection getDirection();
|
||||
void pushBackDefaultItem();
|
||||
|
||||
/**
|
||||
* initialze data length
|
||||
* and create children with parameter length
|
||||
* Insert a default item(create by a cloned model) into listview.
|
||||
*/
|
||||
void initChildWithDataLength(int length);
|
||||
/**
|
||||
* get data length
|
||||
*/
|
||||
int getDataLength();
|
||||
void insertDefaultItem(int index);
|
||||
|
||||
/**
|
||||
* update child function whetn trigger update child event
|
||||
* Push back custom item into listview.
|
||||
*/
|
||||
/**
|
||||
* get update widget child
|
||||
*/
|
||||
UIWidget* getUpdateChild();
|
||||
/**
|
||||
* get update data index
|
||||
*/
|
||||
int getUpdateDataIndex();
|
||||
/**
|
||||
* get and set update success or not
|
||||
*/
|
||||
bool getUpdateSuccess();
|
||||
void setUpdateSuccess(bool sucess);
|
||||
void pushBackCustomItem(UIWidget* item);
|
||||
|
||||
/**
|
||||
* add event call-back function
|
||||
* Insert custom item into listview.
|
||||
*/
|
||||
/**
|
||||
* add event
|
||||
*/
|
||||
void addEventListenter(cocos2d::Object* target, SEL_ListViewEvent selector);
|
||||
|
||||
/* gui mark */
|
||||
/**
|
||||
* get and set degree range for checking move or not with scrolling
|
||||
*/
|
||||
/**/
|
||||
virtual void update(float dt);
|
||||
|
||||
virtual void doLayout(){};
|
||||
void insertCustomItem(UIWidget* item, int index);
|
||||
|
||||
/**
|
||||
* Returns the "class name" of widget.
|
||||
* Removes the last item of listview.
|
||||
*/
|
||||
void removeLastItem();
|
||||
|
||||
/**
|
||||
* Removes a item whose index is same as the parameter.
|
||||
*
|
||||
* @param index of item.
|
||||
*/
|
||||
void removeItem(int index);
|
||||
|
||||
/**
|
||||
* Returns a item whose index is same as the parameter.
|
||||
*
|
||||
* @param index of item.
|
||||
*
|
||||
* @return the item widget.
|
||||
*/
|
||||
UIWidget* getItem(unsigned int index);
|
||||
|
||||
/**
|
||||
* Returns the item container.
|
||||
*/
|
||||
cocos2d::Array* getItems();
|
||||
|
||||
/**
|
||||
* Returns the index of item.
|
||||
*
|
||||
* @param item the item which need to be checked.
|
||||
*
|
||||
* @return the index of item.
|
||||
*/
|
||||
unsigned int getIndex(UIWidget* item) const;
|
||||
|
||||
/**
|
||||
* Changes the gravity of listview.
|
||||
* @see ListViewGravity
|
||||
*/
|
||||
void setGravity(ListViewGravity gravity);
|
||||
|
||||
/**
|
||||
* Changes the margin between each item.
|
||||
*
|
||||
* @param margin
|
||||
*/
|
||||
void setItemsMargin(float margin);
|
||||
|
||||
/**
|
||||
* Refresh the view of list.
|
||||
*
|
||||
* If you change the data, you need to call this mathod.
|
||||
*/
|
||||
void refreshView();
|
||||
|
||||
/**
|
||||
* Changes scroll direction of scrollview.
|
||||
*
|
||||
* @see SCROLLVIEW_DIR SCROLLVIEW_DIR_VERTICAL means vertical scroll, SCROLLVIEW_DIR_HORIZONTAL means horizontal scroll
|
||||
*
|
||||
* @param SCROLLVIEW_DIR
|
||||
*/
|
||||
virtual void setDirection(SCROLLVIEW_DIR dir);
|
||||
|
||||
virtual const char* getDescription() const;
|
||||
|
||||
protected:
|
||||
virtual bool init();
|
||||
|
||||
void updateInnerContainerSize();
|
||||
void remedyLayoutParameter(UIWidget* item);
|
||||
virtual void onSizeChanged();
|
||||
|
||||
void setMoveDirection(ListViewMoveDirection dir);
|
||||
ListViewMoveDirection getMoveDirection();
|
||||
|
||||
virtual void resetProperty();
|
||||
|
||||
virtual void handlePressLogic(const cocos2d::Point &touchPoint);
|
||||
virtual void handleMoveLogic(const cocos2d::Point &touchPoint);
|
||||
virtual void handleReleaseLogic(const cocos2d::Point &touchPoint);
|
||||
virtual void interceptTouchEvent(int handleState,UIWidget* sender,const cocos2d::Point &touchPoint);
|
||||
/* gui mark */
|
||||
// virtual bool isInScrollDegreeRange(UIWidget* widget);
|
||||
/**/
|
||||
virtual void checkChildInfo(int handleState,UIWidget* sender,const cocos2d::Point &touchPoint);
|
||||
|
||||
void moveChildren(float offset);
|
||||
virtual bool scrollChildren(float touchOffset);
|
||||
void autoScrollChildren(float dt);
|
||||
float getCurAutoScrollDistance(float time);
|
||||
void startAutoScrollChildren(float v);
|
||||
void stopAutoScrollChildren();
|
||||
void recordSlidTime(float dt);
|
||||
void startRecordSlidAction();
|
||||
virtual void endRecordSlidAction();
|
||||
|
||||
UIWidget* getCheckPositionChild();
|
||||
UIWidget* getChildFromUpdatePool();
|
||||
void pushChildToPool();
|
||||
void getAndCallback();
|
||||
|
||||
void setUpdateChild(UIWidget* child);
|
||||
void setUpdateDataIndex(int index);
|
||||
void clearCollectOverArray();
|
||||
void collectOverTopChild();
|
||||
void collectOverBottomChild();
|
||||
void collectOverLeftChild();
|
||||
void collectOverRightChild();
|
||||
void setLoopPosition();
|
||||
void updateChild();
|
||||
|
||||
void initChildEvent();
|
||||
void updateChildEvent();
|
||||
|
||||
virtual void setClippingEnabled(bool able){Layout::setClippingEnabled(able);};
|
||||
virtual UIWidget* createCloneInstance();
|
||||
virtual void copySpecialProperties(UIWidget* model);
|
||||
virtual void copyClonedWidgetChildren(UIWidget* model);
|
||||
protected:
|
||||
ListViewDirection _direction;
|
||||
ListViewMoveDirection _moveDirection;
|
||||
|
||||
float _touchStartLocation;
|
||||
float _touchEndLocation;
|
||||
float _touchMoveStartLocation;
|
||||
float _topBoundary;//test
|
||||
float _bottomBoundary;//test
|
||||
float _leftBoundary;
|
||||
float _rightBoundary;
|
||||
|
||||
bool _autoScroll;
|
||||
|
||||
float _autoScrollOriginalSpeed;
|
||||
float _autoScrollAcceleration;
|
||||
|
||||
bool _bePressed;
|
||||
float _slidTime;
|
||||
cocos2d::Point _moveChildPoint;
|
||||
float _childFocusCancelOffset;
|
||||
|
||||
cocos2d::Object* _eventListener;
|
||||
SEL_ListViewEvent _eventSelector;
|
||||
|
||||
cocos2d::Array* _childPool;
|
||||
cocos2d::Array* _updatePool;
|
||||
|
||||
int _dataLength;
|
||||
int _begin;
|
||||
int _end;
|
||||
UIWidget* _updateChild;
|
||||
int _updateDataIndex;
|
||||
bool _updateSuccess;
|
||||
|
||||
cocos2d::Array* _overTopArray;
|
||||
cocos2d::Array* _overBottomArray;
|
||||
cocos2d::Array* _overLeftArray;
|
||||
cocos2d::Array* _overRightArray;
|
||||
|
||||
float _disBoundaryToChild_0;
|
||||
float _disBetweenChild;
|
||||
|
||||
/* gui mark */
|
||||
float _scrollDegreeRange;
|
||||
/**/
|
||||
UIWidget* _model;
|
||||
cocos2d::Array* _items;
|
||||
ListViewGravity _gravity;
|
||||
float _itemsMargin;
|
||||
};
|
||||
|
||||
}
|
||||
|
||||
|
||||
#endif /* defined(__Test__UIListView__) */
|
||||
#endif /* defined(__UIListView__) */
|
||||
|
|
|
@ -25,11 +25,9 @@
|
|||
#include "gui/UILoadingBar.h"
|
||||
#include "extensions/GUI/CCControlExtension/CCScale9Sprite.h"
|
||||
|
||||
using namespace cocos2d;
|
||||
using namespace cocos2d::extension;
|
||||
|
||||
namespace gui {
|
||||
|
||||
|
||||
#define DYNAMIC_CAST_CCSPRITE dynamic_cast<cocos2d::Sprite*>(_barRenderer)
|
||||
|
||||
UILoadingBar::UILoadingBar():
|
||||
|
@ -38,10 +36,10 @@ _percent(100),
|
|||
_totalLength(0),
|
||||
_barRenderer(NULL),
|
||||
_renderBarTexType(UI_TEX_TYPE_LOCAL),
|
||||
_barRendererTextureSize(Size::ZERO),
|
||||
_barRendererTextureSize(cocos2d::Size::ZERO),
|
||||
_scale9Enabled(false),
|
||||
_prevIgnoreSize(true),
|
||||
_capInsets(Rect::ZERO),
|
||||
_capInsets(cocos2d::Rect::ZERO),
|
||||
_textureFile("")
|
||||
{
|
||||
}
|
||||
|
@ -66,9 +64,9 @@ UILoadingBar* UILoadingBar::create()
|
|||
void UILoadingBar::initRenderer()
|
||||
{
|
||||
UIWidget::initRenderer();
|
||||
_barRenderer = CCSprite::create();
|
||||
_barRenderer = cocos2d::Sprite::create();
|
||||
_renderer->addChild(_barRenderer);
|
||||
_barRenderer->setAnchorPoint(Point(0.0f,0.5f));
|
||||
_barRenderer->setAnchorPoint(cocos2d::Point(0.0,0.5));
|
||||
}
|
||||
|
||||
void UILoadingBar::setDirection(LoadingBarType dir)
|
||||
|
@ -82,19 +80,19 @@ void UILoadingBar::setDirection(LoadingBarType dir)
|
|||
switch (_barType)
|
||||
{
|
||||
case LoadingBarTypeLeft:
|
||||
_barRenderer->setAnchorPoint(Point(0.0f,0.5f));
|
||||
_barRenderer->setPosition(Point(-_totalLength*0.5f,0.0f));
|
||||
_barRenderer->setAnchorPoint(cocos2d::Point(0.0f,0.5f));
|
||||
_barRenderer->setPosition(cocos2d::Point(-_totalLength*0.5f,0.0f));
|
||||
if (!_scale9Enabled)
|
||||
{
|
||||
dynamic_cast<Sprite*>(_barRenderer)->setFlippedX(false);
|
||||
dynamic_cast<cocos2d::Sprite*>(_barRenderer)->setFlippedX(false);
|
||||
}
|
||||
break;
|
||||
case LoadingBarTypeRight:
|
||||
_barRenderer->setAnchorPoint(Point(1.0f,0.5f));
|
||||
_barRenderer->setPosition(Point(_totalLength*0.5f,0.0f));
|
||||
_barRenderer->setAnchorPoint(cocos2d::Point(1.0f,0.5f));
|
||||
_barRenderer->setPosition(cocos2d::Point(_totalLength*0.5f,0.0f));
|
||||
if (!_scale9Enabled)
|
||||
{
|
||||
dynamic_cast<Sprite*>(_barRenderer)->setFlippedX(true);
|
||||
dynamic_cast<cocos2d::Sprite*>(_barRenderer)->setFlippedX(true);
|
||||
}
|
||||
break;
|
||||
}
|
||||
|
@ -118,21 +116,23 @@ void UILoadingBar::loadTexture(const char* texture,TextureResType texType)
|
|||
case UI_TEX_TYPE_LOCAL:
|
||||
if (_scale9Enabled)
|
||||
{
|
||||
dynamic_cast<Scale9Sprite*>(_barRenderer)->initWithFile(texture);
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_barRenderer)->initWithFile(texture);
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_barRenderer)->setCapInsets(_capInsets);
|
||||
}
|
||||
else
|
||||
{
|
||||
dynamic_cast<Sprite*>(_barRenderer)->initWithFile(texture);
|
||||
dynamic_cast<cocos2d::Sprite*>(_barRenderer)->initWithFile(texture);
|
||||
}
|
||||
break;
|
||||
case UI_TEX_TYPE_PLIST:
|
||||
if (_scale9Enabled)
|
||||
{
|
||||
dynamic_cast<Scale9Sprite*>(_barRenderer)->initWithSpriteFrameName(texture);
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_barRenderer)->initWithSpriteFrameName(texture);
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_barRenderer)->setCapInsets(_capInsets);
|
||||
}
|
||||
else
|
||||
{
|
||||
dynamic_cast<Sprite*>(_barRenderer)->initWithSpriteFrameName(texture);
|
||||
dynamic_cast<cocos2d::Sprite*>(_barRenderer)->initWithSpriteFrameName(texture);
|
||||
}
|
||||
break;
|
||||
default:
|
||||
|
@ -140,31 +140,31 @@ void UILoadingBar::loadTexture(const char* texture,TextureResType texType)
|
|||
}
|
||||
if (_scale9Enabled)
|
||||
{
|
||||
dynamic_cast<Scale9Sprite*>(_barRenderer)->setColor(getColor());
|
||||
dynamic_cast<Scale9Sprite*>(_barRenderer)->setOpacity(getOpacity());
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_barRenderer)->setColor(getColor());
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_barRenderer)->setOpacity(getOpacity());
|
||||
|
||||
}
|
||||
else
|
||||
{
|
||||
dynamic_cast<Sprite*>(_barRenderer)->setColor(getColor());
|
||||
dynamic_cast<Sprite*>(_barRenderer)->setOpacity(getOpacity());
|
||||
dynamic_cast<cocos2d::Sprite*>(_barRenderer)->setColor(getColor());
|
||||
dynamic_cast<cocos2d::Sprite*>(_barRenderer)->setOpacity(getOpacity());
|
||||
}
|
||||
_barRendererTextureSize.width = _barRenderer->getContentSize().width;
|
||||
_barRendererTextureSize.height = _barRenderer->getContentSize().height;
|
||||
_barRendererTextureSize = _barRenderer->getContentSize();
|
||||
|
||||
switch (_barType)
|
||||
{
|
||||
case LoadingBarTypeLeft:
|
||||
_barRenderer->setAnchorPoint(Point(0.0f,0.5f));
|
||||
_barRenderer->setAnchorPoint(cocos2d::Point(0.0f,0.5f));
|
||||
if (!_scale9Enabled)
|
||||
{
|
||||
dynamic_cast<Sprite*>(_barRenderer)->setFlippedX(false);
|
||||
dynamic_cast<cocos2d::Sprite*>(_barRenderer)->setFlippedX(false);
|
||||
}
|
||||
break;
|
||||
case LoadingBarTypeRight:
|
||||
_barRenderer->setAnchorPoint(Point(1.0f,0.5f));
|
||||
_barRenderer->setAnchorPoint(cocos2d::Point(1.0f,0.5f));
|
||||
if (!_scale9Enabled)
|
||||
{
|
||||
dynamic_cast<Sprite*>(_barRenderer)->setFlippedX(true);
|
||||
dynamic_cast<cocos2d::Sprite*>(_barRenderer)->setFlippedX(true);
|
||||
}
|
||||
break;
|
||||
}
|
||||
|
@ -182,11 +182,11 @@ void UILoadingBar::setScale9Enabled(bool enabled)
|
|||
_barRenderer = NULL;
|
||||
if (_scale9Enabled)
|
||||
{
|
||||
_barRenderer = Scale9Sprite::create();
|
||||
_barRenderer = cocos2d::extension::Scale9Sprite::create();
|
||||
}
|
||||
else
|
||||
{
|
||||
_barRenderer = CCSprite::create();
|
||||
_barRenderer = cocos2d::Sprite::create();
|
||||
}
|
||||
loadTexture(_textureFile.c_str(),_renderBarTexType);
|
||||
_renderer->addChild(_barRenderer);
|
||||
|
@ -203,14 +203,14 @@ void UILoadingBar::setScale9Enabled(bool enabled)
|
|||
setCapInsets(_capInsets);
|
||||
}
|
||||
|
||||
void UILoadingBar::setCapInsets(const Rect &capInsets)
|
||||
void UILoadingBar::setCapInsets(const cocos2d::Rect &capInsets)
|
||||
{
|
||||
_capInsets = capInsets;
|
||||
if (!_scale9Enabled)
|
||||
{
|
||||
return;
|
||||
}
|
||||
dynamic_cast<Scale9Sprite*>(_barRenderer)->setCapInsets(capInsets);
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_barRenderer)->setCapInsets(capInsets);
|
||||
}
|
||||
|
||||
void UILoadingBar::setPercent(int percent)
|
||||
|
@ -231,10 +231,10 @@ void UILoadingBar::setPercent(int percent)
|
|||
{
|
||||
case UI_TEX_TYPE_PLIST:
|
||||
{
|
||||
Sprite* barNode = DYNAMIC_CAST_CCSPRITE;
|
||||
cocos2d::Sprite* barNode = DYNAMIC_CAST_CCSPRITE;
|
||||
if (barNode)
|
||||
{
|
||||
Point to = barNode->getTextureRect().origin;
|
||||
cocos2d::Point to = barNode->getTextureRect().origin;
|
||||
x = to.x;
|
||||
y = to.y;
|
||||
}
|
||||
|
@ -249,7 +249,7 @@ void UILoadingBar::setPercent(int percent)
|
|||
}
|
||||
else
|
||||
{
|
||||
dynamic_cast<Sprite*>(_barRenderer)->setTextureRect(Rect(x, y, _barRendererTextureSize.width * res, _barRendererTextureSize.height));
|
||||
dynamic_cast<cocos2d::Sprite*>(_barRenderer)->setTextureRect(cocos2d::Rect(x, y, _barRendererTextureSize.width * res, _barRendererTextureSize.height));
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -272,12 +272,12 @@ void UILoadingBar::ignoreContentAdaptWithSize(bool ignore)
|
|||
}
|
||||
}
|
||||
|
||||
const Size& UILoadingBar::getContentSize() const
|
||||
const cocos2d::Size& UILoadingBar::getContentSize() const
|
||||
{
|
||||
return _barRendererTextureSize;
|
||||
}
|
||||
|
||||
Node* UILoadingBar::getVirtualRenderer()
|
||||
cocos2d::Node* UILoadingBar::getVirtualRenderer()
|
||||
{
|
||||
return _barRenderer;
|
||||
}
|
||||
|
@ -303,7 +303,7 @@ void UILoadingBar::barRendererScaleChangedWithSize()
|
|||
else
|
||||
{
|
||||
|
||||
Size textureSize = _barRenderer->getContentSize();
|
||||
cocos2d::Size textureSize = _barRendererTextureSize;
|
||||
if (textureSize.width <= 0.0f || textureSize.height <= 0.0f)
|
||||
{
|
||||
_barRenderer->setScale(1.0f);
|
||||
|
@ -318,10 +318,10 @@ void UILoadingBar::barRendererScaleChangedWithSize()
|
|||
switch (_barType)
|
||||
{
|
||||
case LoadingBarTypeLeft:
|
||||
_barRenderer->setPosition(Point(-_totalLength * 0.5f, 0.0f));
|
||||
_barRenderer->setPosition(cocos2d::Point(-_totalLength * 0.5f, 0.0f));
|
||||
break;
|
||||
case LoadingBarTypeRight:
|
||||
_barRenderer->setPosition(Point(_totalLength * 0.5f, 0.0f));
|
||||
_barRenderer->setPosition(cocos2d::Point(_totalLength * 0.5f, 0.0f));
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
|
@ -331,7 +331,7 @@ void UILoadingBar::barRendererScaleChangedWithSize()
|
|||
void UILoadingBar::setScale9Scale()
|
||||
{
|
||||
float width = (float)(_percent) / 100 * _totalLength;
|
||||
dynamic_cast<Scale9Sprite*>(_barRenderer)->setPreferredSize(Size(width, _barRendererTextureSize.height));
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_barRenderer)->setPreferredSize(cocos2d::Size(width, _size.height));
|
||||
}
|
||||
|
||||
const char* UILoadingBar::getDescription() const
|
||||
|
@ -339,4 +339,22 @@ const char* UILoadingBar::getDescription() const
|
|||
return "LoadingBar";
|
||||
}
|
||||
|
||||
UIWidget* UILoadingBar::createCloneInstance()
|
||||
{
|
||||
return UILoadingBar::create();
|
||||
}
|
||||
|
||||
void UILoadingBar::copySpecialProperties(UIWidget *widget)
|
||||
{
|
||||
UILoadingBar* loadingBar = dynamic_cast<UILoadingBar*>(widget);
|
||||
if (loadingBar)
|
||||
{
|
||||
_prevIgnoreSize = loadingBar->_prevIgnoreSize;
|
||||
setScale9Enabled(loadingBar->_scale9Enabled);
|
||||
loadTexture(loadingBar->_textureFile.c_str(), loadingBar->_renderBarTexType);
|
||||
setCapInsets(loadingBar->_capInsets);
|
||||
setPercent(loadingBar->_percent);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
|
@ -34,7 +34,10 @@ typedef enum
|
|||
LoadingBarTypeLeft,
|
||||
LoadingBarTypeRight
|
||||
}LoadingBarType;
|
||||
|
||||
/**
|
||||
* @js NA
|
||||
* @lua NA
|
||||
*/
|
||||
class UILoadingBar : public UIWidget
|
||||
{
|
||||
public:
|
||||
|
@ -126,6 +129,8 @@ protected:
|
|||
virtual void onSizeChanged();
|
||||
void setScale9Scale();
|
||||
void barRendererScaleChangedWithSize();
|
||||
virtual UIWidget* createCloneInstance();
|
||||
virtual void copySpecialProperties(UIWidget* model);
|
||||
protected:
|
||||
LoadingBarType _barType;
|
||||
int _percent;
|
||||
|
|
|
@ -24,8 +24,6 @@
|
|||
|
||||
#include "gui/UIPageView.h"
|
||||
|
||||
using namespace cocos2d;
|
||||
|
||||
namespace gui {
|
||||
|
||||
UIPageView::UIPageView():
|
||||
|
@ -33,9 +31,8 @@ _curPageIdx(0),
|
|||
_pages(NULL),
|
||||
_touchMoveDir(PAGEVIEW_TOUCHLEFT),
|
||||
_touchStartLocation(0.0f),
|
||||
_touchEndLocation(0.0f),
|
||||
_touchMoveStartLocation(0.0f),
|
||||
_movePagePoint(Point::ZERO),
|
||||
_movePagePoint(cocos2d::Point::ZERO),
|
||||
_leftChild(NULL),
|
||||
_rightChild(NULL),
|
||||
_leftBoundary(0.0f),
|
||||
|
@ -52,7 +49,8 @@ _eventSelector(NULL)
|
|||
|
||||
UIPageView::~UIPageView()
|
||||
{
|
||||
_pages->release();
|
||||
_pages->removeAllObjects();
|
||||
CC_SAFE_RELEASE(_pages);
|
||||
}
|
||||
|
||||
UIPageView* UIPageView::create()
|
||||
|
@ -69,12 +67,13 @@ UIPageView* UIPageView::create()
|
|||
|
||||
bool UIPageView::init()
|
||||
{
|
||||
if (Layout::init())
|
||||
if (UILayout::init())
|
||||
{
|
||||
_pages = CCArray::create();
|
||||
_pages = cocos2d::Array::create();
|
||||
_pages->retain();
|
||||
setClippingEnabled(true);
|
||||
setUpdateEnabled(true);
|
||||
setTouchEnabled(true);
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
|
@ -86,6 +85,10 @@ void UIPageView::addWidgetToPage(UIWidget *widget, int pageIdx, bool forceCreate
|
|||
{
|
||||
return;
|
||||
}
|
||||
if (pageIdx < 0)
|
||||
{
|
||||
return;
|
||||
}
|
||||
int pageCount = _pages->count();
|
||||
if (pageIdx < 0 || pageIdx >= pageCount)
|
||||
{
|
||||
|
@ -95,30 +98,29 @@ void UIPageView::addWidgetToPage(UIWidget *widget, int pageIdx, bool forceCreate
|
|||
{
|
||||
CCLOG("pageIdx is %d, it will be added as page id [%d]",pageIdx,pageCount);
|
||||
}
|
||||
Layout* newPage = createPage();
|
||||
UILayout* newPage = createPage();
|
||||
newPage->addChild(widget);
|
||||
addPage(newPage);
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
Layout * page = dynamic_cast<Layout*>(_pages->getObjectAtIndex(pageIdx));
|
||||
UILayout * page = dynamic_cast<UILayout*>(_pages->getObjectAtIndex(pageIdx));
|
||||
if (page)
|
||||
{
|
||||
page->addChild(widget);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
Layout* UIPageView::createPage()
|
||||
UILayout* UIPageView::createPage()
|
||||
{
|
||||
Layout* newPage = Layout::create();
|
||||
UILayout* newPage = UILayout::create();
|
||||
newPage->setSize(getSize());
|
||||
return newPage;
|
||||
}
|
||||
|
||||
void UIPageView::addPage(Layout* page)
|
||||
void UIPageView::addPage(UILayout* page)
|
||||
{
|
||||
if (!page)
|
||||
{
|
||||
|
@ -132,20 +134,20 @@ void UIPageView::addPage(Layout* page)
|
|||
{
|
||||
return;
|
||||
}
|
||||
Size pSize = page->getSize();
|
||||
Size pvSize = getSize();
|
||||
cocos2d::Size pSize = page->getSize();
|
||||
cocos2d::Size pvSize = getSize();
|
||||
if (!pSize.equals(pvSize))
|
||||
{
|
||||
CCLOG("page size does not match pageview size, it will be force sized!");
|
||||
page->setSize(pvSize);
|
||||
}
|
||||
page->setPosition(Point(getPositionXByIndex(_pages->count()), 0));
|
||||
page->setPosition(cocos2d::Point(getPositionXByIndex(_pages->count()), 0));
|
||||
_pages->addObject(page);
|
||||
addChild(page);
|
||||
updateBoundaryPages();
|
||||
}
|
||||
|
||||
void UIPageView::insertPage(Layout* page, int idx)
|
||||
void UIPageView::insertPage(UILayout* page, int idx)
|
||||
{
|
||||
if (idx < 0)
|
||||
{
|
||||
|
@ -172,27 +174,27 @@ void UIPageView::insertPage(Layout* page, int idx)
|
|||
else
|
||||
{
|
||||
_pages->insertObject(page, idx);
|
||||
page->setPosition(Point(getPositionXByIndex(idx), 0));
|
||||
page->setPosition(cocos2d::Point(getPositionXByIndex(idx), 0));
|
||||
addChild(page);
|
||||
Size pSize = page->getSize();
|
||||
Size pvSize = getSize();
|
||||
cocos2d::Size pSize = page->getSize();
|
||||
cocos2d::Size pvSize = getSize();
|
||||
if (!pSize.equals(pvSize))
|
||||
{
|
||||
CCLOG("page size does not match pageview size, it will be force sized!");
|
||||
page->setSize(pvSize);
|
||||
}
|
||||
ccArray* arrayPages = _pages->data;
|
||||
cocos2d::ccArray* arrayPages = _pages->data;
|
||||
int length = arrayPages->num;
|
||||
for (int i=(idx+1); i<length; i++) {
|
||||
UIWidget* behindPage = dynamic_cast<UIWidget*>(arrayPages->arr[i]);
|
||||
Point formerPos = behindPage->getPosition();
|
||||
behindPage->setPosition(Point(formerPos.x+getSize().width, 0));
|
||||
cocos2d::Point formerPos = behindPage->getPosition();
|
||||
behindPage->setPosition(cocos2d::Point(formerPos.x+getSize().width, 0));
|
||||
}
|
||||
updateBoundaryPages();
|
||||
}
|
||||
}
|
||||
|
||||
void UIPageView::removePage(Layout* page)
|
||||
void UIPageView::removePage(UILayout* page)
|
||||
{
|
||||
if (!page)
|
||||
{
|
||||
|
@ -209,7 +211,7 @@ void UIPageView::removePageAtIndex(int index)
|
|||
{
|
||||
return;
|
||||
}
|
||||
Layout* page = dynamic_cast<Layout*>(_pages->getObjectAtIndex(index));
|
||||
UILayout* page = dynamic_cast<UILayout*>(_pages->getObjectAtIndex(index));
|
||||
if (page)
|
||||
{
|
||||
removePage(page);
|
||||
|
@ -222,6 +224,7 @@ void UIPageView::updateBoundaryPages()
|
|||
{
|
||||
_leftChild = NULL;
|
||||
_rightChild = NULL;
|
||||
return;
|
||||
}
|
||||
_leftChild = dynamic_cast<UIWidget*>(_pages->getObjectAtIndex(0));
|
||||
_rightChild = dynamic_cast<UIWidget*>(_pages->getLastObject());
|
||||
|
@ -234,7 +237,7 @@ float UIPageView::getPositionXByIndex(int idx)
|
|||
|
||||
bool UIPageView::addChild(UIWidget* widget)
|
||||
{
|
||||
return Layout::addChild(widget);
|
||||
return UILayout::addChild(widget);
|
||||
}
|
||||
|
||||
bool UIPageView::removeChild(UIWidget* widget)
|
||||
|
@ -242,14 +245,14 @@ bool UIPageView::removeChild(UIWidget* widget)
|
|||
if (_pages->containsObject(widget))
|
||||
{
|
||||
_pages->removeObject(widget);
|
||||
return Layout::removeChild(widget);
|
||||
return UILayout::removeChild(widget);
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
void UIPageView::onSizeChanged()
|
||||
{
|
||||
Layout::onSizeChanged();
|
||||
UILayout::onSizeChanged();
|
||||
_rightBoundary = getSize().width;
|
||||
updateChildrenSize();
|
||||
updateChildrenPosition();
|
||||
|
@ -262,10 +265,10 @@ void UIPageView::updateChildrenSize()
|
|||
return;
|
||||
}
|
||||
|
||||
Size selfSize = getSize();
|
||||
for (int i = 0; i < _pages->count(); i++)
|
||||
cocos2d::Size selfSize = getSize();
|
||||
for (unsigned int i=0; i<_pages->count(); i++)
|
||||
{
|
||||
Layout* page = dynamic_cast<Layout*>(_pages->getObjectAtIndex(i));
|
||||
UILayout* page = dynamic_cast<UILayout*>(_pages->getObjectAtIndex(i));
|
||||
page->setSize(selfSize);
|
||||
}
|
||||
}
|
||||
|
@ -288,18 +291,18 @@ void UIPageView::updateChildrenPosition()
|
|||
_curPageIdx = pageCount-1;
|
||||
}
|
||||
float pageWidth = getSize().width;
|
||||
ccArray* arrayPages = _pages->data;
|
||||
cocos2d::ccArray* arrayPages = _pages->data;
|
||||
for (int i=0; i<pageCount; i++)
|
||||
{
|
||||
Layout* page = dynamic_cast<Layout*>(arrayPages->arr[i]);
|
||||
page->setPosition(Point((i-_curPageIdx)*pageWidth, 0));
|
||||
UILayout* page = dynamic_cast<UILayout*>(arrayPages->arr[i]);
|
||||
page->setPosition(cocos2d::Point((i-_curPageIdx)*pageWidth, 0));
|
||||
}
|
||||
}
|
||||
|
||||
void UIPageView::removeAllChildren()
|
||||
{
|
||||
_pages->removeAllObjects();
|
||||
Layout::removeAllChildren();
|
||||
UILayout::removeAllChildren();
|
||||
}
|
||||
|
||||
void UIPageView::scrollToPage(int idx)
|
||||
|
@ -330,13 +333,16 @@ void UIPageView::update(float dt)
|
|||
step = -_autoScrollDistance;
|
||||
_autoScrollDistance = 0.0f;
|
||||
_isAutoScrolling = false;
|
||||
pageTurningEvent();
|
||||
}
|
||||
else
|
||||
{
|
||||
_autoScrollDistance += step;
|
||||
}
|
||||
scrollPages(-step);
|
||||
if (!_isAutoScrolling)
|
||||
{
|
||||
pageTurningEvent();
|
||||
}
|
||||
break;
|
||||
}
|
||||
break;
|
||||
|
@ -348,13 +354,16 @@ void UIPageView::update(float dt)
|
|||
step = _autoScrollDistance;
|
||||
_autoScrollDistance = 0.0f;
|
||||
_isAutoScrolling = false;
|
||||
pageTurningEvent();
|
||||
}
|
||||
else
|
||||
{
|
||||
_autoScrollDistance -= step;
|
||||
}
|
||||
scrollPages(step);
|
||||
if (!_isAutoScrolling)
|
||||
{
|
||||
pageTurningEvent();
|
||||
}
|
||||
break;
|
||||
}
|
||||
default:
|
||||
|
@ -363,14 +372,14 @@ void UIPageView::update(float dt)
|
|||
}
|
||||
}
|
||||
|
||||
bool UIPageView::onTouchBegan(const Point &touchPoint)
|
||||
bool UIPageView::onTouchBegan(const cocos2d::Point &touchPoint)
|
||||
{
|
||||
bool pass = Layout::onTouchBegan(touchPoint);
|
||||
bool pass = UILayout::onTouchBegan(touchPoint);
|
||||
handlePressLogic(touchPoint);
|
||||
return pass;
|
||||
}
|
||||
|
||||
void UIPageView::onTouchMoved(const Point &touchPoint)
|
||||
void UIPageView::onTouchMoved(const cocos2d::Point &touchPoint)
|
||||
{
|
||||
_touchMovePos.x = touchPoint.x;
|
||||
_touchMovePos.y = touchPoint.y;
|
||||
|
@ -387,15 +396,15 @@ void UIPageView::onTouchMoved(const Point &touchPoint)
|
|||
}
|
||||
}
|
||||
|
||||
void UIPageView::onTouchEnded(const Point &touchPoint)
|
||||
void UIPageView::onTouchEnded(const cocos2d::Point &touchPoint)
|
||||
{
|
||||
Layout::onTouchEnded(touchPoint);
|
||||
UILayout::onTouchEnded(touchPoint);
|
||||
handleReleaseLogic(touchPoint);
|
||||
}
|
||||
|
||||
void UIPageView::movePages(float offset)
|
||||
{
|
||||
ccArray* arrayPages = _pages->data;
|
||||
cocos2d::ccArray* arrayPages = _pages->data;
|
||||
int length = arrayPages->num;
|
||||
for (int i = 0; i < length; i++)
|
||||
{
|
||||
|
@ -447,21 +456,21 @@ bool UIPageView::scrollPages(float touchOffset)
|
|||
return true;
|
||||
}
|
||||
|
||||
void UIPageView::onTouchCancelled(const Point &touchPoint)
|
||||
void UIPageView::onTouchCancelled(const cocos2d::Point &touchPoint)
|
||||
{
|
||||
Layout::onTouchCancelled(touchPoint);
|
||||
UILayout::onTouchCancelled(touchPoint);
|
||||
}
|
||||
|
||||
void UIPageView::handlePressLogic(const Point &touchPoint)
|
||||
void UIPageView::handlePressLogic(const cocos2d::Point &touchPoint)
|
||||
{
|
||||
Point nsp = _renderer->convertToNodeSpace(touchPoint);
|
||||
cocos2d::Point nsp = _renderer->convertToNodeSpace(touchPoint);
|
||||
_touchMoveStartLocation = nsp.x;
|
||||
_touchStartLocation = nsp.x;
|
||||
}
|
||||
|
||||
void UIPageView::handleMoveLogic(const Point &touchPoint)
|
||||
void UIPageView::handleMoveLogic(const cocos2d::Point &touchPoint)
|
||||
{
|
||||
Point nsp = _renderer->convertToNodeSpace(touchPoint);
|
||||
cocos2d::Point nsp = _renderer->convertToNodeSpace(touchPoint);
|
||||
float offset = 0.0;
|
||||
float moveX = nsp.x;
|
||||
offset = moveX - _touchMoveStartLocation;
|
||||
|
@ -477,12 +486,16 @@ void UIPageView::handleMoveLogic(const Point &touchPoint)
|
|||
scrollPages(offset);
|
||||
}
|
||||
|
||||
void UIPageView::handleReleaseLogic(const Point &touchPoint)
|
||||
void UIPageView::handleReleaseLogic(const cocos2d::Point &touchPoint)
|
||||
{
|
||||
if (_pages->count() <= 0)
|
||||
{
|
||||
return;
|
||||
}
|
||||
UIWidget* curPage = dynamic_cast<UIWidget*>(_pages->getObjectAtIndex(_curPageIdx));
|
||||
if (curPage)
|
||||
{
|
||||
Point curPagePos = curPage->getPosition();
|
||||
cocos2d::Point curPagePos = curPage->getPosition();
|
||||
int pageCount = _pages->count();
|
||||
float curPageLocation = curPagePos.x;
|
||||
float pageWidth = getSize().width;
|
||||
|
@ -516,12 +529,12 @@ void UIPageView::handleReleaseLogic(const Point &touchPoint)
|
|||
}
|
||||
}
|
||||
|
||||
void UIPageView::checkChildInfo(int handleState,UIWidget* sender, const Point &touchPoint)
|
||||
void UIPageView::checkChildInfo(int handleState,UIWidget* sender, const cocos2d::Point &touchPoint)
|
||||
{
|
||||
interceptTouchEvent(handleState, sender, touchPoint);
|
||||
}
|
||||
|
||||
void UIPageView::interceptTouchEvent(int handleState, UIWidget *sender, const Point &touchPoint)
|
||||
void UIPageView::interceptTouchEvent(int handleState, UIWidget *sender, const cocos2d::Point &touchPoint)
|
||||
{
|
||||
switch (handleState)
|
||||
{
|
||||
|
@ -556,7 +569,7 @@ void UIPageView::pageTurningEvent()
|
|||
}
|
||||
}
|
||||
|
||||
void UIPageView::addEventListener(Object *target, SEL_PageViewEvent selector)
|
||||
void UIPageView::addEventListener(cocos2d::Object *target, SEL_PageViewEvent selector)
|
||||
{
|
||||
_eventListener = target;
|
||||
_eventSelector = selector;
|
||||
|
@ -567,9 +580,39 @@ int UIPageView::getCurPageIndex() const
|
|||
return _curPageIdx;
|
||||
}
|
||||
|
||||
cocos2d::Array* UIPageView::getPages()
|
||||
{
|
||||
return _pages;
|
||||
}
|
||||
|
||||
const char* UIPageView::getDescription() const
|
||||
{
|
||||
return "PageView";
|
||||
}
|
||||
|
||||
UIWidget* UIPageView::createCloneInstance()
|
||||
{
|
||||
return UIPageView::create();
|
||||
}
|
||||
|
||||
void UIPageView::copyClonedWidgetChildren(UIWidget* model)
|
||||
{
|
||||
cocos2d::ccArray* arrayPages = dynamic_cast<UIPageView*>(model)->getPages()->data;
|
||||
int length = arrayPages->num;
|
||||
for (int i=0; i<length; i++)
|
||||
{
|
||||
UILayout* page = (UILayout*)(arrayPages->arr[i]);
|
||||
addPage(dynamic_cast<UILayout*>(page->clone()));
|
||||
}
|
||||
}
|
||||
|
||||
void UIPageView::copySpecialProperties(UIWidget *widget)
|
||||
{
|
||||
UIPageView* pageView = dynamic_cast<UIPageView*>(widget);
|
||||
if (pageView)
|
||||
{
|
||||
UILayout::copySpecialProperties(widget);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
|
@ -25,7 +25,7 @@
|
|||
#ifndef __UIPAGEVIEW_H__
|
||||
#define __UIPAGEVIEW_H__
|
||||
|
||||
#include "gui/Layout.h"
|
||||
#include "gui/UILayout.h"
|
||||
#include "gui/UIScrollInterface.h"
|
||||
|
||||
namespace gui {
|
||||
|
@ -43,7 +43,7 @@ typedef enum {
|
|||
PAGEVIEW_TOUCHRIGHT
|
||||
}PVTouchDir;
|
||||
|
||||
class UIPageView : public Layout , public UIScrollInterface
|
||||
class UIPageView : public UILayout , public UIScrollInterface
|
||||
{
|
||||
|
||||
public:
|
||||
|
@ -78,21 +78,21 @@ public:
|
|||
*
|
||||
* @param page page to be added to pageview.
|
||||
*/
|
||||
void addPage(Layout* page);
|
||||
void addPage(UILayout* page);
|
||||
|
||||
/**
|
||||
* Inert a page to pageview.
|
||||
*
|
||||
* @param page page to be added to pageview.
|
||||
*/
|
||||
void insertPage(Layout* page, int idx);
|
||||
void insertPage(UILayout* page, int idx);
|
||||
|
||||
/**
|
||||
* Remove a page of pageview.
|
||||
*
|
||||
* @param page page which will be removed.
|
||||
*/
|
||||
void removePage(Layout* page);
|
||||
void removePage(UILayout* page);
|
||||
|
||||
/**
|
||||
* Remove a page at index of pageview.
|
||||
|
@ -115,8 +115,11 @@ public:
|
|||
*/
|
||||
int getCurPageIndex() const;
|
||||
|
||||
cocos2d::Array* getPages();
|
||||
|
||||
// event
|
||||
void addEventListener(cocos2d::Object *target, SEL_PageViewEvent selector);
|
||||
|
||||
|
||||
//override "removeChild" method of widget.
|
||||
virtual bool removeChild(UIWidget* widget);
|
||||
|
@ -140,15 +143,16 @@ public:
|
|||
virtual void update(float dt);
|
||||
|
||||
virtual void doLayout(){};
|
||||
|
||||
|
||||
/**
|
||||
* Returns the "class name" of widget.
|
||||
*/
|
||||
virtual const char* getDescription() const;
|
||||
|
||||
protected:
|
||||
virtual bool addChild(UIWidget* widget);
|
||||
virtual bool init();
|
||||
Layout* createPage();
|
||||
UILayout* createPage();
|
||||
float getPositionXByIndex(int idx);
|
||||
void updateBoundaryPages();
|
||||
virtual void handlePressLogic(const cocos2d::Point &touchPoint);
|
||||
|
@ -162,14 +166,15 @@ protected:
|
|||
void updateChildrenSize();
|
||||
void updateChildrenPosition();
|
||||
virtual void onSizeChanged();
|
||||
|
||||
virtual void setClippingEnabled(bool able){Layout::setClippingEnabled(able);};
|
||||
virtual UIWidget* createCloneInstance();
|
||||
virtual void copySpecialProperties(UIWidget* model);
|
||||
virtual void copyClonedWidgetChildren(UIWidget* model);
|
||||
virtual void setClippingEnabled(bool able){UILayout::setClippingEnabled(able);};
|
||||
protected:
|
||||
int _curPageIdx;
|
||||
cocos2d::Array* _pages;
|
||||
PVTouchDir _touchMoveDir;
|
||||
float _touchStartLocation;
|
||||
float _touchEndLocation;
|
||||
float _touchMoveStartLocation;
|
||||
cocos2d::Point _movePagePoint;
|
||||
UIWidget* _leftChild;
|
||||
|
@ -183,6 +188,7 @@ protected:
|
|||
float _childFocusCancelOffset;
|
||||
cocos2d::Object* _eventListener;
|
||||
SEL_PageViewEvent _eventSelector;
|
||||
|
||||
};
|
||||
|
||||
}
|
||||
|
|
|
@ -24,8 +24,6 @@
|
|||
|
||||
#include "gui/UIRootWidget.h"
|
||||
|
||||
using namespace cocos2d;
|
||||
|
||||
namespace gui {
|
||||
|
||||
UIRootWidget::UIRootWidget()
|
||||
|
@ -50,9 +48,9 @@ UIRootWidget* UIRootWidget::create()
|
|||
|
||||
bool UIRootWidget::init()
|
||||
{
|
||||
if (Layout::init())
|
||||
if (UILayout::init())
|
||||
{
|
||||
setSize(Director::getInstance()->getWinSize());
|
||||
setSize(cocos2d::Director::getInstance()->getWinSize());
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
|
|
|
@ -25,11 +25,15 @@
|
|||
#ifndef __UIROOTWIDGET_H__
|
||||
#define __UIROOTWIDGET_H__
|
||||
|
||||
#include "gui/Layout.h"
|
||||
#include "gui/UILayout.h"
|
||||
|
||||
namespace gui {
|
||||
|
||||
class UIRootWidget : public Layout
|
||||
|
||||
/**
|
||||
* @js NA
|
||||
* @lua NA
|
||||
*/
|
||||
class UIRootWidget : public UILayout
|
||||
{
|
||||
public:
|
||||
/**
|
||||
|
|
|
@ -36,7 +36,6 @@ protected:
|
|||
virtual void handleMoveLogic(const cocos2d::Point &touchPoint) = 0;
|
||||
virtual void handleReleaseLogic(const cocos2d::Point &touchPoint) = 0;
|
||||
virtual void interceptTouchEvent(int handleState, UIWidget* sender, const cocos2d::Point &touchPoint) = 0;
|
||||
// virtual bool isInScrollDegreeRange(UIWidget* widget) = 0;
|
||||
};
|
||||
|
||||
}
|
||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -25,7 +25,7 @@
|
|||
#ifndef __UISCROLLVIEW_H__
|
||||
#define __UISCROLLVIEW_H__
|
||||
|
||||
#include "gui//Layout.h"
|
||||
#include "gui/UILayout.h"
|
||||
#include "gui/UIScrollInterface.h"
|
||||
|
||||
namespace gui {
|
||||
|
@ -34,16 +34,8 @@ enum SCROLLVIEW_DIR
|
|||
{
|
||||
SCROLLVIEW_DIR_NONE,
|
||||
SCROLLVIEW_DIR_VERTICAL,
|
||||
SCROLLVIEW_DIR_HORIZONTAL
|
||||
};
|
||||
|
||||
enum SCROLLVIEW_MOVE_DIR
|
||||
{
|
||||
SCROLLVIEW_MOVE_DIR_NONE,
|
||||
SCROLLVIEW_MOVE_DIR_UP,
|
||||
SCROLLVIEW_MOVE_DIR_DOWN,
|
||||
SCROLLVIEW_MOVE_DIR_LEFT,
|
||||
SCROLLVIEW_MOVE_DIR_RIGHT,
|
||||
SCROLLVIEW_DIR_HORIZONTAL,
|
||||
SCROLLVIEW_DIR_BOTH
|
||||
};
|
||||
|
||||
typedef enum
|
||||
|
@ -52,13 +44,18 @@ typedef enum
|
|||
SCROLLVIEW_EVENT_SCROLL_TO_BOTTOM,
|
||||
SCROLLVIEW_EVENT_SCROLL_TO_LEFT,
|
||||
SCROLLVIEW_EVENT_SCROLL_TO_RIGHT,
|
||||
SCROLLVIEW_EVENT_SCROLLING,
|
||||
SCROLLVIEW_EVENT_BOUNCE_TOP,
|
||||
SCROLLVIEW_EVENT_BOUNCE_BOTTOM,
|
||||
SCROLLVIEW_EVENT_BOUNCE_LEFT,
|
||||
SCROLLVIEW_EVENT_BOUNCE_RIGHT
|
||||
}ScrollviewEventType;
|
||||
|
||||
typedef void (cocos2d::Object::*SEL_ScrollViewEvent)(cocos2d::Object*, ScrollviewEventType);
|
||||
typedef void (cocos2d::CCObject::*SEL_ScrollViewEvent)(cocos2d::Object*, ScrollviewEventType);
|
||||
#define scrollvieweventselector(_SELECTOR) (SEL_ScrollViewEvent)(&_SELECTOR)
|
||||
|
||||
|
||||
class UIScrollView : public Layout , public UIScrollInterface
|
||||
class UIScrollView : public UILayout , public UIScrollInterface
|
||||
{
|
||||
public:
|
||||
/**
|
||||
|
@ -83,7 +80,7 @@ public:
|
|||
*
|
||||
* @param SCROLLVIEW_DIR
|
||||
*/
|
||||
void setDirection(SCROLLVIEW_DIR dir);
|
||||
virtual void setDirection(SCROLLVIEW_DIR dir);
|
||||
|
||||
/**
|
||||
* Gets scroll direction of scrollview.
|
||||
|
@ -101,17 +98,117 @@ public:
|
|||
*
|
||||
* @return inner container.
|
||||
*/
|
||||
Layout* getInnerContainer();
|
||||
UILayout* getInnerContainer();
|
||||
|
||||
/**
|
||||
* Scroll inner container to bottom boundary of scrollview.
|
||||
*/
|
||||
void scrollToBottom();
|
||||
void scrollToBottom(float time, bool attenuated);
|
||||
|
||||
/**
|
||||
* Scroll inner container to top boundary of scrollview.
|
||||
*/
|
||||
void scrollToTop();
|
||||
void scrollToTop(float time, bool attenuated);
|
||||
|
||||
/**
|
||||
* Scroll inner container to left boundary of scrollview.
|
||||
*/
|
||||
void scrollToLeft(float time, bool attenuated);
|
||||
|
||||
/**
|
||||
* Scroll inner container to right boundary of scrollview.
|
||||
*/
|
||||
void scrollToRight(float time, bool attenuated);
|
||||
|
||||
/**
|
||||
* Scroll inner container to top and left boundary of scrollview.
|
||||
*/
|
||||
void scrollToTopLeft(float time, bool attenuated);
|
||||
|
||||
/**
|
||||
* Scroll inner container to top and right boundary of scrollview.
|
||||
*/
|
||||
void scrollToTopRight(float time, bool attenuated);
|
||||
|
||||
/**
|
||||
* Scroll inner container to bottom and left boundary of scrollview.
|
||||
*/
|
||||
void scrollToBottomLeft(float time, bool attenuated);
|
||||
|
||||
/**
|
||||
* Scroll inner container to bottom and right boundary of scrollview.
|
||||
*/
|
||||
void scrollToBottomRight(float time, bool attenuated);
|
||||
|
||||
/**
|
||||
* Scroll inner container to vertical percent position of scrollview.
|
||||
*/
|
||||
void scrollToPercentVertical(float percent, float time, bool attenuated);
|
||||
|
||||
/**
|
||||
* Scroll inner container to horizontal percent position of scrollview.
|
||||
*/
|
||||
void scrollToPercentHorizontal(float percent, float time, bool attenuated);
|
||||
|
||||
/**
|
||||
* Scroll inner container to both direction percent position of scrollview.
|
||||
*/
|
||||
void scrollToPercentBothDirection(const cocos2d::Point& percent, float time, bool attenuated);
|
||||
|
||||
/**
|
||||
* Move inner container to bottom boundary of scrollview.
|
||||
*/
|
||||
void jumpToBottom();
|
||||
|
||||
/**
|
||||
* Move inner container to top boundary of scrollview.
|
||||
*/
|
||||
void jumpToTop();
|
||||
|
||||
/**
|
||||
* Move inner container to left boundary of scrollview.
|
||||
*/
|
||||
void jumpToLeft();
|
||||
|
||||
/**
|
||||
* Move inner container to right boundary of scrollview.
|
||||
*/
|
||||
void jumpToRight();
|
||||
|
||||
/**
|
||||
* Move inner container to top and left boundary of scrollview.
|
||||
*/
|
||||
void jumpToTopLeft();
|
||||
|
||||
/**
|
||||
* Move inner container to top and right boundary of scrollview.
|
||||
*/
|
||||
void jumpToTopRight();
|
||||
|
||||
/**
|
||||
* Move inner container to bottom and left boundary of scrollview.
|
||||
*/
|
||||
void jumpToBottomLeft();
|
||||
|
||||
/**
|
||||
* Move inner container to bottom and right boundary of scrollview.
|
||||
*/
|
||||
void jumpToBottomRight();
|
||||
|
||||
/**
|
||||
* Move inner container to vertical percent position of scrollview.
|
||||
*/
|
||||
void jumpToPercentVertical(float percent);
|
||||
|
||||
/**
|
||||
* Move inner container to horizontal percent position of scrollview.
|
||||
*/
|
||||
void jumpToPercentHorizontal(float percent);
|
||||
|
||||
/**
|
||||
* Move inner container to both direction percent position of scrollview.
|
||||
*/
|
||||
void jumpToPercentBothDirection(const cocos2d::Point& percent);
|
||||
|
||||
/**
|
||||
* Changes inner container size of scrollview.
|
||||
|
@ -134,7 +231,7 @@ public:
|
|||
/**
|
||||
* Add call back function called scrollview event triggered
|
||||
*/
|
||||
void addEventListener(cocos2d::Object* target, SEL_ScrollViewEvent selector);
|
||||
void addEventListener(cocos2d::Object* target, SEL_ScrollViewEvent selector);
|
||||
|
||||
//override "addChild" method of widget.
|
||||
virtual bool addChild(UIWidget* widget);
|
||||
|
@ -165,6 +262,14 @@ public:
|
|||
|
||||
virtual void update(float dt);
|
||||
|
||||
void setBounceEnabled(bool enabled);
|
||||
|
||||
bool isBounceEnabled() const;
|
||||
|
||||
void setInertiaScrollEnabled(bool enabled);
|
||||
|
||||
bool isInertiaScrollEnabled() const;
|
||||
|
||||
/**
|
||||
* Sets LayoutType.
|
||||
*
|
||||
|
@ -192,12 +297,20 @@ public:
|
|||
protected:
|
||||
virtual bool init();
|
||||
virtual void initRenderer();
|
||||
void moveChildren(float offset);
|
||||
void moveChildren(float offsetX, float offsetY);
|
||||
void autoScrollChildren(float dt);
|
||||
void startAutoScrollChildren(float v);
|
||||
void bounceChildren(float dt);
|
||||
void checkBounceBoundary();
|
||||
bool checkNeedBounce();
|
||||
void startAutoScrollChildrenWithOriginalSpeed(const cocos2d::Point& dir, float v, bool attenuated, float acceleration);
|
||||
void startAutoScrollChildrenWithDestination(const cocos2d::Point& des, float time, bool attenuated);
|
||||
void jumpToDestination(const cocos2d::Point& des);
|
||||
void stopAutoScrollChildren();
|
||||
float getCurAutoScrollDistance(float time);
|
||||
virtual bool scrollChildren(float touchOffset);
|
||||
void startBounceChildren(float v);
|
||||
void stopBounceChildren();
|
||||
bool checkCustomScrollDestination(float* touchOffsetX, float* touchOffsetY);
|
||||
virtual bool scrollChildren(float touchOffsetX, float touchOffsetY);
|
||||
bool bounceScrollChildren(float touchOffsetX, float touchOffsetY);
|
||||
void startRecordSlidAction();
|
||||
virtual void endRecordSlidAction();
|
||||
virtual void handlePressLogic(const cocos2d::Point &touchPoint);
|
||||
|
@ -206,48 +319,71 @@ protected:
|
|||
virtual void interceptTouchEvent(int handleState,UIWidget* sender,const cocos2d::Point &touchPoint);
|
||||
virtual void checkChildInfo(int handleState,UIWidget* sender,const cocos2d::Point &touchPoint);
|
||||
void recordSlidTime(float dt);
|
||||
//override "releaseResoures" method of widget.
|
||||
virtual void releaseResoures();
|
||||
|
||||
void scrollToTopEvent();
|
||||
void scrollToBottomEvent();
|
||||
void scrollToLeftEvent();
|
||||
void scrollToRightEvent();
|
||||
void setMoveDirection(SCROLLVIEW_MOVE_DIR dir);
|
||||
SCROLLVIEW_MOVE_DIR getMoveDirection();
|
||||
void scrollingEvent();
|
||||
void bounceTopEvent();
|
||||
void bounceBottomEvent();
|
||||
void bounceLeftEvent();
|
||||
void bounceRightEvent();
|
||||
virtual void onSizeChanged();
|
||||
virtual void setClippingEnabled(bool able){Layout::setClippingEnabled(able);};
|
||||
virtual UIWidget* createCloneInstance();
|
||||
virtual void copySpecialProperties(UIWidget* model);
|
||||
virtual void copyClonedWidgetChildren(UIWidget* model);
|
||||
virtual void setClippingEnabled(bool able){UILayout::setClippingEnabled(able);};
|
||||
protected:
|
||||
Layout* _innerContainer;
|
||||
UILayout* _innerContainer;
|
||||
|
||||
SCROLLVIEW_DIR _direction;
|
||||
SCROLLVIEW_MOVE_DIR _moveDirection;
|
||||
float _touchStartLocation;
|
||||
float _touchEndLocation;
|
||||
float _touchMoveStartLocation;
|
||||
float _topBoundary;//test
|
||||
float _bottomBoundary;//test
|
||||
|
||||
cocos2d::Point _touchBeganPoint;
|
||||
cocos2d::Point _touchMovedPoint;
|
||||
cocos2d::Point _touchEndedPoint;
|
||||
cocos2d::Point _touchMovingPoint;
|
||||
cocos2d::Point _autoScrollDir;
|
||||
|
||||
float _topBoundary;
|
||||
float _bottomBoundary;
|
||||
float _leftBoundary;
|
||||
float _rightBoundary;
|
||||
|
||||
bool _topEnd;
|
||||
bool _bottomEnd;
|
||||
bool _leftEnd;
|
||||
bool _rightEnd;
|
||||
float _bounceTopBoundary;
|
||||
float _bounceBottomBoundary;
|
||||
float _bounceLeftBoundary;
|
||||
float _bounceRightBoundary;
|
||||
|
||||
|
||||
bool _autoScroll;
|
||||
float _autoScrollAddUpTime;
|
||||
|
||||
float _autoScrollOriginalSpeed;
|
||||
float _autoScrollAcceleration;
|
||||
bool _isAutoScrollSpeedAttenuated;
|
||||
bool _needCheckAutoScrollDestination;
|
||||
cocos2d::Point _autoScrollDestination;
|
||||
|
||||
bool _bePressed;
|
||||
float _slidTime;
|
||||
cocos2d::Point _moveChildPoint;
|
||||
float _childFocusCancelOffset;
|
||||
|
||||
bool _leftBounceNeeded;
|
||||
bool _topBounceNeeded;
|
||||
bool _rightBounceNeeded;
|
||||
bool _bottomBounceNeeded;
|
||||
|
||||
bool _bounceEnabled;
|
||||
bool _bouncing;
|
||||
cocos2d::Point _bounceDir;
|
||||
float _bounceOriginalSpeed;
|
||||
bool _inertiaScrollEnabled;
|
||||
|
||||
|
||||
|
||||
cocos2d::Object* _eventListener;
|
||||
SEL_ScrollViewEvent _eventSelector;
|
||||
|
||||
};
|
||||
|
||||
}
|
||||
|
|
|
@ -25,15 +25,12 @@
|
|||
#include "gui/UISlider.h"
|
||||
#include "extensions/GUI/CCControlExtension/CCScale9Sprite.h"
|
||||
|
||||
using namespace cocos2d;
|
||||
using namespace cocos2d::extension;
|
||||
|
||||
namespace gui {
|
||||
|
||||
UISlider::UISlider():
|
||||
_barRenderer(NULL),
|
||||
_progressBarRenderer(NULL),
|
||||
_progressBarTextureSize(Size::ZERO),
|
||||
_progressBarTextureSize(cocos2d::Size::ZERO),
|
||||
_slidBallNormalRenderer(NULL),
|
||||
_slidBallPressedRenderer(NULL),
|
||||
_slidBallDisabledRenderer(NULL),
|
||||
|
@ -47,8 +44,8 @@ _progressBarTextureFile(""),
|
|||
_slidBallNormalTextureFile(""),
|
||||
_slidBallPressedTextureFile(""),
|
||||
_slidBallDisabledTextureFile(""),
|
||||
_capInsetsBarRenderer(Rect::ZERO),
|
||||
_capInsetsProgressBarRenderer(Rect::ZERO),
|
||||
_capInsetsBarRenderer(cocos2d::Rect::ZERO),
|
||||
_capInsetsProgressBarRenderer(cocos2d::Rect::ZERO),
|
||||
_slidPercentListener(NULL),
|
||||
_slidPercentSelector(NULL),
|
||||
_barTexType(UI_TEX_TYPE_LOCAL),
|
||||
|
@ -79,17 +76,17 @@ UISlider* UISlider::create()
|
|||
void UISlider::initRenderer()
|
||||
{
|
||||
UIWidget::initRenderer();
|
||||
_barRenderer = CCSprite::create();
|
||||
_progressBarRenderer = CCSprite::create();
|
||||
_progressBarRenderer->setAnchorPoint(Point(0.0f, 0.5f));
|
||||
_barRenderer = cocos2d::Sprite::create();
|
||||
_progressBarRenderer = cocos2d::Sprite::create();
|
||||
_progressBarRenderer->setAnchorPoint(cocos2d::Point(0.0f, 0.5f));
|
||||
_renderer->addChild(_barRenderer, -1);
|
||||
_renderer->addChild(_progressBarRenderer, -1);
|
||||
_slidBallNormalRenderer = CCSprite::create();
|
||||
_slidBallPressedRenderer = CCSprite::create();
|
||||
_slidBallNormalRenderer = cocos2d::Sprite::create();
|
||||
_slidBallPressedRenderer = cocos2d::Sprite::create();
|
||||
_slidBallPressedRenderer->setVisible(false);
|
||||
_slidBallDisabledRenderer = CCSprite::create();
|
||||
_slidBallDisabledRenderer = cocos2d::Sprite::create();
|
||||
_slidBallDisabledRenderer->setVisible(false);
|
||||
_slidBallRenderer = CCNode::create();
|
||||
_slidBallRenderer = cocos2d::Node::create();
|
||||
_slidBallRenderer->addChild(_slidBallNormalRenderer);
|
||||
_slidBallRenderer->addChild(_slidBallPressedRenderer);
|
||||
_slidBallRenderer->addChild(_slidBallDisabledRenderer);
|
||||
|
@ -109,21 +106,21 @@ void UISlider::loadBarTexture(const char* fileName, TextureResType texType)
|
|||
case UI_TEX_TYPE_LOCAL:
|
||||
if (_scale9Enabled)
|
||||
{
|
||||
dynamic_cast<Scale9Sprite*>(_barRenderer)->initWithFile(fileName);
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_barRenderer)->initWithFile(fileName);
|
||||
}
|
||||
else
|
||||
{
|
||||
dynamic_cast<Sprite*>(_barRenderer)->initWithFile(fileName);
|
||||
dynamic_cast<cocos2d::Sprite*>(_barRenderer)->initWithFile(fileName);
|
||||
}
|
||||
break;
|
||||
case UI_TEX_TYPE_PLIST:
|
||||
if (_scale9Enabled)
|
||||
{
|
||||
dynamic_cast<Scale9Sprite*>(_barRenderer)->initWithSpriteFrameName(fileName);
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_barRenderer)->initWithSpriteFrameName(fileName);
|
||||
}
|
||||
else
|
||||
{
|
||||
dynamic_cast<Sprite*>(_barRenderer)->initWithSpriteFrameName(fileName);
|
||||
dynamic_cast<cocos2d::Sprite*>(_barRenderer)->initWithSpriteFrameName(fileName);
|
||||
}
|
||||
break;
|
||||
default:
|
||||
|
@ -131,13 +128,13 @@ void UISlider::loadBarTexture(const char* fileName, TextureResType texType)
|
|||
}
|
||||
if (_scale9Enabled)
|
||||
{
|
||||
dynamic_cast<Scale9Sprite*>(_barRenderer)->setColor(getColor());
|
||||
dynamic_cast<Scale9Sprite*>(_barRenderer)->setOpacity(getOpacity());
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_barRenderer)->setColor(getColor());
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_barRenderer)->setOpacity(getOpacity());
|
||||
}
|
||||
else
|
||||
{
|
||||
dynamic_cast<Sprite*>(_barRenderer)->setColor(getColor());
|
||||
dynamic_cast<Sprite*>(_barRenderer)->setOpacity(getOpacity());
|
||||
dynamic_cast<cocos2d::Sprite*>(_barRenderer)->setColor(getColor());
|
||||
dynamic_cast<cocos2d::Sprite*>(_barRenderer)->setOpacity(getOpacity());
|
||||
}
|
||||
barRendererScaleChangedWithSize();
|
||||
}
|
||||
|
@ -155,21 +152,21 @@ void UISlider::loadProgressBarTexture(const char *fileName, TextureResType texTy
|
|||
case UI_TEX_TYPE_LOCAL:
|
||||
if (_scale9Enabled)
|
||||
{
|
||||
dynamic_cast<Scale9Sprite*>(_progressBarRenderer)->initWithFile(fileName);
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_progressBarRenderer)->initWithFile(fileName);
|
||||
}
|
||||
else
|
||||
{
|
||||
dynamic_cast<Sprite*>(_progressBarRenderer)->initWithFile(fileName);
|
||||
dynamic_cast<cocos2d::Sprite*>(_progressBarRenderer)->initWithFile(fileName);
|
||||
}
|
||||
break;
|
||||
case UI_TEX_TYPE_PLIST:
|
||||
if (_scale9Enabled)
|
||||
{
|
||||
dynamic_cast<Scale9Sprite*>(_progressBarRenderer)->initWithSpriteFrameName(fileName);
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_progressBarRenderer)->initWithSpriteFrameName(fileName);
|
||||
}
|
||||
else
|
||||
{
|
||||
dynamic_cast<Sprite*>(_progressBarRenderer)->initWithSpriteFrameName(fileName);
|
||||
dynamic_cast<cocos2d::Sprite*>(_progressBarRenderer)->initWithSpriteFrameName(fileName);
|
||||
}
|
||||
break;
|
||||
default:
|
||||
|
@ -177,15 +174,15 @@ void UISlider::loadProgressBarTexture(const char *fileName, TextureResType texTy
|
|||
}
|
||||
if (_scale9Enabled)
|
||||
{
|
||||
dynamic_cast<Scale9Sprite*>(_progressBarRenderer)->setColor(getColor());
|
||||
dynamic_cast<Scale9Sprite*>(_progressBarRenderer)->setOpacity(getOpacity());
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_progressBarRenderer)->setColor(getColor());
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_progressBarRenderer)->setOpacity(getOpacity());
|
||||
}
|
||||
else
|
||||
{
|
||||
dynamic_cast<Sprite*>(_progressBarRenderer)->setColor(getColor());
|
||||
dynamic_cast<Sprite*>(_progressBarRenderer)->setOpacity(getOpacity());
|
||||
dynamic_cast<cocos2d::Sprite*>(_progressBarRenderer)->setColor(getColor());
|
||||
dynamic_cast<cocos2d::Sprite*>(_progressBarRenderer)->setOpacity(getOpacity());
|
||||
}
|
||||
_progressBarRenderer->setAnchorPoint(Point(0.0f, 0.5f));
|
||||
_progressBarRenderer->setAnchorPoint(cocos2d::Point(0.0f, 0.5f));
|
||||
_progressBarTextureSize = _progressBarRenderer->getContentSize();
|
||||
progressBarRendererScaleChangedWithSize();
|
||||
}
|
||||
|
@ -204,13 +201,13 @@ void UISlider::setScale9Enabled(bool able)
|
|||
_progressBarRenderer = NULL;
|
||||
if (_scale9Enabled)
|
||||
{
|
||||
_barRenderer = Scale9Sprite::create();
|
||||
_progressBarRenderer = Scale9Sprite::create();
|
||||
_barRenderer = cocos2d::extension::Scale9Sprite::create();
|
||||
_progressBarRenderer = cocos2d::extension::Scale9Sprite::create();
|
||||
}
|
||||
else
|
||||
{
|
||||
_barRenderer = CCSprite::create();
|
||||
_progressBarRenderer = CCSprite::create();
|
||||
_barRenderer = cocos2d::Sprite::create();
|
||||
_progressBarRenderer = cocos2d::Sprite::create();
|
||||
}
|
||||
loadBarTexture(_textureFile.c_str(), _barTexType);
|
||||
loadProgressBarTexture(_progressBarTextureFile.c_str(), _progressBarTexType);
|
||||
|
@ -239,30 +236,30 @@ void UISlider::ignoreContentAdaptWithSize(bool ignore)
|
|||
}
|
||||
}
|
||||
|
||||
void UISlider::setCapInsets(const Rect &capInsets)
|
||||
void UISlider::setCapInsets(const cocos2d::Rect &capInsets)
|
||||
{
|
||||
setCapInsetsBarRenderer(capInsets);
|
||||
setCapInsetProgressBarRebderer(capInsets);
|
||||
}
|
||||
|
||||
void UISlider::setCapInsetsBarRenderer(const Rect &capInsets)
|
||||
void UISlider::setCapInsetsBarRenderer(const cocos2d::Rect &capInsets)
|
||||
{
|
||||
_capInsetsBarRenderer = capInsets;
|
||||
if (!_scale9Enabled)
|
||||
{
|
||||
return;
|
||||
}
|
||||
dynamic_cast<Scale9Sprite*>(_barRenderer)->setCapInsets(capInsets);
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_barRenderer)->setCapInsets(capInsets);
|
||||
}
|
||||
|
||||
void UISlider::setCapInsetProgressBarRebderer(const Rect &capInsets)
|
||||
void UISlider::setCapInsetProgressBarRebderer(const cocos2d::Rect &capInsets)
|
||||
{
|
||||
_capInsetsProgressBarRenderer = capInsets;
|
||||
if (!_scale9Enabled)
|
||||
{
|
||||
return;
|
||||
}
|
||||
dynamic_cast<Scale9Sprite*>(_progressBarRenderer)->setCapInsets(capInsets);
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_progressBarRenderer)->setCapInsets(capInsets);
|
||||
}
|
||||
|
||||
void UISlider::loadSlidBallTextures(const char* normal,const char* pressed,const char* disabled,TextureResType texType)
|
||||
|
@ -353,10 +350,10 @@ void UISlider::setPercent(int percent)
|
|||
}
|
||||
_percent = percent;
|
||||
float dis = _barLength*(percent/100.0f);
|
||||
_slidBallRenderer->setPosition(Point(-_barLength/2.0f + dis, 0.0f));
|
||||
_slidBallRenderer->setPosition(cocos2d::Point(-_barLength/2.0f + dis, 0.0f));
|
||||
if (_scale9Enabled)
|
||||
{
|
||||
dynamic_cast<Scale9Sprite*>(_progressBarRenderer)->setPreferredSize(Size(dis,_progressBarTextureSize.height));
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_progressBarRenderer)->setPreferredSize(cocos2d::Size(dis,_progressBarTextureSize.height));
|
||||
}
|
||||
else
|
||||
{
|
||||
|
@ -365,10 +362,10 @@ void UISlider::setPercent(int percent)
|
|||
{
|
||||
case UI_TEX_TYPE_PLIST:
|
||||
{
|
||||
Sprite* barNode = dynamic_cast<Sprite*>(_progressBarRenderer);
|
||||
cocos2d::Sprite* barNode = dynamic_cast<cocos2d::Sprite*>(_progressBarRenderer);
|
||||
if (barNode)
|
||||
{
|
||||
Point to = barNode->getTextureRect().origin;
|
||||
cocos2d::Point to = barNode->getTextureRect().origin;
|
||||
x = to.x;
|
||||
y = to.y;
|
||||
}
|
||||
|
@ -377,33 +374,33 @@ void UISlider::setPercent(int percent)
|
|||
default:
|
||||
break;
|
||||
}
|
||||
dynamic_cast<Sprite*>(_progressBarRenderer)->setTextureRect(Rect(x, y, _progressBarTextureSize.width * (percent/100.0f), _progressBarTextureSize.height));
|
||||
dynamic_cast<cocos2d::Sprite*>(_progressBarRenderer)->setTextureRect(cocos2d::Rect(x, y, _progressBarTextureSize.width * (percent/100.0f), _progressBarTextureSize.height));
|
||||
}
|
||||
}
|
||||
|
||||
bool UISlider::onTouchBegan(const Point &touchPoint)
|
||||
bool UISlider::onTouchBegan(const cocos2d::Point &touchPoint)
|
||||
{
|
||||
bool pass = UIWidget::onTouchBegan(touchPoint);
|
||||
Point nsp = _renderer->convertToNodeSpace(touchPoint);
|
||||
cocos2d::Point nsp = _renderer->convertToNodeSpace(touchPoint);
|
||||
setPercent(getPercentWithBallPos(nsp.x));
|
||||
percentChangedEvent();
|
||||
return pass;
|
||||
}
|
||||
|
||||
void UISlider::onTouchMoved(const Point &touchPoint)
|
||||
void UISlider::onTouchMoved(const cocos2d::Point &touchPoint)
|
||||
{
|
||||
Point nsp = _renderer->convertToNodeSpace(touchPoint);
|
||||
_slidBallRenderer->setPosition(Point(nsp.x,0));
|
||||
cocos2d::Point nsp = _renderer->convertToNodeSpace(touchPoint);
|
||||
_slidBallRenderer->setPosition(cocos2d::Point(nsp.x,0));
|
||||
setPercent(getPercentWithBallPos(nsp.x));
|
||||
percentChangedEvent();
|
||||
}
|
||||
|
||||
void UISlider::onTouchEnded(const Point &touchPoint)
|
||||
void UISlider::onTouchEnded(const cocos2d::Point &touchPoint)
|
||||
{
|
||||
UIWidget::onTouchEnded(touchPoint);
|
||||
}
|
||||
|
||||
void UISlider::onTouchCancelled(const Point &touchPoint)
|
||||
void UISlider::onTouchCancelled(const cocos2d::Point &touchPoint)
|
||||
{
|
||||
UIWidget::onTouchCancelled(touchPoint);
|
||||
}
|
||||
|
@ -413,7 +410,7 @@ float UISlider::getPercentWithBallPos(float px)
|
|||
return (((px-(-_barLength/2.0f))/_barLength)*100.0f);
|
||||
}
|
||||
|
||||
void UISlider::addEventListener(Object *target, SEL_SlidPercentChangedEvent selector)
|
||||
void UISlider::addEventListener(cocos2d::Object *target, SEL_SlidPercentChangedEvent selector)
|
||||
{
|
||||
_slidPercentListener = target;
|
||||
_slidPercentSelector = selector;
|
||||
|
@ -438,12 +435,12 @@ void UISlider::onSizeChanged()
|
|||
progressBarRendererScaleChangedWithSize();
|
||||
}
|
||||
|
||||
const Size& UISlider::getContentSize() const
|
||||
const cocos2d::Size& UISlider::getContentSize() const
|
||||
{
|
||||
return _barRenderer->getContentSize();
|
||||
}
|
||||
|
||||
Node* UISlider::getVirtualRenderer()
|
||||
cocos2d::Node* UISlider::getVirtualRenderer()
|
||||
{
|
||||
return _barRenderer;
|
||||
}
|
||||
|
@ -462,11 +459,11 @@ void UISlider::barRendererScaleChangedWithSize()
|
|||
_barLength = _size.width;
|
||||
if (_scale9Enabled)
|
||||
{
|
||||
dynamic_cast<Scale9Sprite*>(_barRenderer)->setPreferredSize(_size);
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_barRenderer)->setPreferredSize(_size);
|
||||
}
|
||||
else
|
||||
{
|
||||
Size btextureSize = _barRenderer->getContentSize();
|
||||
cocos2d::Size btextureSize = _barRenderer->getContentSize();
|
||||
if (btextureSize.width <= 0.0f || btextureSize.height <= 0.0f)
|
||||
{
|
||||
_barRenderer->setScale(1.0f);
|
||||
|
@ -487,7 +484,7 @@ void UISlider::progressBarRendererScaleChangedWithSize()
|
|||
{
|
||||
if (!_scale9Enabled)
|
||||
{
|
||||
Size ptextureSize = _progressBarTextureSize;
|
||||
cocos2d::Size ptextureSize = _progressBarTextureSize;
|
||||
float pscaleX = _size.width / ptextureSize.width;
|
||||
float pscaleY = _size.height / ptextureSize.height;
|
||||
_progressBarRenderer->setScaleX(pscaleX);
|
||||
|
@ -498,11 +495,11 @@ void UISlider::progressBarRendererScaleChangedWithSize()
|
|||
{
|
||||
if (_scale9Enabled)
|
||||
{
|
||||
dynamic_cast<Scale9Sprite*>(_progressBarRenderer)->setPreferredSize(_size);
|
||||
dynamic_cast<cocos2d::extension::Scale9Sprite*>(_progressBarRenderer)->setPreferredSize(_size);
|
||||
}
|
||||
else
|
||||
{
|
||||
Size ptextureSize = _progressBarTextureSize;
|
||||
cocos2d::Size ptextureSize = _progressBarTextureSize;
|
||||
if (ptextureSize.width <= 0.0f || ptextureSize.height <= 0.0f)
|
||||
{
|
||||
_progressBarRenderer->setScale(1.0f);
|
||||
|
@ -514,7 +511,7 @@ void UISlider::progressBarRendererScaleChangedWithSize()
|
|||
_progressBarRenderer->setScaleY(pscaleY);
|
||||
}
|
||||
}
|
||||
_progressBarRenderer->setPosition(Point(-_barLength * 0.5f, 0.0f));
|
||||
_progressBarRenderer->setPosition(cocos2d::Point(-_barLength * 0.5f, 0.0f));
|
||||
setPercent(_percent);
|
||||
}
|
||||
|
||||
|
@ -544,4 +541,25 @@ const char* UISlider::getDescription() const
|
|||
return "Slider";
|
||||
}
|
||||
|
||||
UIWidget* UISlider::createCloneInstance()
|
||||
{
|
||||
return UISlider::create();
|
||||
}
|
||||
|
||||
void UISlider::copySpecialProperties(UIWidget *widget)
|
||||
{
|
||||
UISlider* slider = dynamic_cast<UISlider*>(widget);
|
||||
if (slider)
|
||||
{
|
||||
_prevIgnoreSize = slider->_prevIgnoreSize;
|
||||
setScale9Enabled(slider->_scale9Enabled);
|
||||
loadBarTexture(slider->_textureFile.c_str(), slider->_barTexType);
|
||||
loadProgressBarTexture(slider->_progressBarTextureFile.c_str(), slider->_progressBarTexType);
|
||||
loadSlidBallTextureNormal(slider->_slidBallNormalTextureFile.c_str(), slider->_ballNTexType);
|
||||
loadSlidBallTexturePressed(slider->_slidBallPressedTextureFile.c_str(), slider->_ballPTexType);
|
||||
loadSlidBallTextureDisabled(slider->_slidBallDisabledTextureFile.c_str(), slider->_ballDTexType);
|
||||
setPercent(slider->getPercent());
|
||||
}
|
||||
}
|
||||
|
||||
}
|
|
@ -34,9 +34,13 @@ typedef enum
|
|||
SLIDER_PERCENTCHANGED
|
||||
}SliderEventType;
|
||||
|
||||
typedef void (cocos2d::CCObject::*SEL_SlidPercentChangedEvent)(cocos2d::Object*,SliderEventType);
|
||||
typedef void (cocos2d::Object::*SEL_SlidPercentChangedEvent)(cocos2d::Object*,SliderEventType);
|
||||
#define sliderpercentchangedselector(_SELECTOR) (SEL_SlidPercentChangedEvent)(&_SELECTOR)
|
||||
|
||||
/**
|
||||
* @js NA
|
||||
* @lua NA
|
||||
*/
|
||||
class UISlider : public UIWidget
|
||||
{
|
||||
public:
|
||||
|
@ -185,6 +189,7 @@ public:
|
|||
* Returns the "class name" of widget.
|
||||
*/
|
||||
virtual const char* getDescription() const;
|
||||
|
||||
protected:
|
||||
virtual void initRenderer();
|
||||
float getPercentWithBallPos(float location);
|
||||
|
@ -195,6 +200,8 @@ protected:
|
|||
virtual void onSizeChanged();
|
||||
void barRendererScaleChangedWithSize();
|
||||
void progressBarRendererScaleChangedWithSize();
|
||||
virtual UIWidget* createCloneInstance();
|
||||
virtual void copySpecialProperties(UIWidget* model);
|
||||
protected:
|
||||
cocos2d::Node* _barRenderer;
|
||||
cocos2d::Node* _progressBarRenderer;
|
||||
|
|
|
@ -24,19 +24,17 @@
|
|||
|
||||
#include "gui/UITextField.h"
|
||||
|
||||
using namespace cocos2d;
|
||||
|
||||
namespace gui {
|
||||
|
||||
UICCTextField::UICCTextField()
|
||||
: m_bMaxLengthEnabled(false)
|
||||
, m_nMaxLength(0)
|
||||
, m_bPasswordEnabled(false)
|
||||
, m_strPasswordStyleText("*")
|
||||
, m_bAttachWithIME(false)
|
||||
, m_bDetachWithIME(false)
|
||||
, m_bInsertText(false)
|
||||
, m_bDeleteBackward(false)
|
||||
: _maxLengthEnabled(false)
|
||||
, _maxLength(0)
|
||||
, _passwordEnabled(false)
|
||||
, _passwordStyleText("*")
|
||||
, _attachWithIME(false)
|
||||
, _detachWithIME(false)
|
||||
, _insertText(false)
|
||||
, _deleteBackward(false)
|
||||
{
|
||||
}
|
||||
|
||||
|
@ -64,26 +62,26 @@ UICCTextField * UICCTextField::create(const char *placeholder, const char *fontN
|
|||
|
||||
void UICCTextField::onEnter()
|
||||
{
|
||||
CCTextFieldTTF::setDelegate(this);
|
||||
cocos2d::TextFieldTTF::setDelegate(this);
|
||||
}
|
||||
|
||||
|
||||
bool UICCTextField::onTextFieldAttachWithIME(TextFieldTTF *pSender)
|
||||
bool UICCTextField::onTextFieldAttachWithIME(cocos2d::TextFieldTTF *pSender)
|
||||
{
|
||||
setAttachWithIME(true);
|
||||
return false;
|
||||
}
|
||||
|
||||
bool UICCTextField::onTextFieldInsertText(TextFieldTTF *pSender, const char *text, int nLen)
|
||||
bool UICCTextField::onTextFieldInsertText(cocos2d::TextFieldTTF *pSender, const char *text, int nLen)
|
||||
{
|
||||
if (nLen == 1 && strcmp(text, "\n") == 0)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
setInsertText(true);
|
||||
if (m_bMaxLengthEnabled)
|
||||
if (_maxLengthEnabled)
|
||||
{
|
||||
if (CCTextFieldTTF::getCharCount() >= m_nMaxLength)
|
||||
if (cocos2d::TextFieldTTF::getCharCount() >= _maxLength)
|
||||
{
|
||||
return true;
|
||||
}
|
||||
|
@ -92,13 +90,13 @@ bool UICCTextField::onTextFieldInsertText(TextFieldTTF *pSender, const char *tex
|
|||
return false;
|
||||
}
|
||||
|
||||
bool UICCTextField::onTextFieldDeleteBackward(TextFieldTTF *pSender, const char *delText, int nLen)
|
||||
bool UICCTextField::onTextFieldDeleteBackward(cocos2d::TextFieldTTF *pSender, const char *delText, int nLen)
|
||||
{
|
||||
setDeleteBackward(true);
|
||||
return false;
|
||||
}
|
||||
|
||||
bool UICCTextField::onTextFieldDetachWithIME(TextFieldTTF *pSender)
|
||||
bool UICCTextField::onTextFieldDetachWithIME(cocos2d::TextFieldTTF *pSender)
|
||||
{
|
||||
setDetachWithIME(true);
|
||||
return false;
|
||||
|
@ -107,11 +105,11 @@ bool UICCTextField::onTextFieldDetachWithIME(TextFieldTTF *pSender)
|
|||
void UICCTextField::insertText(const char * text, int len)
|
||||
{
|
||||
std::string str_text = text;
|
||||
int str_len = strlen(CCTextFieldTTF::getString());
|
||||
int str_len = strlen(cocos2d::TextFieldTTF::getString());
|
||||
|
||||
if (strcmp(text, "\n") != 0)
|
||||
{
|
||||
if (m_bMaxLengthEnabled)
|
||||
if (_maxLengthEnabled)
|
||||
{
|
||||
int multiple = 1;
|
||||
char value = text[0];
|
||||
|
@ -120,26 +118,26 @@ void UICCTextField::insertText(const char * text, int len)
|
|||
multiple = 3;
|
||||
}
|
||||
|
||||
if (str_len + len > m_nMaxLength * multiple)
|
||||
if (str_len + len > _maxLength * multiple)
|
||||
{
|
||||
str_text = str_text.substr(0, m_nMaxLength * multiple);
|
||||
len = m_nMaxLength * multiple;
|
||||
str_text = str_text.substr(0, _maxLength * multiple);
|
||||
len = _maxLength * multiple;
|
||||
/*
|
||||
int mod = str_len % 3;
|
||||
int offset = (mod == 0) ? 0 : (3 - mod);
|
||||
int amount = str_len + offset;
|
||||
str_text = str_text.substr(0, m_nMaxLength - amount);
|
||||
str_text = str_text.substr(0, _maxLength - amount);
|
||||
// CCLOG("str_test = %s", str_text.c_str());
|
||||
*/
|
||||
}
|
||||
}
|
||||
}
|
||||
CCTextFieldTTF::insertText(str_text.c_str(), len);
|
||||
cocos2d::TextFieldTTF::insertText(str_text.c_str(), len);
|
||||
|
||||
// password
|
||||
if (m_bPasswordEnabled)
|
||||
if (_passwordEnabled)
|
||||
{
|
||||
if (CCTextFieldTTF::getCharCount() > 0)
|
||||
if (cocos2d::TextFieldTTF::getCharCount() > 0)
|
||||
{
|
||||
setPasswordText(_inputText->c_str());
|
||||
}
|
||||
|
@ -148,12 +146,12 @@ void UICCTextField::insertText(const char * text, int len)
|
|||
|
||||
void UICCTextField::deleteBackward()
|
||||
{
|
||||
CCTextFieldTTF::deleteBackward();
|
||||
cocos2d::TextFieldTTF::deleteBackward();
|
||||
|
||||
if (CCTextFieldTTF::getCharCount() > 0)
|
||||
if (cocos2d::TextFieldTTF::getCharCount() > 0)
|
||||
{
|
||||
// password
|
||||
if (m_bPasswordEnabled)
|
||||
if (_passwordEnabled)
|
||||
{
|
||||
setPasswordText(_inputText->c_str());
|
||||
}
|
||||
|
@ -162,47 +160,47 @@ void UICCTextField::deleteBackward()
|
|||
|
||||
void UICCTextField::openIME()
|
||||
{
|
||||
CCTextFieldTTF::attachWithIME();
|
||||
cocos2d::TextFieldTTF::attachWithIME();
|
||||
}
|
||||
|
||||
void UICCTextField::closeIME()
|
||||
{
|
||||
CCTextFieldTTF::detachWithIME();
|
||||
cocos2d::TextFieldTTF::detachWithIME();
|
||||
}
|
||||
|
||||
void UICCTextField::setMaxLengthEnabled(bool enable)
|
||||
{
|
||||
m_bMaxLengthEnabled = enable;
|
||||
_maxLengthEnabled = enable;
|
||||
}
|
||||
|
||||
bool UICCTextField::isMaxLengthEnabled()
|
||||
{
|
||||
return m_bMaxLengthEnabled;
|
||||
return _maxLengthEnabled;
|
||||
}
|
||||
|
||||
void UICCTextField::setMaxLength(int length)
|
||||
{
|
||||
m_nMaxLength = length;
|
||||
_maxLength = length;
|
||||
}
|
||||
|
||||
int UICCTextField::getMaxLength()
|
||||
{
|
||||
return m_nMaxLength;
|
||||
return _maxLength;
|
||||
}
|
||||
|
||||
int UICCTextField::getCharCount()
|
||||
{
|
||||
return CCTextFieldTTF::getCharCount();
|
||||
return cocos2d::TextFieldTTF::getCharCount();
|
||||
}
|
||||
|
||||
void UICCTextField::setPasswordEnabled(bool enable)
|
||||
{
|
||||
m_bPasswordEnabled = enable;
|
||||
_passwordEnabled = enable;
|
||||
}
|
||||
|
||||
bool UICCTextField::isPasswordEnabled()
|
||||
{
|
||||
return m_bPasswordEnabled;
|
||||
return _passwordEnabled;
|
||||
}
|
||||
|
||||
void UICCTextField::setPasswordStyleText(const char* styleText)
|
||||
|
@ -216,7 +214,7 @@ void UICCTextField::setPasswordStyleText(const char* styleText)
|
|||
{
|
||||
return;
|
||||
}
|
||||
m_strPasswordStyleText = styleText;
|
||||
_passwordStyleText = styleText;
|
||||
}
|
||||
|
||||
void UICCTextField::setPasswordText(const char *text)
|
||||
|
@ -224,49 +222,49 @@ void UICCTextField::setPasswordText(const char *text)
|
|||
std::string tempStr;
|
||||
for (size_t i = 0; i < strlen(text); ++i)
|
||||
{
|
||||
tempStr.append(m_strPasswordStyleText);
|
||||
tempStr.append(_passwordStyleText);
|
||||
}
|
||||
CCLabelTTF::setString(tempStr.c_str());
|
||||
cocos2d::LabelTTF::setString(tempStr.c_str());
|
||||
}
|
||||
|
||||
void UICCTextField::setAttachWithIME(bool attach)
|
||||
{
|
||||
m_bAttachWithIME = attach;
|
||||
_attachWithIME = attach;
|
||||
}
|
||||
|
||||
bool UICCTextField::getAttachWithIME()
|
||||
{
|
||||
return m_bAttachWithIME;
|
||||
return _attachWithIME;
|
||||
}
|
||||
|
||||
void UICCTextField::setDetachWithIME(bool detach)
|
||||
{
|
||||
m_bDetachWithIME = detach;
|
||||
_detachWithIME = detach;
|
||||
}
|
||||
|
||||
bool UICCTextField::getDetachWithIME()
|
||||
{
|
||||
return m_bDetachWithIME;
|
||||
return _detachWithIME;
|
||||
}
|
||||
|
||||
void UICCTextField::setInsertText(bool insert)
|
||||
{
|
||||
m_bInsertText = insert;
|
||||
_insertText = insert;
|
||||
}
|
||||
|
||||
bool UICCTextField::getInsertText()
|
||||
{
|
||||
return m_bInsertText;
|
||||
return _insertText;
|
||||
}
|
||||
|
||||
void UICCTextField::setDeleteBackward(bool deleteBackward)
|
||||
{
|
||||
m_bDeleteBackward = deleteBackward;
|
||||
_deleteBackward = deleteBackward;
|
||||
}
|
||||
|
||||
bool UICCTextField::getDeleteBackward()
|
||||
{
|
||||
return m_bDeleteBackward;
|
||||
return _deleteBackward;
|
||||
}
|
||||
|
||||
|
||||
|
@ -278,7 +276,8 @@ _touchWidth(0.0f),
|
|||
_touchHeight(0.0f),
|
||||
_useTouchArea(false),
|
||||
_eventListener(NULL),
|
||||
_eventSelector(NULL)
|
||||
_eventSelector(NULL),
|
||||
_passwordStyleText("")
|
||||
{
|
||||
}
|
||||
|
||||
|
@ -315,7 +314,7 @@ void UITextField::initRenderer()
|
|||
_renderer->addChild(_textFieldRenderer);
|
||||
}
|
||||
|
||||
void UITextField::setTouchSize(const Size &size)
|
||||
void UITextField::setTouchSize(const cocos2d::Size &size)
|
||||
{
|
||||
_useTouchArea = true;
|
||||
_touchWidth = size.width;
|
||||
|
@ -361,7 +360,7 @@ const char* UITextField::getStringValue()
|
|||
return _textFieldRenderer->getString();
|
||||
}
|
||||
|
||||
bool UITextField::onTouchBegan(const Point &touchPoint)
|
||||
bool UITextField::onTouchBegan(const cocos2d::Point &touchPoint)
|
||||
{
|
||||
bool pass = UIWidget::onTouchBegan(touchPoint);
|
||||
_textFieldRenderer->attachWithIME();
|
||||
|
@ -401,6 +400,8 @@ bool UITextField::isPasswordEnabled()
|
|||
void UITextField::setPasswordStyleText(const char *styleText)
|
||||
{
|
||||
_textFieldRenderer->setPasswordStyleText(styleText);
|
||||
|
||||
_passwordStyleText = styleText;
|
||||
}
|
||||
|
||||
void UITextField::update(float dt)
|
||||
|
@ -489,7 +490,7 @@ void UITextField::insertTextEvent()
|
|||
{
|
||||
if (_eventListener && _eventSelector)
|
||||
{
|
||||
(_eventListener->*_eventSelector)(this, TEXTFIELD_EVENT_INDERT_TEXT);
|
||||
(_eventListener->*_eventSelector)(this, TEXTFIELD_EVENT_INSERT_TEXT);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -501,19 +502,19 @@ void UITextField::deleteBackwardEvent()
|
|||
}
|
||||
}
|
||||
|
||||
void UITextField::addEventListener(Object *target, SEL_TextFieldEvent selecor)
|
||||
void UITextField::addEventListener(cocos2d::Object *target, SEL_TextFieldEvent selecor)
|
||||
{
|
||||
_eventListener = target;
|
||||
_eventSelector = selecor;
|
||||
}
|
||||
|
||||
void UITextField::setAnchorPoint(const Point &pt)
|
||||
void UITextField::setAnchorPoint(const cocos2d::Point &pt)
|
||||
{
|
||||
UIWidget::setAnchorPoint(pt);
|
||||
_textFieldRenderer->setAnchorPoint(pt);
|
||||
}
|
||||
|
||||
void UITextField::setColor(const Color3B &color)
|
||||
void UITextField::setColor(const cocos2d::Color3B &color)
|
||||
{
|
||||
UIWidget::setColor(color);
|
||||
_textFieldRenderer->setColor(color);
|
||||
|
@ -539,7 +540,7 @@ void UITextField::textfieldRendererScaleChangedWithSize()
|
|||
}
|
||||
else
|
||||
{
|
||||
Size textureSize = getContentSize();
|
||||
cocos2d::Size textureSize = getContentSize();
|
||||
if (textureSize.width <= 0.0f || textureSize.height <= 0.0f)
|
||||
{
|
||||
_textFieldRenderer->setScale(1.0f);
|
||||
|
@ -552,12 +553,12 @@ void UITextField::textfieldRendererScaleChangedWithSize()
|
|||
}
|
||||
}
|
||||
|
||||
const Size& UITextField::getContentSize() const
|
||||
const cocos2d::Size& UITextField::getContentSize() const
|
||||
{
|
||||
return _textFieldRenderer->getContentSize();
|
||||
}
|
||||
|
||||
Node* UITextField::getVirtualRenderer()
|
||||
cocos2d::Node* UITextField::getVirtualRenderer()
|
||||
{
|
||||
return _textFieldRenderer;
|
||||
}
|
||||
|
@ -567,4 +568,34 @@ const char* UITextField::getDescription() const
|
|||
return "TextField";
|
||||
}
|
||||
|
||||
void UITextField::attachWithIME()
|
||||
{
|
||||
_textFieldRenderer->attachWithIME();
|
||||
}
|
||||
|
||||
UIWidget* UITextField::createCloneInstance()
|
||||
{
|
||||
return UITextField::create();
|
||||
}
|
||||
|
||||
void UITextField::copySpecialProperties(UIWidget *widget)
|
||||
{
|
||||
UITextField* textField = dynamic_cast<UITextField*>(widget);
|
||||
if (textField)
|
||||
{
|
||||
setText(textField->_textFieldRenderer->getString());
|
||||
setPlaceHolder(textField->getStringValue());
|
||||
setFontSize(textField->_textFieldRenderer->getFontSize());
|
||||
setFontName(textField->_textFieldRenderer->getFontName());
|
||||
setMaxLengthEnabled(textField->isMaxLengthEnabled());
|
||||
setMaxLength(textField->getMaxLength());
|
||||
setPasswordEnabled(textField->isPasswordEnabled());
|
||||
setPasswordStyleText(textField->_passwordStyleText.c_str());
|
||||
setAttachWithIME(textField->getAttachWithIME());
|
||||
setDetachWithIME(textField->getDetachWithIME());
|
||||
setInsertText(textField->getInsertText());
|
||||
setDeleteBackward(textField->getDeleteBackward());
|
||||
}
|
||||
}
|
||||
|
||||
}
|
|
@ -30,6 +30,10 @@
|
|||
|
||||
namespace gui {
|
||||
|
||||
/**
|
||||
* @js NA
|
||||
* @lua NA
|
||||
*/
|
||||
class UICCTextField: public cocos2d::TextFieldTTF, public cocos2d::TextFieldDelegate
|
||||
{
|
||||
public:
|
||||
|
@ -70,32 +74,32 @@ public:
|
|||
bool getInsertText();
|
||||
void setDeleteBackward(bool deleteBackward);
|
||||
bool getDeleteBackward();
|
||||
|
||||
|
||||
protected:
|
||||
bool m_bMaxLengthEnabled;
|
||||
int m_nMaxLength;
|
||||
bool m_bPasswordEnabled;
|
||||
std::string m_strPasswordStyleText;
|
||||
bool m_bAttachWithIME;
|
||||
bool m_bDetachWithIME;
|
||||
bool m_bInsertText;
|
||||
bool m_bDeleteBackward;
|
||||
bool _maxLengthEnabled;
|
||||
int _maxLength;
|
||||
bool _passwordEnabled;
|
||||
std::string _passwordStyleText;
|
||||
bool _attachWithIME;
|
||||
bool _detachWithIME;
|
||||
bool _insertText;
|
||||
bool _deleteBackward;
|
||||
};
|
||||
|
||||
|
||||
typedef enum
|
||||
{
|
||||
TEXTFIELD_EVENT_ATTACH_WITH_IME,
|
||||
TEXTFIELD_EVENT_DETACH_WITH_IME,
|
||||
TEXTFIELD_EVENT_INDERT_TEXT,
|
||||
TEXTFIELD_EVENT_INSERT_TEXT,
|
||||
TEXTFIELD_EVENT_DELETE_BACKWARD,
|
||||
}TextFiledEventType;
|
||||
|
||||
typedef void (cocos2d::Object::*SEL_TextFieldEvent)(cocos2d::Object*, TextFiledEventType);
|
||||
#define textfieldeventselector(_SELECTOR) (SEL_TextFieldEvent)(&_SELECTOR)
|
||||
|
||||
//class UITextField : public UIWidget
|
||||
/** class UITextField : public UIWidget
|
||||
* @js NA
|
||||
* @lua NA
|
||||
*/
|
||||
class UITextField : public UIWidget
|
||||
{
|
||||
public:
|
||||
|
@ -129,22 +133,19 @@ public:
|
|||
bool getDeleteBackward();
|
||||
void setDeleteBackward(bool deleteBackward);
|
||||
void addEventListener(cocos2d::Object* target, SEL_TextFieldEvent selecor);
|
||||
|
||||
virtual void setAnchorPoint(const cocos2d::Point &pt);
|
||||
virtual void setColor(const cocos2d::Color3B &color);
|
||||
virtual void setOpacity(int opacity);
|
||||
|
||||
/**
|
||||
* Returns the "class name" of widget.
|
||||
*/
|
||||
virtual const char* getDescription() const;
|
||||
/*compatibel*/
|
||||
/**
|
||||
* These methods will be removed
|
||||
*/
|
||||
void setMaxLengthEnable(bool is){setMaxLengthEnabled(is);};
|
||||
void setPasswordEnable(bool is){setPasswordEnabled(is);};
|
||||
/************/
|
||||
|
||||
virtual const cocos2d::Size& getContentSize() const;
|
||||
virtual cocos2d::Node* getVirtualRenderer();
|
||||
void attachWithIME();
|
||||
protected:
|
||||
// event
|
||||
void attachWithIMEEvent();
|
||||
|
@ -153,9 +154,11 @@ protected:
|
|||
void deleteBackwardEvent();
|
||||
virtual void onSizeChanged();
|
||||
void textfieldRendererScaleChangedWithSize();
|
||||
virtual UIWidget* createCloneInstance();
|
||||
virtual void copySpecialProperties(UIWidget* model);
|
||||
protected:
|
||||
UICCTextField* _textFieldRenderer;
|
||||
|
||||
|
||||
float _touchWidth;
|
||||
float _touchHeight;
|
||||
bool _useTouchArea;
|
||||
|
@ -163,6 +166,7 @@ protected:
|
|||
cocos2d::Object* _eventListener;
|
||||
SEL_TextFieldEvent _eventSelector;
|
||||
|
||||
std::string _passwordStyleText;
|
||||
};
|
||||
|
||||
}
|
||||
|
|
|
@ -24,11 +24,9 @@
|
|||
|
||||
#include "gui/UIWidget.h"
|
||||
#include "gui/UILayer.h"
|
||||
#include "gui/Layout.h"
|
||||
#include "gui/UILayout.h"
|
||||
#include "gui/UIHelper.h"
|
||||
|
||||
using namespace cocos2d;
|
||||
|
||||
namespace gui {
|
||||
|
||||
#define DYNAMIC_CAST_CCBLENDPROTOCOL dynamic_cast<cocos2d::BlendProtocol*>(_renderer)
|
||||
|
@ -45,31 +43,31 @@ _touchEnabled(false),
|
|||
_touchPassedEnabled(false),
|
||||
_focus(false),
|
||||
_widgetZOrder(0),
|
||||
_anchorPoint(Point(0.5f, 0.5f)),
|
||||
_anchorPoint(cocos2d::Point(0.5f, 0.5f)),
|
||||
_widgetParent(NULL),
|
||||
_brightStyle(BRIGHT_NONE),
|
||||
_updateEnabled(false),
|
||||
_renderer(NULL),
|
||||
_touchStartPos(Point::ZERO),
|
||||
_touchMovePos(Point::ZERO),
|
||||
_touchEndPos(Point::ZERO),
|
||||
_touchStartPos(cocos2d::Point::ZERO),
|
||||
_touchMovePos(cocos2d::Point::ZERO),
|
||||
_touchEndPos(cocos2d::Point::ZERO),
|
||||
_touchEventListener(NULL),
|
||||
_touchEventSelector(NULL),
|
||||
_widgetTag(-1),
|
||||
_name("default"),
|
||||
_widgetType(WidgetTypeWidget),
|
||||
_actionTag(0),
|
||||
_size(Size::ZERO),
|
||||
_customSize(Size::ZERO),
|
||||
_layoutParameter(NULL),
|
||||
_size(cocos2d::Size::ZERO),
|
||||
_customSize(cocos2d::Size::ZERO),
|
||||
_layoutParameterDictionary(NULL),
|
||||
_ignoreSize(false),
|
||||
_children(NULL),
|
||||
_affectByClipping(false),
|
||||
_scheduler(NULL),
|
||||
_sizeType(SIZE_ABSOLUTE),
|
||||
_sizePercent(Point::ZERO),
|
||||
_sizePercent(cocos2d::Point::ZERO),
|
||||
_positionType(POSITION_ABSOLUTE),
|
||||
_positionPercent(Point::ZERO),
|
||||
_positionPercent(cocos2d::Point::ZERO),
|
||||
_isRunning(false)
|
||||
{
|
||||
|
||||
|
@ -79,7 +77,8 @@ UIWidget::~UIWidget()
|
|||
{
|
||||
releaseResoures();
|
||||
setParent(NULL);
|
||||
CC_SAFE_RELEASE_NULL(_layoutParameter);
|
||||
_layoutParameterDictionary->removeAllObjects();
|
||||
CC_SAFE_RELEASE(_layoutParameterDictionary);
|
||||
CC_SAFE_RELEASE(_scheduler);
|
||||
}
|
||||
|
||||
|
@ -97,12 +96,14 @@ UIWidget* UIWidget::create()
|
|||
|
||||
bool UIWidget::init()
|
||||
{
|
||||
_children = Array::create();
|
||||
_children = cocos2d::Array::create();
|
||||
_children->retain();
|
||||
_layoutParameterDictionary = cocos2d::Dictionary::create();
|
||||
CC_SAFE_RETAIN(_layoutParameterDictionary);
|
||||
initRenderer();
|
||||
_renderer->retain();
|
||||
_renderer->setZOrder(_widgetZOrder);
|
||||
RGBAProtocol* renderRGBA = DYNAMIC_CAST_CCRGBAPROTOCOL;
|
||||
cocos2d::RGBAProtocol* renderRGBA = DYNAMIC_CAST_CCRGBAPROTOCOL;
|
||||
if (renderRGBA)
|
||||
{
|
||||
renderRGBA->setCascadeColorEnabled(true);
|
||||
|
@ -110,14 +111,13 @@ bool UIWidget::init()
|
|||
}
|
||||
setBright(true);
|
||||
ignoreContentAdaptWithSize(true);
|
||||
_scheduler = Director::getInstance()->getScheduler();
|
||||
_scheduler = cocos2d::Director::getInstance()->getScheduler();
|
||||
CC_SAFE_RETAIN(_scheduler);
|
||||
return true;
|
||||
}
|
||||
|
||||
void UIWidget::releaseResoures()
|
||||
{
|
||||
setUpdateEnabled(false);
|
||||
removeAllChildren();
|
||||
_children->release();
|
||||
_renderer->removeAllChildrenWithCleanup(true);
|
||||
|
@ -157,7 +157,7 @@ bool UIWidget::addChild(UIWidget *child)
|
|||
else
|
||||
{
|
||||
bool seekSucceed = false;
|
||||
ccArray* arrayChildren = _children->data;
|
||||
cocos2d::ccArray* arrayChildren = _children->data;
|
||||
for (int i=childrenCount-1; i>=0; --i)
|
||||
{
|
||||
UIWidget* widget = (UIWidget*)(arrayChildren->arr[i]);
|
||||
|
@ -203,7 +203,7 @@ bool UIWidget::removeChild(UIWidget *child)
|
|||
{
|
||||
child->onExit();
|
||||
}
|
||||
child->disableUpdate();
|
||||
child->setUpdateEnabled(false);
|
||||
child->setParent(NULL);
|
||||
_renderer->removeChild(child->getRenderer());
|
||||
_children->removeObject(child);
|
||||
|
@ -246,7 +246,7 @@ void UIWidget::reorderChild(UIWidget* child)
|
|||
else
|
||||
{
|
||||
bool seekSucceed = false;
|
||||
ccArray* arrayChildren = _children->data;
|
||||
cocos2d::ccArray* arrayChildren = _children->data;
|
||||
for (int i=childrenCount-1; i>=0; --i)
|
||||
{
|
||||
UIWidget* widget = (UIWidget*)(arrayChildren->arr[i]);
|
||||
|
@ -274,21 +274,6 @@ void UIWidget::reorderChild(UIWidget* child)
|
|||
CC_SAFE_RELEASE(child);
|
||||
}
|
||||
|
||||
void UIWidget::disableUpdate()
|
||||
{
|
||||
if (_scheduler)
|
||||
{
|
||||
_scheduler->unscheduleUpdateForTarget(this);
|
||||
}
|
||||
int childrenCount = _children->data->num;
|
||||
ccArray* arrayChildren = _children->data;
|
||||
for (int i=0; i<childrenCount; i++)
|
||||
{
|
||||
UIWidget* child = (UIWidget*)(arrayChildren->arr[i]);
|
||||
child->disableUpdate();
|
||||
}
|
||||
}
|
||||
|
||||
void UIWidget::setEnabled(bool enabled)
|
||||
{
|
||||
_enabled = enabled;
|
||||
|
@ -299,9 +284,9 @@ void UIWidget::setEnabled(bool enabled)
|
|||
}
|
||||
else
|
||||
{
|
||||
dynamic_cast<RectClippingNode*>(_renderer)->setEnabled(enabled);
|
||||
dynamic_cast<UIRectClippingNode*>(_renderer)->setEnabled(enabled);
|
||||
}
|
||||
ccArray* arrayChildren = _children->data;
|
||||
cocos2d::ccArray* arrayChildren = _children->data;
|
||||
int childrenCount = arrayChildren->num;
|
||||
for (int i = 0; i < childrenCount; i++)
|
||||
{
|
||||
|
@ -312,15 +297,15 @@ void UIWidget::setEnabled(bool enabled)
|
|||
|
||||
UIWidget* UIWidget::getChildByName(const char *name)
|
||||
{
|
||||
return CCUIHELPER->seekWidgetByName(this, name);
|
||||
return UIHelper::seekWidgetByName(this, name);
|
||||
}
|
||||
|
||||
UIWidget* UIWidget::getChildByTag(int tag)
|
||||
{
|
||||
return CCUIHELPER->seekWidgetByTag(this, tag);
|
||||
return UIHelper::seekWidgetByTag(this, tag);
|
||||
}
|
||||
|
||||
Array* UIWidget::getChildren()
|
||||
cocos2d::Array* UIWidget::getChildren()
|
||||
{
|
||||
return _children;
|
||||
}
|
||||
|
@ -330,7 +315,7 @@ void UIWidget::initRenderer()
|
|||
_renderer = GUIRenderer::create();
|
||||
}
|
||||
|
||||
void UIWidget::setSize(const Size &size)
|
||||
void UIWidget::setSize(const cocos2d::Size &size)
|
||||
{
|
||||
_customSize = size;
|
||||
if (_ignoreSize)
|
||||
|
@ -343,19 +328,19 @@ void UIWidget::setSize(const Size &size)
|
|||
}
|
||||
if (_isRunning)
|
||||
{
|
||||
_sizePercent = (_widgetParent == NULL) ? Point::ZERO : Point(_customSize.width / _widgetParent->getSize().width, _customSize.height / _widgetParent->getSize().height);
|
||||
_sizePercent = (_widgetParent == NULL) ? cocos2d::Point::ZERO : cocos2d::Point(_customSize.width / _widgetParent->getSize().width, _customSize.height / _widgetParent->getSize().height);
|
||||
}
|
||||
onSizeChanged();
|
||||
}
|
||||
|
||||
void UIWidget::setSizePercent(const Point &percent)
|
||||
void UIWidget::setSizePercent(const cocos2d::Point &percent)
|
||||
{
|
||||
_sizePercent = percent;
|
||||
if (!_isRunning)
|
||||
{
|
||||
return;
|
||||
}
|
||||
Size cSize = (_widgetParent == NULL) ? Size::ZERO : Size(_widgetParent->getSize().width * percent.x , _widgetParent->getSize().height * percent.y);
|
||||
cocos2d::Size cSize = (_widgetParent == NULL) ? cocos2d::Size::ZERO : cocos2d::Size(_widgetParent->getSize().width * percent.x , _widgetParent->getSize().height * percent.y);
|
||||
if (_ignoreSize)
|
||||
{
|
||||
_size = getContentSize();
|
||||
|
@ -381,11 +366,11 @@ void UIWidget::updateSizeAndPosition()
|
|||
{
|
||||
_size = _customSize;
|
||||
}
|
||||
_sizePercent = (_widgetParent == NULL) ? Point::ZERO : Point(_customSize.width / _widgetParent->getSize().width, _customSize.height / _widgetParent->getSize().height);
|
||||
_sizePercent = (_widgetParent == NULL) ? cocos2d::Point::ZERO : cocos2d::Point(_customSize.width / _widgetParent->getSize().width, _customSize.height / _widgetParent->getSize().height);
|
||||
break;
|
||||
case SIZE_PERCENT:
|
||||
{
|
||||
Size cSize = (_widgetParent == NULL) ? Size::ZERO : Size(_widgetParent->getSize().width * _sizePercent.x , _widgetParent->getSize().height * _sizePercent.y);
|
||||
cocos2d::Size cSize = (_widgetParent == NULL) ? cocos2d::Size::ZERO : cocos2d::Size(_widgetParent->getSize().width * _sizePercent.x , _widgetParent->getSize().height * _sizePercent.y);
|
||||
if (_ignoreSize)
|
||||
{
|
||||
_size = getContentSize();
|
||||
|
@ -401,16 +386,16 @@ void UIWidget::updateSizeAndPosition()
|
|||
break;
|
||||
}
|
||||
onSizeChanged();
|
||||
Point absPos = getPosition();
|
||||
cocos2d::Point absPos = getPosition();
|
||||
switch (_positionType)
|
||||
{
|
||||
case POSITION_ABSOLUTE:
|
||||
_positionPercent = (_widgetParent == NULL) ? Point::ZERO : Point(absPos.x / _widgetParent->getSize().width, absPos.y / _widgetParent->getSize().height);
|
||||
_positionPercent = (_widgetParent == NULL) ? cocos2d::Point::ZERO : cocos2d::Point(absPos.x / _widgetParent->getSize().width, absPos.y / _widgetParent->getSize().height);
|
||||
break;
|
||||
case POSITION_PERCENT:
|
||||
{
|
||||
Size parentSize = _widgetParent->getSize();
|
||||
absPos = Point(parentSize.width * _positionPercent.x, parentSize.height * _positionPercent.y);
|
||||
cocos2d::Size parentSize = _widgetParent->getSize();
|
||||
absPos = cocos2d::Point(parentSize.width * _positionPercent.x, parentSize.height * _positionPercent.y);
|
||||
}
|
||||
break;
|
||||
default:
|
||||
|
@ -434,7 +419,7 @@ void UIWidget::ignoreContentAdaptWithSize(bool ignore)
|
|||
_ignoreSize = ignore;
|
||||
if (_ignoreSize)
|
||||
{
|
||||
Size s = getContentSize();
|
||||
cocos2d::Size s = getContentSize();
|
||||
_size = s;
|
||||
}
|
||||
else
|
||||
|
@ -449,27 +434,27 @@ bool UIWidget::isIgnoreContentAdaptWithSize() const
|
|||
return _ignoreSize;
|
||||
}
|
||||
|
||||
const Size& UIWidget::getSize() const
|
||||
const cocos2d::Size& UIWidget::getSize() const
|
||||
{
|
||||
return _size;
|
||||
}
|
||||
|
||||
const Point& UIWidget::getSizePercent() const
|
||||
const cocos2d::Point& UIWidget::getSizePercent() const
|
||||
{
|
||||
return _sizePercent;
|
||||
}
|
||||
|
||||
Point UIWidget::getWorldPosition()
|
||||
cocos2d::Point UIWidget::getWorldPosition()
|
||||
{
|
||||
return _renderer->convertToWorldSpace(Point::ZERO);
|
||||
return _renderer->convertToWorldSpace(cocos2d::Point::ZERO);
|
||||
}
|
||||
|
||||
Point UIWidget::convertToWorldSpace(const Point& pt)
|
||||
cocos2d::Point UIWidget::convertToWorldSpace(const cocos2d::Point& pt)
|
||||
{
|
||||
return _renderer->convertToWorldSpace(pt);
|
||||
}
|
||||
|
||||
Node* UIWidget::getVirtualRenderer()
|
||||
cocos2d::Node* UIWidget::getVirtualRenderer()
|
||||
{
|
||||
return _renderer;
|
||||
}
|
||||
|
@ -479,7 +464,7 @@ void UIWidget::onSizeChanged()
|
|||
|
||||
}
|
||||
|
||||
const Size& UIWidget::getContentSize() const
|
||||
const cocos2d::Size& UIWidget::getContentSize() const
|
||||
{
|
||||
return _size;
|
||||
}
|
||||
|
@ -511,6 +496,10 @@ bool UIWidget::isTouchEnabled() const
|
|||
|
||||
void UIWidget::setUpdateEnabled(bool enable)
|
||||
{
|
||||
if (enable == _updateEnabled)
|
||||
{
|
||||
return;
|
||||
}
|
||||
_updateEnabled = enable;
|
||||
if (enable)
|
||||
{
|
||||
|
@ -616,7 +605,7 @@ void UIWidget::didNotSelectSelf()
|
|||
|
||||
}
|
||||
|
||||
bool UIWidget::onTouchBegan(const Point &touchPoint)
|
||||
bool UIWidget::onTouchBegan(const cocos2d::Point &touchPoint)
|
||||
{
|
||||
setFocused(true);
|
||||
_touchStartPos.x = touchPoint.x;
|
||||
|
@ -629,7 +618,7 @@ bool UIWidget::onTouchBegan(const Point &touchPoint)
|
|||
return _touchPassedEnabled;
|
||||
}
|
||||
|
||||
void UIWidget::onTouchMoved(const Point &touchPoint)
|
||||
void UIWidget::onTouchMoved(const cocos2d::Point &touchPoint)
|
||||
{
|
||||
_touchMovePos.x = touchPoint.x;
|
||||
_touchMovePos.y = touchPoint.y;
|
||||
|
@ -641,7 +630,7 @@ void UIWidget::onTouchMoved(const Point &touchPoint)
|
|||
moveEvent();
|
||||
}
|
||||
|
||||
void UIWidget::onTouchEnded(const Point &touchPoint)
|
||||
void UIWidget::onTouchEnded(const cocos2d::Point &touchPoint)
|
||||
{
|
||||
_touchEndPos.x = touchPoint.x;
|
||||
_touchEndPos.y = touchPoint.y;
|
||||
|
@ -661,13 +650,13 @@ void UIWidget::onTouchEnded(const Point &touchPoint)
|
|||
}
|
||||
}
|
||||
|
||||
void UIWidget::onTouchCancelled(const Point &touchPoint)
|
||||
void UIWidget::onTouchCancelled(const cocos2d::Point &touchPoint)
|
||||
{
|
||||
setFocused(false);
|
||||
cancelUpEvent();
|
||||
}
|
||||
|
||||
void UIWidget::onTouchLongClicked(const Point &touchPoint)
|
||||
void UIWidget::onTouchLongClicked(const cocos2d::Point &touchPoint)
|
||||
{
|
||||
longClickEvent();
|
||||
}
|
||||
|
@ -709,31 +698,31 @@ void UIWidget::longClickEvent()
|
|||
|
||||
}
|
||||
|
||||
void UIWidget::addTouchEventListener(Object *target, SEL_TouchEvent selector)
|
||||
void UIWidget::addTouchEventListener(cocos2d::Object *target, SEL_TouchEvent selector)
|
||||
{
|
||||
_touchEventListener = target;
|
||||
_touchEventSelector = selector;
|
||||
}
|
||||
|
||||
Node* UIWidget::getRenderer()
|
||||
cocos2d::Node* UIWidget::getRenderer()
|
||||
{
|
||||
return _renderer;
|
||||
}
|
||||
|
||||
void UIWidget::addRenderer(Node* renderer, int zOrder)
|
||||
void UIWidget::addRenderer(cocos2d::Node* renderer, int zOrder)
|
||||
{
|
||||
_renderer->addChild(renderer, zOrder);
|
||||
}
|
||||
|
||||
void UIWidget::removeRenderer(Node* renderer, bool cleanup)
|
||||
void UIWidget::removeRenderer(cocos2d::Node* renderer, bool cleanup)
|
||||
{
|
||||
_renderer->removeChild(renderer,cleanup);
|
||||
}
|
||||
|
||||
bool UIWidget::hitTest(const Point &pt)
|
||||
bool UIWidget::hitTest(const cocos2d::Point &pt)
|
||||
{
|
||||
Point nsp = _renderer->convertToNodeSpace(pt);
|
||||
Rect bb = Rect(-_size.width * _anchorPoint.x, -_size.height * _anchorPoint.y, _size.width, _size.height);
|
||||
cocos2d::Point nsp = _renderer->convertToNodeSpace(pt);
|
||||
cocos2d::Rect bb = cocos2d::Rect(-_size.width * _anchorPoint.x, -_size.height * _anchorPoint.y, _size.width, _size.height);
|
||||
if (nsp.x >= bb.origin.x && nsp.x <= bb.origin.x + bb.size.width && nsp.y >= bb.origin.y && nsp.y <= bb.origin.y + bb.size.height)
|
||||
{
|
||||
return true;
|
||||
|
@ -741,14 +730,14 @@ bool UIWidget::hitTest(const Point &pt)
|
|||
return false;
|
||||
}
|
||||
|
||||
bool UIWidget::clippingParentAreaContainPoint(const Point &pt)
|
||||
bool UIWidget::clippingParentAreaContainPoint(const cocos2d::Point &pt)
|
||||
{
|
||||
_affectByClipping = false;
|
||||
UIWidget* parent = getParent();
|
||||
UIWidget* clippingParent = NULL;
|
||||
while (parent)
|
||||
{
|
||||
Layout* layoutParent = dynamic_cast<Layout*>(parent);
|
||||
UILayout* layoutParent = dynamic_cast<UILayout*>(parent);
|
||||
if (layoutParent)
|
||||
{
|
||||
if (layoutParent->isClippingEnabled())
|
||||
|
@ -783,7 +772,7 @@ bool UIWidget::clippingParentAreaContainPoint(const Point &pt)
|
|||
return true;
|
||||
}
|
||||
|
||||
void UIWidget::checkChildInfo(int handleState, UIWidget *sender, const Point &touchPoint)
|
||||
void UIWidget::checkChildInfo(int handleState, UIWidget *sender, const cocos2d::Point &touchPoint)
|
||||
{
|
||||
if (_widgetParent)
|
||||
{
|
||||
|
@ -791,27 +780,27 @@ void UIWidget::checkChildInfo(int handleState, UIWidget *sender, const Point &to
|
|||
}
|
||||
}
|
||||
|
||||
void UIWidget::setPosition(const Point &pos)
|
||||
void UIWidget::setPosition(const cocos2d::Point &pos)
|
||||
{
|
||||
if (_isRunning)
|
||||
{
|
||||
_positionPercent = (_widgetParent == NULL) ? Point::ZERO : Point(pos.x / _widgetParent->getSize().width, pos.y / _widgetParent->getSize().height);
|
||||
_positionPercent = (_widgetParent == NULL) ? cocos2d::Point::ZERO : cocos2d::Point(pos.x / _widgetParent->getSize().width, pos.y / _widgetParent->getSize().height);
|
||||
}
|
||||
_renderer->setPosition(pos);
|
||||
}
|
||||
|
||||
void UIWidget::setPositionPercent(const Point &percent)
|
||||
void UIWidget::setPositionPercent(const cocos2d::Point &percent)
|
||||
{
|
||||
_positionPercent = percent;
|
||||
if (_isRunning)
|
||||
{
|
||||
Size parentSize = _widgetParent->getSize();
|
||||
Point absPos = Point(parentSize.width * _positionPercent.x, parentSize.height * _positionPercent.y);
|
||||
cocos2d::Size parentSize = _widgetParent->getSize();
|
||||
cocos2d::Point absPos = cocos2d::Point(parentSize.width * _positionPercent.x, parentSize.height * _positionPercent.y);
|
||||
_renderer->setPosition(absPos);
|
||||
}
|
||||
}
|
||||
|
||||
void UIWidget::setAnchorPoint(const Point &pt)
|
||||
void UIWidget::setAnchorPoint(const cocos2d::Point &pt)
|
||||
{
|
||||
_anchorPoint = pt;
|
||||
_renderer->setAnchorPoint(pt);
|
||||
|
@ -822,12 +811,12 @@ void UIWidget::updateAnchorPoint()
|
|||
setAnchorPoint(_anchorPoint);
|
||||
}
|
||||
|
||||
const Point& UIWidget::getPosition()
|
||||
const cocos2d::Point& UIWidget::getPosition()
|
||||
{
|
||||
return _renderer->getPosition();
|
||||
}
|
||||
|
||||
const Point& UIWidget::getPositionPercent()
|
||||
const cocos2d::Point& UIWidget::getPositionPercent()
|
||||
{
|
||||
return _positionPercent;
|
||||
}
|
||||
|
@ -842,7 +831,7 @@ PositionType UIWidget::getPositionType() const
|
|||
return _positionType;
|
||||
}
|
||||
|
||||
const Point& UIWidget::getAnchorPoint()
|
||||
const cocos2d::Point& UIWidget::getAnchorPoint()
|
||||
{
|
||||
return _anchorPoint;
|
||||
}
|
||||
|
@ -930,36 +919,12 @@ bool UIWidget::isEnabled() const
|
|||
|
||||
float UIWidget::getLeftInParent()
|
||||
{
|
||||
float leftPos = 0.0f;
|
||||
switch (_widgetType)
|
||||
{
|
||||
case WidgetTypeWidget:
|
||||
leftPos = getPosition().x - getAnchorPoint().x * _size.width;
|
||||
break;
|
||||
case WidgetTypeContainer:
|
||||
leftPos = getPosition().x;
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
return leftPos;
|
||||
return getPosition().x - getAnchorPoint().x * _size.width;;
|
||||
}
|
||||
|
||||
float UIWidget::getBottomInParent()
|
||||
{
|
||||
float bottomPos = 0.0f;
|
||||
switch (_widgetType)
|
||||
{
|
||||
case WidgetTypeWidget:
|
||||
bottomPos = getPosition().y - getAnchorPoint().y * _size.height;
|
||||
break;
|
||||
case WidgetTypeContainer:
|
||||
bottomPos = getPosition().y;
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
return bottomPos;
|
||||
return getPosition().y - getAnchorPoint().y * _size.height;;
|
||||
}
|
||||
|
||||
float UIWidget::getRightInParent()
|
||||
|
@ -982,17 +947,17 @@ void UIWidget::setParent(UIWidget* parent)
|
|||
_widgetParent = parent;
|
||||
}
|
||||
|
||||
Action* UIWidget::runAction(Action *action)
|
||||
cocos2d::Action* UIWidget::runAction(cocos2d::Action *action)
|
||||
{
|
||||
return _renderer->runAction(action);
|
||||
}
|
||||
|
||||
void UIWidget::setActionManager(ActionManager *actionManager)
|
||||
void UIWidget::setActionManager(cocos2d::ActionManager *actionManager)
|
||||
{
|
||||
_renderer->setActionManager(actionManager);
|
||||
}
|
||||
|
||||
ActionManager* UIWidget::getActionManager()
|
||||
cocos2d::ActionManager* UIWidget::getActionManager()
|
||||
{
|
||||
return _renderer->getActionManager();
|
||||
}
|
||||
|
@ -1002,7 +967,7 @@ void UIWidget::stopAllActions()
|
|||
_renderer->stopAllActions();
|
||||
}
|
||||
|
||||
void UIWidget::stopAction(Action *action)
|
||||
void UIWidget::stopAction(cocos2d::Action *action)
|
||||
{
|
||||
_renderer->stopAction(action);
|
||||
}
|
||||
|
@ -1012,33 +977,33 @@ void UIWidget::stopActionByTag(int tag)
|
|||
_renderer->stopActionByTag(tag);
|
||||
}
|
||||
|
||||
Action* UIWidget::getActionByTag(int tag)
|
||||
cocos2d::Action* UIWidget::getActionByTag(int tag)
|
||||
{
|
||||
return _renderer->getActionByTag(tag);
|
||||
}
|
||||
|
||||
void UIWidget::setColor(const Color3B &color)
|
||||
void UIWidget::setColor(const cocos2d::Color3B &color)
|
||||
{
|
||||
RGBAProtocol* rgbap = DYNAMIC_CAST_CCRGBAPROTOCOL;
|
||||
cocos2d::RGBAProtocol* rgbap = DYNAMIC_CAST_CCRGBAPROTOCOL;
|
||||
if (rgbap)
|
||||
{
|
||||
rgbap->setColor(color);
|
||||
}
|
||||
}
|
||||
|
||||
const Color3B& UIWidget::getColor()
|
||||
const cocos2d::Color3B& UIWidget::getColor()
|
||||
{
|
||||
RGBAProtocol* rgbap = DYNAMIC_CAST_CCRGBAPROTOCOL;
|
||||
cocos2d::RGBAProtocol* rgbap = DYNAMIC_CAST_CCRGBAPROTOCOL;
|
||||
if (rgbap)
|
||||
{
|
||||
return rgbap->getColor();
|
||||
}
|
||||
return Color3B::WHITE;
|
||||
return cocos2d::Color3B::WHITE;
|
||||
}
|
||||
|
||||
void UIWidget::setOpacity(int opacity)
|
||||
{
|
||||
RGBAProtocol* rgbap = DYNAMIC_CAST_CCRGBAPROTOCOL;
|
||||
cocos2d::RGBAProtocol* rgbap = DYNAMIC_CAST_CCRGBAPROTOCOL;
|
||||
if (rgbap)
|
||||
{
|
||||
rgbap->setOpacity(opacity);
|
||||
|
@ -1047,7 +1012,7 @@ void UIWidget::setOpacity(int opacity)
|
|||
|
||||
int UIWidget::getOpacity()
|
||||
{
|
||||
RGBAProtocol* rgbap = DYNAMIC_CAST_CCRGBAPROTOCOL;
|
||||
cocos2d::RGBAProtocol* rgbap = DYNAMIC_CAST_CCRGBAPROTOCOL;
|
||||
if (rgbap)
|
||||
{
|
||||
return rgbap->getOpacity();
|
||||
|
@ -1057,7 +1022,7 @@ int UIWidget::getOpacity()
|
|||
|
||||
bool UIWidget::isCascadeOpacityEnabled()
|
||||
{
|
||||
RGBAProtocol* rgbap = DYNAMIC_CAST_CCRGBAPROTOCOL;
|
||||
cocos2d::RGBAProtocol* rgbap = DYNAMIC_CAST_CCRGBAPROTOCOL;
|
||||
if (rgbap)
|
||||
{
|
||||
return rgbap->isCascadeOpacityEnabled();
|
||||
|
@ -1067,7 +1032,7 @@ bool UIWidget::isCascadeOpacityEnabled()
|
|||
|
||||
void UIWidget::setCascadeOpacityEnabled(bool cascadeOpacityEnabled)
|
||||
{
|
||||
RGBAProtocol* rgbap = DYNAMIC_CAST_CCRGBAPROTOCOL;
|
||||
cocos2d::RGBAProtocol* rgbap = DYNAMIC_CAST_CCRGBAPROTOCOL;
|
||||
if (rgbap)
|
||||
{
|
||||
rgbap->setCascadeOpacityEnabled(cascadeOpacityEnabled);
|
||||
|
@ -1076,7 +1041,7 @@ void UIWidget::setCascadeOpacityEnabled(bool cascadeOpacityEnabled)
|
|||
|
||||
bool UIWidget::isCascadeColorEnabled()
|
||||
{
|
||||
RGBAProtocol* rgbap = DYNAMIC_CAST_CCRGBAPROTOCOL;
|
||||
cocos2d::RGBAProtocol* rgbap = DYNAMIC_CAST_CCRGBAPROTOCOL;
|
||||
if (rgbap)
|
||||
{
|
||||
return rgbap->isCascadeColorEnabled();
|
||||
|
@ -1086,33 +1051,33 @@ bool UIWidget::isCascadeColorEnabled()
|
|||
|
||||
void UIWidget::setCascadeColorEnabled(bool cascadeColorEnabled)
|
||||
{
|
||||
RGBAProtocol* rgbap = DYNAMIC_CAST_CCRGBAPROTOCOL;
|
||||
cocos2d::RGBAProtocol* rgbap = DYNAMIC_CAST_CCRGBAPROTOCOL;
|
||||
if (rgbap)
|
||||
{
|
||||
rgbap->setCascadeColorEnabled(cascadeColorEnabled);
|
||||
}
|
||||
}
|
||||
|
||||
void UIWidget::setBlendFunc(BlendFunc blendFunc)
|
||||
void UIWidget::setBlendFunc(cocos2d::BlendFunc blendFunc)
|
||||
{
|
||||
BlendProtocol * blendNode = DYNAMIC_CAST_CCBLENDPROTOCOL;
|
||||
cocos2d::BlendProtocol * blendNode = DYNAMIC_CAST_CCBLENDPROTOCOL;
|
||||
if (blendNode)
|
||||
{
|
||||
blendNode->setBlendFunc(blendFunc);
|
||||
}
|
||||
}
|
||||
|
||||
const Point& UIWidget::getTouchStartPos()
|
||||
const cocos2d::Point& UIWidget::getTouchStartPos()
|
||||
{
|
||||
return _touchStartPos;
|
||||
}
|
||||
|
||||
const Point& UIWidget::getTouchMovePos()
|
||||
const cocos2d::Point& UIWidget::getTouchMovePos()
|
||||
{
|
||||
return _touchMovePos;
|
||||
}
|
||||
|
||||
const Point& UIWidget::getTouchEndPos()
|
||||
const cocos2d::Point& UIWidget::getTouchEndPos()
|
||||
{
|
||||
return _touchEndPos;
|
||||
}
|
||||
|
@ -1142,19 +1107,14 @@ WidgetType UIWidget::getWidgetType() const
|
|||
return _widgetType;
|
||||
}
|
||||
|
||||
void UIWidget::setLayoutParameter(LayoutParameter *parameter)
|
||||
void UIWidget::setLayoutParameter(UILayoutParameter *parameter)
|
||||
{
|
||||
if (_layoutParameter)
|
||||
{
|
||||
CC_SAFE_RELEASE_NULL(_layoutParameter);
|
||||
}
|
||||
_layoutParameter = parameter;
|
||||
CC_SAFE_RETAIN(_layoutParameter);
|
||||
_layoutParameterDictionary->setObject(parameter, parameter->getLayoutType());
|
||||
}
|
||||
|
||||
LayoutParameter* UIWidget::getLayoutParameter()
|
||||
UILayoutParameter* UIWidget::getLayoutParameter(LayoutParameterType type)
|
||||
{
|
||||
return _layoutParameter;
|
||||
return dynamic_cast<UILayoutParameter*>(_layoutParameterDictionary->objectForKey(type));
|
||||
}
|
||||
|
||||
const char* UIWidget::getDescription() const
|
||||
|
@ -1162,6 +1122,71 @@ const char* UIWidget::getDescription() const
|
|||
return "Widget";
|
||||
}
|
||||
|
||||
UIWidget* UIWidget::clone()
|
||||
{
|
||||
UIWidget* clonedWidget = createCloneInstance();
|
||||
clonedWidget->copyProperties(this);
|
||||
clonedWidget->copyClonedWidgetChildren(this);
|
||||
return clonedWidget;
|
||||
}
|
||||
|
||||
UIWidget* UIWidget::createCloneInstance()
|
||||
{
|
||||
return UIWidget::create();
|
||||
}
|
||||
|
||||
void UIWidget::copyClonedWidgetChildren(UIWidget* model)
|
||||
{
|
||||
cocos2d::ccArray* arrayWidgetChildren = model->getChildren()->data;
|
||||
int length = arrayWidgetChildren->num;
|
||||
for (int i=0; i<length; i++)
|
||||
{
|
||||
UIWidget* child = (UIWidget*)(arrayWidgetChildren->arr[i]);
|
||||
addChild(child->clone());
|
||||
}
|
||||
}
|
||||
|
||||
void UIWidget::copySpecialProperties(UIWidget* model)
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
void UIWidget::copyProperties(UIWidget *widget)
|
||||
{
|
||||
setEnabled(widget->isEnabled());
|
||||
setVisible(widget->isVisible());
|
||||
setBright(widget->isBright());
|
||||
setTouchEnabled(widget->isTouchEnabled());
|
||||
_touchPassedEnabled = false;
|
||||
setZOrder(widget->getZOrder());
|
||||
setUpdateEnabled(widget->isUpdateEnabled());
|
||||
setTag(widget->getTag());
|
||||
setName(widget->getName());
|
||||
setActionTag(widget->getActionTag());
|
||||
_ignoreSize = widget->_ignoreSize;
|
||||
_size = widget->_size;
|
||||
_customSize = widget->_customSize;
|
||||
copySpecialProperties(widget);
|
||||
_sizeType = widget->getSizeType();
|
||||
_sizePercent = widget->_sizePercent;
|
||||
_positionType = widget->_positionType;
|
||||
_positionPercent = widget->_positionPercent;
|
||||
setPosition(widget->getPosition());
|
||||
setAnchorPoint(widget->getAnchorPoint());
|
||||
setScaleX(widget->getScaleX());
|
||||
setScaleY(widget->getScaleY());
|
||||
setRotation(widget->getRotation());
|
||||
setRotationX(widget->getRotationX());
|
||||
setRotationY(widget->getRotationY());
|
||||
setFlipX(widget->isFlipX());
|
||||
setFlipY(widget->isFlipY());
|
||||
setColor(widget->getColor());
|
||||
setOpacity(widget->getOpacity());
|
||||
setCascadeOpacityEnabled(widget->isCascadeOpacityEnabled());
|
||||
setCascadeColorEnabled(widget->isCascadeColorEnabled());
|
||||
onSizeChanged();
|
||||
}
|
||||
|
||||
/*temp action*/
|
||||
void UIWidget::setActionTag(int tag)
|
||||
{
|
||||
|
@ -1214,7 +1239,7 @@ void GUIRenderer::visit()
|
|||
{
|
||||
return;
|
||||
}
|
||||
NodeRGBA::visit();
|
||||
cocos2d::NodeRGBA::visit();
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
|
|
@ -27,9 +27,9 @@
|
|||
|
||||
#include "cocos2d.h"
|
||||
#include "gui/UILayoutDefine.h"
|
||||
#include "gui/LayoutParameter.h"
|
||||
namespace gui {
|
||||
#include "gui/UILayoutParameter.h"
|
||||
|
||||
namespace gui {
|
||||
|
||||
typedef enum
|
||||
{
|
||||
|
@ -72,11 +72,10 @@ typedef enum
|
|||
|
||||
typedef void (cocos2d::Object::*SEL_TouchEvent)(cocos2d::Object*,TouchEventType);
|
||||
#define toucheventselector(_SELECTOR) (SEL_TouchEvent)(&_SELECTOR)
|
||||
|
||||
//class UILayer;
|
||||
/*temp action*/
|
||||
class UIActionNode;
|
||||
|
||||
/**
|
||||
* @js NA
|
||||
* @lua NA
|
||||
*/
|
||||
class UIWidget : public cocos2d::Object
|
||||
{
|
||||
public:
|
||||
|
@ -260,12 +259,7 @@ public:
|
|||
* Removes all children from the container, and do a cleanup to all running actions depending on the cleanup parameter.
|
||||
*/
|
||||
virtual void removeAllChildren();
|
||||
|
||||
/**
|
||||
* Unschedules the "update" method.
|
||||
*/
|
||||
void disableUpdate();
|
||||
|
||||
|
||||
/**
|
||||
* Reorders a child according to a new z value.
|
||||
*
|
||||
|
@ -304,27 +298,27 @@ public:
|
|||
/**
|
||||
* Gets the renderer of widget
|
||||
*
|
||||
* renderer is a CCNode, it's for drawing
|
||||
* renderer is a Node, it's for drawing
|
||||
*
|
||||
* @return a CCNode object
|
||||
* @return a Node object
|
||||
*/
|
||||
cocos2d::Node* getRenderer();
|
||||
|
||||
/**
|
||||
* Add a CCNode for rendering.
|
||||
* Add a Node for rendering.
|
||||
*
|
||||
* renderer is a CCNode, it's for drawing
|
||||
* renderer is a Node, it's for drawing
|
||||
*
|
||||
* @param renderer A render node
|
||||
*
|
||||
* @param zOrder Z order for drawing priority. Please refer to CCNode::setZOrder(int)
|
||||
* @param zOrder Z order for drawing priority. Please refer to Node::setZOrder(int)
|
||||
*/
|
||||
void addRenderer(cocos2d::Node* renderer, int zOrder);
|
||||
|
||||
/**
|
||||
* Remove a CCNode from widget.
|
||||
* Remove a Node from widget.
|
||||
*
|
||||
* renderer is a CCNode, it's for drawing
|
||||
* renderer is a Node, it's for drawing
|
||||
*
|
||||
* @param renderer A render node which needs to be removed
|
||||
*
|
||||
|
@ -359,7 +353,7 @@ public:
|
|||
/**
|
||||
* Changes the position (x,y) of the widget in OpenGL coordinates
|
||||
*
|
||||
* Usually we use ccp(x,y) to compose Point object.
|
||||
* Usually we use p(x,y) to compose Point object.
|
||||
* The original point (0,0) is at the left-bottom corner of screen.
|
||||
*
|
||||
* @param position The position (x,y) of the widget in OpenGL coordinates
|
||||
|
@ -369,7 +363,7 @@ public:
|
|||
/**
|
||||
* Changes the position (x,y) of the widget in OpenGL coordinates
|
||||
*
|
||||
* Usually we use ccp(x,y) to compose Point object.
|
||||
* Usually we use p(x,y) to compose Point object.
|
||||
* The original point (0,0) is at the left-bottom corner of screen.
|
||||
*
|
||||
* @param percent The percent (x,y) of the widget in OpenGL coordinates
|
||||
|
@ -809,15 +803,21 @@ public:
|
|||
* @see LayoutParameter
|
||||
*
|
||||
* @param LayoutParameter pointer
|
||||
*
|
||||
* @param type Relative or Linear
|
||||
*/
|
||||
void setLayoutParameter(LayoutParameter* parameter);
|
||||
void setLayoutParameter(UILayoutParameter* parameter);
|
||||
|
||||
/**
|
||||
* Gets LayoutParameter of widget.
|
||||
*
|
||||
* @see LayoutParameter
|
||||
*
|
||||
* @param type Relative or Linear
|
||||
*
|
||||
* @return LayoutParameter
|
||||
*/
|
||||
LayoutParameter* getLayoutParameter();
|
||||
UILayoutParameter* getLayoutParameter(LayoutParameterType type);
|
||||
|
||||
/**
|
||||
* Ignore the widget size
|
||||
|
@ -850,7 +850,7 @@ public:
|
|||
*
|
||||
* For example, a button's Virtual Renderer is it's texture renderer.
|
||||
*
|
||||
* @return CCNode pointer.
|
||||
* @return Node pointer.
|
||||
*/
|
||||
virtual cocos2d::Node* getVirtualRenderer();
|
||||
|
||||
|
@ -871,14 +871,15 @@ public:
|
|||
*/
|
||||
virtual const cocos2d::Size& getContentSize() const;
|
||||
|
||||
virtual void onEnter();
|
||||
virtual void onExit();
|
||||
|
||||
/**
|
||||
* Returns the "class name" of widget.
|
||||
*/
|
||||
virtual const char* getDescription() const;
|
||||
|
||||
UIWidget* clone();
|
||||
|
||||
virtual void onEnter();
|
||||
virtual void onExit();
|
||||
/*temp action*/
|
||||
void setActionTag(int tag);
|
||||
int getActionTag();
|
||||
|
@ -913,6 +914,10 @@ protected:
|
|||
*/
|
||||
virtual void releaseResoures();
|
||||
void updateSizeAndPosition();
|
||||
void copyProperties(UIWidget* model);
|
||||
virtual UIWidget* createCloneInstance();
|
||||
virtual void copySpecialProperties(UIWidget* model);
|
||||
virtual void copyClonedWidgetChildren(UIWidget* model);
|
||||
protected:
|
||||
bool _enabled; ///< Highest control of widget
|
||||
bool _visible; ///< is this widget visible
|
||||
|
@ -930,7 +935,7 @@ protected:
|
|||
cocos2d::Point _touchMovePos; ///< touch moved point
|
||||
cocos2d::Point _touchEndPos; ///< touch ended point
|
||||
|
||||
cocos2d::Object* _touchEventListener;
|
||||
Object* _touchEventListener;
|
||||
SEL_TouchEvent _touchEventSelector;
|
||||
|
||||
|
||||
|
@ -941,7 +946,7 @@ protected:
|
|||
int _actionTag;
|
||||
cocos2d::Size _size;
|
||||
cocos2d::Size _customSize;
|
||||
LayoutParameter* _layoutParameter;
|
||||
cocos2d::Dictionary* _layoutParameterDictionary;
|
||||
bool _ignoreSize;
|
||||
cocos2d::Array* _children;
|
||||
bool _affectByClipping;
|
||||
|
@ -954,7 +959,10 @@ protected:
|
|||
cocos2d::Point _positionPercent;
|
||||
bool _isRunning;
|
||||
};
|
||||
|
||||
/**
|
||||
* @js NA
|
||||
* @lua NA
|
||||
*/
|
||||
class GUIRenderer : public cocos2d::NodeRGBA
|
||||
{
|
||||
public:
|
||||
|
@ -969,5 +977,4 @@ protected:
|
|||
};
|
||||
|
||||
}
|
||||
|
||||
#endif /* defined(__UIWidget__) */
|
||||
|
|
|
@ -19,7 +19,6 @@ CocosGUITestScene::~CocosGUITestScene()
|
|||
{
|
||||
cocostudio::SceneReader::getInstance()->purgeSceneReader();
|
||||
cocostudio::ActionManagerEx::purgeActionManager();
|
||||
gui::UIHelper::purgeUIHelper();
|
||||
}
|
||||
|
||||
void CocosGUITestScene::runThisTest()
|
||||
|
|
|
@ -44,78 +44,25 @@ bool UIDragPanelTest::init()
|
|||
alert->setPosition(Point(widgetSize.width / 2.0f, widgetSize.height / 2.0f - alert->getSize().height * 2.925));
|
||||
m_pUiLayer->addWidget(alert);
|
||||
|
||||
Layout *background = dynamic_cast<Layout*>(m_pUiLayer->getWidgetByName("background_Panel"));
|
||||
|
||||
// Create the dragpanel
|
||||
UIDragPanel* dragPanel = UIDragPanel::create();
|
||||
dragPanel->setTouchEnabled(true);
|
||||
dragPanel->setBackGroundImageScale9Enabled(true);
|
||||
dragPanel->setBackGroundImage("cocosgui/scrollviewbg.png");
|
||||
dragPanel->setSize(Size(210, 122.5));
|
||||
Size backgroundSize = background->getContentSize();
|
||||
dragPanel->setPosition(Point((widgetSize.width - backgroundSize.width) / 2 +
|
||||
(backgroundSize.width - dragPanel->getSize().width) / 2,
|
||||
(widgetSize.height - backgroundSize.height) / 2 +
|
||||
(backgroundSize.height - dragPanel->getSize().height) / 2));
|
||||
dragPanel->addEventListener(this, dragpaneleventselector(UIDragPanelTest::dragPanelEvent));
|
||||
|
||||
UIImageView* imageView = UIImageView::create();
|
||||
imageView->setTouchEnabled(true);
|
||||
imageView->loadTexture("cocosgui/b11.png");
|
||||
dragPanel->addChild(imageView);
|
||||
|
||||
dragPanel->setInnerContainerSize(imageView->getContentSize());
|
||||
Size innerSize = dragPanel->getInnerContainerSize();
|
||||
imageView->setPosition(Point(innerSize.width / 2, innerSize.height / 2));
|
||||
|
||||
m_pUiLayer->addWidget(dragPanel);
|
||||
UIScrollView* sc = UIScrollView::create();
|
||||
sc->setBackGroundColor(Color3B::GREEN);
|
||||
sc->setBackGroundColorType(LAYOUT_COLOR_SOLID);
|
||||
sc->setDirection(SCROLLVIEW_DIR_BOTH);
|
||||
sc->setInnerContainerSize(Size(480, 320));
|
||||
sc->setSize(Size(100,100));
|
||||
sc->setPosition(Point(100,100));
|
||||
sc->scrollToPercentBothDirection(Point(50, 50), 1, true);
|
||||
UIImageView* iv = UIImageView::create();
|
||||
iv->loadTexture("cocosgui/Hello.png");
|
||||
iv->setPosition(Point(240, 160));
|
||||
sc->addChild(iv);
|
||||
m_pUiLayer->addWidget(sc);
|
||||
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
void UIDragPanelTest::dragPanelEvent(Object *pSender, DragPanelEventType type)
|
||||
{
|
||||
switch (type)
|
||||
{
|
||||
case DRAGPANEL_EVENT_BERTH_LEFTBOTTOM:
|
||||
m_pDisplayValueLabel->setText(CCString::createWithFormat("Berth To Left Bottom")->getCString());
|
||||
break;
|
||||
|
||||
case DRAGPANEL_EVENT_BERTH_LFETTOP:
|
||||
m_pDisplayValueLabel->setText(CCString::createWithFormat("Berth To Left Top")->getCString());
|
||||
break;
|
||||
|
||||
case DRAGPANEL_EVENT_BERTH_RIGHTBOTTOM:
|
||||
m_pDisplayValueLabel->setText(CCString::createWithFormat("Berth To Right Bottom")->getCString());
|
||||
break;
|
||||
|
||||
case DRAGPANEL_EVENT_BERTH_RIGHTTOP:
|
||||
m_pDisplayValueLabel->setText(CCString::createWithFormat("Berth To Right Top")->getCString());
|
||||
break;
|
||||
|
||||
case DRAGPANEL_EVENT_BERTH_LEFT:
|
||||
m_pDisplayValueLabel->setText(CCString::createWithFormat("Berth To Left")->getCString());
|
||||
break;
|
||||
|
||||
case DRAGPANEL_EVENT_BERTH_TOP:
|
||||
m_pDisplayValueLabel->setText(CCString::createWithFormat("Berth To Top")->getCString());
|
||||
break;
|
||||
|
||||
case DRAGPANEL_EVENT_BERTH_RIGHT:
|
||||
m_pDisplayValueLabel->setText(CCString::createWithFormat("Berth To Right")->getCString());
|
||||
break;
|
||||
|
||||
case DRAGPANEL_EVENT_BERTH_BOTTOM:
|
||||
m_pDisplayValueLabel->setText(CCString::createWithFormat("Berth To Bottom")->getCString());
|
||||
break;
|
||||
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
// UIDragPanelTest_Bounce
|
||||
UIDragPanelTest_Bounce::UIDragPanelTest_Bounce()
|
||||
: m_pDisplayValueLabel(NULL)
|
||||
|
@ -151,76 +98,23 @@ bool UIDragPanelTest_Bounce::init()
|
|||
alert->setPosition(Point(widgetSize.width / 2.0f, widgetSize.height / 2.0f - alert->getSize().height * 2.925));
|
||||
m_pUiLayer->addWidget(alert);
|
||||
|
||||
Layout *background = dynamic_cast<Layout*>(m_pUiLayer->getWidgetByName("background_Panel"));
|
||||
|
||||
// Create the dragpanel
|
||||
UIDragPanel* dragPanel = UIDragPanel::create();
|
||||
dragPanel->setTouchEnabled(true);
|
||||
dragPanel->setBounceEnable(true);
|
||||
dragPanel->setBackGroundImageScale9Enabled(true);
|
||||
dragPanel->setBackGroundImage("cocosgui/green_edit.png");
|
||||
dragPanel->setSize(Size(210, 122.5));
|
||||
Size backgroundSize = background->getContentSize();
|
||||
dragPanel->setPosition(Point((widgetSize.width - backgroundSize.width) / 2 +
|
||||
(backgroundSize.width - dragPanel->getSize().width) / 2,
|
||||
(widgetSize.height - backgroundSize.height) / 2 +
|
||||
(backgroundSize.height - dragPanel->getSize().height) / 2));
|
||||
dragPanel->addEventListener(this, dragpaneleventselector(UIDragPanelTest_Bounce::dragPanelEvent));
|
||||
|
||||
UIImageView* imageView = UIImageView::create();
|
||||
imageView->setTouchEnabled(true);
|
||||
imageView->loadTexture("cocosgui/b11.png");
|
||||
dragPanel->addChild(imageView);
|
||||
|
||||
dragPanel->setInnerContainerSize(imageView->getContentSize());
|
||||
Size innerSize = dragPanel->getInnerContainerSize();
|
||||
imageView->setPosition(Point(innerSize.width / 2, innerSize.height / 2));
|
||||
|
||||
m_pUiLayer->addWidget(dragPanel);
|
||||
|
||||
UIScrollView* sc = UIScrollView::create();
|
||||
sc->setBackGroundColor(Color3B::GREEN);
|
||||
sc->setBackGroundColorType(LAYOUT_COLOR_SOLID);
|
||||
sc->setBounceEnabled(true);
|
||||
sc->setDirection(SCROLLVIEW_DIR_BOTH);
|
||||
sc->setInnerContainerSize(Size(480, 320));
|
||||
sc->setSize(Size(100,100));
|
||||
sc->setPosition(Point(100,100));
|
||||
sc->scrollToPercentBothDirection(Point(50, 50), 1, true);
|
||||
UIImageView* iv = UIImageView::create();
|
||||
iv->loadTexture("cocosgui/Hello.png");
|
||||
iv->setPosition(Point(240, 160));
|
||||
sc->addChild(iv);
|
||||
m_pUiLayer->addWidget(sc);
|
||||
return true;
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
void UIDragPanelTest_Bounce::dragPanelEvent(Object *pSender, DragPanelEventType type)
|
||||
{
|
||||
switch (type)
|
||||
{
|
||||
case DRAGPANEL_EVENT_BOUNCE_LEFTBOTTOM:
|
||||
m_pDisplayValueLabel->setText(CCString::createWithFormat("Bounce To Left Bottom")->getCString());
|
||||
break;
|
||||
|
||||
case DRAGPANEL_EVENT_BOUNCE_LEFTTOP:
|
||||
m_pDisplayValueLabel->setText(CCString::createWithFormat("Bounce To Left Top")->getCString());
|
||||
break;
|
||||
|
||||
case DRAGPANEL_EVENT_BOUNCE_RIGHTBOTTOM:
|
||||
m_pDisplayValueLabel->setText(CCString::createWithFormat("Bounce To Right Bottom")->getCString());
|
||||
break;
|
||||
|
||||
case DRAGPANEL_EVENT_BOUNCE_RIGHTTOP:
|
||||
m_pDisplayValueLabel->setText(CCString::createWithFormat("Bounce To Right Top")->getCString());
|
||||
break;
|
||||
|
||||
case DRAGPANEL_EVENT_BOUNCE_LEFT:
|
||||
m_pDisplayValueLabel->setText(CCString::createWithFormat("Bounce To Left")->getCString());
|
||||
break;
|
||||
|
||||
case DRAGPANEL_EVENT_BOUNCE_TOP:
|
||||
m_pDisplayValueLabel->setText(CCString::createWithFormat("Bounce To Top")->getCString());
|
||||
break;
|
||||
|
||||
case DRAGPANEL_EVENT_BOUNCE_RIGHT:
|
||||
m_pDisplayValueLabel->setText(CCString::createWithFormat("Bounce To Right")->getCString());
|
||||
break;
|
||||
|
||||
case DRAGPANEL_EVENT_BOUNCE_BOTTOM:
|
||||
m_pDisplayValueLabel->setText(CCString::createWithFormat("Bounce To Bottom")->getCString());
|
||||
break;
|
||||
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -33,7 +33,6 @@ public:
|
|||
UIDragPanelTest();
|
||||
~UIDragPanelTest();
|
||||
bool init();
|
||||
void dragPanelEvent(Object* pSender, DragPanelEventType type);
|
||||
|
||||
protected:
|
||||
UI_SCENE_CREATE_FUNC(UIDragPanelTest)
|
||||
|
@ -46,7 +45,6 @@ public:
|
|||
UIDragPanelTest_Bounce();
|
||||
~UIDragPanelTest_Bounce();
|
||||
bool init();
|
||||
void dragPanelEvent(Object* pSender, DragPanelEventType type);
|
||||
|
||||
protected:
|
||||
UI_SCENE_CREATE_FUNC(UIDragPanelTest_Bounce)
|
||||
|
|
|
@ -45,54 +45,23 @@ bool UIListViewTest_Vertical::init()
|
|||
alert->setPosition(Point(widgetSize.width / 2.0f, widgetSize.height / 2.0f - alert->getSize().height * 2.925));
|
||||
m_pUiLayer->addWidget(alert);
|
||||
|
||||
Layout *background = dynamic_cast<Layout*>(m_pUiLayer->getWidgetByName("background_Panel"));
|
||||
|
||||
// Create the list view
|
||||
m_nCount = 0;
|
||||
m_array = CCArray::create();
|
||||
m_array->retain();
|
||||
for (int i = 0; i < 20; ++i)
|
||||
UIListView* lv = UIListView::create();
|
||||
UIButton* model = UIButton::create();
|
||||
model->loadTextures("cocosgui/animationbuttonnormal.png", "cocosgui/animationbuttonpressed.png", "");
|
||||
lv->setItemModel(model);
|
||||
|
||||
for (int i=0; i<20; i++)
|
||||
{
|
||||
String* ccstr = String::createWithFormat("object_%d", i);
|
||||
m_array->addObject(ccstr);
|
||||
lv->pushBackDefaultItem();
|
||||
}
|
||||
|
||||
UIListView *listView = UIListView::create();
|
||||
listView->setTouchEnabled(true);
|
||||
listView->setBackGroundImageScale9Enabled(true);
|
||||
listView->setBackGroundImage("cocosgui/green_edit.png");
|
||||
listView->setSize(Size(240, 130));
|
||||
Size backgroundSize = background->getContentSize();
|
||||
listView->setPosition(Point((widgetSize.width - backgroundSize.width) / 2 +
|
||||
(backgroundSize.width - listView->getSize().width) / 2,
|
||||
(widgetSize.height - backgroundSize.height) / 2 +
|
||||
(backgroundSize.height - listView->getSize().height) / 2));
|
||||
|
||||
float listWidth = listView->getSize().width;
|
||||
float listHeight = listView->getSize().height;
|
||||
|
||||
for (int i = 0; i < 5; ++i)
|
||||
{
|
||||
UIButton* textButton = UIButton::create();
|
||||
textButton->setName("TextButton");
|
||||
textButton->setTouchEnabled(true);
|
||||
textButton->loadTextures("cocosgui/backtotoppressed.png", "cocosgui/backtotopnormal.png", "");
|
||||
|
||||
Layout *layout = Layout::create();
|
||||
layout->setName(String::createWithFormat("panel_%i", i)->getCString());
|
||||
layout->setSize(Size(textButton->getSize().width, textButton->getSize().height));
|
||||
textButton->setPosition(Point(layout->getSize().width / 2, layout->getSize().height / 2));
|
||||
layout->addChild(textButton);
|
||||
|
||||
Size panel_size = layout->getSize();
|
||||
layout->setPosition(Point((listWidth - panel_size.width) / 2,
|
||||
(listHeight - (panel_size.height + panel_size.height * 0.25)) - i * (panel_size.height + panel_size.height * 0.25)));
|
||||
|
||||
listView->addChild(layout);
|
||||
}
|
||||
listView->addEventListenter(this, listvieweventselector(UIListViewTest_Vertical::listViewEvent));
|
||||
listView->initChildWithDataLength(m_array->count());
|
||||
m_pUiLayer->addWidget(listView);
|
||||
lv->setItemsMargin(10);
|
||||
lv->setGravity(LISTVIEW_GRAVITY_CENTER_HORIZONTAL);
|
||||
lv->setSize(Size(100, 100));
|
||||
lv->setBackGroundColorType(LAYOUT_COLOR_SOLID);
|
||||
lv->setBackGroundColor(Color3B::GREEN);
|
||||
lv->setPosition(Point(100, 100));
|
||||
m_pUiLayer->addWidget(lv);
|
||||
|
||||
return true;
|
||||
}
|
||||
|
@ -100,46 +69,6 @@ bool UIListViewTest_Vertical::init()
|
|||
return false;
|
||||
}
|
||||
|
||||
void UIListViewTest_Vertical::listViewEvent(Object *pSender, ListViewEventType type)
|
||||
{
|
||||
switch (type)
|
||||
{
|
||||
case LISTVIEW_EVENT_INIT_CHILD:
|
||||
{
|
||||
String* ccstr = static_cast<String*>(m_array->getObjectAtIndex(m_nCount));
|
||||
UIListView* list = dynamic_cast<UIListView*>(pSender);
|
||||
|
||||
Layout* layout = dynamic_cast<Layout*>(list->getUpdateChild());
|
||||
UIButton* textButton = dynamic_cast<UIButton*>(layout->getChildByName("TextButton"));
|
||||
textButton->setTitleText(ccstr->getCString());
|
||||
|
||||
m_nCount++;
|
||||
}
|
||||
break;
|
||||
|
||||
case LISTVIEW_EVENT_UPDATE_CHILD:
|
||||
{
|
||||
UIListView* list = dynamic_cast<UIListView*>(pSender);
|
||||
int index = list->getUpdateDataIndex();
|
||||
|
||||
if (index < 0 || index >= list->getDataLength())
|
||||
{
|
||||
list->setUpdateSuccess(false);
|
||||
}
|
||||
|
||||
String* ccstr = static_cast<String*>(m_array->getObjectAtIndex(index));
|
||||
Layout* layout = dynamic_cast<Layout*>(list->getUpdateChild());
|
||||
UIButton* textButton = dynamic_cast<UIButton*>(layout->getChildByName("TextButton"));
|
||||
textButton->setTitleText(ccstr->getCString());
|
||||
list->setUpdateSuccess(true);
|
||||
}
|
||||
break;
|
||||
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
// UIListViewTest_Horizontal
|
||||
|
||||
UIListViewTest_Horizontal::UIListViewTest_Horizontal()
|
||||
|
@ -176,97 +105,26 @@ bool UIListViewTest_Horizontal::init()
|
|||
alert->setPosition(Point(widgetSize.width / 2.0f, widgetSize.height / 2.0f - alert->getSize().height * 2.925));
|
||||
m_pUiLayer->addWidget(alert);
|
||||
|
||||
Layout *background = dynamic_cast<Layout*>(m_pUiLayer->getWidgetByName("background_Panel"));
|
||||
|
||||
UIListView* lv = UIListView::create();
|
||||
lv->setDirection(SCROLLVIEW_DIR_HORIZONTAL);
|
||||
UIButton* model = UIButton::create();
|
||||
model->loadTextures("cocosgui/animationbuttonnormal.png", "cocosgui/animationbuttonpressed.png", "");
|
||||
lv->setItemModel(model);
|
||||
|
||||
// Create the list view
|
||||
m_nCount = 0;
|
||||
m_array = CCArray::create();
|
||||
m_array->retain();
|
||||
for (int i = 0; i < 20; ++i)
|
||||
for (int i=0; i<20; i++)
|
||||
{
|
||||
String* ccstr = String::createWithFormat("object_%d", i);
|
||||
m_array->addObject(ccstr);
|
||||
lv->pushBackDefaultItem();
|
||||
}
|
||||
|
||||
UIListView *listView = UIListView::create();
|
||||
listView->setDirection(LISTVIEW_DIR_HORIZONTAL);
|
||||
listView->setTouchEnabled(true);
|
||||
listView->setBackGroundImageScale9Enabled(true);
|
||||
listView->setBackGroundImage("cocosgui/green_edit.png");
|
||||
listView->setSize(Size(240, 130));
|
||||
Size backgroundSize = background->getContentSize();
|
||||
listView->setPosition(Point((widgetSize.width - backgroundSize.width) / 2 +
|
||||
(backgroundSize.width - listView->getSize().width) / 2,
|
||||
(widgetSize.height - backgroundSize.height) / 2 +
|
||||
(backgroundSize.height - listView->getSize().height) / 2));
|
||||
|
||||
float listHeight = listView->getSize().height;
|
||||
|
||||
for (int i = 0; i < 3; ++i)
|
||||
{
|
||||
UIButton* textButton = UIButton::create();
|
||||
textButton->setName("TextButton");
|
||||
textButton->setTouchEnabled(true);
|
||||
textButton->loadTextures("cocosgui/backtotoppressed.png", "cocosgui/backtotopnormal.png", "");
|
||||
|
||||
Layout *layout = Layout::create();
|
||||
layout->setName(String::createWithFormat("panel_%i", i)->getCString());
|
||||
layout->setSize(Size(textButton->getSize().width, textButton->getSize().height));
|
||||
textButton->setPosition(Point(layout->getSize().width / 2, layout->getSize().height / 2));
|
||||
layout->addChild(textButton);
|
||||
|
||||
Size layout_size = layout->getSize();
|
||||
layout->setPosition(Point(0 + (layout_size.width * 0.2) + i * (layout_size.width + layout_size.width * 0.2),
|
||||
(listHeight - layout_size.height) / 2));
|
||||
|
||||
listView->addChild(layout);
|
||||
}
|
||||
listView->addEventListenter(this, listvieweventselector(UIListViewTest_Horizontal::listViewEvent));
|
||||
listView->initChildWithDataLength(m_array->count());
|
||||
m_pUiLayer->addWidget(listView);
|
||||
|
||||
lv->setItemsMargin(10);
|
||||
lv->setGravity(LISTVIEW_GRAVITY_CENTER_VERTICAL);
|
||||
lv->setSize(Size(100, 100));
|
||||
lv->setBackGroundColorType(LAYOUT_COLOR_SOLID);
|
||||
lv->setBackGroundColor(Color3B::GREEN);
|
||||
lv->setPosition(Point(100, 100));
|
||||
m_pUiLayer->addWidget(lv);
|
||||
return true;
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
void UIListViewTest_Horizontal::listViewEvent(Object *pSender, ListViewEventType type)
|
||||
{
|
||||
switch (type)
|
||||
{
|
||||
case LISTVIEW_EVENT_INIT_CHILD:
|
||||
{
|
||||
String* ccstr = static_cast<String*>(m_array->getObjectAtIndex(m_nCount));
|
||||
UIListView* list = dynamic_cast<UIListView*>(pSender);
|
||||
|
||||
Layout* layout = dynamic_cast<Layout*>(list->getUpdateChild());
|
||||
UIButton* textButton = dynamic_cast<UIButton*>(layout->getChildByName("TextButton"));
|
||||
textButton->setTitleText(ccstr->getCString());
|
||||
|
||||
m_nCount++;
|
||||
}
|
||||
break;
|
||||
|
||||
case LISTVIEW_EVENT_UPDATE_CHILD:
|
||||
{
|
||||
UIListView* list = dynamic_cast<UIListView*>(pSender);
|
||||
int index = list->getUpdateDataIndex();
|
||||
|
||||
if (index < 0 || index >= list->getDataLength())
|
||||
{
|
||||
list->setUpdateSuccess(false);
|
||||
}
|
||||
|
||||
String* ccstr = static_cast<String*>(m_array->getObjectAtIndex(index));
|
||||
Layout* layout = dynamic_cast<Layout*>(list->getUpdateChild());
|
||||
UIButton* textButton = dynamic_cast<UIButton*>(layout->getChildByName("TextButton"));
|
||||
textButton->setTitleText(ccstr->getCString());
|
||||
list->setUpdateSuccess(true);
|
||||
}
|
||||
break;
|
||||
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
|
@ -33,7 +33,6 @@ public:
|
|||
UIListViewTest_Vertical();
|
||||
~UIListViewTest_Vertical();
|
||||
bool init();
|
||||
void listViewEvent(Object* pSender, ListViewEventType type);
|
||||
|
||||
protected:
|
||||
UI_SCENE_CREATE_FUNC(UIListViewTest_Vertical)
|
||||
|
@ -49,7 +48,6 @@ public:
|
|||
UIListViewTest_Horizontal();
|
||||
~UIListViewTest_Horizontal();
|
||||
bool init();
|
||||
void listViewEvent(Object* pSender, ListViewEventType type);
|
||||
|
||||
protected:
|
||||
UI_SCENE_CREATE_FUNC(UIListViewTest_Horizontal)
|
||||
|
|
|
@ -44,7 +44,7 @@ bool UIPageViewTest::init()
|
|||
alert->setPosition(Point(widgetSize.width / 2.0f, widgetSize.height / 2.0f - alert->getSize().height * 2.925));
|
||||
m_pUiLayer->addWidget(alert);
|
||||
|
||||
Layout *background = dynamic_cast<Layout*>(m_pUiLayer->getWidgetByName("background_Panel"));
|
||||
UILayout *background = dynamic_cast<UILayout*>(m_pUiLayer->getWidgetByName("background_Panel"));
|
||||
|
||||
// Create the page view
|
||||
UIPageView* pageView = UIPageView::create();
|
||||
|
@ -58,7 +58,7 @@ bool UIPageViewTest::init()
|
|||
|
||||
for (int i = 0; i < 3; ++i)
|
||||
{
|
||||
Layout* layout = Layout::create();
|
||||
UILayout* layout = UILayout::create();
|
||||
layout->setSize(Size(240, 130));
|
||||
|
||||
UIImageView* imageView = UIImageView::create();
|
||||
|
|
|
@ -34,10 +34,10 @@ bool UIPanelTest::init()
|
|||
alert->setPosition(Point(widgetSize.width / 2.0f, widgetSize.height / 2.0f - alert->getSize().height * 2.925));
|
||||
m_pUiLayer->addWidget(alert);
|
||||
|
||||
Layout *background = dynamic_cast<Layout*>(m_pUiLayer->getWidgetByName("background_Panel"));
|
||||
UILayout *background = dynamic_cast<UILayout*>(m_pUiLayer->getWidgetByName("background_Panel"));
|
||||
|
||||
// Create the layout
|
||||
Layout* layout = Layout::create();
|
||||
UILayout* layout = UILayout::create();
|
||||
layout->setSize(Size(280, 150));
|
||||
Size backgroundSize = background->getSize();
|
||||
layout->setPosition(Point((widgetSize.width - backgroundSize.width) / 2 +
|
||||
|
@ -98,10 +98,10 @@ bool UIPanelTest_Color::init()
|
|||
alert->setPosition(Point(widgetSize.width / 2.0f, widgetSize.height / 2.0f - alert->getSize().height * 2.925));
|
||||
m_pUiLayer->addWidget(alert);
|
||||
|
||||
Layout *background = dynamic_cast<Layout*>(m_pUiLayer->getWidgetByName("background_Panel"));
|
||||
UILayout *background = dynamic_cast<UILayout*>(m_pUiLayer->getWidgetByName("background_Panel"));
|
||||
|
||||
// Create the layout with color render
|
||||
Layout* layout = Layout::create();
|
||||
UILayout* layout = UILayout::create();
|
||||
layout->setBackGroundColorType(LAYOUT_COLOR_SOLID);
|
||||
layout->setBackGroundColor(Color3B(128, 128, 128));
|
||||
layout->setSize(Size(280, 150));
|
||||
|
@ -163,10 +163,10 @@ bool UIPanelTest_Gradient::init()
|
|||
alert->setPosition(Point(widgetSize.width / 2.0f, widgetSize.height / 2.0f - alert->getSize().height * 2.925));
|
||||
m_pUiLayer->addWidget(alert);
|
||||
|
||||
Layout *background = dynamic_cast<Layout*>(m_pUiLayer->getWidgetByName("background_Panel"));
|
||||
UILayout *background = dynamic_cast<UILayout*>(m_pUiLayer->getWidgetByName("background_Panel"));
|
||||
|
||||
// Create the layout with gradient render
|
||||
Layout* layout = Layout::create();
|
||||
UILayout* layout = UILayout::create();
|
||||
layout->setBackGroundColorType(LAYOUT_COLOR_GRADIENT);
|
||||
layout->setBackGroundColor(Color3B(64, 64, 64), Color3B(192, 192, 192));
|
||||
layout->setSize(Size(280, 150));
|
||||
|
@ -228,10 +228,10 @@ bool UIPanelTest_BackGroundImage::init()
|
|||
alert->setPosition(Point(widgetSize.width / 2.0f, widgetSize.height / 2.0f - alert->getSize().height * 2.925));
|
||||
m_pUiLayer->addWidget(alert);
|
||||
|
||||
Layout *background = dynamic_cast<Layout*>(m_pUiLayer->getWidgetByName("background_Panel"));
|
||||
UILayout *background = dynamic_cast<UILayout*>(m_pUiLayer->getWidgetByName("background_Panel"));
|
||||
|
||||
// Create the layout with background image
|
||||
Layout* layout = Layout::create();
|
||||
UILayout* layout = UILayout::create();
|
||||
layout->setClippingEnabled(true);
|
||||
layout->setBackGroundImage("cocosgui/Hello.png");
|
||||
layout->setSize(Size(280, 150));
|
||||
|
@ -293,10 +293,10 @@ bool UIPanelTest_BackGroundImage_Scale9::init()
|
|||
alert->setPosition(Point(widgetSize.width / 2.0f, widgetSize.height / 2.0f - alert->getSize().height * 2.925));
|
||||
m_pUiLayer->addWidget(alert);
|
||||
|
||||
Layout *background = dynamic_cast<Layout*>(m_pUiLayer->getWidgetByName("background_Panel"));
|
||||
UILayout *background = dynamic_cast<UILayout*>(m_pUiLayer->getWidgetByName("background_Panel"));
|
||||
|
||||
// Create the layout with background image
|
||||
Layout* layout = Layout::create();
|
||||
UILayout* layout = UILayout::create();
|
||||
layout->setBackGroundImageScale9Enabled(true);
|
||||
layout->setBackGroundImage("cocosgui/green_edit.png");
|
||||
layout->setSize(Size(280, 150));
|
||||
|
@ -358,10 +358,10 @@ bool UIPanelTest_Layout_Linear_Vertical::init()
|
|||
alert->setPosition(Point(widgetSize.width / 2.0f, widgetSize.height / 2.0f - alert->getSize().height * 2.925));
|
||||
m_pUiLayer->addWidget(alert);
|
||||
|
||||
Layout *background = dynamic_cast<Layout*>(m_pUiLayer->getWidgetByName("background_Panel"));
|
||||
UILayout *background = dynamic_cast<UILayout*>(m_pUiLayer->getWidgetByName("background_Panel"));
|
||||
|
||||
// Create the layout
|
||||
Layout* layout = Layout::create();
|
||||
UILayout* layout = UILayout::create();
|
||||
layout->setLayoutType(LAYOUT_LINEAR_VERTICAL);
|
||||
layout->setSize(Size(280, 150));
|
||||
Size backgroundSize = background->getSize();
|
||||
|
@ -377,7 +377,7 @@ bool UIPanelTest_Layout_Linear_Vertical::init()
|
|||
button->loadTextures("cocosgui/animationbuttonnormal.png", "cocosgui/animationbuttonpressed.png", "");
|
||||
layout->addChild(button);
|
||||
|
||||
LinearLayoutParameter* lp1 = LinearLayoutParameter::create();
|
||||
UILinearLayoutParameter* lp1 = UILinearLayoutParameter::create();
|
||||
button->setLayoutParameter(lp1);
|
||||
lp1->setGravity(LINEAR_GRAVITY_CENTER_HORIZONTAL);
|
||||
lp1->setMargin(UIMargin(0, 5, 0, 10));
|
||||
|
@ -389,7 +389,7 @@ bool UIPanelTest_Layout_Linear_Vertical::init()
|
|||
textButton->setTitleText("Text Button");
|
||||
layout->addChild(textButton);
|
||||
|
||||
LinearLayoutParameter* lp2 = LinearLayoutParameter::create();
|
||||
UILinearLayoutParameter* lp2 = UILinearLayoutParameter::create();
|
||||
textButton->setLayoutParameter(lp2);
|
||||
lp2->setGravity(LINEAR_GRAVITY_CENTER_HORIZONTAL);
|
||||
lp2->setMargin(UIMargin(0, 10, 0, 10));
|
||||
|
@ -402,7 +402,7 @@ bool UIPanelTest_Layout_Linear_Vertical::init()
|
|||
button_scale9->setSize(Size(100, button_scale9->getContentSize().height));
|
||||
layout->addChild(button_scale9);
|
||||
|
||||
LinearLayoutParameter* lp3 = LinearLayoutParameter::create();
|
||||
UILinearLayoutParameter* lp3 = UILinearLayoutParameter::create();
|
||||
button_scale9->setLayoutParameter(lp3);
|
||||
lp3->setGravity(LINEAR_GRAVITY_CENTER_HORIZONTAL);
|
||||
lp3->setMargin(UIMargin(0, 10, 0, 10));
|
||||
|
@ -441,10 +441,10 @@ bool UIPanelTest_Layout_Linear_Horizontal::init()
|
|||
alert->setPosition(Point(widgetSize.width / 2.0f, widgetSize.height / 2.0f - alert->getSize().height * 2.925));
|
||||
m_pUiLayer->addWidget(alert);
|
||||
|
||||
Layout *background = dynamic_cast<Layout*>(m_pUiLayer->getWidgetByName("background_Panel"));
|
||||
UILayout *background = dynamic_cast<UILayout*>(m_pUiLayer->getWidgetByName("background_Panel"));
|
||||
|
||||
// Create the layout
|
||||
Layout* layout = Layout::create();
|
||||
UILayout* layout = UILayout::create();
|
||||
layout->setLayoutType(LAYOUT_LINEAR_HORIZONTAL);
|
||||
layout->setClippingEnabled(true);
|
||||
layout->setSize(Size(280, 150));
|
||||
|
@ -460,7 +460,7 @@ bool UIPanelTest_Layout_Linear_Horizontal::init()
|
|||
button->loadTextures("cocosgui/animationbuttonnormal.png", "cocosgui/animationbuttonpressed.png", "");
|
||||
layout->addChild(button);
|
||||
|
||||
LinearLayoutParameter* lp1 = LinearLayoutParameter::create();
|
||||
UILinearLayoutParameter* lp1 = UILinearLayoutParameter::create();
|
||||
button->setLayoutParameter(lp1);
|
||||
lp1->setGravity(LINEAR_GRAVITY_CENTER_VERTICAL);
|
||||
lp1->setMargin(UIMargin(0, 10, 0, 10));
|
||||
|
@ -472,7 +472,7 @@ bool UIPanelTest_Layout_Linear_Horizontal::init()
|
|||
textButton->setTitleText("Text Button");
|
||||
layout->addChild(textButton);
|
||||
|
||||
LinearLayoutParameter* lp2 = LinearLayoutParameter::create();
|
||||
UILinearLayoutParameter* lp2 = UILinearLayoutParameter::create();
|
||||
textButton->setLayoutParameter(lp2);
|
||||
lp2->setGravity(LINEAR_GRAVITY_CENTER_VERTICAL);
|
||||
lp2->setMargin(UIMargin(0, 10, 0, 10));
|
||||
|
@ -485,7 +485,7 @@ bool UIPanelTest_Layout_Linear_Horizontal::init()
|
|||
button_scale9->setSize(Size(100, button_scale9->getContentSize().height));
|
||||
layout->addChild(button_scale9);
|
||||
|
||||
LinearLayoutParameter* lp3 = LinearLayoutParameter::create();
|
||||
UILinearLayoutParameter* lp3 = UILinearLayoutParameter::create();
|
||||
button_scale9->setLayoutParameter(lp3);
|
||||
lp3->setGravity(LINEAR_GRAVITY_CENTER_VERTICAL);
|
||||
lp3->setMargin(UIMargin(0, 10, 0, 10));
|
||||
|
@ -524,10 +524,10 @@ bool UIPanelTest_Layout_Relative::init()
|
|||
alert->setPosition(Point(widgetSize.width / 2.0f, widgetSize.height / 2.0f - alert->getSize().height * 2.925));
|
||||
m_pUiLayer->addWidget(alert);
|
||||
|
||||
Layout *background = dynamic_cast<Layout*>(m_pUiLayer->getWidgetByName("background_Panel"));
|
||||
UILayout *background = dynamic_cast<UILayout*>(m_pUiLayer->getWidgetByName("background_Panel"));
|
||||
|
||||
// Create the layout
|
||||
Layout* layout = Layout::create();
|
||||
UILayout* layout = UILayout::create();
|
||||
layout->setLayoutType(LAYOUT_RELATIVE);
|
||||
layout->setSize(Size(280, 150));
|
||||
layout->setBackGroundColorType(LAYOUT_COLOR_SOLID);
|
||||
|
@ -544,9 +544,9 @@ bool UIPanelTest_Layout_Relative::init()
|
|||
button->loadTextures("cocosgui/animationbuttonnormal.png", "cocosgui/animationbuttonpressed.png", "");
|
||||
layout->addChild(button);
|
||||
|
||||
RelativeLayoutParameter* rp1 = RelativeLayoutParameter::create();
|
||||
UIRelativeLayoutParameter* rp1 = UIRelativeLayoutParameter::create();
|
||||
button->setLayoutParameter(rp1);
|
||||
rp1->setAlign(RELATIVE_ALIGN_PARENT_BOTTOM);
|
||||
rp1->setAlign(RELATIVE_ALIGN_PARENT_BOTTOM_CENTER_HORIZONTAL);
|
||||
// rp1->setMargin(UIMargin(0, 10, 0, 10));
|
||||
|
||||
|
||||
|
@ -556,9 +556,9 @@ bool UIPanelTest_Layout_Relative::init()
|
|||
textButton->setTitleText("Text Button");
|
||||
layout->addChild(textButton);
|
||||
|
||||
RelativeLayoutParameter* rp2 = RelativeLayoutParameter::create();
|
||||
UIRelativeLayoutParameter* rp2 = UIRelativeLayoutParameter::create();
|
||||
textButton->setLayoutParameter(rp2);
|
||||
rp2->setAlign(RELATIVE_ALIGN_PARENT_LEFT);
|
||||
rp2->setAlign(RELATIVE_ALIGN_PARENT_LEFT_BOTTOM);
|
||||
|
||||
|
||||
UIButton* button_scale9 = UIButton::create();
|
||||
|
@ -568,9 +568,9 @@ bool UIPanelTest_Layout_Relative::init()
|
|||
button_scale9->setSize(Size(100, button_scale9->getContentSize().height));
|
||||
layout->addChild(button_scale9);
|
||||
|
||||
RelativeLayoutParameter* rp3 = RelativeLayoutParameter::create();
|
||||
UIRelativeLayoutParameter* rp3 = UIRelativeLayoutParameter::create();
|
||||
textButton->setLayoutParameter(rp3);
|
||||
rp3->setAlign(RELATIVE_ALIGN_PARENT_RIGHT);
|
||||
rp3->setAlign(RELATIVE_ALIGN_PARENT_RIGHT_BOTTOM);
|
||||
|
||||
|
||||
layout->doLayout();
|
||||
|
|
|
@ -3,6 +3,7 @@
|
|||
#include "UIScene.h"
|
||||
#include "UISceneManager.h"
|
||||
#include "../ExtensionsTest.h"
|
||||
#include "editor-support/cocostudio/CCSGUIReader.h"
|
||||
|
||||
using namespace gui;
|
||||
|
||||
|
@ -25,7 +26,7 @@ bool UIScene::init()
|
|||
m_pUiLayer = UILayer::create();
|
||||
addChild(m_pUiLayer);
|
||||
|
||||
m_pWidget = dynamic_cast<Layout*>(CCUIHELPER->createWidgetFromJsonFile("cocosgui/UITest/UITest.json"));
|
||||
m_pWidget = dynamic_cast<UILayout*>(cocostudio::CCSGUIReader::shareReader()->widgetFromJsonFile("cocosgui/UITest/UITest.json"));
|
||||
m_pUiLayer->addWidget(m_pWidget);
|
||||
|
||||
m_pSceneTitle = dynamic_cast<UILabel*>(m_pUiLayer->getWidgetByName("UItest"));
|
||||
|
|
|
@ -95,7 +95,7 @@ protected:
|
|||
|
||||
protected:
|
||||
UILayer *m_pUiLayer;
|
||||
Layout *m_pWidget;
|
||||
UILayout *m_pWidget;
|
||||
};
|
||||
|
||||
#endif /* defined(__TestCpp__UIScene__) */
|
||||
|
|
|
@ -44,7 +44,7 @@ bool UIScrollViewTest_Vertical::init()
|
|||
alert->setPosition(Point(widgetSize.width / 2.0f, widgetSize.height / 2.0f - alert->getSize().height * 2.925));
|
||||
m_pUiLayer->addWidget(alert);
|
||||
|
||||
Layout *background = dynamic_cast<Layout*>(m_pUiLayer->getWidgetByName("background_Panel"));
|
||||
UILayout *background = dynamic_cast<UILayout*>(m_pUiLayer->getWidgetByName("background_Panel"));
|
||||
|
||||
// Create the scrollview by vertical
|
||||
UIScrollView* scrollView = UIScrollView::create();
|
||||
|
@ -129,10 +129,11 @@ bool UIScrollViewTest_Horizontal::init()
|
|||
alert->setPosition(Point(widgetSize.width / 2.0f, widgetSize.height / 2.0f - alert->getSize().height * 2.925));
|
||||
m_pUiLayer->addWidget(alert);
|
||||
|
||||
Layout *background = dynamic_cast<Layout*>(m_pUiLayer->getWidgetByName("background_Panel"));
|
||||
UILayout *background = dynamic_cast<UILayout*>(m_pUiLayer->getWidgetByName("background_Panel"));
|
||||
|
||||
// Create the scrollview by horizontal
|
||||
UIScrollView* scrollView = UIScrollView::create();
|
||||
UIScrollView* scrollView = UIScrollView::create();
|
||||
scrollView->setBounceEnabled(true);
|
||||
scrollView->setDirection(SCROLLVIEW_DIR_HORIZONTAL);
|
||||
scrollView->setTouchEnabled(true);
|
||||
scrollView->setSize(Size(280, 150));
|
||||
|
|
|
@ -82,7 +82,7 @@ void UITextFieldTest::textFieldEvent(Object *pSender, TextFiledEventType type)
|
|||
}
|
||||
break;
|
||||
|
||||
case TEXTFIELD_EVENT_INDERT_TEXT:
|
||||
case TEXTFIELD_EVENT_INSERT_TEXT:
|
||||
m_pDisplayValueLabel->setText(CCString::createWithFormat("insert words")->getCString());
|
||||
break;
|
||||
|
||||
|
@ -132,7 +132,7 @@ bool UITextFieldTest_MaxLength::init()
|
|||
|
||||
// Create the textfield
|
||||
UITextField* textField = UITextField::create();
|
||||
textField->setMaxLengthEnable(true);
|
||||
textField->setMaxLengthEnabled(true);
|
||||
textField->setMaxLength(3);
|
||||
textField->setTouchEnabled(true);
|
||||
textField->setFontName(font_UITextFieldTest);
|
||||
|
@ -170,7 +170,7 @@ void UITextFieldTest_MaxLength::textFieldEvent(Object *pSender, TextFiledEventTy
|
|||
}
|
||||
break;
|
||||
|
||||
case TEXTFIELD_EVENT_INDERT_TEXT:
|
||||
case TEXTFIELD_EVENT_INSERT_TEXT:
|
||||
{
|
||||
UITextField* textField = dynamic_cast<UITextField*>(pSender);
|
||||
m_pDisplayValueLabel->setText(CCString::createWithFormat("insert words max length %d", textField->getMaxLength())->getCString());
|
||||
|
@ -226,7 +226,7 @@ bool UITextFieldTest_Password::init()
|
|||
|
||||
// Create the textfield
|
||||
UITextField* textField = UITextField::create();
|
||||
textField->setPasswordEnable(true);
|
||||
textField->setPasswordEnabled(true);
|
||||
textField->setPasswordStyleText("*");
|
||||
textField->setTouchEnabled(true);
|
||||
textField->setFontName(font_UITextFieldTest);
|
||||
|
@ -264,7 +264,7 @@ void UITextFieldTest_Password::textFieldEvent(Object *pSender, TextFiledEventTyp
|
|||
}
|
||||
break;
|
||||
|
||||
case TEXTFIELD_EVENT_INDERT_TEXT:
|
||||
case TEXTFIELD_EVENT_INSERT_TEXT:
|
||||
m_pDisplayValueLabel->setText(CCString::createWithFormat("insert words password")->getCString());
|
||||
break;
|
||||
|
||||
|
|
|
@ -14,7 +14,6 @@ SceneEditorTestLayer::~SceneEditorTestLayer()
|
|||
ArmatureDataManager::getInstance()->destoryInstance();
|
||||
SceneReader::getInstance()->purgeSceneReader();
|
||||
ActionManagerEx::shareManager()->purgeActionManager();
|
||||
UIHelper::instance()->purgeUIHelper();
|
||||
}
|
||||
|
||||
SceneEditorTestLayer::SceneEditorTestLayer()
|
||||
|
|
|
@ -1 +0,0 @@
|
|||
3275ac270645139eb273b2a47c215f39bcb0e0d5
|
Loading…
Reference in New Issue