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 9.9 kB

7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308
  1. var ms = null;
  2. window.onload = function()
  3. {
  4. GM_xmlhttpRequest({
  5. method: "GET",
  6. url:"monsters-info/mon.json",
  7. onload: function(response) {
  8. ms = JSON.parse(response.response);
  9. initialize();//初始化
  10. test(); //测试代码
  11. },
  12. onerror: function(response) {
  13. console.error("怪物数据获取错误",response);
  14. }
  15. });
  16. }
  17. //初始化
  18. function initialize()
  19. {
  20. var monstersList = document.querySelector("#monsters-list");
  21. ms.forEach(function(m){
  22. var opt = monstersList.appendChild(document.createElement("option"));
  23. opt.value = m.id;
  24. opt.label = m.id + " | " + m.name + " | " + m.ename;
  25. });
  26. //编辑框
  27. var editBox = document.querySelector(".edit-box");
  28. var settingBox = editBox.querySelector(".setting-box")
  29. //id搜索
  30. var monstersSearch = editBox.querySelector(".edit-box .m-id");
  31. monstersSearch.onchange = function(){
  32. if (/^\d+$/.test(this.value))
  33. {
  34. editChangeMonId(parseInt(this.value));
  35. }
  36. }
  37. monstersSearch.oninput = monstersSearch.onchange;
  38. //觉醒
  39. var monEditAwokens = Array.prototype.slice.call(settingBox.querySelectorAll(".m-awoken-ul>.awoken-icon"));
  40. monEditAwokens.forEach(function(akDom,idx,domArr){
  41. akDom.onclick = function(){
  42. if (idx >= domArr.filter(function(d){return !d.classList.contains("display-none")}).length-1)
  43. domArr[0].innerHTML = "★";
  44. else
  45. domArr[0].innerHTML = idx;
  46. for(var ai=1;ai<domArr.length;ai++)
  47. {
  48. if(ai<=idx)
  49. {
  50. if(domArr[ai].classList.contains("unselected-awoken"))
  51. domArr[ai].classList.remove("unselected-awoken");
  52. }
  53. else
  54. {
  55. if(!domArr[ai].classList.contains("unselected-awoken"))
  56. domArr[ai].classList.add("unselected-awoken");
  57. }
  58. }
  59. }
  60. })
  61. //等级
  62. var monEditLv = settingBox.querySelector(".m-level");
  63. var monEditLvMax = settingBox.querySelector(".m-level-btn-max");
  64. monEditLvMax.onclick = function(){
  65. monEditLv.value = this.value;
  66. }
  67. //加蛋
  68. var monEditAddHp = settingBox.querySelector(".m-add-hp");
  69. var monEditAddAtk = settingBox.querySelector(".m-add-atk");
  70. var monEditAddRcv = settingBox.querySelector(".m-add-rcv");
  71. var monEditAddHp99 = settingBox.querySelector(".m-add-hp-btn-99");
  72. monEditAddHp99.onclick = function(){monEditAddHp.value = this.value}
  73. var monEditAddAtk99 = settingBox.querySelector(".m-add-atk-btn-99");
  74. monEditAddAtk99.onclick = function(){monEditAddAtk.value = this.value}
  75. var monEditAddRcv99 = settingBox.querySelector(".m-add-rcv-btn-99");
  76. monEditAddRcv99.onclick = function(){monEditAddRcv.value = this.value}
  77. var monEditAdd297 = settingBox.querySelector(".m-add-btn-297");
  78. monEditAdd297.onclick = function(){monEditAddHp.value = monEditAddAtk.value = monEditAddRcv.value = 99}
  79. //潜觉
  80. var monEditLatentUl = settingBox.querySelector(".m-latent-ul");
  81. var latent = editBox.latent = [];
  82. var monEditLatents = Array.prototype.slice.call(monEditLatentUl.querySelectorAll("li"));
  83. var monEditLatentAllowableUl = settingBox.querySelector(".m-latent-allowable-ul");
  84. var monEditLatentsAllowable = Array.prototype.slice.call(monEditLatentAllowableUl.querySelectorAll("li"));
  85. function usedHole(latent) //计算用了多少潜觉格子
  86. {
  87. return latent.reduce(function(previous,current){
  88. return previous + (current>= 12?2:1);
  89. },0);
  90. }
  91. function refreshLatent() //刷新潜觉
  92. {
  93. if (this.value<0) return;
  94. var usedHoleN = usedHole(latent);
  95. for (var ai=0;ai<6;ai++)
  96. {
  97. if (latent[ai])
  98. {
  99. monEditLatents[ai].className = "latent-icon latent-icon-" + latent[ai];
  100. monEditLatents[ai].value = ai;
  101. }
  102. else if(ai<(6-usedHoleN+latent.length))
  103. {
  104. monEditLatents[ai].className = "latent-icon";
  105. monEditLatents[ai].value = -1;
  106. }
  107. else
  108. {
  109. monEditLatents[ai].className = "display-none";
  110. monEditLatents[ai].value = -1;
  111. }
  112. }
  113. }
  114. editBox.refreshLatent = refreshLatent;
  115. //已有觉醒的去除
  116. monEditLatents.forEach(function(l){
  117. l.onclick = function(){
  118. var aIdx = parseInt(this.value);
  119. latent.splice(aIdx,1);
  120. refreshLatent();
  121. }
  122. })
  123. //可选觉醒的添加
  124. monEditLatentsAllowable.forEach(function(la){
  125. la.onclick = function(){
  126. if (this.classList.contains("unselected-latent")) return;
  127. var lIdx = parseInt(this.value);
  128. var usedHoleN = usedHole(latent);
  129. if (lIdx >= 12 && usedHoleN<=4)
  130. latent.push(lIdx);
  131. else if (lIdx < 12 && usedHoleN<=5)
  132. latent.push(lIdx);
  133. refreshLatent();
  134. /*
  135. var allowHole = monEditLatents.filter(function(l){ //返回空余潜觉格子
  136. return !l.classList.contains("display-none") && //没被隐藏的
  137. Array.prototype.slice.call(l.classList).filter(function(c){ //存在觉醒图标className的
  138. return /^latent\-icon\-\d+$/ig.test(c);
  139. }).length<1;
  140. })
  141. var lIdx = parseInt(this.value);
  142. if (lIdx >= 12)
  143. { //占两格
  144. if (allowHole.length>=2)
  145. {
  146. allowHole[0].className = "latent-icon latent-icon-" + lIdx;
  147. allowHole.value = lIdx;
  148. allowHole[allowHole.length-1].className = "display-none";
  149. }
  150. }else
  151. { //占一格
  152. if (allowHole.length>=1)
  153. {
  154. allowHole[0].className = "latent-icon latent-icon-" + lIdx;
  155. allowHole.value = lIdx;
  156. }
  157. }
  158. */
  159. }
  160. })
  161. }
  162. function changeid(mon,monDom,awokenDom)
  163. {
  164. var md = ms[mon.id]; //怪物固定数据
  165. /*
  166. mon.id
  167. mon.level
  168. mon.awoken
  169. mon.addition
  170. mon.acquisitusAwoken
  171. */
  172. if (mon.id>-1) //如果提供了id
  173. {
  174. monDom.className = "monster";
  175. monDom.classList.add("pet-cards-" + Math.ceil(mon.id/100)); //添加图片编号
  176. var idxInPage = (mon.id-1) % 100; //获取当前页面的总序号
  177. monDom.classList.add("pet-cards-index-x-" + idxInPage % 10); //添加X方向序号
  178. monDom.classList.add("pet-cards-index-y-" + parseInt(idxInPage / 10)); //添加Y方向序号
  179. monDom.querySelector(".property").className = "property property-" + md.ppt[0]; //主属性
  180. monDom.querySelector(".subproperty").className = "subproperty subproperty-" + md.ppt[1]; //副属性
  181. monDom.title = "No." + mon.id + " " + md.name;
  182. monDom.href = "http://pad.skyozora.com/pets/" + mon.id;
  183. }
  184. if (mon.level>0) //如果提供了等级
  185. {
  186. monDom.querySelector(".level").innerHTML = mon.level || 99;
  187. }
  188. if (mon.awoken>-1) //如果提供了觉醒
  189. {
  190. var awokenIcon = monDom.querySelector(".awoken-count");
  191. if (mon.awoken == 0 || md.awoken.length < 1) //没觉醒
  192. {
  193. awokenIcon.classList.add("display-none");
  194. awokenIcon.innerHTML = "";
  195. }else
  196. {
  197. awokenIcon.classList.remove("display-none");
  198. if (mon.awoken < md.awoken.length) //觉醒没满直接写数字
  199. awokenIcon.innerHTML = mon.awoken;
  200. else //满觉醒打星星
  201. awokenIcon.innerHTML = "★";
  202. }
  203. }
  204. if (mon.addition) //如果提供了加值
  205. {
  206. monDom.querySelector(".addition .hp").innerHTML = mon.addition[0];
  207. monDom.querySelector(".addition .atk").innerHTML = mon.addition[1];
  208. monDom.querySelector(".addition .rcv").innerHTML = mon.addition[2];
  209. if (mon.addition[0]+mon.addition[1]+mon.addition[2] >= 297)
  210. {
  211. monDom.querySelector(".addition").classList.add("has297");
  212. }else
  213. {
  214. monDom.querySelector(".addition").classList.remove("has297");
  215. }
  216. }
  217. if (awokenDom && mon.acquisitusAwoken) //如果提供了潜觉
  218. {
  219. }
  220. }
  221. function test()
  222. {
  223. var m1 = document.querySelector(".formation-A-box .formation-team .team-1 .monster");
  224. var a1 = document.querySelector(".formation-A-box .formation-team .team-1 .acquisitus-awoken-ul");
  225. changeid({
  226. id:5209,
  227. level:98,
  228. awoken:8,
  229. addition:[99,99,99],
  230. acquisitusAwoken:[],
  231. },m1,a1)
  232. editChangeMonId(3264);
  233. }
  234. function editChangeMonId(id)
  235. {
  236. var md = ms[id]; //怪物固定数据
  237. if (!md){
  238. id = 0;
  239. md = ms[0]
  240. }
  241. var editBox = document.querySelector(".edit-box");
  242. var monInfoBox = editBox.querySelector(".monsterinfo-box");
  243. var me = monInfoBox.querySelector(".monster");
  244. changeid({id:id,},me); //改变图像
  245. var mId = monInfoBox.querySelector(".monster-id");
  246. mId.innerHTML = id;
  247. var mRare = monInfoBox.querySelector(".monster-rare");
  248. mRare.className = "monster-rare rare-" + md.rare;
  249. var mName = monInfoBox.querySelector(".monster-name");
  250. mName.innerHTML = md.name;
  251. var mType = monInfoBox.querySelectorAll(".monster-type li");
  252. for (var ti=0;ti<mType.length;ti++)
  253. {
  254. if (md.type[ti])
  255. {
  256. mType[ti].className = "type-name type-name-" + md.type[ti];
  257. mType[ti].firstChild.className = "type-icon type-icon-" + md.type[ti];
  258. }else
  259. {
  260. mType[ti].className = "display-none";
  261. }
  262. }
  263. var settingBox = editBox.querySelector(".setting-box");
  264. var mAwoken = settingBox.querySelectorAll(".m-awoken-ul li");
  265. mAwoken[0].innerHTML = md.awoken.length?"★":"0";
  266. for (var ai=1;ai<mAwoken.length;ai++)
  267. {
  268. if (md.awoken[ai-1])
  269. {
  270. mAwoken[ai].className = "awoken-icon awoken-" + md.awoken[ai-1];
  271. }else
  272. {
  273. mAwoken[ai].className = "display-none";
  274. }
  275. }
  276. var monEditLvMax = settingBox.querySelector(".m-level-btn-max");
  277. monEditLvMax.innerHTML = monEditLvMax.value = md.maxLevel;
  278. var monEditLv = settingBox.querySelector(".m-level");
  279. monEditLv.value = md.maxLevel>99?99:md.maxLevel;
  280. var monLatentAllowUl = editBox.querySelector(".m-latent-allowable-ul");
  281. //该宠Type允许的杀
  282. var allowLatent = uniq(md.type.reduce(function (previous, t, index, array) {
  283. return previous.concat(type_allowable_latent[t]);
  284. },[]));
  285. for(var li=17;li<=24;li++)
  286. {
  287. var latentDom = monLatentAllowUl.querySelector(".latent-icon-" + li);
  288. if (allowLatent.indexOf(li)>=0)
  289. {
  290. if(latentDom.classList.contains("unselected-latent"))
  291. latentDom.classList.remove("unselected-latent");
  292. }else
  293. {
  294. if(!latentDom.classList.contains("unselected-latent"))
  295. latentDom.classList.add("unselected-latent");
  296. }
  297. }
  298. editBox.latent.length = 0;
  299. editBox.refreshLatent();
  300. }

智龙迷城队伍图制作工具

Contributors (1)