You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

script.js 18 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567
  1. var ms = null;
  2. var memberTeamObj = function(){
  3. return {id:0,level:0,awoken:0,plus:[0,0,0],latent:[]};
  4. }
  5. var memberAssistObj = function(){
  6. return {id:0,level:0,awoken:0,plus:[0,0,0]};
  7. }
  8. var teamObj = function(){
  9. return [
  10. [
  11. new memberTeamObj(),
  12. new memberTeamObj(),
  13. new memberTeamObj(),
  14. new memberTeamObj(),
  15. new memberTeamObj(),
  16. new memberTeamObj(),
  17. ],
  18. [
  19. new memberAssistObj(),
  20. new memberAssistObj(),
  21. new memberAssistObj(),
  22. new memberAssistObj(),
  23. new memberAssistObj(),
  24. new memberAssistObj(),
  25. ],
  26. ];
  27. }
  28. var formation = {
  29. title:"",
  30. detail:"",
  31. team:[
  32. new teamObj(),//队伍A
  33. new teamObj(),//队伍B
  34. ]
  35. };
  36. window.onload = function()
  37. {
  38. GM_xmlhttpRequest({
  39. method: "GET",
  40. url:"monsters-info/mon.json",
  41. onload: function(response) {
  42. ms = JSON.parse(response.response);
  43. initialize();//初始化
  44. try
  45. {
  46. var idataQer = getQueryString("data");
  47. if (idataQer)
  48. {
  49. var idata = JSON.parse(idataQer);
  50. formation = idata;
  51. refreshAll(formation);
  52. }
  53. }catch(e)
  54. {
  55. console.log("初始数据解码出错",e);
  56. }
  57. },
  58. onerror: function(response) {
  59. console.error("怪物数据获取错误",response);
  60. }
  61. });
  62. }
  63. window.onpopstate = function()
  64. { //前进后退时修改页面
  65. try
  66. {
  67. var idataQer = getQueryString("data");
  68. if (idataQer)
  69. {
  70. var idata = JSON.parse(idataQer);
  71. formation = idata;
  72. refreshAll(formation);
  73. }
  74. }catch(e)
  75. {
  76. console.log("初始数据解码出错",e);
  77. }
  78. }
  79. //创建新的分享地址
  80. function creatNewUrl(){
  81. if (!!(window.history && history.pushState)) {
  82. // 支持History API
  83. history.pushState(null, null, '?data=' + encodeURIComponent(JSON.stringify(formation)));
  84. }
  85. }
  86. //获取URL参数
  87. function getQueryString(name) {
  88. var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)", "i");
  89. var r = window.location.search.substr(1).match(reg);
  90. if (r != null) return decodeURIComponent(r[2]); return null;
  91. }
  92. //初始化
  93. function initialize()
  94. {
  95. var monstersList = document.querySelector("#monsters-list");
  96. ms.forEach(function(m){
  97. var opt = monstersList.appendChild(document.createElement("option"));
  98. opt.value = m.id;
  99. opt.label = m.id + " | " + m.name["ja"] + " | " + m.name["en"] + " | " + m.name["ko"];
  100. });
  101. //标题和介绍文本框
  102. var txtTitle = document.querySelector(".title-box .title");
  103. var txtDetail = document.querySelector(".detail-box .detail");
  104. txtTitle.onchange = function(){
  105. formation.title = this.value;
  106. creatNewUrl();
  107. }
  108. txtDetail.onchange = function(){
  109. formation.detail = this.value;
  110. creatNewUrl();
  111. }
  112. txtDetail.onblur = function(){
  113. this.style.height=this.scrollHeight+"px";
  114. }
  115. //队伍框
  116. var formationBox = document.querySelector(".formation-box");
  117. formationBox.formationBox = formation;
  118. //编辑框
  119. var editBox = document.querySelector(".edit-box");
  120. editBox.latent = []; //储存潜在觉醒
  121. editBox.assist = false; //储存是否为辅助宠物
  122. editBox.monsterBox = null;
  123. editBox.latentBox = null;
  124. editBox.memberIdx = []; //储存队伍数组下标
  125. editBox.show = function(){
  126. editBox.classList.remove("display-none");
  127. formationBox.classList.add("blur-bg");
  128. }
  129. editBox.hide = function(){
  130. editBox.classList.add("display-none");
  131. formationBox.classList.remove("blur-bg");
  132. }
  133. var settingBox = editBox.querySelector(".setting-box")
  134. //id搜索
  135. var monstersSearch = editBox.querySelector(".edit-box .m-id");
  136. monstersSearch.onchange = function(){
  137. if (/^\d+$/.test(this.value))
  138. {
  139. editBoxChangeMonId(parseInt(this.value));
  140. }
  141. }
  142. monstersSearch.oninput = monstersSearch.onchange;
  143. //觉醒
  144. var monEditAwokens = Array.prototype.slice.call(settingBox.querySelectorAll(".m-awoken-ul>.awoken-icon"));
  145. monEditAwokens.forEach(function(akDom,idx,domArr){
  146. akDom.onclick = function(){
  147. if (idx>0 && idx>=domArr.filter(function(d){return !d.classList.contains("display-none")}).length-1)
  148. domArr[0].innerHTML = "★";
  149. else
  150. domArr[0].innerHTML = idx;
  151. for(var ai=1;ai<domArr.length;ai++)
  152. {
  153. if(ai<=idx)
  154. {
  155. if(domArr[ai].classList.contains("unselected-awoken"))
  156. domArr[ai].classList.remove("unselected-awoken");
  157. }
  158. else
  159. {
  160. if(!domArr[ai].classList.contains("unselected-awoken"))
  161. domArr[ai].classList.add("unselected-awoken");
  162. }
  163. }
  164. }
  165. })
  166. //等级
  167. var monEditLv = settingBox.querySelector(".m-level");
  168. var monEditLvMax = settingBox.querySelector(".m-level-btn-max");
  169. monEditLvMax.onclick = function(){
  170. monEditLv.value = this.value;
  171. }
  172. //加蛋
  173. var monEditAddHp = settingBox.querySelector(".m-plus-hp");
  174. var monEditAddAtk = settingBox.querySelector(".m-plus-atk");
  175. var monEditAddRcv = settingBox.querySelector(".m-plus-rcv");
  176. var monEditAddHp99 = settingBox.querySelector(".m-plus-hp-btn-99");
  177. monEditAddHp99.onclick = function(){monEditAddHp.value = this.value}
  178. var monEditAddAtk99 = settingBox.querySelector(".m-plus-atk-btn-99");
  179. monEditAddAtk99.onclick = function(){monEditAddAtk.value = this.value}
  180. var monEditAddRcv99 = settingBox.querySelector(".m-plus-rcv-btn-99");
  181. monEditAddRcv99.onclick = function(){monEditAddRcv.value = this.value}
  182. var monEditAdd297 = settingBox.querySelector(".m-plus-btn-297");
  183. monEditAdd297.onclick = function(){monEditAddHp.value = monEditAddAtk.value = monEditAddRcv.value = 99}
  184. //潜觉
  185. var monEditLatentUl = settingBox.querySelector(".m-latent-ul");
  186. var monEditLatents = Array.prototype.slice.call(monEditLatentUl.querySelectorAll("li"));
  187. var monEditLatentAllowableUl = settingBox.querySelector(".m-latent-allowable-ul");
  188. var monEditLatentsAllowable = Array.prototype.slice.call(monEditLatentAllowableUl.querySelectorAll("li"));
  189. function refreshLatent(latent) //刷新潜觉
  190. {
  191. if (this.value<0) return;
  192. var usedHoleN = usedHole(latent);
  193. for (var ai=0;ai<6;ai++)
  194. {
  195. if (latent[ai])
  196. {
  197. monEditLatents[ai].className = "latent-icon latent-icon-" + latent[ai];
  198. monEditLatents[ai].value = ai;
  199. }
  200. else if(ai<(6-usedHoleN+latent.length))
  201. {
  202. monEditLatents[ai].className = "latent-icon";
  203. monEditLatents[ai].value = -1;
  204. }
  205. else
  206. {
  207. monEditLatents[ai].className = "display-none";
  208. monEditLatents[ai].value = -1;
  209. }
  210. }
  211. }
  212. editBox.refreshLatent = refreshLatent;
  213. //已有觉醒的去除
  214. monEditLatents.forEach(function(l){
  215. l.onclick = function(){
  216. var aIdx = parseInt(this.value);
  217. editBox.latent.splice(aIdx,1);
  218. refreshLatent(editBox.latent);
  219. }
  220. })
  221. //可选觉醒的添加
  222. monEditLatentsAllowable.forEach(function(la){
  223. la.onclick = function(){
  224. if (this.classList.contains("unselected-latent")) return;
  225. var lIdx = parseInt(this.value);
  226. var usedHoleN = usedHole(editBox.latent);
  227. if (lIdx >= 12 && usedHoleN<=4)
  228. editBox.latent.push(lIdx);
  229. else if (lIdx < 12 && usedHoleN<=5)
  230. editBox.latent.push(lIdx);
  231. refreshLatent(editBox.latent);
  232. }
  233. })
  234. var btnCancel = editBox.querySelector(".button-cancel");
  235. var btnDone = editBox.querySelector(".button-done");
  236. var btnNull = editBox.querySelector(".button-null");
  237. var btnDelay = editBox.querySelector(".button-delay");
  238. btnCancel.onclick = function(){
  239. btnDone.classList.remove("cant-assist");
  240. btnDone.disabled = false;
  241. editBox.memberIdx = [];
  242. editBox.hide();
  243. }
  244. btnDone.onclick = function(){
  245. if (parseInt(monEditLv.value) == 0)
  246. {
  247. btnNull.onclick();
  248. return;
  249. }
  250. var mD = formation.team[editBox.memberIdx[0]][editBox.memberIdx[1]][editBox.memberIdx[2]] = editBox.assist?new memberAssistObj():new memberTeamObj();
  251. mD.id = parseInt(monstersSearch.value);
  252. mD.level = parseInt(monEditLv.value);
  253. mD.awoken = monEditAwokens.filter(function(akDom){
  254. return !akDom.classList.contains("unselected-awoken") && !akDom.classList.contains("display-none")
  255. }).length - 1;
  256. mD.plus[0] = parseInt(monEditAddHp.value);
  257. mD.plus[1] = parseInt(monEditAddAtk.value);
  258. mD.plus[2] = parseInt(monEditAddRcv.value);
  259. if (!editBox.assist)
  260. {
  261. mD.latent = editBox.latent.concat();
  262. }
  263. changeid(mD,editBox.monsterBox,editBox.latentBox);
  264. creatNewUrl();
  265. editBox.hide();
  266. }
  267. btnNull.onclick = function(){
  268. var mD = formation.team[editBox.memberIdx[0]][editBox.memberIdx[1]][editBox.memberIdx[2]] = {id:0};
  269. changeid(mD,editBox.monsterBox,editBox.latentBox);
  270. creatNewUrl();
  271. editBox.hide();
  272. }
  273. btnDelay.onclick = function(){ //应对威吓
  274. var mD = formation.team[editBox.memberIdx[0]][editBox.memberIdx[1]][editBox.memberIdx[2]] = {id:-1};
  275. changeid(mD,editBox.monsterBox,editBox.latentBox);
  276. creatNewUrl();
  277. editBox.hide();
  278. }
  279. }
  280. function usedHole(latent) //计算用了多少潜觉格子
  281. {
  282. return latent.reduce(function(previous,current){
  283. return previous + (current>= 12?2:1);
  284. },0);
  285. }
  286. function changeid(mon,monDom,latentDom)
  287. {
  288. var md = ms[mon.id]; //怪物固定数据
  289. if (mon.id<0) //如果是延迟
  290. {
  291. monDom.parentNode.classList.add("delay");
  292. monDom.parentNode.classList.remove("null");
  293. return;
  294. }else if (mon.id==0) //如果是空
  295. {
  296. monDom.parentNode.classList.add("null");
  297. monDom.parentNode.classList.remove("delay");
  298. return;
  299. }else (mon.id>-1) //如果提供了id
  300. {
  301. monDom.parentNode.classList.remove("null");
  302. monDom.parentNode.classList.remove("delay");
  303. monDom.className = "monster";
  304. monDom.classList.add("pet-cards-" + Math.ceil(mon.id/100)); //添加图片编号
  305. var idxInPage = (mon.id-1) % 100; //获取当前页面的总序号
  306. monDom.classList.add("pet-cards-index-x-" + idxInPage % 10); //添加X方向序号
  307. monDom.classList.add("pet-cards-index-y-" + parseInt(idxInPage / 10)); //添加Y方向序号
  308. monDom.querySelector(".property").className = "property property-" + md.ppt[0]; //主属性
  309. monDom.querySelector(".subproperty").className = "subproperty subproperty-" + md.ppt[1]; //副属性
  310. monDom.title = "No." + mon.id + " " + md.name["ja"];
  311. monDom.href = "http://pad.skyozora.com/pets/" + mon.id;
  312. }
  313. if (mon.level>0) //如果提供了等级
  314. {
  315. var levelDom = monDom.querySelector(".level");
  316. levelDom.innerHTML = mon.level;
  317. if (mon.level == 99 || (mon.level >= md.maxLevel && md.maxLevel <=99))
  318. {
  319. levelDom.classList.add("max");
  320. }else
  321. {
  322. levelDom.classList.remove("max");
  323. }
  324. if (md.maxLevel>99 && mon.level>=99)
  325. levelDom.classList.add("_110");
  326. else
  327. levelDom.classList.remove("_110");
  328. }
  329. if (mon.awoken>-1) //如果提供了觉醒
  330. {
  331. var awokenIcon = monDom.querySelector(".awoken-count");
  332. if (mon.awoken == 0 || md.awoken.length < 1) //没觉醒
  333. {
  334. awokenIcon.classList.add("display-none");
  335. awokenIcon.innerHTML = "";
  336. }else
  337. {
  338. awokenIcon.classList.remove("display-none");
  339. if (mon.awoken < md.awoken.length) //觉醒没满直接写数字
  340. {
  341. awokenIcon.innerHTML = mon.awoken;
  342. awokenIcon.classList.remove("allowable-assist");
  343. }else //满觉醒打星星
  344. {
  345. awokenIcon.innerHTML = "★";
  346. if (md.assist)
  347. awokenIcon.classList.add("allowable-assist");
  348. else
  349. awokenIcon.classList.remove("allowable-assist");
  350. }
  351. }
  352. }
  353. if (mon.plus) //如果提供了加值
  354. {
  355. monDom.querySelector(".plus .hp").innerHTML = mon.plus[0];
  356. monDom.querySelector(".plus .atk").innerHTML = mon.plus[1];
  357. monDom.querySelector(".plus .rcv").innerHTML = mon.plus[2];
  358. if (mon.plus[0]+mon.plus[1]+mon.plus[2] >= 297)
  359. {
  360. monDom.querySelector(".plus").classList.add("has297");
  361. }else
  362. {
  363. monDom.querySelector(".plus").classList.remove("has297");
  364. }
  365. }
  366. if (latentDom && mon.latent) //如果提供了潜觉
  367. {
  368. var latent = mon.latent.sort(function(a,b){return b-a;});
  369. if (latent.length < 1)
  370. latentDom.classList.add("display-none");
  371. else
  372. latentDom.classList.remove("display-none");
  373. var latentDoms = Array.prototype.slice.call(latentDom.querySelectorAll("li"));
  374. var usedHoleN = usedHole(latent);
  375. for (var ai=0;ai<6;ai++)
  376. {
  377. if (latent[ai])
  378. {
  379. latentDoms[ai].className = "latent-icon latent-icon-" + latent[ai];
  380. }
  381. else if(ai<(6-usedHoleN+latent.length))
  382. {
  383. latentDoms[ai].className = "latent-icon";
  384. }
  385. else
  386. {
  387. latentDoms[ai].className = "display-none";
  388. }
  389. }
  390. }
  391. }
  392. //点击怪物头像,出现编辑框
  393. function editMon(AorB,isAssist,tempIdx)
  394. {
  395. //数据
  396. var mD = formation.team[AorB][isAssist][tempIdx];
  397. //对应的Dom
  398. var formationBox = AorB?document.querySelector(".formation-box .formation-B-box"):document.querySelector(".formation-box .formation-A-box");
  399. var teamBox = isAssist?formationBox.querySelector(".formation-assist"):formationBox.querySelector(".formation-team");
  400. var memberBox = teamBox.querySelector(".member-" + (tempIdx+1));
  401. var editBox = document.querySelector(".edit-box");
  402. var monsterBox = memberBox.querySelector(".monster");
  403. editBox.show();
  404. editBox.assist = isAssist;
  405. editBox.monsterBox = monsterBox;
  406. editBox.memberIdx = [AorB,isAssist,tempIdx]; //储存队伍数组下标
  407. editBox.assist = isAssist;
  408. if (!isAssist)
  409. {
  410. var latentBox = formationBox.querySelector(".formation-latents .latents-"+(tempIdx+1)+" .latent-ul");
  411. editBox.latentBox = latentBox;
  412. }
  413. var monstersSearch = editBox.querySelector(".search-box .m-id");
  414. monstersSearch.value = mD.id>0?mD.id:0;
  415. monstersSearch.onchange();
  416. var settingBox = editBox.querySelector(".setting-box");
  417. var monEditAwokens = settingBox.querySelectorAll(".m-awoken-ul .awoken-icon");
  418. if (mD.awoken>0) monEditAwokens[mD.awoken].onclick();
  419. var monEditLv = settingBox.querySelector(".m-level");
  420. monEditLv.value = mD.level || 1;
  421. var monEditAddHp = settingBox.querySelector(".m-plus-hp");
  422. var monEditAddAtk = settingBox.querySelector(".m-plus-atk");
  423. var monEditAddRcv = settingBox.querySelector(".m-plus-rcv");
  424. if (mD.plus)
  425. {
  426. monEditAddHp.value = mD.plus[0];
  427. monEditAddAtk.value = mD.plus[1];
  428. monEditAddRcv.value = mD.plus[2];
  429. }
  430. var btnDelay = editBox.querySelector(".button-delay");
  431. if (!isAssist)
  432. {
  433. editBox.latent = mD.latent || [];
  434. editBox.refreshLatent(editBox.latent);
  435. btnDelay.classList.add("display-none");
  436. settingBox.querySelector(".row-mon-latent").classList.remove("display-none");
  437. editBox.querySelector(".edit-box-title").classList.remove("edit-box-title-assist");
  438. }else
  439. {
  440. btnDelay.classList.remove("display-none");
  441. settingBox.querySelector(".row-mon-latent").classList.add("display-none");
  442. editBox.querySelector(".edit-box-title").classList.add("edit-box-title-assist");
  443. }
  444. }
  445. function editBoxChangeMonId(id)
  446. {
  447. var md = ms[id]; //怪物固定数据
  448. if (!md){
  449. id = 0;
  450. md = ms[0]
  451. }
  452. var editBox = document.querySelector(".edit-box");
  453. var monInfoBox = editBox.querySelector(".monsterinfo-box");
  454. var me = monInfoBox.querySelector(".monster");
  455. changeid({id:id,},me); //改变图像
  456. var mId = monInfoBox.querySelector(".monster-id");
  457. mId.innerHTML = id;
  458. var mRare = monInfoBox.querySelector(".monster-rare");
  459. mRare.className = "monster-rare rare-" + md.rare;
  460. var mName = monInfoBox.querySelector(".monster-name");
  461. mName.innerHTML = md.name["ja"];
  462. var mType = monInfoBox.querySelectorAll(".monster-type li");
  463. for (var ti=0;ti<mType.length;ti++)
  464. {
  465. if (md.type[ti]>=0)
  466. {
  467. mType[ti].className = "type-name type-name-" + md.type[ti];
  468. mType[ti].firstChild.className = "type-icon type-icon-" + md.type[ti];
  469. }else
  470. {
  471. mType[ti].className = "display-none";
  472. }
  473. }
  474. var settingBox = editBox.querySelector(".setting-box");
  475. var mAwoken = settingBox.querySelectorAll(".m-awoken-ul li");
  476. mAwoken[0].innerHTML = md.awoken.length?"★":"0";
  477. for (var ai=1;ai<mAwoken.length;ai++)
  478. {
  479. if (md.awoken[ai-1])
  480. {
  481. mAwoken[ai].className = "awoken-icon awoken-" + md.awoken[ai-1];
  482. }else
  483. {
  484. mAwoken[ai].className = "display-none";
  485. }
  486. }
  487. var monEditLvMax = settingBox.querySelector(".m-level-btn-max");
  488. monEditLvMax.innerHTML = monEditLvMax.value = md.maxLevel;
  489. var monEditLv = settingBox.querySelector(".m-level");
  490. monEditLv.value = md.maxLevel>99?99:md.maxLevel;
  491. var monLatentAllowUl = settingBox.querySelector(".m-latent-allowable-ul");
  492. //该宠Type允许的杀
  493. var allowLatent = uniq(md.type.reduce(function (previous, t, index, array) {
  494. return previous.concat(type_allowable_latent[t]);
  495. },[]));
  496. for(var li=17;li<=24;li++)
  497. {
  498. var latentDom = monLatentAllowUl.querySelector(".latent-icon-" + li);
  499. if (allowLatent.indexOf(li)>=0)
  500. {
  501. if(latentDom.classList.contains("unselected-latent"))
  502. latentDom.classList.remove("unselected-latent");
  503. }else
  504. {
  505. if(!latentDom.classList.contains("unselected-latent"))
  506. latentDom.classList.add("unselected-latent");
  507. }
  508. }
  509. if (editBox.assist)
  510. {
  511. var btnDone = editBox.querySelector(".button-done");
  512. if (!md.assist)
  513. {
  514. btnDone.classList.add("cant-assist");
  515. btnDone.disabled = true;
  516. }else
  517. {
  518. btnDone.classList.remove("cant-assist");
  519. btnDone.disabled = false;
  520. }
  521. }
  522. editBox.latent.length = 0;
  523. editBox.refreshLatent(editBox.latent);
  524. }
  525. function refreshAll(fmt){
  526. var txtTitle = document.querySelector(".title-box .title");
  527. var txtDetail = document.querySelector(".detail-box .detail");
  528. txtTitle.value = fmt.title || "";
  529. txtDetail.value = fmt.detail || "";
  530. txtDetail.onblur();
  531. var formationA = document.querySelector(".formation-box .formation-A-box");
  532. var formationB = document.querySelector(".formation-box .formation-B-box");
  533. var fATeam = formationA.querySelectorAll(".formation-team .monster");
  534. var fALatents = formationA.querySelectorAll(".formation-latents .latent-ul");
  535. var fAAssist = formationA.querySelectorAll(".formation-assist .monster");
  536. var fBTeam = formationB.querySelectorAll(".formation-team .monster");
  537. var fBLatents = formationB.querySelectorAll(".formation-latents .latent-ul");
  538. var fBAssist = formationB.querySelectorAll(".formation-assist .monster");
  539. for (var ti=0;ti<5;ti++)
  540. {
  541. changeid(fmt.team[0][0][ti],fATeam[ti],fALatents[ti]);
  542. changeid(fmt.team[0][1][ti],fAAssist[ti]);
  543. changeid(fmt.team[1][0][ti],fBTeam[ti],fBLatents[ti]);
  544. changeid(fmt.team[1][1][ti],fBAssist[ti]);
  545. }
  546. }

智龙迷城队伍图制作工具

Contributors (1)