dataManager.cpp 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737
  1. #include "datahpp/dataManager.h"
  2. #include <iostream>
  3. #include <QFile>
  4. #include <QJsonDocument>
  5. #include <QApplication>
  6. #include <QDir>
  7. DataManager* DataManager::getInstance()
  8. {
  9. static DataManager dataManager;
  10. return &dataManager;
  11. }
  12. DataManager::DataManager()
  13. {
  14. jsonTemp = new ReadJsonSrc(":/file/file/template.json");
  15. loadData();
  16. }
  17. DataManager::~DataManager()
  18. {
  19. delete jsonTemp;
  20. saveData();
  21. }
  22. QString DataManager::getFileName(QString filePath)
  23. {
  24. if(filePath == "双击添加资源文件") return filePath;
  25. int size = filePath.count();
  26. int pos = 0;
  27. for(int i=size-1;i>=0;i--){
  28. if(filePath[i] == '/'){
  29. pos = i+1;
  30. break;
  31. }
  32. }
  33. QString fileName;
  34. for(int i=pos;i<size;i++){
  35. fileName.push_back(filePath[i]);
  36. }
  37. return fileName;
  38. }
  39. //模板配置
  40. QVector<ReadJsonSrc::Fields> DataManager::getTempFields(QString key, QString name)
  41. {
  42. QVector<ReadJsonSrc::Fields> nullVec;
  43. int index = jsonTemp->getTemplateIndex(key,name);
  44. if(index == -1) return nullVec;
  45. return jsonTemp->templateMap[key][index].fields;
  46. }
  47. void DataManager::updateTempData()
  48. {
  49. ReadJsonSrc* tmp = jsonTemp;
  50. jsonTemp = new ReadJsonSrc(":/file/file/template.json");
  51. delete tmp;
  52. }
  53. QStringList DataManager::getList(QString elem,ListType listType)
  54. {
  55. QStringList list;
  56. if(listType == ListType::Anim){
  57. for(const auto &i:elements[elem]->statusEffect) list.push_back(i.name);
  58. }
  59. else if(listType == ListType::CollAnim){
  60. for(const auto &i:elements[elem]->collAnim) list.push_back(i.name);
  61. }
  62. else if(listType == ListType::Pool){
  63. for(const auto &i:elements[elem]->container) list.push_back(i.poolName);
  64. }
  65. else if(listType == ListType::AnimType){
  66. for(const auto &i:jsonTemp->templateMap["collAnimTemp"]) list.push_back(i.name);
  67. }
  68. else if(listType == ListType::StatusVal){
  69. for(const auto &i:elements[elem]->statusConfig) list.push_back(i.statusValue);
  70. }
  71. else if(listType == ListType::Events){
  72. for(const auto &i:jsonTemp->templateMap["eventTemp"]) list.push_back(i.name);
  73. }
  74. else if(listType == ListType::Actions){
  75. for(const auto &i:jsonTemp->templateMap["actionTemp"]) list.push_back(i.name);
  76. }
  77. else if(listType == ListType::PoolType){
  78. for(const auto &i:jsonTemp->templateMap["poolTemp"]) list.push_back(i.name);
  79. }
  80. else if(listType == ListType::Elem) return elements.keys();
  81. return list;
  82. }
  83. //元素及其基础属性
  84. bool DataManager::existElem(QString elemName)
  85. {
  86. return elements.contains(elemName);
  87. }
  88. void DataManager::addElem(QString elemName)
  89. {
  90. elements[elemName] = new ElemPropertyData();
  91. }
  92. void DataManager::delElem(QString elemName)
  93. {
  94. delete elements[elemName];
  95. elements.remove(elemName);
  96. }
  97. void DataManager::changeElemName(QString oriName, QString newName)
  98. {
  99. ElemPropertyData* tmp = elements[oriName];
  100. elements.remove(oriName);
  101. elements[newName] = tmp;
  102. }
  103. void DataManager::changeMarkValue(QString elem, QString val)
  104. {
  105. elements[elem]->labelName = val;
  106. }
  107. void DataManager::changePos(QString elem, QString val)
  108. {
  109. elements[elem]->pos = val;
  110. }
  111. void DataManager::changeMaxLayer(QString elem, QString val)
  112. {
  113. elements[elem]->maxLayer = val;
  114. }
  115. void DataManager::changeScore(QString elem, QString val)
  116. {
  117. elements[elem]->score = val;
  118. }
  119. void DataManager::changeDropConfig(QString elem, int index)
  120. {
  121. elements[elem]->dropConfig = static_cast<ElemPropertyData::DROPOPT>(index);
  122. }
  123. void DataManager::changeIconPath(QString elem, QString iconPath)
  124. {
  125. elements[elem]->iconPath = iconPath;
  126. }
  127. void DataManager::changeLinkedState(QString elem, int state)
  128. {
  129. elements[elem]->canBeLinked = state;
  130. }
  131. void DataManager::changeMoveAwayState(QString elem, int state)
  132. {
  133. elements[elem]->canMoveAway = state;
  134. }
  135. QString DataManager::getMarkValue(QString elem)
  136. {
  137. return elements[elem]->labelName;
  138. }
  139. QString DataManager::getPos(QString elem)
  140. {
  141. return elements[elem]->pos;
  142. }
  143. QString DataManager::getMaxLayer(QString elem)
  144. {
  145. return elements[elem]->maxLayer;
  146. }
  147. QString DataManager::getScore(QString elem)
  148. {
  149. return elements[elem]->score;
  150. }
  151. int DataManager::getDropConfig(QString elem)
  152. {
  153. return static_cast<int>(elements[elem]->dropConfig);
  154. }
  155. QString DataManager::getIconPath(QString elem)
  156. {
  157. return elements[elem]->iconPath;
  158. }
  159. bool DataManager::getMoveAwayState(QString elem)
  160. {
  161. return elements[elem]->canMoveAway;
  162. }
  163. bool DataManager::getLinkedState(QString elem)
  164. {
  165. return elements[elem]->canBeLinked;
  166. }
  167. //状态与效果动画
  168. QVector<ElemPropertyData::StatusEffect> DataManager::getAnimVec(QString elem)
  169. {
  170. return elements[elem]->statusEffect;
  171. }
  172. QStringList DataManager::getTimelineList(QString elem,QString filePath)
  173. {
  174. return elements[elem]->getTimelineList(filePath);
  175. }
  176. bool DataManager::existAnim(QString elem,QString animName)
  177. {
  178. if(elements[elem]->getAnimIndex(animName) == -1) return false;
  179. return true;
  180. }
  181. void DataManager::addAnim(QString elem, QString animName)
  182. {
  183. elements[elem]->statusEffect.push_back(ElemPropertyData::StatusEffect(animName));
  184. }
  185. void DataManager::delAnim(QString elem,int index)
  186. {
  187. elements[elem]->statusEffect.remove(index);
  188. }
  189. void DataManager::changeAnimTable(QString elem, QString newData, int row, int column)
  190. {
  191. if(column == 0) elements[elem]->statusEffect[row].name = newData;
  192. else if(column == 1) elements[elem]->statusEffect[row].res = newData;
  193. else if (column == 2) elements[elem]->statusEffect[row].timeline = newData;
  194. else if (column == 3) elements[elem]->statusEffect[row].zOrder = newData;
  195. }
  196. void DataManager::copyAnim(QString elem, QString animName, int copyIndex)
  197. {
  198. ElemPropertyData::StatusEffect anim(animName);
  199. ElemPropertyData::StatusEffect copyData = elements[elem]->statusEffect[copyIndex];
  200. anim.res = copyData.res;
  201. anim.timeline = copyData.timeline;
  202. anim.zOrder = copyData.zOrder;
  203. elements[elem]->statusEffect.push_back(anim);
  204. }
  205. //收集动画
  206. QString DataManager::getAnimType(QString elem, int index)
  207. {
  208. return elements[elem]->collAnim[index].type;
  209. }
  210. void DataManager::setAnimType(QString elem, QString newType, int index)
  211. {
  212. elements[elem]->collAnim[index].type = newType;
  213. elements[elem]->collAnim[index].dataMap.clear();
  214. }
  215. QMap<QString,QString> DataManager::getCollAnimDataMap(QString elem, int index)
  216. {
  217. return elements[elem]->collAnim[index].dataMap;
  218. }
  219. void DataManager::setCollAnimDataMapVal(QString elem, int index, QString key, QString val)
  220. {
  221. elements[elem]->collAnim[index].dataMap[key] = val;
  222. }
  223. bool DataManager::existCollAnim(QString elem, QString collAnimName)
  224. {
  225. if(elements[elem]->getCollAnimIndex(collAnimName) == -1) return false;
  226. return true;
  227. }
  228. void DataManager::addCollAnim(QString elem,QString collAnimName)
  229. {
  230. ElemPropertyData::CollAnim collAnim(collAnimName);
  231. elements[elem]->collAnim.push_back(collAnim);
  232. }
  233. void DataManager::delCollAnim(QString elem,int index)
  234. {
  235. elements[elem]->collAnim.remove(index);
  236. }
  237. void DataManager::changeCollAnimName(QString elem,int index,QString newName)
  238. {
  239. elements[elem]->collAnim[index].name = newName;
  240. }
  241. //状态配置
  242. ElemPropertyData::StatusConfig DataManager::getStatusConfigData(QString elem,int index)
  243. {
  244. return elements[elem]->statusConfig[index];
  245. }
  246. void DataManager::changeEventTable(QString elem,QString newData,int statusIndex,int row,int column)
  247. {
  248. QVector<ElemPropertyData::EventConfig> &eventTable = elements[elem]->statusConfig[statusIndex].eventConfig;
  249. if(column == 0) eventTable[row].name = newData;
  250. else if(column == 2) eventTable[row].changeMagnitude = newData.toInt();
  251. else if(column == 3) eventTable[row].specialEffect = newData;
  252. else if(column == 5) eventTable[row].triggerAction = newData;
  253. }
  254. void DataManager::changeActionConfigData(QString elem, int statusIndex, int row, QMap<QString, QString> data)
  255. {
  256. elements[elem]->statusConfig[statusIndex].eventConfig[row].actionConfig = data;
  257. }
  258. void DataManager::setEventTableCheckBox(QString elem, int statusIndex, int row, int column, int state)
  259. {
  260. QVector<ElemPropertyData::EventConfig> &eventTable = elements[elem]->statusConfig[statusIndex].eventConfig;
  261. if(column == 1) eventTable[row].consisColor = state;
  262. else if(column == 4) eventTable[row].elimATLattices = state;
  263. }
  264. void DataManager::setFundCheckBox(QString elem, int statusIndex, CheckType checkType, int state)
  265. {
  266. if(checkType == CheckType::Dropable) elements[elem]->statusConfig[statusIndex].dropable = state;
  267. else if(checkType == CheckType::MultiHit) elements[elem]->statusConfig[statusIndex].multiHit = state;
  268. else if(checkType == CheckType::NeedColl) elements[elem]->statusConfig[statusIndex].needCollect = state;
  269. }
  270. bool DataManager::existStatusVal(QString elem, QString statusVal)
  271. {
  272. if(elements[elem]->getStatusValIndex(statusVal) == -1) return false;
  273. return true;
  274. }
  275. void DataManager::addStatus(QString elem, QString statusVal)
  276. {
  277. ElemPropertyData::StatusConfig status(statusVal);
  278. if(elements[elem]->dropConfig == ElemPropertyData::DROPOPT::DROPABLE) status.dropable = true;
  279. if(elements[elem]->dropConfig == ElemPropertyData::DROPOPT::NOTDROPABLE) status.dropable = false;
  280. elements[elem]->statusConfig.push_back(status);
  281. }
  282. void DataManager::delStatus(QString elem, int index)
  283. {
  284. elements[elem]->statusConfig.remove(index);
  285. }
  286. void DataManager::changeStatusVal(QString elem, int index, QString newVal)
  287. {
  288. elements[elem]->statusConfig[index].statusValue = newVal;
  289. }
  290. void DataManager::changeStatusFundVal(QString elem, StatusDataType type, QString newData,int index)
  291. {
  292. if(type == StatusDataType::ClickAnim) elements[elem]->statusConfig[index].clickAnim = newData;
  293. else if(type == StatusDataType::InitAnim) elements[elem]->statusConfig[index].initAnim = newData;
  294. else if(type == StatusDataType::CollAnim) elements[elem]->statusConfig[index].collAnim = newData;
  295. else if(type == StatusDataType::CollTar) elements[elem]->statusConfig[index].collTargetType = newData;
  296. }
  297. void DataManager::addEvent(QString elem, int index)
  298. {
  299. ElemPropertyData::EventConfig event;
  300. elements[elem]->statusConfig[index].eventConfig.push_back(event);
  301. }
  302. void DataManager::delEvent(QString elem, int statusIndex, int row)
  303. {
  304. elements[elem]->statusConfig[statusIndex].eventConfig.remove(row);
  305. }
  306. void DataManager::updateAllDropState(QString elem, bool state)
  307. {
  308. int size = elements[elem]->statusConfig.size();
  309. for(int i=0;i<size;i++){
  310. elements[elem]->statusConfig[i].dropable = state;
  311. }
  312. }
  313. void DataManager::copyStatus(QString elem, QString statusVal, int copyIndex)
  314. {
  315. ElemPropertyData::StatusConfig status(statusVal);
  316. ElemPropertyData::StatusConfig copyData = elements[elem]->statusConfig[copyIndex];
  317. status.initAnim = copyData.initAnim;
  318. status.clickAnim = copyData.clickAnim;
  319. status.multiHit = copyData.multiHit;
  320. status.dropable = copyData.dropable;
  321. if(copyData.needCollect){
  322. status.needCollect = true;
  323. status.collTargetType = copyData.collTargetType;
  324. status.collAnim = copyData.collAnim;
  325. }
  326. status.eventConfig = copyData.eventConfig;
  327. elements[elem]->statusConfig.push_back(status);
  328. }
  329. //容器池
  330. ElemPropertyData::ContainerConfig DataManager::getContainData(QString elem,int index)
  331. {
  332. return elements[elem]->container[index];
  333. }
  334. void DataManager::changeContainTable(QString elem, int index, int row, int column, QString data)
  335. {
  336. QVector<ElemPropertyData::ContainTable> &table = elements[elem]->container[index].table;
  337. if(column == 0) table[row].key = data;
  338. else if(column == 1) table[row].res = data;
  339. else if(column == 2) table[row].initTimeline = data;
  340. else if(column == 3) table[row].clickTimeline = data;
  341. else if(column == 4) table[row].effectTimeline = data;
  342. else if(column == 5) table[row].vanishTimeline = data;
  343. else if(column == 6) table[row].zOrder = data;
  344. }
  345. bool DataManager::existPool(QString elem, QString poolName)
  346. {
  347. if(elements[elem]->getPoolIndex(poolName) == -1) return false;
  348. return true;
  349. }
  350. void DataManager::addPool(QString elem, QString poolName)
  351. {
  352. ElemPropertyData::ContainerConfig pool(poolName);
  353. elements[elem]->container.push_back(pool);
  354. }
  355. void DataManager::delPool(QString elem, int index)
  356. {
  357. elements[elem]->container.remove(index);
  358. }
  359. void DataManager::changePoolName(QString elem, int index, QString newName)
  360. {
  361. elements[elem]->container[index].poolName = newName;
  362. }
  363. bool DataManager::existKey(QString elem,int poolIndex,QString key)
  364. {
  365. if(elements[elem]->getKeyIndex(poolIndex,key) == -1) return false;
  366. return true;
  367. }
  368. void DataManager::addKey(QString elem, int poolIndex,QString keyName)
  369. {
  370. ElemPropertyData::ContainTable key(keyName);
  371. elements[elem]->container[poolIndex].table.push_back(key);
  372. }
  373. void DataManager::delKey(QString elem, int poolIndex, int row)
  374. {
  375. elements[elem]->container[poolIndex].table.remove(row);
  376. }
  377. void DataManager::changeContainType(QString elem, int poolIndex, QString poolType)
  378. {
  379. elements[elem]->container[poolIndex].type = poolType;
  380. }
  381. void DataManager::copyKey(QString elem, int poolIndex, QString keyName, int copyIndex)
  382. {
  383. ElemPropertyData::ContainTable copyData = elements[elem]->container[poolIndex].table[copyIndex];
  384. ElemPropertyData::ContainTable key(keyName);
  385. key.clickTimeline = copyData.clickTimeline;
  386. key.effectTimeline = copyData.effectTimeline;
  387. key.initTimeline = copyData.initTimeline;
  388. key.res = copyData.res;
  389. key.vanishTimeline = copyData.vanishTimeline;
  390. key.zOrder = copyData.zOrder;
  391. elements[elem]->container[poolIndex].table.push_back(key);
  392. }
  393. //子元素
  394. QVector<ElemPropertyData::ChildElem> DataManager::getChildElemTable(QString elem)
  395. {
  396. return elements[elem]->childElem;
  397. }
  398. void DataManager::changeChildElemTable(QString elem, int row, int column, QString data)
  399. {
  400. QVector<ElemPropertyData::ChildElem> &table = elements[elem]->childElem;
  401. if(column == 0) table[row].name = data;
  402. else if(column == 1) table[row].container = data;
  403. }
  404. bool DataManager::existChildElem(QString elem, QString childElemName)
  405. {
  406. if(elements[elem]->getChildElemIndex(childElemName) == -1) return false;
  407. return true;
  408. }
  409. void DataManager::addChildElem(QString elem, QString childElemName)
  410. {
  411. ElemPropertyData::ChildElem childElem(childElemName);
  412. elements[elem]->childElem.push_back(childElem);
  413. }
  414. void DataManager::delChildElem(QString elem, int index)
  415. {
  416. elements[elem]->childElem.remove(index);
  417. }
  418. //数据保存
  419. ///加载数据
  420. bool DataManager::loadData()
  421. {
  422. QFile loadFile(QDir::homePath() + "/Documents/RedInterstitialData/ElemsConf/data.json");
  423. if(!loadFile.open(QIODevice::ReadOnly)){
  424. qWarning("can't open data file!");
  425. return false;
  426. }
  427. QJsonDocument loadDoc(QJsonDocument::fromJson(loadFile.readAll()));
  428. read(loadDoc.object());
  429. loadFile.close();
  430. return true;
  431. }
  432. ///读数据
  433. void DataManager::read(const QJsonObject &json)
  434. {
  435. elements.clear();
  436. QStringList keys = json.keys();
  437. for(int i=0;i<keys.size();i++)
  438. {
  439. QString elem = keys[i];
  440. elements[elem] = new ElemPropertyData();
  441. elements[elem]->readData(json[elem].toObject());
  442. }
  443. }
  444. ///写数据
  445. void DataManager::write(QJsonObject &json) const
  446. {
  447. QStringList keys = elements.keys();
  448. for(int i=0;i<keys.size();i++)
  449. {
  450. QString elem = keys[i];
  451. QJsonObject obj;
  452. elements[elem]->writeData(obj);
  453. json.insert(elem,obj);
  454. }
  455. }
  456. ///保存数据
  457. bool DataManager::saveData()
  458. {
  459. QJsonObject dataObj;
  460. write(dataObj);
  461. //判断该路径是否存在,若不存在则创建
  462. QString path = QDir::homePath()+"/Documents/RedInterstitialData/ElemsConf";
  463. std::cout<<qPrintable(path)<<std::endl;
  464. QDir *dir = new QDir;
  465. if(!dir->exists(path)){
  466. bool ismkdir = dir->mkpath(path);
  467. if(!ismkdir){
  468. qDebug() << "create path fail" <<Qt::endl;
  469. return false;
  470. }
  471. }
  472. delete dir;
  473. QFile file(QDir::homePath() + "/Documents/RedInterstitialData/ElemsConf/data.json");
  474. if(!file.open(QIODevice::WriteOnly)){
  475. qDebug()<<"file open failed!";
  476. return false;
  477. }
  478. QJsonDocument jdoc;
  479. jdoc.setObject(dataObj);
  480. file.write(jdoc.toJson(QJsonDocument::Indented));
  481. file.close();
  482. return true;
  483. }
  484. //导出数据
  485. ///检查标识值是否重复
  486. bool DataManager::findElemLabelName(QString elem,QString labelName)
  487. {
  488. QStringList elems= elements.keys();
  489. for(int i=0;i<elems.size();i++)
  490. {
  491. if(elem!=elems[i] && labelName==elements[elems[i]]->labelName)
  492. return true;
  493. }
  494. return false;
  495. }
  496. ///数据导出合法性检查
  497. bool DataManager::exportIsValid()
  498. {
  499. QStringList elems= elements.keys();
  500. for(int i=0;i<elems.size();i++)
  501. {
  502. QString key = elems[i];
  503. ElemPropertyData* data = elements[key];
  504. QString elemMessage = "元素"+key+"导出错误!";
  505. //基础属性合法性检查
  506. if(data->labelName.toInt() <= 0){
  507. exportMessage = elemMessage+"\n标识值必须是大于0的数字!";
  508. return false;
  509. }
  510. if(findElemLabelName(key,data->labelName)){
  511. exportMessage = "元素标识值重复!";
  512. return false;
  513. }
  514. if(data->maxLayer.toInt() <= 0){
  515. exportMessage = elemMessage+"\n最大层数必须是大于0的数字!";
  516. return false;
  517. }
  518. if(data->score.toInt() <= 0){
  519. exportMessage = elemMessage+"\n分数必须是大于0的数字!";
  520. return false;
  521. }
  522. if(data->pos.isEmpty() || getGridPos(data->pos).isEmpty()){
  523. exportMessage = elemMessage+"\n位置数据不合法!";
  524. return false;
  525. }
  526. //状态与效果动画检查
  527. QVector<ElemPropertyData::StatusEffect> animVec = data->statusEffect;
  528. for(int j=0;j<animVec.size();j++)
  529. {
  530. if(animVec[j].res == "双击添加资源文件"){
  531. exportMessage = elemMessage+"\n动画"+animVec[j].name+"未添加资源文件!";
  532. return false;
  533. }
  534. if(animVec[j].timeline == "尚未选择"){
  535. exportMessage = elemMessage+"\n动画"+animVec[j].name+"未选择时间线!";
  536. return false;
  537. }
  538. }
  539. //收集动画
  540. QVector<ElemPropertyData::CollAnim> collAnimVec = data->collAnim;
  541. for(int j=0;j<collAnimVec.size();j++)
  542. {
  543. if(collAnimVec[j].type == "尚未选择"){
  544. exportMessage = elemMessage+"\n收集动画"+collAnimVec[j].name+"未选择动画类型";
  545. return false;
  546. }
  547. QMap<QString,QString> collMap = collAnimVec[j].dataMap;
  548. QStringList collMapKeys = collMap.keys();
  549. for(int k=0;k<collMapKeys.size();k++)
  550. {
  551. QString collMapKey = collMapKeys[k];
  552. //检查动态配置选项中有没有为空的单行输入或未选择的下拉选项
  553. if(collMap[collMapKey].isEmpty() || collMap[collMapKey] == "尚未选择"){
  554. exportMessage = elemMessage+"\n收集动画"+collAnimVec[j].name+collMapKey+"属性配置不完全";
  555. return false;
  556. }
  557. }
  558. }
  559. //状态配置
  560. QVector<ElemPropertyData::StatusConfig> statusVec = data->statusConfig;
  561. for(int j=0;j<statusVec.size();j++)
  562. {
  563. //基础属性
  564. if(statusVec[j].initAnim == "尚未选择"){
  565. exportMessage = elemMessage+"\n状态"+statusVec[j].statusValue+"未选择初始动画";
  566. return false;
  567. }
  568. if(statusVec[j].clickAnim == "尚未选择"){
  569. exportMessage = elemMessage+"\n状态"+statusVec[j].statusValue+"未选择点击动画";
  570. return false;
  571. }
  572. if(statusVec[j].needCollect){
  573. if(statusVec[j].collTargetType.isEmpty() || statusVec[j].collTargetType.toInt() <= 0){
  574. exportMessage = elemMessage+"\n状态"+statusVec[j].statusValue+"收集的目标类型必须是大于0的数字";
  575. return false;
  576. }
  577. }
  578. //事件配置
  579. QVector<ElemPropertyData::EventConfig> eventVec = statusVec[j].eventConfig;
  580. for(int k=0;k<eventVec.size();k++)
  581. {
  582. if(eventVec[k].name == "尚未选择"){
  583. exportMessage = elemMessage+"\n状态"+statusVec[j].statusValue+"事件配置未选择事件名称";
  584. return false;
  585. }
  586. if(eventVec[k].specialEffect == "尚未选择"){
  587. exportMessage = elemMessage+"\n状态"+statusVec[j].statusValue+"事件配置未选择特效";
  588. return false;
  589. }
  590. //触发动作暂不处理
  591. }
  592. }
  593. //容器池配置
  594. QVector<ElemPropertyData::ContainerConfig> poolVec = data->container;
  595. for(int j=0;j<poolVec.size();j++)
  596. {
  597. if(poolVec[j].type == "尚未选择"){
  598. exportMessage = elemMessage+"\n容器"+poolVec[j].poolName+"未选择类型";
  599. return false;
  600. }
  601. QVector<ElemPropertyData::ContainTable> table = poolVec[j].table;
  602. for(int k=0;k<table.size();k++)
  603. {
  604. if(table[k].res == "双击添加资源文件"){
  605. exportMessage = elemMessage+"\n容器"+poolVec[j].poolName+"键"+table[k].key+"未选择资源文件";
  606. return false;
  607. }
  608. if(table[k].initTimeline == "尚未选择" || table[k].clickTimeline == "尚未选择" || table[k].effectTimeline == "尚未选择" || table[k].vanishTimeline == "尚未选择"){
  609. exportMessage = elemMessage+"\n容器"+poolVec[j].poolName+"键"+table[k].key+"未选择时间线";
  610. return false;
  611. }
  612. }
  613. }
  614. //子元素配置
  615. QVector<ElemPropertyData::ChildElem> childElemVec = data->childElem;
  616. for(int j=0;j<childElemVec.size();j++)
  617. {
  618. if(childElemVec[j].container == "尚未选择"){
  619. exportMessage = elemMessage+"\n容器"+"子元素"+childElemVec[j].name+"使用的池子未选择";
  620. return false;
  621. }
  622. }
  623. }
  624. return true;
  625. }
  626. QString DataManager::getExportMessage()
  627. {
  628. return exportMessage;
  629. }
  630. ///将位置字符串拆分成多对坐标
  631. QVector<QVector<int>> DataManager::getGridPos(QString str)
  632. {
  633. //转换失败返回空数组
  634. QVector<QVector<int>> nullAns;
  635. QVector<QVector<int>> posNumPairs;
  636. //依据逗号分割
  637. QStringList posStrPairs = str.split(QLatin1Char(','));
  638. for(int i=0;i<posStrPairs.size();i++)
  639. {
  640. //依据:分割,若分割组数不为2说明输入不合法
  641. QStringList posStrPair = posStrPairs[i].split(QLatin1Char(':'));
  642. if(posStrPair.size()!=2) return nullAns;
  643. QVector<int> posNumPair;
  644. //检查第一个字符串是否为数字
  645. bool ok;
  646. int num1 = posStrPair[0].toInt(&ok);
  647. if(!ok) return nullAns;
  648. posNumPair.push_back(num1);
  649. //检查第二个字符串是否为数字
  650. int num2 = posStrPair[1].toInt(&ok);
  651. if(!ok) return nullAns;
  652. posNumPair.push_back(num2);
  653. posNumPairs.push_back(posNumPair);
  654. }
  655. return posNumPairs;
  656. }
  657. bool DataManager::exportData(QString fileName)
  658. {
  659. if(!exportIsValid()) return false;
  660. //导出为json
  661. QJsonObject dataObj;
  662. QStringList keys = elements.keys();
  663. for(int i=0;i<keys.size();i++)
  664. {
  665. QString elem = keys[i];
  666. QJsonObject obj;
  667. elements[elem]->exportData(obj);
  668. dataObj.insert(elements[elem]->labelName,obj);
  669. }
  670. QFile file(fileName);
  671. if(!file.open(QIODevice::WriteOnly)){
  672. qDebug()<<"file open failed!";
  673. return false;
  674. }
  675. QJsonObject elemObj;
  676. elemObj["elements"] = dataObj;
  677. QJsonDocument jdoc;
  678. jdoc.setObject(elemObj);
  679. file.write(jdoc.toJson(QJsonDocument::Indented));
  680. file.close();
  681. return true;
  682. }
  683. QString DataManager::getTempId(QString key, QString name)
  684. {
  685. int index = jsonTemp->getTemplateIndex(key,name);
  686. return jsonTemp->templateMap[key][index].id;
  687. }
  688. QString DataManager::getTempFieldId(QString key, QString name, QString fieldName)
  689. {
  690. int nameIndex = jsonTemp->getTemplateIndex(key,name);
  691. QVector<ReadJsonSrc::Fields> fields = jsonTemp->templateMap[key][nameIndex].fields;
  692. for(int i=0;i<fields.size();i++)
  693. {
  694. if(fields[i].name == fieldName)
  695. return fields[i].id;
  696. }
  697. QString str;
  698. return str;
  699. }