2013-09-13 22:20:20 +08:00
|
|
|
/****************************************************************************
|
2014-01-17 13:10:04 +08:00
|
|
|
Copyright (c) 2013-2014 Chukong Technologies Inc.
|
|
|
|
|
|
|
|
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.
|
|
|
|
****************************************************************************/
|
2013-09-13 22:20:20 +08:00
|
|
|
|
|
|
|
#ifndef __LAYOUTPARMETER_H__
|
|
|
|
#define __LAYOUTPARMETER_H__
|
|
|
|
|
2013-10-16 16:48:39 +08:00
|
|
|
#include "gui/UILayoutDefine.h"
|
2013-09-13 22:20:20 +08:00
|
|
|
|
2013-12-23 15:02:52 +08:00
|
|
|
NS_CC_BEGIN
|
|
|
|
|
2014-02-24 18:56:45 +08:00
|
|
|
namespace ui {
|
2013-09-13 22:20:20 +08:00
|
|
|
|
|
|
|
typedef enum
|
|
|
|
{
|
|
|
|
LAYOUT_PARAMETER_NONE,
|
|
|
|
LAYOUT_PARAMETER_LINEAR,
|
|
|
|
LAYOUT_PARAMETER_RELATIVE
|
|
|
|
}LayoutParameterType;
|
2013-12-23 15:02:52 +08:00
|
|
|
/**
|
|
|
|
* @js NA
|
|
|
|
* @lua NA
|
|
|
|
*/
|
2014-02-20 10:53:49 +08:00
|
|
|
class LayoutParameter : public Ref
|
2013-09-13 22:20:20 +08:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
* Default constructor
|
|
|
|
*/
|
2013-12-23 15:02:52 +08:00
|
|
|
LayoutParameter() : _margin(Margin()){_layoutParameterType = LAYOUT_PARAMETER_NONE;};
|
2013-09-13 22:20:20 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Default destructor
|
|
|
|
*/
|
2013-12-23 15:02:52 +08:00
|
|
|
virtual ~LayoutParameter(){};
|
2013-09-13 22:20:20 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Allocates and initializes.
|
|
|
|
* @return A initialized LayoutParameter which is marked as "autorelease".
|
|
|
|
*/
|
2013-12-23 15:02:52 +08:00
|
|
|
static LayoutParameter* create();
|
2013-09-13 22:20:20 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets Margin parameter for LayoutParameter.
|
|
|
|
*
|
2013-12-23 15:02:52 +08:00
|
|
|
* @see Margin
|
2013-09-13 22:20:20 +08:00
|
|
|
*
|
|
|
|
* @param margin
|
|
|
|
*/
|
2013-12-23 15:02:52 +08:00
|
|
|
void setMargin(const Margin& margin);
|
2013-09-13 22:20:20 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets Margin parameter of LayoutParameter.
|
|
|
|
*
|
2013-12-23 15:02:52 +08:00
|
|
|
* @see Margin
|
2013-09-13 22:20:20 +08:00
|
|
|
*
|
2013-12-23 15:02:52 +08:00
|
|
|
* @return const Margin&
|
2013-09-13 22:20:20 +08:00
|
|
|
*/
|
2013-12-23 15:02:52 +08:00
|
|
|
const Margin& getMargin() const;
|
2013-09-13 22:20:20 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets LayoutParameterType of LayoutParameter.
|
|
|
|
*
|
|
|
|
* @see LayoutParameterType
|
|
|
|
*
|
|
|
|
* @return LayoutParameterType
|
|
|
|
*/
|
|
|
|
LayoutParameterType getLayoutType() const;
|
2014-01-17 13:10:04 +08:00
|
|
|
|
|
|
|
LayoutParameter* clone();
|
|
|
|
virtual LayoutParameter* createCloneInstance();
|
|
|
|
virtual void copyProperties(LayoutParameter* model);
|
2013-09-13 22:20:20 +08:00
|
|
|
protected:
|
2013-12-23 15:02:52 +08:00
|
|
|
Margin _margin;
|
2013-09-16 20:54:13 +08:00
|
|
|
LayoutParameterType _layoutParameterType;
|
2013-09-13 22:20:20 +08:00
|
|
|
};
|
2013-11-06 16:04:06 +08:00
|
|
|
/**
|
|
|
|
* @js NA
|
|
|
|
* @lua NA
|
|
|
|
*/
|
2013-12-23 15:02:52 +08:00
|
|
|
class LinearLayoutParameter : public LayoutParameter
|
2013-09-13 22:20:20 +08:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
* Default constructor
|
|
|
|
*/
|
2013-12-23 15:02:52 +08:00
|
|
|
LinearLayoutParameter() : _linearGravity(LINEAR_GRAVITY_NONE){_layoutParameterType = LAYOUT_PARAMETER_LINEAR;};
|
2013-09-13 22:20:20 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Default destructor
|
|
|
|
*/
|
2013-12-23 15:02:52 +08:00
|
|
|
virtual ~LinearLayoutParameter(){};
|
2013-09-13 22:20:20 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Allocates and initializes.
|
|
|
|
* @return A initialized LayoutParameter which is marked as "autorelease".
|
|
|
|
*/
|
2013-12-23 15:02:52 +08:00
|
|
|
static LinearLayoutParameter* create();
|
2013-09-13 22:20:20 +08:00
|
|
|
|
|
|
|
/**
|
2013-12-23 15:02:52 +08:00
|
|
|
* Sets LinearGravity parameter for LayoutParameter.
|
2013-09-13 22:20:20 +08:00
|
|
|
*
|
2013-12-23 15:02:52 +08:00
|
|
|
* @see LinearGravity
|
2013-09-13 22:20:20 +08:00
|
|
|
*
|
2013-12-23 15:02:52 +08:00
|
|
|
* @param LinearGravity
|
2013-09-13 22:20:20 +08:00
|
|
|
*/
|
2013-12-23 15:02:52 +08:00
|
|
|
void setGravity(LinearGravity gravity);
|
2013-09-13 22:20:20 +08:00
|
|
|
|
|
|
|
/**
|
2013-12-23 15:02:52 +08:00
|
|
|
* Gets LinearGravity parameter for LayoutParameter.
|
2013-09-13 22:20:20 +08:00
|
|
|
*
|
2013-12-23 15:02:52 +08:00
|
|
|
* @see LinearGravity
|
2013-09-13 22:20:20 +08:00
|
|
|
*
|
2013-12-23 15:02:52 +08:00
|
|
|
* @return LinearGravity
|
2013-09-13 22:20:20 +08:00
|
|
|
*/
|
2013-12-23 15:02:52 +08:00
|
|
|
LinearGravity getGravity() const;
|
2014-01-20 13:44:44 +08:00
|
|
|
virtual LayoutParameter* createCloneInstance() override;
|
|
|
|
virtual void copyProperties(LayoutParameter* model) override;
|
2013-09-13 22:20:20 +08:00
|
|
|
protected:
|
2013-12-23 15:02:52 +08:00
|
|
|
LinearGravity _linearGravity;
|
2013-09-13 22:20:20 +08:00
|
|
|
};
|
2013-11-06 16:04:06 +08:00
|
|
|
/**
|
|
|
|
* @js NA
|
|
|
|
* @lua NA
|
|
|
|
*/
|
|
|
|
|
2013-12-23 15:02:52 +08:00
|
|
|
class RelativeLayoutParameter : public LayoutParameter
|
2013-09-13 22:20:20 +08:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
* Default constructor
|
|
|
|
*/
|
2013-12-23 15:02:52 +08:00
|
|
|
RelativeLayoutParameter() : _relativeAlign(RELATIVE_ALIGN_NONE),_relativeWidgetName(""),_relativeLayoutName(""),_put(false){_layoutParameterType = LAYOUT_PARAMETER_RELATIVE;};
|
2013-09-13 22:20:20 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Default destructor
|
|
|
|
*/
|
2013-12-23 15:02:52 +08:00
|
|
|
virtual ~RelativeLayoutParameter(){};
|
2013-09-13 22:20:20 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Allocates and initializes.
|
|
|
|
* @return A initialized LayoutParameter which is marked as "autorelease".
|
|
|
|
*/
|
2013-12-23 15:02:52 +08:00
|
|
|
static RelativeLayoutParameter* create();
|
2013-09-13 22:20:20 +08:00
|
|
|
|
|
|
|
/**
|
2013-12-23 15:02:52 +08:00
|
|
|
* Sets RelativeAlign parameter for LayoutParameter.
|
2013-09-13 22:20:20 +08:00
|
|
|
*
|
2013-12-23 15:02:52 +08:00
|
|
|
* @see RelativeAlign
|
2013-09-13 22:20:20 +08:00
|
|
|
*
|
2013-12-23 15:02:52 +08:00
|
|
|
* @param RelativeAlign
|
2013-09-13 22:20:20 +08:00
|
|
|
*/
|
2013-12-23 15:02:52 +08:00
|
|
|
void setAlign(RelativeAlign align);
|
2013-09-13 22:20:20 +08:00
|
|
|
|
|
|
|
/**
|
2013-12-23 15:02:52 +08:00
|
|
|
* Gets RelativeAlign parameter for LayoutParameter.
|
2013-09-13 22:20:20 +08:00
|
|
|
*
|
2013-12-23 15:02:52 +08:00
|
|
|
* @see RelativeAlign
|
2013-09-13 22:20:20 +08:00
|
|
|
*
|
2013-12-23 15:02:52 +08:00
|
|
|
* @return RelativeAlign
|
2013-09-13 22:20:20 +08:00
|
|
|
*/
|
2013-12-23 15:02:52 +08:00
|
|
|
RelativeAlign getAlign() const;
|
2013-09-13 22:20:20 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets a key for LayoutParameter. Witch widget named this is relative to.
|
|
|
|
*
|
|
|
|
* @param name
|
|
|
|
*/
|
|
|
|
void setRelativeToWidgetName(const char* name);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the key of LayoutParameter. Witch widget named this is relative to.
|
|
|
|
*
|
|
|
|
* @return name
|
|
|
|
*/
|
|
|
|
const char* getRelativeToWidgetName() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets a name in Relative Layout for LayoutParameter.
|
|
|
|
*
|
|
|
|
* @param name
|
|
|
|
*/
|
|
|
|
void setRelativeName(const char* name);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets a name in Relative Layout of LayoutParameter.
|
|
|
|
*
|
|
|
|
* @return name
|
|
|
|
*/
|
|
|
|
const char* getRelativeName() const;
|
2014-01-17 13:10:04 +08:00
|
|
|
|
2014-01-20 13:44:44 +08:00
|
|
|
virtual LayoutParameter* createCloneInstance() override;
|
|
|
|
virtual void copyProperties(LayoutParameter* model) override;
|
2013-09-13 22:20:20 +08:00
|
|
|
protected:
|
2013-12-23 15:02:52 +08:00
|
|
|
RelativeAlign _relativeAlign;
|
2013-09-25 19:04:37 +08:00
|
|
|
std::string _relativeWidgetName;
|
|
|
|
std::string _relativeLayoutName;
|
2013-11-06 16:04:06 +08:00
|
|
|
bool _put;
|
2013-12-23 15:02:52 +08:00
|
|
|
friend class Layout;
|
2013-09-13 22:20:20 +08:00
|
|
|
};
|
|
|
|
|
2013-10-15 18:00:03 +08:00
|
|
|
}
|
2013-09-13 22:20:20 +08:00
|
|
|
|
2013-12-23 15:02:52 +08:00
|
|
|
NS_CC_END
|
|
|
|
|
2013-09-13 22:20:20 +08:00
|
|
|
#endif /* defined(__LayoutParameter__) */
|