CCNodeLoader.cpp 45 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170
  1. #include "editor-support/cocosbuilder/CCNodeLoader.h"
  2. #include "editor-support/cocosbuilder/CCBSelectorResolver.h"
  3. #include "editor-support/cocosbuilder/CCBMemberVariableAssigner.h"
  4. #include "editor-support/cocosbuilder/CCBAnimationManager.h"
  5. #include "editor-support/cocosbuilder/CCNode+CCBRelativePositioning.h"
  6. #include "deprecated/CCArray.h"
  7. #include "deprecated/CCString.h"
  8. #include "base/CCDirector.h"
  9. #include "renderer/CCTextureCache.h"
  10. #include "2d/CCSpriteFrameCache.h"
  11. #include "2d/CCAnimationCache.h"
  12. #include "platform/CCFileUtils.h"
  13. using namespace std;
  14. using namespace cocos2d;
  15. using namespace cocos2d::extension;
  16. namespace cocosbuilder {
  17. NodeLoader::NodeLoader()
  18. {
  19. }
  20. NodeLoader::~NodeLoader()
  21. {
  22. }
  23. ValueMap& NodeLoader::getCustomProperties()
  24. {
  25. return _customProperties;
  26. }
  27. Node * NodeLoader::loadNode(Node * pParent, CCBReader * ccbReader)
  28. {
  29. Node * ccNode = this->createNode(pParent, ccbReader);
  30. //clear _customProperties, ready for load next node.
  31. _customProperties.clear();
  32. return ccNode;
  33. }
  34. void NodeLoader::parseProperties(Node * pNode, Node * pParent, CCBReader * ccbReader)
  35. {
  36. int numRegularProps = ccbReader->readInt(false);
  37. int numExturaProps = ccbReader->readInt(false);
  38. int propertyCount = numRegularProps + numExturaProps;
  39. for(int i = 0; i < propertyCount; i++) {
  40. bool isExtraProp = (i >= numRegularProps);
  41. CCBReader::PropertyType type = (CCBReader::PropertyType)ccbReader->readInt(false);
  42. std::string propertyName = ccbReader->readCachedString();
  43. // Check if the property can be set for this platform
  44. bool setProp = false;
  45. CCBReader::PlatformType platform = (CCBReader::PlatformType)ccbReader->readByte();
  46. if(platform == CCBReader::PlatformType::ALL)
  47. {
  48. setProp = true;
  49. }
  50. // Cocos2d-x is using touch event callback for all platforms,
  51. // it's different from cocos2d-iphone which uses mouse event for Mac port.
  52. // So we just need to touch event by using CCBReader::PlatformType::IOS.
  53. //#if (CC_TARGET_PLATFORM == CC_PLATFORM_IOS) || (CC_TARGET_PLATFORM == CC_PLATFORM_ANDROID)
  54. if(platform == CCBReader::PlatformType::IOS)
  55. {
  56. setProp = true;
  57. }
  58. // #elif (CC_TARGET_PLATFORM == CC_PLATFORM_MAC)
  59. // if(platform == CCBReader::PlatformType::MAC)
  60. // {
  61. // setProp = true;
  62. // }
  63. // #endif
  64. // Forward properties for sub ccb files
  65. if (dynamic_cast<CCBFile*>(pNode) != nullptr)
  66. {
  67. CCBFile *ccbNode = (CCBFile*)pNode;
  68. if (ccbNode->getCCBFileNode() && isExtraProp)
  69. {
  70. pNode = ccbNode->getCCBFileNode();
  71. // Skip properties that doesn't have a value to override
  72. __Array *extraPropsNames = (__Array*)pNode->getUserObject();
  73. Ref* pObj = nullptr;
  74. bool bFound = false;
  75. CCARRAY_FOREACH(extraPropsNames, pObj)
  76. {
  77. __String* pStr = static_cast<__String*>(pObj);
  78. if (0 == pStr->compare(propertyName.c_str()))
  79. {
  80. bFound = true;
  81. break;
  82. }
  83. }
  84. setProp &= bFound;
  85. }
  86. }
  87. else if (isExtraProp && pNode == ccbReader->getAnimationManager()->getRootNode())
  88. {
  89. __Array *extraPropsNames = static_cast<__Array*>(pNode->getUserObject());
  90. if (! extraPropsNames)
  91. {
  92. extraPropsNames = __Array::create();
  93. pNode->setUserObject(extraPropsNames);
  94. }
  95. extraPropsNames->addObject(__String::create(propertyName));
  96. }
  97. switch(type)
  98. {
  99. case CCBReader::PropertyType::POSITION:
  100. {
  101. Vec2 position = this->parsePropTypePosition(pNode, pParent, ccbReader, propertyName.c_str());
  102. if (setProp)
  103. {
  104. this->onHandlePropTypePosition(pNode, pParent, propertyName.c_str(), position, ccbReader);
  105. }
  106. break;
  107. }
  108. case CCBReader::PropertyType::POINT:
  109. {
  110. Vec2 point = this->parsePropTypePoint(pNode, pParent, ccbReader);
  111. if (setProp)
  112. {
  113. this->onHandlePropTypePoint(pNode, pParent, propertyName.c_str(), point, ccbReader);
  114. }
  115. break;
  116. }
  117. case CCBReader::PropertyType::POINT_LOCK:
  118. {
  119. Vec2 pointLock = this->parsePropTypePointLock(pNode, pParent, ccbReader);
  120. if (setProp)
  121. {
  122. this->onHandlePropTypePointLock(pNode, pParent, propertyName.c_str(), pointLock, ccbReader);
  123. }
  124. break;
  125. }
  126. case CCBReader::PropertyType::SIZE:
  127. {
  128. Size size = this->parsePropTypeSize(pNode, pParent, ccbReader);
  129. if(setProp) {
  130. this->onHandlePropTypeSize(pNode, pParent, propertyName.c_str(), size, ccbReader);
  131. }
  132. break;
  133. }
  134. case CCBReader::PropertyType::SCALE_LOCK:
  135. {
  136. float * scaleLock = this->parsePropTypeScaleLock(pNode, pParent, ccbReader, propertyName.c_str());
  137. if(setProp)
  138. {
  139. this->onHandlePropTypeScaleLock(pNode, pParent, propertyName.c_str(), scaleLock, ccbReader);
  140. }
  141. CC_SAFE_DELETE_ARRAY(scaleLock);
  142. break;
  143. }
  144. case CCBReader::PropertyType::FLOAT:
  145. {
  146. float f = this->parsePropTypeFloat(pNode, pParent, ccbReader);
  147. if(setProp)
  148. {
  149. this->onHandlePropTypeFloat(pNode, pParent, propertyName.c_str(), f, ccbReader);
  150. }
  151. break;
  152. }
  153. case CCBReader::PropertyType::FLOAT_XY:
  154. {
  155. float * xy = this->parsePropTypeFloatXY(pNode, pParent, ccbReader);
  156. if(setProp)
  157. {
  158. this->onHandlePropTypeFloatXY(pNode, pParent, propertyName.c_str(), xy, ccbReader);
  159. }
  160. CC_SAFE_DELETE_ARRAY(xy);
  161. break;
  162. }
  163. case CCBReader::PropertyType::DEGREES:
  164. {
  165. float degrees = this->parsePropTypeDegrees(pNode, pParent, ccbReader, propertyName.c_str());
  166. if(setProp)
  167. {
  168. this->onHandlePropTypeDegrees(pNode, pParent, propertyName.c_str(), degrees, ccbReader);
  169. }
  170. break;
  171. }
  172. case CCBReader::PropertyType::FLOAT_SCALE:
  173. {
  174. float floatScale = this->parsePropTypeFloatScale(pNode, pParent, ccbReader);
  175. if(setProp)
  176. {
  177. this->onHandlePropTypeFloatScale(pNode, pParent, propertyName.c_str(), floatScale, ccbReader);
  178. }
  179. break;
  180. }
  181. case CCBReader::PropertyType::INTEGER:
  182. {
  183. int integer = this->parsePropTypeInteger(pNode, pParent, ccbReader);
  184. if(setProp)
  185. {
  186. this->onHandlePropTypeInteger(pNode, pParent, propertyName.c_str(), integer, ccbReader);
  187. }
  188. break;
  189. }
  190. case CCBReader::PropertyType::INTEGER_LABELED:
  191. {
  192. int integerLabeled = this->parsePropTypeIntegerLabeled(pNode, pParent, ccbReader);
  193. if(setProp)
  194. {
  195. this->onHandlePropTypeIntegerLabeled(pNode, pParent, propertyName.c_str(), integerLabeled, ccbReader);
  196. }
  197. break;
  198. }
  199. case CCBReader::PropertyType::FLOAT_VAR:
  200. {
  201. float * floatVar = this->parsePropTypeFloatVar(pNode, pParent, ccbReader);
  202. if(setProp)
  203. {
  204. this->onHandlePropTypeFloatVar(pNode, pParent, propertyName.c_str(), floatVar, ccbReader);
  205. }
  206. CC_SAFE_DELETE_ARRAY(floatVar);
  207. break;
  208. }
  209. case CCBReader::PropertyType::CHECK:
  210. {
  211. bool check = this->parsePropTypeCheck(pNode, pParent, ccbReader, propertyName.c_str());
  212. if(setProp)
  213. {
  214. this->onHandlePropTypeCheck(pNode, pParent, propertyName.c_str(), check, ccbReader);
  215. }
  216. break;
  217. }
  218. case CCBReader::PropertyType::SPRITEFRAME:
  219. {
  220. SpriteFrame * ccSpriteFrame = this->parsePropTypeSpriteFrame(pNode, pParent, ccbReader, propertyName.c_str());
  221. if(setProp)
  222. {
  223. this->onHandlePropTypeSpriteFrame(pNode, pParent, propertyName.c_str(), ccSpriteFrame, ccbReader);
  224. }
  225. break;
  226. }
  227. case CCBReader::PropertyType::ANIMATION:
  228. {
  229. Animation * ccAnimation = this->parsePropTypeAnimation(pNode, pParent, ccbReader);
  230. if(setProp)
  231. {
  232. this->onHandlePropTypeAnimation(pNode, pParent, propertyName.c_str(), ccAnimation, ccbReader);
  233. }
  234. break;
  235. }
  236. case CCBReader::PropertyType::TEXTURE:
  237. {
  238. Texture2D * ccTexture2D = this->parsePropTypeTexture(pNode, pParent, ccbReader);
  239. if(setProp)
  240. {
  241. this->onHandlePropTypeTexture(pNode, pParent, propertyName.c_str(), ccTexture2D, ccbReader);
  242. }
  243. break;
  244. }
  245. case CCBReader::PropertyType::BYTE:
  246. {
  247. unsigned char byte = this->parsePropTypeByte(pNode, pParent, ccbReader, propertyName.c_str());
  248. if(setProp)
  249. {
  250. this->onHandlePropTypeByte(pNode, pParent, propertyName.c_str(), byte, ccbReader);
  251. }
  252. break;
  253. }
  254. case CCBReader::PropertyType::COLOR3:
  255. {
  256. Color3B color3B = this->parsePropTypeColor3(pNode, pParent, ccbReader, propertyName.c_str());
  257. if(setProp)
  258. {
  259. this->onHandlePropTypeColor3(pNode, pParent, propertyName.c_str(), color3B, ccbReader);
  260. }
  261. break;
  262. }
  263. case CCBReader::PropertyType::COLOR4F_VAR:
  264. {
  265. Color4F * color4FVar = this->parsePropTypeColor4FVar(pNode, pParent, ccbReader);
  266. if(setProp)
  267. {
  268. this->onHandlePropTypeColor4FVar(pNode, pParent, propertyName.c_str(), color4FVar, ccbReader);
  269. }
  270. CC_SAFE_DELETE_ARRAY(color4FVar);
  271. break;
  272. }
  273. case CCBReader::PropertyType::FLIP:
  274. {
  275. bool * flip = this->parsePropTypeFlip(pNode, pParent, ccbReader);
  276. if(setProp) {
  277. this->onHandlePropTypeFlip(pNode, pParent, propertyName.c_str(), flip, ccbReader);
  278. }
  279. CC_SAFE_DELETE_ARRAY(flip);
  280. break;
  281. }
  282. case CCBReader::PropertyType::BLEND_MODE:
  283. {
  284. BlendFunc blendFunc = this->parsePropTypeBlendFunc(pNode, pParent, ccbReader);
  285. if(setProp)
  286. {
  287. this->onHandlePropTypeBlendFunc(pNode, pParent, propertyName.c_str(), blendFunc, ccbReader);
  288. }
  289. break;
  290. }
  291. case CCBReader::PropertyType::FNT_FILE:
  292. {
  293. std::string fntFile = ccbReader->getCCBRootPath() + this->parsePropTypeFntFile(pNode, pParent, ccbReader);
  294. if(setProp)
  295. {
  296. this->onHandlePropTypeFntFile(pNode, pParent, propertyName.c_str(), fntFile.c_str(), ccbReader);
  297. }
  298. break;
  299. }
  300. case CCBReader::PropertyType::FONT_TTF:
  301. {
  302. std::string fontTTF = this->parsePropTypeFontTTF(pNode, pParent, ccbReader);
  303. if(setProp) {
  304. this->onHandlePropTypeFontTTF(pNode, pParent, propertyName.c_str(), fontTTF.c_str(), ccbReader);
  305. }
  306. break;
  307. }
  308. case CCBReader::PropertyType::STRING:
  309. {
  310. std::string string = this->parsePropTypeString(pNode, pParent, ccbReader);
  311. if(setProp) {
  312. this->onHandlePropTypeString(pNode, pParent, propertyName.c_str(), string.c_str(), ccbReader);
  313. }
  314. break;
  315. }
  316. case CCBReader::PropertyType::TEXT:
  317. {
  318. std::string text = this->parsePropTypeText(pNode, pParent, ccbReader);
  319. if(setProp) {
  320. this->onHandlePropTypeText(pNode, pParent, propertyName.c_str(), text.c_str(), ccbReader);
  321. }
  322. break;
  323. }
  324. case CCBReader::PropertyType::BLOCK:
  325. {
  326. BlockData * blockData = this->parsePropTypeBlock(pNode, pParent, ccbReader);
  327. if(setProp) {
  328. this->onHandlePropTypeBlock(pNode, pParent, propertyName.c_str(), blockData, ccbReader);
  329. }
  330. CC_SAFE_DELETE(blockData);
  331. break;
  332. }
  333. case CCBReader::PropertyType::BLOCK_CONTROL:
  334. {
  335. BlockControlData * blockControlData = this->parsePropTypeBlockControl(pNode, pParent, ccbReader);
  336. if(setProp && blockControlData != nullptr) {
  337. this->onHandlePropTypeBlockControl(pNode, pParent, propertyName.c_str(), blockControlData, ccbReader);
  338. }
  339. CC_SAFE_DELETE(blockControlData);
  340. break;
  341. }
  342. case CCBReader::PropertyType::CCB_FILE:
  343. {
  344. Node * ccbFileNode = this->parsePropTypeCCBFile(pNode, pParent, ccbReader);
  345. if(setProp) {
  346. this->onHandlePropTypeCCBFile(pNode, pParent, propertyName.c_str(), ccbFileNode, ccbReader);
  347. }
  348. break;
  349. }
  350. default:
  351. ASSERT_FAIL_UNEXPECTED_PROPERTYTYPE(static_cast<int>(type));
  352. break;
  353. }
  354. }
  355. }
  356. Vec2 NodeLoader::parsePropTypePosition(Node * pNode, Node * pParent, CCBReader * ccbReader, const char *pPropertyName)
  357. {
  358. float x = ccbReader->readFloat();
  359. float y = ccbReader->readFloat();
  360. CCBReader::PositionType type = static_cast<CCBReader::PositionType>(ccbReader->readInt(false));
  361. Size containerSize = ccbReader->getAnimationManager()->getContainerSize(pParent);
  362. Vec2 pt = getAbsolutePosition(Vec2(x,y), type, containerSize, pPropertyName);
  363. pNode->setPosition(pt);
  364. if (ccbReader->getAnimatedProperties()->find(pPropertyName) != ccbReader->getAnimatedProperties()->end())
  365. {
  366. ValueVector vec;
  367. vec.push_back(Value(x));
  368. vec.push_back(Value(y));
  369. vec.push_back(Value((int)type));
  370. ccbReader->getAnimationManager()->setBaseValue(Value(vec), pNode, pPropertyName);
  371. }
  372. return pt;
  373. }
  374. Vec2 NodeLoader::parsePropTypePoint(Node * /*pNode*/, Node * /*pParent*/, CCBReader * ccbReader)
  375. {
  376. float x = ccbReader->readFloat();
  377. float y = ccbReader->readFloat();
  378. return Vec2(x, y);
  379. }
  380. Vec2 NodeLoader::parsePropTypePointLock(Node * /*pNode*/, Node * /*pParent*/, CCBReader * ccbReader) {
  381. float x = ccbReader->readFloat();
  382. float y = ccbReader->readFloat();
  383. return Vec2(x, y);
  384. }
  385. Size NodeLoader::parsePropTypeSize(Node * /*pNode*/, Node * pParent, CCBReader * ccbReader) {
  386. float width = ccbReader->readFloat();
  387. float height = ccbReader->readFloat();
  388. CCBReader::SizeType type = static_cast<CCBReader::SizeType>(ccbReader->readInt(false));
  389. Size containerSize = ccbReader->getAnimationManager()->getContainerSize(pParent);
  390. switch (type)
  391. {
  392. case CCBReader::SizeType::ABSOLUTE:
  393. {
  394. /* Nothing. */
  395. break;
  396. }
  397. case CCBReader::SizeType::RELATIVE_CONTAINER:
  398. {
  399. width = containerSize.width - width;
  400. height = containerSize.height - height;
  401. break;
  402. }
  403. case CCBReader::SizeType::PERCENT:
  404. {
  405. width = (int)(containerSize.width * width / 100.0f);
  406. height = (int)(containerSize.height * height / 100.0f);
  407. break;
  408. }
  409. case CCBReader::SizeType::HORIZONTAL_PERCENT:
  410. {
  411. width = (int)(containerSize.width * width / 100.0f);
  412. break;
  413. }
  414. case CCBReader::SizeType::VERTICAL_PERCENT:
  415. {
  416. height = (int)(containerSize.height * height / 100.0f);
  417. break;
  418. }
  419. case CCBReader::SizeType::MULTIPLY_RESOLUTION:
  420. {
  421. float resolutionScale = CCBReader::getResolutionScale();
  422. width *= resolutionScale;
  423. height *= resolutionScale;
  424. break;
  425. }
  426. default:
  427. {
  428. log("Unknown CCB type.");
  429. }
  430. break;
  431. }
  432. return Size(width, height);
  433. }
  434. float * NodeLoader::parsePropTypeFloatXY(Node * /*pNode*/, Node * /*pParent*/, CCBReader * ccbReader) {
  435. float x = ccbReader->readFloat();
  436. float y = ccbReader->readFloat();
  437. float * floatXY = new (std::nothrow) float[2];
  438. floatXY[0] = x;
  439. floatXY[1] = y;
  440. return floatXY;
  441. }
  442. float * NodeLoader::parsePropTypeScaleLock(Node * pNode, Node * /*pParent*/, CCBReader * ccbReader, const char *pPropertyName) {
  443. float x = ccbReader->readFloat();
  444. float y = ccbReader->readFloat();
  445. CCBReader::ScaleType type = static_cast<CCBReader::ScaleType>(ccbReader->readInt(false));
  446. setRelativeScale(pNode, x, y, type, pPropertyName);
  447. if (ccbReader->getAnimatedProperties()->find(pPropertyName) != ccbReader->getAnimatedProperties()->end())
  448. {
  449. ValueVector baseValue;
  450. baseValue.push_back(Value(x));
  451. baseValue.push_back(Value(y));
  452. baseValue.push_back(Value((int)type));
  453. ccbReader->getAnimationManager()->setBaseValue(Value(baseValue), pNode, pPropertyName);
  454. }
  455. if (type == CCBReader::ScaleType::MULTIPLY_RESOLUTION)
  456. {
  457. x *= ccbReader->getResolutionScale();
  458. y *= ccbReader->getResolutionScale();
  459. }
  460. float * scaleLock = new (std::nothrow) float[2];
  461. scaleLock[0] = x;
  462. scaleLock[1] = y;
  463. return scaleLock;
  464. }
  465. float NodeLoader::parsePropTypeFloat(Node * /*pNode*/, Node * /*pParent*/, CCBReader * ccbReader) {
  466. return ccbReader->readFloat();
  467. }
  468. float NodeLoader::parsePropTypeDegrees(Node * pNode, Node * /*pParent*/, CCBReader * ccbReader, const char *pPropertyName) {
  469. float ret = ccbReader->readFloat();
  470. if (ccbReader->getAnimatedProperties()->find(pPropertyName) != ccbReader->getAnimatedProperties()->end())
  471. {
  472. ccbReader->getAnimationManager()->setBaseValue(Value(ret), pNode, pPropertyName);
  473. }
  474. return ret;
  475. }
  476. float NodeLoader::parsePropTypeFloatScale(Node * /*pNode*/, Node * /*pParent*/, CCBReader * ccbReader)
  477. {
  478. float f = ccbReader->readFloat();
  479. CCBReader::ScaleType type = static_cast<CCBReader::ScaleType>(ccbReader->readInt(false));
  480. if(type == CCBReader::ScaleType::MULTIPLY_RESOLUTION)
  481. {
  482. f *= ccbReader->getResolutionScale();
  483. }
  484. return f;
  485. }
  486. int NodeLoader::parsePropTypeInteger(Node * /*pNode*/, Node * /*pParent*/, CCBReader * ccbReader)
  487. {
  488. return ccbReader->readInt(true);
  489. }
  490. int NodeLoader::parsePropTypeIntegerLabeled(Node * /*pNode*/, Node * /*pParent*/, CCBReader * ccbReader)
  491. {
  492. return ccbReader->readInt(true);
  493. }
  494. float * NodeLoader::parsePropTypeFloatVar(Node * /*pNode*/, Node * /*pParent*/, CCBReader * ccbReader)
  495. {
  496. float f = ccbReader->readFloat();
  497. float fVar = ccbReader->readFloat();
  498. float * arr = new (std::nothrow) float[2];
  499. arr[0] = f;
  500. arr[1] = fVar;
  501. return arr;
  502. }
  503. bool NodeLoader::parsePropTypeCheck(Node * pNode, Node * /*pParent*/, CCBReader * ccbReader, const char *pPropertyName)
  504. {
  505. bool ret = ccbReader->readBool();
  506. if (ccbReader->getAnimatedProperties()->find(pPropertyName) != ccbReader->getAnimatedProperties()->end())
  507. {
  508. ccbReader->getAnimationManager()->setBaseValue(Value(ret), pNode, pPropertyName);
  509. }
  510. return ret;
  511. }
  512. SpriteFrame * NodeLoader::parsePropTypeSpriteFrame(Node * pNode, Node * /*pParent*/, CCBReader * ccbReader, const char *pPropertyName)
  513. {
  514. std::string spriteSheet = ccbReader->readCachedString();
  515. std::string spriteFile = ccbReader->readCachedString();
  516. SpriteFrame *spriteFrame = nullptr;
  517. if (!spriteFile.empty())
  518. {
  519. if (spriteSheet.empty())
  520. {
  521. spriteFile = ccbReader->getCCBRootPath() + spriteFile;
  522. Texture2D * texture = Director::getInstance()->getTextureCache()->addImage(spriteFile);
  523. if(texture != nullptr) {
  524. Rect bounds = Rect(0, 0, texture->getContentSize().width, texture->getContentSize().height);
  525. spriteFrame = SpriteFrame::createWithTexture(texture, bounds);
  526. }
  527. }
  528. else
  529. {
  530. SpriteFrameCache * frameCache = SpriteFrameCache::getInstance();
  531. spriteSheet = ccbReader->getCCBRootPath() + spriteSheet;
  532. // Load the sprite sheet only if it is not loaded
  533. if (ccbReader->getLoadedSpriteSheet().find(spriteSheet) == ccbReader->getLoadedSpriteSheet().end())
  534. {
  535. frameCache->addSpriteFramesWithFile(spriteSheet);
  536. ccbReader->getLoadedSpriteSheet().insert(spriteSheet);
  537. }
  538. spriteFrame = frameCache->getSpriteFrameByName(spriteFile);
  539. }
  540. if (ccbReader->getAnimatedProperties()->find(pPropertyName) != ccbReader->getAnimatedProperties()->end())
  541. {
  542. ccbReader->getAnimationManager()->setObject(spriteFrame, pNode, pPropertyName);
  543. }
  544. }
  545. return spriteFrame;
  546. }
  547. Animation * NodeLoader::parsePropTypeAnimation(Node * /*pNode*/, Node * /*pParent*/, CCBReader * ccbReader) {
  548. std::string animationFile = ccbReader->getCCBRootPath() + ccbReader->readCachedString();
  549. std::string animation = ccbReader->readCachedString();
  550. Animation * ccAnimation = nullptr;
  551. // Support for stripping relative file paths, since ios doesn't currently
  552. // know what to do with them, since its pulling from bundle.
  553. // Eventually this should be handled by a client side asset manager
  554. // interface which figured out what resources to load.
  555. // TODO: Does this problem exist in C++?
  556. animation = CCBReader::lastPathComponent(animation.c_str());
  557. animationFile = CCBReader::lastPathComponent(animationFile.c_str());
  558. if (!animation.empty())
  559. {
  560. AnimationCache * animationCache = AnimationCache::getInstance();
  561. animationCache->addAnimationsWithFile(animationFile);
  562. ccAnimation = animationCache->getAnimation(animation);
  563. }
  564. return ccAnimation;
  565. }
  566. Texture2D * NodeLoader::parsePropTypeTexture(Node * /*pNode*/, Node * /*pParent*/, CCBReader * ccbReader) {
  567. std::string spriteFile = ccbReader->getCCBRootPath() + ccbReader->readCachedString();
  568. if (!spriteFile.empty())
  569. {
  570. return Director::getInstance()->getTextureCache()->addImage(spriteFile);
  571. }
  572. else
  573. {
  574. return nullptr;
  575. }
  576. }
  577. unsigned char NodeLoader::parsePropTypeByte(Node * pNode, Node * /*pParent*/, CCBReader * ccbReader, const char *pPropertyName)
  578. {
  579. unsigned char ret = ccbReader->readByte();
  580. if (ccbReader->getAnimatedProperties()->find(pPropertyName) != ccbReader->getAnimatedProperties()->end())
  581. {
  582. ccbReader->getAnimationManager()->setBaseValue(Value(ret), pNode, pPropertyName);
  583. }
  584. return ret;
  585. }
  586. Color3B NodeLoader::parsePropTypeColor3(Node * pNode, Node * /*pParent*/, CCBReader * ccbReader, const char *pPropertyName) {
  587. unsigned char r = ccbReader->readByte();
  588. unsigned char g = ccbReader->readByte();
  589. unsigned char b = ccbReader->readByte();
  590. Color3B color(r, g, b);
  591. ValueMap colorMap;
  592. colorMap["r"] = r;
  593. colorMap["g"] = g;
  594. colorMap["b"] = b;
  595. if (ccbReader->getAnimatedProperties()->find(pPropertyName) != ccbReader->getAnimatedProperties()->end())
  596. {
  597. ccbReader->getAnimationManager()->setBaseValue(Value(colorMap), pNode, pPropertyName);
  598. }
  599. return color;
  600. }
  601. Color4F * NodeLoader::parsePropTypeColor4FVar(Node * /*pNode*/, Node * /*pParent*/, CCBReader * ccbReader) {
  602. float red = ccbReader->readFloat();
  603. float green = ccbReader->readFloat();
  604. float blue = ccbReader->readFloat();
  605. float alpha = ccbReader->readFloat();
  606. float redVar = ccbReader->readFloat();
  607. float greenVar = ccbReader->readFloat();
  608. float blueVar = ccbReader->readFloat();
  609. float alphaVar = ccbReader->readFloat();
  610. Color4F * colors = new (std::nothrow) Color4F[2];
  611. colors[0].r = red;
  612. colors[0].g = green;
  613. colors[0].b = blue;
  614. colors[0].a = alpha;
  615. colors[1].r = redVar;
  616. colors[1].g = greenVar;
  617. colors[1].b = blueVar;
  618. colors[1].a = alphaVar;
  619. return colors;
  620. }
  621. bool * NodeLoader::parsePropTypeFlip(Node * /*pNode*/, Node * /*pParent*/, CCBReader * ccbReader) {
  622. bool flipX = ccbReader->readBool();
  623. bool flipY = ccbReader->readBool();
  624. bool * arr = new (std::nothrow) bool[2];
  625. arr[0] = flipX;
  626. arr[1] = flipY;
  627. return arr;
  628. }
  629. BlendFunc NodeLoader::parsePropTypeBlendFunc(Node * /*pNode*/, Node * /*pParent*/, CCBReader * ccbReader)
  630. {
  631. int source = ccbReader->readInt(false);
  632. int destination = ccbReader->readInt(false);
  633. BlendFunc blendFunc;
  634. blendFunc.src = source;
  635. blendFunc.dst = destination;
  636. return blendFunc;
  637. }
  638. std::string NodeLoader::parsePropTypeFntFile(Node * /*pNode*/, Node * /*pParent*/, CCBReader * ccbReader)
  639. {
  640. return ccbReader->readCachedString();
  641. }
  642. std::string NodeLoader::parsePropTypeString(Node * /*pNode*/, Node * /*pParent*/, CCBReader * ccbReader) {
  643. return ccbReader->readCachedString();
  644. }
  645. std::string NodeLoader::parsePropTypeText(Node * /*pNode*/, Node * /*pParent*/, CCBReader * ccbReader) {
  646. return ccbReader->readCachedString();
  647. }
  648. std::string NodeLoader::parsePropTypeFontTTF(Node * /*pNode*/, Node * /*pParent*/, CCBReader * ccbReader) {
  649. std::string fontTTF = ccbReader->readCachedString();
  650. // String * ttfEnding = String::create(".ttf");
  651. // TODO: Fix me if it is wrong
  652. /* If the fontTTF comes with the ".ttf" extension, prepend the absolute path.
  653. * System fonts come without the ".ttf" extension and do not need the path prepended. */
  654. /*
  655. if(CCBReader::endsWith(CCBReader::toLowerCase(fontTTF), ttfEnding)){
  656. fontTTF = CCBReader::concat(ccbReader->getCCBRootPath(), fontTTF);
  657. }
  658. */
  659. return fontTTF;
  660. }
  661. BlockData * NodeLoader::parsePropTypeBlock(Node * pNode, Node * /*pParent*/, CCBReader * ccbReader)
  662. {
  663. std::string selectorName = ccbReader->readCachedString();
  664. CCBReader::TargetType selectorTarget = static_cast<CCBReader::TargetType>(ccbReader->readInt(false));
  665. if(selectorTarget != CCBReader::TargetType::NONE)
  666. {
  667. Ref* target = nullptr;
  668. if(!ccbReader->isJSControlled())
  669. {
  670. if(selectorTarget == CCBReader::TargetType::DOCUMENT_ROOT)
  671. {
  672. target = ccbReader->getAnimationManager()->getRootNode();
  673. }
  674. else if(selectorTarget == CCBReader::TargetType::OWNER)
  675. {
  676. target = ccbReader->getOwner();
  677. }
  678. if(target != nullptr)
  679. {
  680. if(!selectorName.empty())
  681. {
  682. SEL_MenuHandler selMenuHandler = 0;
  683. CCBSelectorResolver * targetAsCCBSelectorResolver = dynamic_cast<CCBSelectorResolver *>(target);
  684. if(targetAsCCBSelectorResolver != nullptr)
  685. {
  686. selMenuHandler = targetAsCCBSelectorResolver->onResolveCCBCCMenuItemSelector(target, selectorName.c_str());
  687. }
  688. if(selMenuHandler == 0)
  689. {
  690. CCBSelectorResolver * ccbSelectorResolver = ccbReader->getCCBSelectorResolver();
  691. if(ccbSelectorResolver != nullptr)
  692. {
  693. selMenuHandler = ccbSelectorResolver->onResolveCCBCCMenuItemSelector(target, selectorName.c_str());
  694. }
  695. }
  696. if(selMenuHandler == 0) {
  697. CCLOG("Skipping selector '%s' since no CCBSelectorResolver is present.", selectorName.c_str());
  698. } else {
  699. BlockData * blockData = new (std::nothrow) BlockData();
  700. blockData->mSELMenuHandler = selMenuHandler;
  701. blockData->_target = target;
  702. return blockData;
  703. }
  704. } else {
  705. CCLOG("Unexpected empty selector.");
  706. }
  707. } else {
  708. CCLOG("Unexpected nullptr target for selector.");
  709. }
  710. }
  711. else
  712. {
  713. if (selectorTarget == CCBReader::TargetType::DOCUMENT_ROOT)
  714. {
  715. ccbReader->addDocumentCallbackNode(pNode);
  716. ccbReader->addDocumentCallbackName(selectorName);
  717. // Since there isn't a Control::EventType::NONE, add a TOUCH_DOWN type as a placeholder.
  718. ccbReader->addDocumentCallbackControlEvents(Control::EventType::TOUCH_DOWN);
  719. }
  720. else if (selectorTarget == CCBReader::TargetType::OWNER)
  721. {
  722. ccbReader->addOwnerCallbackNode(pNode);
  723. ccbReader->addOwnerCallbackName(selectorName);
  724. // Since there isn't a Control::EventType::NONE, add a TOUCH_DOWN type as a placeholder.
  725. ccbReader->addOwnerCallbackControlEvents(Control::EventType::TOUCH_DOWN);
  726. }
  727. }
  728. }
  729. return nullptr;
  730. }
  731. BlockControlData * NodeLoader::parsePropTypeBlockControl(Node * pNode, Node * /*pParent*/, CCBReader * ccbReader)
  732. {
  733. std::string selectorName = ccbReader->readCachedString();
  734. CCBReader::TargetType selectorTarget = static_cast<CCBReader::TargetType>(ccbReader->readInt(false));
  735. int controlEvents = ccbReader->readInt(false);
  736. if(selectorTarget != CCBReader::TargetType::NONE)
  737. {
  738. if(!ccbReader->isJSControlled())
  739. {
  740. Ref* target = nullptr;
  741. if(selectorTarget == CCBReader::TargetType::DOCUMENT_ROOT)
  742. {
  743. target = ccbReader->getAnimationManager()->getRootNode();
  744. }
  745. else if(selectorTarget == CCBReader::TargetType::OWNER)
  746. {
  747. target = ccbReader->getOwner();
  748. }
  749. if(target != nullptr)
  750. {
  751. if(!selectorName.empty())
  752. {
  753. Control::Handler selControlHandler = 0;
  754. CCBSelectorResolver * targetAsCCBSelectorResolver = dynamic_cast<CCBSelectorResolver *>(target);
  755. if(targetAsCCBSelectorResolver != nullptr)
  756. {
  757. selControlHandler = targetAsCCBSelectorResolver->onResolveCCBCCControlSelector(target, selectorName.c_str());
  758. }
  759. if(selControlHandler == 0)
  760. {
  761. CCBSelectorResolver * ccbSelectorResolver = ccbReader->getCCBSelectorResolver();
  762. if(ccbSelectorResolver != nullptr)
  763. {
  764. selControlHandler = ccbSelectorResolver->onResolveCCBCCControlSelector(target, selectorName.c_str());
  765. }
  766. }
  767. if(selControlHandler == 0)
  768. {
  769. CCLOG("Skipping selector '%s' since no CCBSelectorResolver is present.", selectorName.c_str());
  770. }
  771. else
  772. {
  773. BlockControlData * blockControlData = new (std::nothrow) BlockControlData();
  774. blockControlData->mSELControlHandler = selControlHandler;
  775. blockControlData->_target = target;
  776. blockControlData->mControlEvents = (Control::EventType)controlEvents;
  777. return blockControlData;
  778. }
  779. } else {
  780. CCLOG("Unexpected empty selector.");
  781. }
  782. } else {
  783. CCLOG("Unexpected nullptr target for selector.");
  784. }
  785. }
  786. else
  787. {
  788. if(selectorTarget == CCBReader::TargetType::DOCUMENT_ROOT)
  789. {
  790. ccbReader->addDocumentCallbackNode(pNode);
  791. ccbReader->addDocumentCallbackName(selectorName);
  792. ccbReader->addDocumentCallbackControlEvents((Control::EventType)controlEvents);
  793. }
  794. else
  795. {
  796. ccbReader->addOwnerCallbackNode(pNode);
  797. ccbReader->addOwnerCallbackName(selectorName);
  798. ccbReader->addOwnerCallbackControlEvents((Control::EventType)controlEvents);
  799. }
  800. }
  801. }
  802. return nullptr;
  803. }
  804. Node * NodeLoader::parsePropTypeCCBFile(Node * /*pNode*/, Node * pParent, CCBReader * pCCBReader) {
  805. std::string ccbFileName = pCCBReader->getCCBRootPath() + pCCBReader->readCachedString();
  806. /* Change path extension to .ccbi. */
  807. std::string ccbFileWithoutPathExtension = CCBReader::deletePathExtension(ccbFileName.c_str());
  808. ccbFileName = ccbFileWithoutPathExtension + ".ccbi";
  809. // Load sub file
  810. std::string path = FileUtils::getInstance()->fullPathForFilename(ccbFileName);
  811. auto dataPtr = std::make_shared<Data>(FileUtils::getInstance()->getDataFromFile(path));
  812. CCBReader * reader = new (std::nothrow) CCBReader(pCCBReader);
  813. reader->autorelease();
  814. reader->getAnimationManager()->setRootContainerSize(pParent->getContentSize());
  815. reader->_data = dataPtr;
  816. reader->_bytes = dataPtr->getBytes();
  817. reader->_currentByte = 0;
  818. reader->_currentBit = 0;
  819. CC_SAFE_RETAIN(pCCBReader->_owner);
  820. reader->_owner = pCCBReader->_owner;
  821. reader->getAnimationManager()->_owner = reader->_owner;
  822. // The assignments below are done in the CCBReader constructor.
  823. // reader->_ownerOutletNames = pCCBReader->_ownerOutletNames;
  824. // reader->_ownerOutletNodes = pCCBReader->_ownerOutletNodes;
  825. // reader->_ownerOutletNodes->retain();
  826. // reader->_ownerCallbackNames = pCCBReader->_ownerCallbackNames;
  827. // reader->_ownerCallbackNodes = pCCBReader->_ownerCallbackNodes;
  828. // reader->_ownerCallbackNodes->retain();
  829. Node * ccbFileNode = reader->readFileWithCleanUp(false, pCCBReader->getAnimationManagers());
  830. if (ccbFileNode && reader->getAnimationManager()->getAutoPlaySequenceId() != -1)
  831. {
  832. // Auto play animations
  833. reader->getAnimationManager()->runAnimationsForSequenceIdTweenDuration(reader->getAnimationManager()->getAutoPlaySequenceId(), 0);
  834. }
  835. if (reader->isJSControlled() && pCCBReader->isJSControlled() && nullptr == reader->_owner)
  836. {
  837. //set variables and callback to owner
  838. //set callback
  839. auto ownerCallbackNames = reader->getOwnerCallbackNames();
  840. auto& ownerCallbackNodes = reader->getOwnerCallbackNodes();
  841. if (!ownerCallbackNames.empty() && !ownerCallbackNodes.empty())
  842. {
  843. CCASSERT(ownerCallbackNames.size() == ownerCallbackNodes.size(),
  844. "ownerCallbackNames size should equal to ownerCallbackNodes size.");
  845. ssize_t nCount = ownerCallbackNames.size();
  846. for (ssize_t i = 0 ; i < nCount; i++)
  847. {
  848. pCCBReader->addOwnerCallbackName(ownerCallbackNames[i].asString());
  849. pCCBReader->addOwnerCallbackNode(ownerCallbackNodes.at(i));
  850. }
  851. }
  852. //set variables
  853. auto ownerOutletNames = reader->getOwnerOutletNames();
  854. auto ownerOutletNodes = reader->getOwnerOutletNodes();
  855. if (!ownerOutletNames.empty() && !ownerOutletNodes.empty())
  856. {
  857. CCASSERT(ownerOutletNames.size() == ownerOutletNodes.size(),
  858. "ownerOutletNames size should be equal to ownerOutletNodes's size.");
  859. ssize_t nCount = ownerOutletNames.size();
  860. for (ssize_t i = 0 ; i < nCount; i++)
  861. {
  862. pCCBReader->addOwnerOutletName(ownerOutletNames.at(i).asString());
  863. pCCBReader->addOwnerOutletNode(ownerOutletNodes.at(i));
  864. }
  865. }
  866. }
  867. return ccbFileNode;
  868. }
  869. void NodeLoader::onHandlePropTypePosition(Node * pNode, Node * /*pParent*/, const char* pPropertyName, Vec2 pPosition, CCBReader * /*ccbReader*/) {
  870. if(strcmp(pPropertyName, PROPERTY_POSITION) == 0) {
  871. pNode->setPosition(pPosition);
  872. } else {
  873. ASSERT_FAIL_UNEXPECTED_PROPERTY(pPropertyName);
  874. }
  875. }
  876. void NodeLoader::onHandlePropTypePoint(Node * pNode, Node * /*pParent*/, const char* pPropertyName, Vec2 pPoint, CCBReader * /*ccbReader*/) {
  877. if(strcmp(pPropertyName, PROPERTY_ANCHORPOINT) == 0) {
  878. pNode->setAnchorPoint(pPoint);
  879. } else {
  880. ASSERT_FAIL_UNEXPECTED_PROPERTY(pPropertyName);
  881. }
  882. }
  883. void NodeLoader::onHandlePropTypePointLock(Node * /*pNode*/, Node * /*pParent*/, const char* pPropertyName, Vec2 /*pPointLock*/, CCBReader * /*ccbReader*/) {
  884. ASSERT_FAIL_UNEXPECTED_PROPERTY(pPropertyName);
  885. }
  886. void NodeLoader::onHandlePropTypeSize(Node * pNode, Node * /*pParent*/, const char* pPropertyName, Size pSize, CCBReader * /*ccbReader*/) {
  887. if(strcmp(pPropertyName, PROPERTY_CONTENTSIZE) == 0) {
  888. pNode->setContentSize(pSize);
  889. } else {
  890. ASSERT_FAIL_UNEXPECTED_PROPERTY(pPropertyName);
  891. }
  892. }
  893. void NodeLoader::onHandlePropTypeFloatXY(Node * pNode, Node * /*pParent*/, const char* pPropertyName, float * pFloat, CCBReader * /*ccbReader*/) {
  894. if(strcmp(pPropertyName, PROPERTY_SKEW) == 0) {
  895. pNode->setSkewX(pFloat[0]);
  896. pNode->setSkewY(pFloat[1]);
  897. } else {
  898. ASSERT_FAIL_UNEXPECTED_PROPERTY(pPropertyName);
  899. }
  900. }
  901. void NodeLoader::onHandlePropTypeScaleLock(Node * pNode, Node * /*pParent*/, const char* pPropertyName, float * pScaleLock, CCBReader * /*ccbReader*/) {
  902. if(strcmp(pPropertyName, PROPERTY_SCALE) == 0) {
  903. pNode->setScaleX(pScaleLock[0]);
  904. pNode->setScaleY(pScaleLock[1]);
  905. } else {
  906. ASSERT_FAIL_UNEXPECTED_PROPERTY(pPropertyName);
  907. }
  908. }
  909. void NodeLoader::onHandlePropTypeFloat(Node * /*pNode*/, Node * /*pParent*/, const char* pPropertyName, float pFloat, CCBReader * /*ccbReader*/) {
  910. // ASSERT_FAIL_UNEXPECTED_PROPERTY(pPropertyName);
  911. // It may be a custom property, add it to custom property dictionary.
  912. _customProperties[pPropertyName] = Value(pFloat);
  913. }
  914. void NodeLoader::onHandlePropTypeDegrees(Node * pNode, Node * /*pParent*/, const char* pPropertyName, float pDegrees, CCBReader * /*ccbReader*/) {
  915. if(strcmp(pPropertyName, PROPERTY_ROTATION) == 0) {
  916. pNode->setRotation(pDegrees);
  917. } else if(strcmp(pPropertyName, PROPERTY_ROTATIONX) == 0) {
  918. pNode->setRotationSkewX(pDegrees);
  919. } else if(strcmp(pPropertyName, PROPERTY_ROTATIONY) == 0) {
  920. pNode->setRotationSkewY(pDegrees);
  921. }
  922. else {
  923. ASSERT_FAIL_UNEXPECTED_PROPERTY(pPropertyName);
  924. }
  925. }
  926. void NodeLoader::onHandlePropTypeFloatScale(Node * /*pNode*/, Node * /*pParent*/, const char* pPropertyName, float /*pFloatScale*/, CCBReader * /*ccbReader*/) {
  927. ASSERT_FAIL_UNEXPECTED_PROPERTY(pPropertyName);
  928. }
  929. void NodeLoader::onHandlePropTypeInteger(Node * pNode, Node * /*pParent*/, const char* pPropertyName, int pInteger, CCBReader * /*ccbReader*/) {
  930. if(strcmp(pPropertyName, PROPERTY_TAG) == 0) {
  931. pNode->setTag(pInteger);
  932. } else {
  933. // ASSERT_FAIL_UNEXPECTED_PROPERTY(pPropertyName);
  934. // It may be a custom property, add it to custom property dictionary.
  935. _customProperties[pPropertyName] = Value(pInteger);
  936. }
  937. }
  938. void NodeLoader::onHandlePropTypeIntegerLabeled(Node * /*pNode*/, Node * /*pParent*/, const char* pPropertyName, int /*pIntegerLabeled*/, CCBReader * /*ccbReader*/) {
  939. ASSERT_FAIL_UNEXPECTED_PROPERTY(pPropertyName);
  940. }
  941. void NodeLoader::onHandlePropTypeFloatVar(Node * /*pNode*/, Node * /*pParent*/, const char* pPropertyName, float * /*pFloatVar*/, CCBReader * /*ccbReader*/) {
  942. ASSERT_FAIL_UNEXPECTED_PROPERTY(pPropertyName);
  943. }
  944. void NodeLoader::onHandlePropTypeCheck(Node * pNode, Node * /*pParent*/, const char* pPropertyName, bool pCheck, CCBReader * /*ccbReader*/) {
  945. if(strcmp(pPropertyName, PROPERTY_VISIBLE) == 0) {
  946. pNode->setVisible(pCheck);
  947. } else if(strcmp(pPropertyName, PROPERTY_IGNOREANCHORPOINTFORPOSITION) == 0) {
  948. pNode->setIgnoreAnchorPointForPosition(pCheck);
  949. } else {
  950. //ASSERT_FAIL_UNEXPECTED_PROPERTY(pPropertyName);
  951. // It may be a custom property, add it to custom property dictionary.
  952. _customProperties[pPropertyName] = Value(pCheck);
  953. }
  954. }
  955. void NodeLoader::onHandlePropTypeSpriteFrame(Node * /*pNode*/, Node * /*pParent*/, const char* pPropertyName, SpriteFrame * /*pSpriteFrame*/, CCBReader * /*ccbReader*/) {
  956. ASSERT_FAIL_UNEXPECTED_PROPERTY(pPropertyName);
  957. }
  958. void NodeLoader::onHandlePropTypeAnimation(Node * /*pNode*/, Node * /*pParent*/, const char* pPropertyName, Animation * /*pAnimation*/, CCBReader * /*ccbReader*/) {
  959. ASSERT_FAIL_UNEXPECTED_PROPERTY(pPropertyName);
  960. }
  961. void NodeLoader::onHandlePropTypeTexture(Node * /*pNode*/, Node * /*pParent*/, const char* pPropertyName, Texture2D * /*pTexture2D*/, CCBReader * /*ccbReader*/) {
  962. ASSERT_FAIL_UNEXPECTED_PROPERTY(pPropertyName);
  963. }
  964. void NodeLoader::onHandlePropTypeByte(Node * /*pNode*/, Node * /*pParent*/, const char* pPropertyName, unsigned char /*pByte*/, CCBReader * /*ccbReader*/) {
  965. ASSERT_FAIL_UNEXPECTED_PROPERTY(pPropertyName);
  966. }
  967. void NodeLoader::onHandlePropTypeColor3(Node * /*pNode*/, Node * /*pParent*/, const char* pPropertyName, Color3B /*pColor3B*/, CCBReader * /*ccbReader*/) {
  968. ASSERT_FAIL_UNEXPECTED_PROPERTY(pPropertyName);
  969. }
  970. void NodeLoader::onHandlePropTypeColor4FVar(Node * /*pNode*/, Node * /*pParent*/, const char* pPropertyName, Color4F * /*pColor4FVar*/, CCBReader * /*ccbReader*/) {
  971. ASSERT_FAIL_UNEXPECTED_PROPERTY(pPropertyName);
  972. }
  973. void NodeLoader::onHandlePropTypeFlip(Node * /*pNode*/, Node * /*pParent*/, const char* pPropertyName, bool * /*pFlip*/, CCBReader * /*ccbReader*/) {
  974. ASSERT_FAIL_UNEXPECTED_PROPERTY(pPropertyName);
  975. }
  976. void NodeLoader::onHandlePropTypeBlendFunc(Node * /*pNode*/, Node * /*pParent*/, const char* pPropertyName, BlendFunc /*pBlendFunc*/, CCBReader * /*ccbReader*/) {
  977. ASSERT_FAIL_UNEXPECTED_PROPERTY(pPropertyName);
  978. }
  979. void NodeLoader::onHandlePropTypeFntFile(Node * /*pNode*/, Node * /*pParent*/, const char* pPropertyName, const char* /*pFntFile*/, CCBReader * /*ccbReader*/) {
  980. ASSERT_FAIL_UNEXPECTED_PROPERTY(pPropertyName);
  981. }
  982. void NodeLoader::onHandlePropTypeString(Node * /*pNode*/, Node * /*pParent*/, const char* pPropertyName, const char * pString, CCBReader * /*ccbReader*/) {
  983. // ASSERT_FAIL_UNEXPECTED_PROPERTY(pPropertyName);
  984. // It may be a custom property, add it to custom property dictionary.
  985. _customProperties[pPropertyName] = Value(pString);
  986. }
  987. void NodeLoader::onHandlePropTypeText(Node * /*pNode*/, Node * /*pParent*/, const char* pPropertyName, const char * /*pText*/, CCBReader * /*ccbReader*/) {
  988. ASSERT_FAIL_UNEXPECTED_PROPERTY(pPropertyName);
  989. }
  990. void NodeLoader::onHandlePropTypeFontTTF(Node * /*pNode*/, Node * /*pParent*/, const char* pPropertyName, const char * /*pFontTTF*/, CCBReader * /*ccbReader*/) {
  991. ASSERT_FAIL_UNEXPECTED_PROPERTY(pPropertyName);
  992. }
  993. void NodeLoader::onHandlePropTypeBlock(Node * /*pNode*/, Node * /*pParent*/, const char* pPropertyName, BlockData * /*pBlockData*/, CCBReader * /*ccbReader*/) {
  994. ASSERT_FAIL_UNEXPECTED_PROPERTY(pPropertyName);
  995. }
  996. void NodeLoader::onHandlePropTypeBlockControl(Node * /*pNode*/, Node * /*pParent*/, const char* pPropertyName, BlockControlData * /*pBlockControlData*/, CCBReader * /*ccbReader*/) {
  997. ASSERT_FAIL_UNEXPECTED_PROPERTY(pPropertyName);
  998. }
  999. void NodeLoader::onHandlePropTypeCCBFile(Node * /*pNode*/, Node * /*pParent*/, const char* pPropertyName, Node * /*pCCBFileNode*/, CCBReader * /*ccbReader*/) {
  1000. ASSERT_FAIL_UNEXPECTED_PROPERTY(pPropertyName);
  1001. }
  1002. }