您的位置:首页 > 移动开发 > Cocos引擎

cocos2d-x 2.1 -- 读取.plist文件

2013-07-16 11:39 411 查看
在cocos2d-x中可以用.plist格式的文件来保存数据,它是XML文件格式的一种,在cocos2d-x解析.plist方面相关的资料比较少,但本身也很简单,要解析.plist文件可以参考cocos2d-x类库中的CCSpriteFrameCache类和CCParticleSystem类,它主要是使用CCDictionary类来对.plist文件进行操作。

下面有一个.plist文件:

[html] view plaincopy

<?xml version="1.0" encoding="UTF-8"?>

<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">

<plist version="1.0">

<dict>

<key>level1</key>

<dict>

<key>bg_far_scene</key>

<dict>

<key>path</key>

<string>images/far_scene.png</string>

<key>pos</key>

<string>{358, 309}</string>

</dict>

<key>bg_near_scene</key>

<dict>

<key>path</key>

<string>images/near_scene.png</string>

<key>pos</key>

<string>{360, 100}</string>

</dict>

</dict>

</dict>

</plist>

读取.plist文件的代码如下:

[cpp] view plaincopy

const char* testPlistPath = "BSPlistDatas\\test.plist";

const char* fullPath = CCFileUtils::sharedFileUtils()->fullPathFromRelativeFile("test.plist", testPlistPath);

CCDictionary* plistDic = CCDictionary::createWithContentsOfFile(testPlistPath);

CCDictionary* levelDic = dynamic_cast<CCDictionary*>(plistDic->objectForKey("level1"));

CCDictionary* farScene = dynamic_cast<CCDictionary*>(levelDic->objectForKey("bg_far_scene"));

CCString* farScenePath = dynamic_cast<CCString*>(farScene->objectForKey("path"));

CCPoint point = CCPointFromString(farScene->valueForKey("pos")->getCString());

CCLog("path = %s", farScenePath->getCString());

CCLog("pos = %f, %f", point.x, point.y);

第一行是.plist文件的相对路径,通过CCFileUtils类获得文件中绝对路径后,使用CCDictionary::createWithContensOfFile(filePath);将文件中内容加载到CCDictionary数据结构的内存中,然后通过xxxForKey获得相应的key下的value。

这里需要注意的是,当在读取'pos'的时候,它的值一个{x, y}的字符串,这是.plist文件中的数组存储规则,我们可以通过cocos2d-x提供函数api将这样的字符串转化为CCpoint对象。

[cpp] view plaincopy

<span style="white-space:pre"> </span>CCPoint point = CCPointFromString(farScene->valueForKey("pos")->getCString());

上面这句话就是做了这样的一个转化的过程,同样的cocos2d-x还支持CCSize、CCRect的字符串的转化。他们转化的方法以及在.plist中对应的字符串格式如下:

CCPoint: CCPointFromString();{x, y}

CCSize: CCSizeFromString();{w, h}

CCRect: CCSizeFromString();{x, y, w, h}

这样我们2D游戏所初始化所需要的数据都基本上够用了,可以尝试将游戏的初始数据放在.plist中,然后修改调整数值就可以直接修改plist文件,而无需重新编译程序了,从而实现游戏数据和游戏逻辑的分离。

在cocos2d-x中可以用.plist格式的文件来保存数据,它是XML文件格式的一种,在cocos2d-x解析.plist方面相关的资料比较少,但本身也很简单,要解析.plist文件可以参考cocos2d-x类库中的CCSpriteFrameCache类和CCParticleSystem类,它主要是使用CCDictionary类来对.plist文件进行操作。

下面有一个.plist文件:

[html] view plaincopy

<?xml version="1.0" encoding="UTF-8"?>

<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">

<plist version="1.0">

<dict>

<key>level1</key>

<dict>

<key>bg_far_scene</key>

<dict>

<key>path</key>

<string>images/far_scene.png</string>

<key>pos</key>

<string>{358, 309}</string>

</dict>

<key>bg_near_scene</key>

<dict>

<key>path</key>

<string>images/near_scene.png</string>

<key>pos</key>

<string>{360, 100}</string>

</dict>

</dict>

</dict>

</plist>

读取.plist文件的代码如下:

[cpp] view plaincopy

const char* testPlistPath = "BSPlistDatas\\test.plist";

const char* fullPath = CCFileUtils::sharedFileUtils()->fullPathFromRelativeFile("test.plist", testPlistPath);

CCDictionary* plistDic = CCDictionary::createWithContentsOfFile(testPlistPath);

CCDictionary* levelDic = dynamic_cast<CCDictionary*>(plistDic->objectForKey("level1"));

CCDictionary* farScene = dynamic_cast<CCDictionary*>(levelDic->objectForKey("bg_far_scene"));

CCString* farScenePath = dynamic_cast<CCString*>(farScene->objectForKey("path"));

CCPoint point = CCPointFromString(farScene->valueForKey("pos")->getCString());

CCLog("path = %s", farScenePath->getCString());

CCLog("pos = %f, %f", point.x, point.y);

第一行是.plist文件的相对路径,通过CCFileUtils类获得文件中绝对路径后,使用CCDictionary::createWithContensOfFile(filePath);将文件中内容加载到CCDictionary数据结构的内存中,然后通过xxxForKey获得相应的key下的value。

这里需要注意的是,当在读取'pos'的时候,它的值一个{x, y}的字符串,这是.plist文件中的数组存储规则,我们可以通过cocos2d-x提供函数api将这样的字符串转化为CCpoint对象。

[cpp] view plaincopy

<span style="white-space:pre"> </span>CCPoint point = CCPointFromString(farScene->valueForKey("pos")->getCString());

上面这句话就是做了这样的一个转化的过程,同样的cocos2d-x还支持CCSize、CCRect的字符串的转化。他们转化的方法以及在.plist中对应的字符串格式如下:

CCPoint: CCPointFromString();{x, y}

CCSize: CCSizeFromString();{w, h}

CCRect: CCSizeFromString();{x, y, w, h}

这样我们2D游戏所初始化所需要的数据都基本上够用了,可以尝试将游戏的初始数据放在.plist中,然后修改调整数值就可以直接修改plist文件,而无需重新编译程序了,从而实现游戏数据和游戏逻辑的分离。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: