dataManager.cpp 23 KB

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