2019-11-23 20:27:39 +08:00
|
|
|
/****************************************************************************
|
|
|
|
Copyright (c) 2010 Neophit
|
|
|
|
Copyright (c) 2010 Ricardo Quesada
|
|
|
|
Copyright (c) 2010-2012 cocos2d-x.org
|
|
|
|
Copyright (c) 2011 Zynga Inc.
|
|
|
|
Copyright (c) 2013-2016 Chukong Technologies Inc.
|
|
|
|
Copyright (c) 2017-2018 Xiamen Yaji Software Co., Ltd.
|
|
|
|
|
2022-07-09 01:23:11 +08:00
|
|
|
https://axis-project.github.io/
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
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 __CCTMX_OBJECT_GROUP_H__
|
|
|
|
#define __CCTMX_OBJECT_GROUP_H__
|
|
|
|
|
2021-10-23 23:27:14 +08:00
|
|
|
#include "math/CCMath.h"
|
2019-11-23 20:27:39 +08:00
|
|
|
#include "base/CCValue.h"
|
|
|
|
#include "base/CCRef.h"
|
|
|
|
|
|
|
|
NS_CC_BEGIN
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @addtogroup _2d
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
|
|
|
/** @brief TMXObjectGroup represents the TMX object group.
|
|
|
|
* @since v0.99.0
|
|
|
|
*/
|
|
|
|
class CC_DLL TMXObjectGroup : public Ref
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
* @js ctor
|
|
|
|
*/
|
|
|
|
TMXObjectGroup();
|
|
|
|
/**
|
|
|
|
* @js NA
|
|
|
|
* @lua NA
|
|
|
|
*/
|
|
|
|
virtual ~TMXObjectGroup();
|
2021-12-25 10:04:45 +08:00
|
|
|
|
|
|
|
/** Get the group name.
|
2019-11-23 20:27:39 +08:00
|
|
|
*
|
|
|
|
* @return The group name.
|
|
|
|
*/
|
2021-12-31 12:12:40 +08:00
|
|
|
std::string_view getGroupName() const { return _groupName; }
|
2021-12-25 10:04:45 +08:00
|
|
|
|
|
|
|
/** Set the group name.
|
2019-11-23 20:27:39 +08:00
|
|
|
*
|
|
|
|
* @param groupName A string,it is used to set the group name.
|
|
|
|
*/
|
2021-12-31 12:12:40 +08:00
|
|
|
void setGroupName(std::string_view groupName) { _groupName = groupName; }
|
2019-11-23 20:27:39 +08:00
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
/** Return the value for the specific property name.
|
2019-11-23 20:27:39 +08:00
|
|
|
*
|
|
|
|
* @param propertyName The specific property name.
|
|
|
|
* @return Return the value for the specific property name.
|
|
|
|
* @js NA
|
|
|
|
*/
|
2021-12-31 12:12:40 +08:00
|
|
|
Value getProperty(std::string_view propertyName) const;
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/** Return the dictionary for the specific object name.
|
|
|
|
* It will return the 1st object found on the array for the given name.
|
|
|
|
*
|
|
|
|
* @return Return the dictionary for the specific object name.
|
|
|
|
*/
|
2021-12-31 12:12:40 +08:00
|
|
|
ValueMap getObject(std::string_view objectName) const;
|
2021-12-25 10:04:45 +08:00
|
|
|
|
|
|
|
/** Gets the offset position of child objects.
|
2019-11-23 20:27:39 +08:00
|
|
|
*
|
|
|
|
* @return The offset position of child objects.
|
|
|
|
*/
|
|
|
|
const Vec2& getPositionOffset() const { return _positionOffset; }
|
2021-12-25 10:04:45 +08:00
|
|
|
|
|
|
|
/** Sets the offset position of child objects.
|
2019-11-23 20:27:39 +08:00
|
|
|
*
|
|
|
|
* @param offset The offset position of child objects.
|
|
|
|
*/
|
|
|
|
void setPositionOffset(const Vec2& offset) { _positionOffset = offset; }
|
2021-12-25 10:04:45 +08:00
|
|
|
|
|
|
|
/** Gets the list of properties stored in a dictionary.
|
2019-11-23 20:27:39 +08:00
|
|
|
*
|
|
|
|
* @return The list of properties stored in a dictionary.
|
|
|
|
*/
|
|
|
|
const ValueMap& getProperties() const { return _properties; }
|
|
|
|
ValueMap& getProperties() { return _properties; }
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/** Sets the list of properties.
|
|
|
|
*
|
|
|
|
* @param properties The list of properties.
|
|
|
|
*/
|
2021-12-25 10:04:45 +08:00
|
|
|
void setProperties(const ValueMap& properties) { _properties = properties; }
|
|
|
|
|
|
|
|
/** Gets the array of the objects.
|
2019-11-23 20:27:39 +08:00
|
|
|
*
|
|
|
|
* @return The array of the objects.
|
|
|
|
*/
|
|
|
|
const ValueVector& getObjects() const { return _objects; }
|
|
|
|
ValueVector& getObjects() { return _objects; }
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/** Sets the array of the objects.
|
|
|
|
*
|
|
|
|
* @param objects The array of the objects.
|
|
|
|
*/
|
2021-12-25 10:04:45 +08:00
|
|
|
void setObjects(const ValueVector& objects) { _objects = objects; }
|
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
protected:
|
|
|
|
/** name of the group */
|
|
|
|
std::string _groupName;
|
|
|
|
/** offset position of child objects */
|
|
|
|
Vec2 _positionOffset;
|
|
|
|
/** list of properties stored in a dictionary */
|
|
|
|
ValueMap _properties;
|
|
|
|
/** array of the objects */
|
|
|
|
ValueVector _objects;
|
|
|
|
};
|
|
|
|
|
|
|
|
// end of tilemap_parallax_nodes group
|
|
|
|
/** @} */
|
|
|
|
|
|
|
|
NS_CC_END
|
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
#endif //__CCTMX_OBJECT_GROUP_H__
|