dataManager.cpp 25 KB

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