dataManager.cpp 25 KB

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