2010-11-13 11:34:49 +08:00
|
|
|
/****************************************************************************
|
2012-09-24 21:22:20 +08:00
|
|
|
Copyright (c) 2010-2012 cocos2d-x.org
|
2011-03-19 10:59:01 +08:00
|
|
|
Copyright (c) 2009-2010 Ricardo Quesada
|
2011-07-04 14:11:43 +08:00
|
|
|
Copyright (c) 2011 Zynga Inc.
|
2010-11-13 11:34:49 +08:00
|
|
|
|
|
|
|
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.
|
|
|
|
****************************************************************************/
|
2011-03-23 22:16:20 +08:00
|
|
|
|
|
|
|
|
2010-11-13 11:34:49 +08:00
|
|
|
#ifndef __CC_TM_XML_PARSER__
|
|
|
|
#define __CC_TM_XML_PARSER__
|
2011-01-15 18:05:35 +08:00
|
|
|
|
2012-06-19 13:50:11 +08:00
|
|
|
#include "cocoa/CCArray.h"
|
|
|
|
#include "cocoa/CCDictionary.h"
|
|
|
|
#include "cocoa/CCGeometry.h"
|
|
|
|
#include "platform/CCSAXParser.h"
|
2011-03-23 22:16:20 +08:00
|
|
|
|
2012-03-20 17:27:06 +08:00
|
|
|
#include <string>
|
|
|
|
|
2012-03-20 15:04:53 +08:00
|
|
|
NS_CC_BEGIN
|
|
|
|
|
2013-06-20 14:13:12 +08:00
|
|
|
class TMXObjectGroup;
|
2012-03-20 15:04:53 +08:00
|
|
|
|
|
|
|
/** @file
|
|
|
|
* Internal TMX parser
|
|
|
|
*
|
|
|
|
* IMPORTANT: These classed should not be documented using doxygen strings
|
|
|
|
* since the user should not use them.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2012-06-20 18:09:11 +08:00
|
|
|
/**
|
|
|
|
* @addtogroup tilemap_parallax_nodes
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
2012-03-20 15:04:53 +08:00
|
|
|
enum {
|
2012-04-19 14:35:52 +08:00
|
|
|
TMXLayerAttribNone = 1 << 0,
|
|
|
|
TMXLayerAttribBase64 = 1 << 1,
|
|
|
|
TMXLayerAttribGzip = 1 << 2,
|
|
|
|
TMXLayerAttribZlib = 1 << 3,
|
2012-03-20 15:04:53 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
enum {
|
2012-04-19 14:35:52 +08:00
|
|
|
TMXPropertyNone,
|
|
|
|
TMXPropertyMap,
|
|
|
|
TMXPropertyLayer,
|
|
|
|
TMXPropertyObjectGroup,
|
|
|
|
TMXPropertyObject,
|
|
|
|
TMXPropertyTile
|
2012-03-20 15:04:53 +08:00
|
|
|
};
|
|
|
|
|
2012-04-19 14:35:52 +08:00
|
|
|
typedef enum ccTMXTileFlags_ {
|
2013-06-20 14:13:12 +08:00
|
|
|
kTMXTileHorizontalFlag = 0x80000000,
|
|
|
|
kTMXTileVerticalFlag = 0x40000000,
|
|
|
|
kTMXTileDiagonalFlag = 0x20000000,
|
|
|
|
kFlipedAll = (kTMXTileHorizontalFlag|kTMXTileVerticalFlag|kTMXTileDiagonalFlag),
|
|
|
|
kFlippedMask = ~(kFlipedAll)
|
2012-04-19 14:35:52 +08:00
|
|
|
} ccTMXTileFlags;
|
|
|
|
|
2012-03-20 15:04:53 +08:00
|
|
|
// Bits on the far end of the 32-bit global tile ID (GID's) are used for tile flags
|
|
|
|
|
2013-06-20 14:13:12 +08:00
|
|
|
/** @brief TMXLayerInfo contains the information about the layers like:
|
2012-03-20 15:04:53 +08:00
|
|
|
- Layer name
|
|
|
|
- Layer size
|
|
|
|
- Layer opacity at creation time (it can be modified at runtime)
|
|
|
|
- Whether the layer is visible (if it's not visible, then the CocosNode won't be created)
|
|
|
|
|
|
|
|
This information is obtained from the TMX file.
|
|
|
|
*/
|
2013-06-20 14:13:12 +08:00
|
|
|
class CC_DLL TMXLayerInfo : public Object
|
2012-03-20 15:04:53 +08:00
|
|
|
{
|
|
|
|
public:
|
2013-07-20 04:16:38 +08:00
|
|
|
TMXLayerInfo();
|
|
|
|
virtual ~TMXLayerInfo();
|
|
|
|
|
2013-07-20 13:01:27 +08:00
|
|
|
void setProperties(Dictionary *properties);
|
|
|
|
Dictionary* getProperties();
|
2013-07-20 04:16:38 +08:00
|
|
|
|
|
|
|
Dictionary *_properties;
|
2013-06-15 14:03:30 +08:00
|
|
|
std::string _name;
|
2013-07-20 04:16:38 +08:00
|
|
|
Size _layerSize;
|
2013-06-15 14:03:30 +08:00
|
|
|
unsigned int *_tiles;
|
|
|
|
bool _visible;
|
|
|
|
unsigned char _opacity;
|
|
|
|
bool _ownTiles;
|
|
|
|
unsigned int _minGID;
|
|
|
|
unsigned int _maxGID;
|
2013-07-20 04:16:38 +08:00
|
|
|
Point _offset;
|
2012-03-20 15:04:53 +08:00
|
|
|
};
|
|
|
|
|
2013-06-20 14:13:12 +08:00
|
|
|
/** @brief TMXTilesetInfo contains the information about the tilesets like:
|
2012-03-20 15:04:53 +08:00
|
|
|
- Tileset name
|
2012-09-17 15:02:24 +08:00
|
|
|
- Tileset spacing
|
2012-03-20 15:04:53 +08:00
|
|
|
- Tileset margin
|
|
|
|
- size of the tiles
|
|
|
|
- Image used for the tiles
|
|
|
|
- Image size
|
|
|
|
|
|
|
|
This information is obtained from the TMX file.
|
|
|
|
*/
|
2013-06-20 14:13:12 +08:00
|
|
|
class CC_DLL TMXTilesetInfo : public Object
|
2012-03-20 15:04:53 +08:00
|
|
|
{
|
|
|
|
public:
|
2013-06-15 14:03:30 +08:00
|
|
|
std::string _name;
|
|
|
|
unsigned int _firstGid;
|
2013-06-20 14:13:12 +08:00
|
|
|
Size _tileSize;
|
2013-06-15 14:03:30 +08:00
|
|
|
unsigned int _spacing;
|
|
|
|
unsigned int _margin;
|
2012-04-19 14:35:52 +08:00
|
|
|
//! filename containing the tiles (should be spritesheet / texture atlas)
|
2013-06-15 14:03:30 +08:00
|
|
|
std::string _sourceImage;
|
2012-04-19 14:35:52 +08:00
|
|
|
//! size in pixels of the image
|
2013-06-20 14:13:12 +08:00
|
|
|
Size _imageSize;
|
2012-03-20 15:04:53 +08:00
|
|
|
public:
|
2013-06-20 14:13:12 +08:00
|
|
|
TMXTilesetInfo();
|
|
|
|
virtual ~TMXTilesetInfo();
|
|
|
|
Rect rectForGID(unsigned int gid);
|
2012-03-20 15:04:53 +08:00
|
|
|
};
|
|
|
|
|
2013-06-20 14:13:12 +08:00
|
|
|
/** @brief TMXMapInfo contains the information about the map like:
|
2012-03-20 15:04:53 +08:00
|
|
|
- Map orientation (hexagonal, isometric or orthogonal)
|
|
|
|
- Tile size
|
|
|
|
- Map size
|
|
|
|
|
|
|
|
And it also contains:
|
|
|
|
- Layers (an array of TMXLayerInfo objects)
|
|
|
|
- Tilesets (an array of TMXTilesetInfo objects)
|
|
|
|
- ObjectGroups (an array of TMXObjectGroupInfo objects)
|
|
|
|
|
|
|
|
This information is obtained from the TMX file.
|
|
|
|
|
|
|
|
*/
|
2013-06-20 14:13:12 +08:00
|
|
|
class CC_DLL TMXMapInfo : public Object, public SAXDelegator
|
2012-04-19 14:35:52 +08:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
/// map orientation
|
2013-06-15 14:03:30 +08:00
|
|
|
CC_SYNTHESIZE(int, _orientation, Orientation);
|
2012-04-19 14:35:52 +08:00
|
|
|
/// map width & height
|
2013-06-20 14:13:12 +08:00
|
|
|
CC_SYNTHESIZE_PASS_BY_REF(Size, _mapSize, MapSize);
|
2012-04-19 14:35:52 +08:00
|
|
|
/// tiles width & height
|
2013-06-20 14:13:12 +08:00
|
|
|
CC_SYNTHESIZE_PASS_BY_REF(Size, _tileSize, TileSize);
|
2012-04-19 14:35:52 +08:00
|
|
|
/// Layers
|
2013-06-20 14:13:12 +08:00
|
|
|
CC_PROPERTY(Array*, _layers, Layers);
|
2012-04-19 14:35:52 +08:00
|
|
|
/// tilesets
|
2013-06-20 14:13:12 +08:00
|
|
|
CC_PROPERTY(Array*, _tilesets, Tilesets);
|
2012-04-19 14:35:52 +08:00
|
|
|
/// ObjectGroups
|
2013-06-20 14:13:12 +08:00
|
|
|
CC_PROPERTY(Array*, _objectGroups, ObjectGroups);
|
2012-04-19 14:35:52 +08:00
|
|
|
/// parent element
|
2013-06-15 14:03:30 +08:00
|
|
|
CC_SYNTHESIZE(int, _parentElement, ParentElement);
|
2012-04-19 14:35:52 +08:00
|
|
|
/// parent GID
|
2013-06-15 14:03:30 +08:00
|
|
|
CC_SYNTHESIZE(unsigned int, _parentGID, ParentGID);
|
2012-04-19 14:35:52 +08:00
|
|
|
/// layer attribs
|
2013-06-15 14:03:30 +08:00
|
|
|
CC_SYNTHESIZE(int, _layerAttribs, LayerAttribs);
|
2012-09-17 15:02:24 +08:00
|
|
|
/// is storing characters?
|
2013-06-15 14:03:30 +08:00
|
|
|
CC_SYNTHESIZE(bool, _storingCharacters, StoringCharacters);
|
2012-04-19 14:35:52 +08:00
|
|
|
/// properties
|
2013-06-20 14:13:12 +08:00
|
|
|
CC_PROPERTY(Dictionary*, _properties, Properties);
|
2012-04-19 14:35:52 +08:00
|
|
|
public:
|
2013-06-20 14:13:12 +08:00
|
|
|
TMXMapInfo();
|
|
|
|
virtual ~TMXMapInfo();
|
2012-04-19 14:35:52 +08:00
|
|
|
/** creates a TMX Format with a tmx file */
|
2013-06-20 14:13:12 +08:00
|
|
|
static TMXMapInfo * formatWithTMXFile(const char *tmxFile);
|
2012-04-19 14:35:52 +08:00
|
|
|
/** creates a TMX Format with an XML string and a TMX resource path */
|
2013-06-20 14:13:12 +08:00
|
|
|
static TMXMapInfo * formatWithXML(const char* tmxString, const char* resourcePath);
|
2012-09-17 15:02:24 +08:00
|
|
|
/** initializes a TMX format with a tmx file */
|
2012-04-19 14:35:52 +08:00
|
|
|
bool initWithTMXFile(const char *tmxFile);
|
|
|
|
/** initializes a TMX format with an XML string and a TMX resource path */
|
|
|
|
bool initWithXML(const char* tmxString, const char* resourcePath);
|
2012-09-17 15:02:24 +08:00
|
|
|
/** initializes parsing of an XML file, either a tmx (Map) file or tsx (Tileset) file */
|
2012-04-19 14:35:52 +08:00
|
|
|
bool parseXMLFile(const char *xmlFilename);
|
2012-09-17 15:02:24 +08:00
|
|
|
/* initializes parsing of an XML string, either a tmx (Map) string or tsx (Tileset) string */
|
2012-04-19 14:35:52 +08:00
|
|
|
bool parseXMLString(const char *xmlString);
|
|
|
|
|
2013-06-20 14:13:12 +08:00
|
|
|
Dictionary* getTileProperties();
|
|
|
|
void setTileProperties(Dictionary* tileProperties);
|
2012-04-19 14:35:52 +08:00
|
|
|
|
2013-06-20 14:13:12 +08:00
|
|
|
// implement pure virtual methods of SAXDelegator
|
2012-04-19 14:35:52 +08:00
|
|
|
void startElement(void *ctx, const char *name, const char **atts);
|
|
|
|
void endElement(void *ctx, const char *name);
|
|
|
|
void textHandler(void *ctx, const char *ch, int len);
|
|
|
|
|
2013-06-15 14:03:30 +08:00
|
|
|
inline const char* getCurrentString(){ return _currentString.c_str(); }
|
|
|
|
inline void setCurrentString(const char *currentString){ _currentString = currentString; }
|
|
|
|
inline const char* getTMXFileName(){ return _TMXFileName.c_str(); }
|
|
|
|
inline void setTMXFileName(const char *fileName){ _TMXFileName = fileName; }
|
2012-03-20 15:04:53 +08:00
|
|
|
private:
|
2012-04-19 14:35:52 +08:00
|
|
|
void internalInit(const char* tmxFileName, const char* resourcePath);
|
2012-03-20 15:04:53 +08:00
|
|
|
protected:
|
2012-04-19 14:35:52 +08:00
|
|
|
//! tmx filename
|
2013-06-15 14:03:30 +08:00
|
|
|
std::string _TMXFileName;
|
2012-04-19 14:35:52 +08:00
|
|
|
// tmx resource path
|
2013-06-15 14:03:30 +08:00
|
|
|
std::string _resources;
|
2012-04-19 14:35:52 +08:00
|
|
|
//! current string
|
2013-06-15 14:03:30 +08:00
|
|
|
std::string _currentString;
|
2012-04-19 14:35:52 +08:00
|
|
|
//! tile properties
|
2013-06-20 14:13:12 +08:00
|
|
|
Dictionary* _tileProperties;
|
2013-06-15 14:03:30 +08:00
|
|
|
unsigned int _currentFirstGID;
|
2012-03-20 15:04:53 +08:00
|
|
|
};
|
|
|
|
|
2012-06-20 18:09:11 +08:00
|
|
|
// end of tilemap_parallax_nodes group
|
|
|
|
/// @}
|
|
|
|
|
2012-03-20 15:04:53 +08:00
|
|
|
NS_CC_END
|
2010-11-13 11:34:49 +08:00
|
|
|
|
2011-03-23 22:16:20 +08:00
|
|
|
#endif
|
2010-11-13 11:34:49 +08:00
|
|
|
|