dataManager.cpp 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744
  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. //TODO: 删除状态值时出现数组越界
  283. void DataManager::delStatus(QString elem, int index)
  284. {
  285. std::cout<<"current index:"<<index<<std::endl;
  286. std::cout<<"statusConfig size:"<<elements[elem]->statusConfig.size()<<std::endl;
  287. std::cout<<qPrintable(elements[elem]->statusConfig[index].statusValue)<<std::endl;
  288. elements[elem]->statusConfig.remove(index);
  289. }
  290. void DataManager::changeStatusVal(QString elem, int index, QString newVal)
  291. {
  292. elements[elem]->statusConfig[index].statusValue = newVal;
  293. }
  294. void DataManager::changeStatusFundVal(QString elem, StatusDataType type, QString newData,int index)
  295. {
  296. if(type == StatusDataType::ClickAnim) elements[elem]->statusConfig[index].clickAnim = newData;
  297. else if(type == StatusDataType::InitAnim) elements[elem]->statusConfig[index].initAnim = newData;
  298. else if(type == StatusDataType::CollAnim) elements[elem]->statusConfig[index].collAnim = newData;
  299. else if(type == StatusDataType::CollTar) elements[elem]->statusConfig[index].collTargetType = newData;
  300. }
  301. void DataManager::addEvent(QString elem, int index)
  302. {
  303. ElemPropertyData::EventConfig event;
  304. elements[elem]->statusConfig[index].eventConfig.push_back(event);
  305. }
  306. void DataManager::delEvent(QString elem, int statusIndex, int row)
  307. {
  308. elements[elem]->statusConfig[statusIndex].eventConfig.remove(row);
  309. }
  310. void DataManager::updateAllDropState(QString elem, bool state)
  311. {
  312. int size = elements[elem]->statusConfig.size();
  313. for(int i=0;i<size;i++){
  314. elements[elem]->statusConfig[i].dropable = state;
  315. }
  316. }
  317. void DataManager::copyStatus(QString elem, QString statusVal, int copyIndex)
  318. {
  319. ElemPropertyData::StatusConfig status(statusVal);
  320. ElemPropertyData::StatusConfig copyData = elements[elem]->statusConfig[copyIndex];
  321. status.initAnim = copyData.initAnim;
  322. status.clickAnim = copyData.clickAnim;
  323. status.multiHit = copyData.multiHit;
  324. status.dropable = copyData.dropable;
  325. if(copyData.needCollect){
  326. status.needCollect = true;
  327. status.collTargetType = copyData.collTargetType;
  328. status.collAnim = copyData.collAnim;
  329. }
  330. status.eventConfig = copyData.eventConfig;
  331. elements[elem]->statusConfig.push_back(status);
  332. }
  333. //容器池
  334. ElemPropertyData::ContainerConfig DataManager::getContainData(QString elem,int index)
  335. {
  336. return elements[elem]->container[index];
  337. }
  338. void DataManager::changeContainTable(QString elem, int index, int row, int column, QString data)
  339. {
  340. QVector<ElemPropertyData::ContainTable> &table = elements[elem]->container[index].table;
  341. if(column == 0) table[row].key = data;
  342. else if(column == 1) table[row].res = data;
  343. else if(column == 2) table[row].initTimeline = data;
  344. else if(column == 3) table[row].clickTimeline = data;
  345. else if(column == 4) table[row].effectTimeline = data;
  346. else if(column == 5) table[row].vanishTimeline = data;
  347. else if(column == 6) table[row].zOrder = data;
  348. }
  349. bool DataManager::existPool(QString elem, QString poolName)
  350. {
  351. if(elements[elem]->getPoolIndex(poolName) == -1) return false;
  352. return true;
  353. }
  354. void DataManager::addPool(QString elem, QString poolName)
  355. {
  356. ElemPropertyData::ContainerConfig pool(poolName);
  357. elements[elem]->container.push_back(pool);
  358. }
  359. void DataManager::delPool(QString elem, int index)
  360. {
  361. std::cout<<"current pool index:"<<index<<std::endl;
  362. std::cout<<"pool size:"<<elements[elem]->container.size()<<std::endl;
  363. std::cout<<qPrintable(elements[elem]->container[index].poolName)<<std::endl;
  364. elements[elem]->container.remove(index);
  365. }
  366. void DataManager::changePoolName(QString elem, int index, QString newName)
  367. {
  368. elements[elem]->container[index].poolName = newName;
  369. }
  370. bool DataManager::existKey(QString elem,int poolIndex,QString key)
  371. {
  372. if(elements[elem]->getKeyIndex(poolIndex,key) == -1) return false;
  373. return true;
  374. }
  375. void DataManager::addKey(QString elem, int poolIndex,QString keyName)
  376. {
  377. ElemPropertyData::ContainTable key(keyName);
  378. elements[elem]->container[poolIndex].table.push_back(key);
  379. }
  380. void DataManager::delKey(QString elem, int poolIndex, int row)
  381. {
  382. elements[elem]->container[poolIndex].table.remove(row);
  383. }
  384. void DataManager::changeContainType(QString elem, int poolIndex, QString poolType)
  385. {
  386. elements[elem]->container[poolIndex].type = poolType;
  387. }
  388. void DataManager::copyKey(QString elem, int poolIndex, QString keyName, int copyIndex)
  389. {
  390. ElemPropertyData::ContainTable copyData = elements[elem]->container[poolIndex].table[copyIndex];
  391. ElemPropertyData::ContainTable key(keyName);
  392. key.clickTimeline = copyData.clickTimeline;
  393. key.effectTimeline = copyData.effectTimeline;
  394. key.initTimeline = copyData.initTimeline;
  395. key.res = copyData.res;
  396. key.vanishTimeline = copyData.vanishTimeline;
  397. key.zOrder = copyData.zOrder;
  398. elements[elem]->container[poolIndex].table.push_back(key);
  399. }
  400. //子元素
  401. QVector<ElemPropertyData::ChildElem> DataManager::getChildElemTable(QString elem)
  402. {
  403. return elements[elem]->childElem;
  404. }
  405. void DataManager::changeChildElemTable(QString elem, int row, int column, QString data)
  406. {
  407. QVector<ElemPropertyData::ChildElem> &table = elements[elem]->childElem;
  408. if(column == 0) table[row].name = data;
  409. else if(column == 1) table[row].container = data;
  410. }
  411. bool DataManager::existChildElem(QString elem, QString childElemName)
  412. {
  413. if(elements[elem]->getChildElemIndex(childElemName) == -1) return false;
  414. return true;
  415. }
  416. void DataManager::addChildElem(QString elem, QString childElemName)
  417. {
  418. ElemPropertyData::ChildElem childElem(childElemName);
  419. elements[elem]->childElem.push_back(childElem);
  420. }
  421. void DataManager::delChildElem(QString elem, int index)
  422. {
  423. elements[elem]->childElem.remove(index);
  424. }
  425. //数据保存
  426. ///加载数据
  427. bool DataManager::loadData()
  428. {
  429. QFile loadFile(QDir::homePath() + "/Documents/RedInterstitialData/ElemsConf/data.json");
  430. if(!loadFile.open(QIODevice::ReadOnly)){
  431. qWarning("can't open data file!");
  432. return false;
  433. }
  434. QJsonDocument loadDoc(QJsonDocument::fromJson(loadFile.readAll()));
  435. read(loadDoc.object());
  436. loadFile.close();
  437. return true;
  438. }
  439. ///读数据
  440. void DataManager::read(const QJsonObject &json)
  441. {
  442. elements.clear();
  443. QStringList keys = json.keys();
  444. for(int i=0;i<keys.size();i++)
  445. {
  446. QString elem = keys[i];
  447. elements[elem] = new ElemPropertyData();
  448. elements[elem]->readData(json[elem].toObject());
  449. }
  450. }
  451. ///写数据
  452. void DataManager::write(QJsonObject &json) const
  453. {
  454. QStringList keys = elements.keys();
  455. for(int i=0;i<keys.size();i++)
  456. {
  457. QString elem = keys[i];
  458. QJsonObject obj;
  459. elements[elem]->writeData(obj);
  460. json.insert(elem,obj);
  461. }
  462. }
  463. ///保存数据
  464. bool DataManager::saveData()
  465. {
  466. QJsonObject dataObj;
  467. write(dataObj);
  468. //判断该路径是否存在,若不存在则创建
  469. QString path = QDir::homePath()+"/Documents/RedInterstitialData/ElemsConf";
  470. std::cout<<qPrintable(path)<<std::endl;
  471. QDir *dir = new QDir;
  472. if(!dir->exists(path)){
  473. bool ismkdir = dir->mkpath(path);
  474. if(!ismkdir){
  475. qDebug() << "create path fail" <<Qt::endl;
  476. return false;
  477. }
  478. }
  479. delete dir;
  480. QFile file(QDir::homePath() + "/Documents/RedInterstitialData/ElemsConf/data.json");
  481. if(!file.open(QIODevice::WriteOnly)){
  482. qDebug()<<"file open failed!";
  483. return false;
  484. }
  485. QJsonDocument jdoc;
  486. jdoc.setObject(dataObj);
  487. file.write(jdoc.toJson(QJsonDocument::Indented));
  488. file.close();
  489. return true;
  490. }
  491. //导出数据
  492. ///检查标识值是否重复
  493. bool DataManager::findElemLabelName(QString elem,QString labelName)
  494. {
  495. QStringList elems= elements.keys();
  496. for(int i=0;i<elems.size();i++)
  497. {
  498. if(elem!=elems[i] && labelName==elements[elems[i]]->labelName)
  499. return true;
  500. }
  501. return false;
  502. }
  503. ///数据导出合法性检查
  504. bool DataManager::exportIsValid()
  505. {
  506. QStringList elems= elements.keys();
  507. for(int i=0;i<elems.size();i++)
  508. {
  509. QString key = elems[i];
  510. ElemPropertyData* data = elements[key];
  511. QString elemMessage = "元素"+key+"导出错误!";
  512. //基础属性合法性检查
  513. if(data->labelName.toInt() <= 0){
  514. exportMessage = elemMessage+"\n标识值必须是大于0的数字!";
  515. return false;
  516. }
  517. if(findElemLabelName(key,data->labelName)){
  518. exportMessage = "元素标识值重复!";
  519. return false;
  520. }
  521. if(data->maxLayer.toInt() <= 0){
  522. exportMessage = elemMessage+"\n最大层数必须是大于0的数字!";
  523. return false;
  524. }
  525. if(data->score.toInt() <= 0){
  526. exportMessage = elemMessage+"\n分数必须是大于0的数字!";
  527. return false;
  528. }
  529. if(data->pos.isEmpty() || getGridPos(data->pos).isEmpty()){
  530. exportMessage = elemMessage+"\n位置数据不合法!";
  531. return false;
  532. }
  533. //状态与效果动画检查
  534. QVector<ElemPropertyData::StatusEffect> animVec = data->statusEffect;
  535. for(int j=0;j<animVec.size();j++)
  536. {
  537. if(animVec[j].res == "双击添加资源文件"){
  538. exportMessage = elemMessage+"\n动画"+animVec[j].name+"未添加资源文件!";
  539. return false;
  540. }
  541. if(animVec[j].timeline == "尚未选择"){
  542. exportMessage = elemMessage+"\n动画"+animVec[j].name+"未选择时间线!";
  543. return false;
  544. }
  545. }
  546. //收集动画
  547. QVector<ElemPropertyData::CollAnim> collAnimVec = data->collAnim;
  548. for(int j=0;j<collAnimVec.size();j++)
  549. {
  550. if(collAnimVec[j].type == "尚未选择"){
  551. exportMessage = elemMessage+"\n收集动画"+collAnimVec[j].name+"未选择动画类型";
  552. return false;
  553. }
  554. QMap<QString,QString> collMap = collAnimVec[j].dataMap;
  555. QStringList collMapKeys = collMap.keys();
  556. for(int k=0;k<collMapKeys.size();k++)
  557. {
  558. QString collMapKey = collMapKeys[k];
  559. //检查动态配置选项中有没有为空的单行输入或未选择的下拉选项
  560. if(collMap[collMapKey].isEmpty() || collMap[collMapKey] == "尚未选择"){
  561. exportMessage = elemMessage+"\n收集动画"+collAnimVec[j].name+collMapKey+"属性配置不完全";
  562. return false;
  563. }
  564. }
  565. }
  566. //状态配置
  567. QVector<ElemPropertyData::StatusConfig> statusVec = data->statusConfig;
  568. for(int j=0;j<statusVec.size();j++)
  569. {
  570. //基础属性
  571. if(statusVec[j].initAnim == "尚未选择"){
  572. exportMessage = elemMessage+"\n状态"+statusVec[j].statusValue+"未选择初始动画";
  573. return false;
  574. }
  575. if(statusVec[j].clickAnim == "尚未选择"){
  576. exportMessage = elemMessage+"\n状态"+statusVec[j].statusValue+"未选择点击动画";
  577. return false;
  578. }
  579. if(statusVec[j].needCollect){
  580. if(statusVec[j].collTargetType.isEmpty() || statusVec[j].collTargetType.toInt() <= 0){
  581. exportMessage = elemMessage+"\n状态"+statusVec[j].statusValue+"收集的目标类型必须是大于0的数字";
  582. return false;
  583. }
  584. }
  585. //事件配置
  586. QVector<ElemPropertyData::EventConfig> eventVec = statusVec[j].eventConfig;
  587. for(int k=0;k<eventVec.size();k++)
  588. {
  589. if(eventVec[k].name == "尚未选择"){
  590. exportMessage = elemMessage+"\n状态"+statusVec[j].statusValue+"事件配置未选择事件名称";
  591. return false;
  592. }
  593. if(eventVec[k].specialEffect == "尚未选择"){
  594. exportMessage = elemMessage+"\n状态"+statusVec[j].statusValue+"事件配置未选择特效";
  595. return false;
  596. }
  597. //触发动作暂不处理
  598. }
  599. }
  600. //容器池配置
  601. QVector<ElemPropertyData::ContainerConfig> poolVec = data->container;
  602. for(int j=0;j<poolVec.size();j++)
  603. {
  604. if(poolVec[j].type == "尚未选择"){
  605. exportMessage = elemMessage+"\n容器"+poolVec[j].poolName+"未选择类型";
  606. return false;
  607. }
  608. QVector<ElemPropertyData::ContainTable> table = poolVec[j].table;
  609. for(int k=0;k<table.size();k++)
  610. {
  611. if(table[k].res == "双击添加资源文件"){
  612. exportMessage = elemMessage+"\n容器"+poolVec[j].poolName+"键"+table[k].key+"未选择资源文件";
  613. return false;
  614. }
  615. if(table[k].initTimeline == "尚未选择" || table[k].clickTimeline == "尚未选择" || table[k].effectTimeline == "尚未选择" || table[k].vanishTimeline == "尚未选择"){
  616. exportMessage = elemMessage+"\n容器"+poolVec[j].poolName+"键"+table[k].key+"未选择时间线";
  617. return false;
  618. }
  619. }
  620. }
  621. //子元素配置
  622. QVector<ElemPropertyData::ChildElem> childElemVec = data->childElem;
  623. for(int j=0;j<childElemVec.size();j++)
  624. {
  625. if(childElemVec[j].container == "尚未选择"){
  626. exportMessage = elemMessage+"\n容器"+poolVec[j].poolName+"子元素"+childElemVec[j].name+"使用的池子未选择";
  627. return false;
  628. }
  629. }
  630. }
  631. return true;
  632. }
  633. QString DataManager::getExportMessage()
  634. {
  635. return exportMessage;
  636. }
  637. ///将位置字符串拆分成多对坐标
  638. QVector<QVector<int>> DataManager::getGridPos(QString str)
  639. {
  640. //转换失败返回空数组
  641. QVector<QVector<int>> nullAns;
  642. QVector<QVector<int>> posNumPairs;
  643. //依据逗号分割
  644. QStringList posStrPairs = str.split(QLatin1Char(','));
  645. for(int i=0;i<posStrPairs.size();i++)
  646. {
  647. //依据:分割,若分割组数不为2说明输入不合法
  648. QStringList posStrPair = posStrPairs[i].split(QLatin1Char(':'));
  649. if(posStrPair.size()!=2) return nullAns;
  650. QVector<int> posNumPair;
  651. //检查第一个字符串是否为数字
  652. bool ok;
  653. int num1 = posStrPair[0].toInt(&ok);
  654. if(!ok) return nullAns;
  655. posNumPair.push_back(num1);
  656. //检查第二个字符串是否为数字
  657. int num2 = posStrPair[1].toInt(&ok);
  658. if(!ok) return nullAns;
  659. posNumPair.push_back(num2);
  660. posNumPairs.push_back(posNumPair);
  661. }
  662. return posNumPairs;
  663. }
  664. bool DataManager::exportData(QString fileName)
  665. {
  666. if(!exportIsValid()) return false;
  667. //导出为json
  668. QJsonObject dataObj;
  669. QStringList keys = elements.keys();
  670. for(int i=0;i<keys.size();i++)
  671. {
  672. QString elem = keys[i];
  673. QJsonObject obj;
  674. elements[elem]->exportData(obj);
  675. dataObj.insert(elements[elem]->labelName,obj);
  676. }
  677. QFile file(fileName);
  678. if(!file.open(QIODevice::WriteOnly)){
  679. qDebug()<<"file open failed!";
  680. return false;
  681. }
  682. QJsonObject elemObj;
  683. elemObj["elements"] = dataObj;
  684. QJsonDocument jdoc;
  685. jdoc.setObject(elemObj);
  686. file.write(jdoc.toJson(QJsonDocument::Indented));
  687. file.close();
  688. return true;
  689. }
  690. QString DataManager::getTempId(QString key, QString name)
  691. {
  692. int index = jsonTemp->getTemplateIndex(key,name);
  693. return jsonTemp->templateMap[key][index].id;
  694. }
  695. QString DataManager::getTempFieldId(QString key, QString name, QString fieldName)
  696. {
  697. int nameIndex = jsonTemp->getTemplateIndex(key,name);
  698. QVector<ReadJsonSrc::Fields> fields = jsonTemp->templateMap[key][nameIndex].fields;
  699. for(int i=0;i<fields.size();i++)
  700. {
  701. if(fields[i].name == fieldName)
  702. return fields[i].id;
  703. }
  704. QString str;
  705. return str;
  706. }