Skip to content

Instantly share code, notes, and snippets.

@Hunlongyu
Last active December 30, 2022 02:36
Show Gist options
  • Save Hunlongyu/743151a1480751ca54b5e93da76cf6ee to your computer and use it in GitHub Desktop.
Save Hunlongyu/743151a1480751ca54b5e93da76cf6ee to your computer and use it in GitHub Desktop.
修改 等级,金币,属性值,转生点数。
// ==UserScript==
// @author Hunlongyu
// @name 『游戏助手』vue-idle-game
// @namespace https://github.com/Hunlongyu
// @icon https://i.loli.net/2019/04/22/5cbd720718fdb.png
// @description 挂机放置类小游戏, 修改 等级,金币,属性值,转生点数。
// @version 0.1.2
// @match https://game.dusays.com/*
// @match http://couy.xyz/*
// @grant GM_addStyle
// @grant GM_getResourceText
// @run-at document-end
// @require https://cdn.jsdelivr.net/npm/[email protected]/base64.min.js
// @resource PURE https://cdn.jsdelivr.net/npm/[email protected]/build/pure-min.css
// @supportURL https://gist.github.com/Hunlongyu/743151a1480751ca54b5e93da76cf6ee
// ==/UserScript==
(function() {
'use strict'
function getLocalStorageSD() {
const sd = localStorage.getItem("_sd");
if (sd) return sd;
const data = `
ZXlKd2JHRjVaWEpGY1hWcGNHMWxiblFpT25zaWNHeGhlV1Z5VjJWaGNHOXVJanA3SW14Mklqb3hMQ0pwZEdWdFZIbHdaU0k2SW5kbFlYQnZiaUlzSW5GMVlXeHBkSGtpT25zaWJ
tRnRaU0k2SXVlZ3RPYVhweUlzSW5GMVlXeHBkSGxEYjJWbVptbGphV1Z1ZENJNk1DNDNMQ0p3Y205aVlXSnBiR2wwZVNJNklqQXVNalVpTENKamIyeHZjaUk2SWlOaE1XRXhZVEVpTENKbGVIUnlZVVZ1
ZEhKNVRuVnRJam94ZlN3aWRIbHdaU0k2ZXlKdVlXMWxJam9pNXBhdzVvbUw1NSt0NVltUklpd2laR1Z6SWpvaTVwYXc1b21MNkkrYzZiaWg1TDIvNTVTbzU1cUU1NSt0NVltUklpd2lhV052YmxOeVl5S
TZJaTR2YVdOdmJuTXZWMTlUZDI5eVpEQXdNUzV3Ym1jaUxDSmxiblJ5ZVNJNlczc2lkbUZzUTI5bFptWnBZMmxsYm5RaU9qQXVPU3dpZG1Gc2RXVWlPakVzSW5Ob2IzZFdZV3dpT2lJck1TSXNJblI1Y0d
VaU9pSkJWRXNpTENKdVlXMWxJam9pNXBTNzVZZTc1WXFiSW4xZGZTd2laWGgwY21GRmJuUnllU0k2VzNzaWRtRnNkV1VpT2pFc0luTm9iM2RXWVd3aU9pSXJNU0lzSW5SNWNHVWlPaUpCVkVzaUxDSnVZ
VzFsSWpvaTVwUzc1WWU3NVlxYkluMWRmU3dpY0d4aGVXVnlRWEp0YjNJaU9uc2liSFlpT2pFc0ltbDBaVzFVZVhCbElqb2lZWEp0YjNJaUxDSnhkV0ZzYVhSNUlqcDdJbTVoYldVaU9pTG5vTFRtbDZja
UxDSnhkV0ZzYVhSNVEyOWxabVpwWTJsbGJuUWlPakF1Tnl3aWNISnZZbUZpYVd4cGRIa2lPaUl3TGpJMUlpd2lZMjlzYjNJaU9pSWpZVEZoTVdFeElpd2laWGgwY21GRmJuUnllVTUxYlNJNk1YMHNJblI
1Y0dVaU9uc2libUZ0WlNJNkl1YVdzT2FKaStXNGcraWhveUlzSW1SbGN5STZJdWFXc09hSmkraVBuT200b2VlcHYrZWFoT2FacnVtQW11aWhvK2VKcVNJc0ltbGpiMjVUY21NaU9pSXVMMmxqYjI1ekwwR
mZRVE11Y0c1bklpd2laVzUwY25raU9sdDdJblpoYkVOdlpXWm1hV05wWlc1MElqb3dMamtzSW5aaGJIVmxJam94TENKemFHOTNWbUZzSWpvaUt6RWlMQ0owZVhCbElqb2lSRVZHSWl3aWJtRnRaU0k2SX
VtWXN1VytvZVdLbXlKOVhYMHNJbVY0ZEhKaFJXNTBjbmtpT2x0N0luUjVjR1VpT2lKSVVDSXNJblpoYkhWbElqb3hNQ3dpYzJodmQxWmhiQ0k2SWlzeE1DSXNJbTVoYldVaU9pTG5sSi9sa2IzbGdMd2l
mVjE5TENKd2JHRjVaWEpTYVc1bklqcDdJbXgySWpveExDSnBkR1Z0Vkhsd1pTSTZJbkpwYm1jaUxDSnhkV0ZzYVhSNUlqcDdJbTVoYldVaU9pTG5vTFRtbDZjaUxDSnhkV0ZzYVhSNVEyOWxabVpwWTJs
bGJuUWlPakF1Tnl3aWNISnZZbUZpYVd4cGRIa2lPaUl3TGpJMUlpd2lZMjlzYjNJaU9pSWpZVEZoTVdFeElpd2laWGgwY21GRmJuUnllVTUxYlNJNk1YMHNJblI1Y0dVaU9uc2libUZ0WlNJNkl1YVdzT
2FKaSthTWgrZU9yeUlzSW1SbGN5STZJdVM0Z09TNHF1YVpydW1BbXVlYWhPYU1oK2VPcnlJc0ltbGpiMjVUY21NaU9pSXVMMmxqYjI1ekwwRmpYekV3TG5CdVp5SXNJbVZ1ZEhKNUlqcGJleUoyWVd4RG
IyVm1abWxqYVdWdWRDSTZNQzQ1TENKMllXeDFaU0k2TWpBc0luTm9iM2RXWVd3aU9pSXJNakFpTENKMGVYQmxJam9pU0ZBaUxDSnVZVzFsSWpvaTU1U2Y1Wkc5NVlDOEluMWRmU3dpWlhoMGNtRkZiblJ
5ZVNJNlczc2lkSGx3WlNJNklrTlNTVlFpTENKMllXeDFaU0k2TVRBc0luTm9iM2RXWVd3aU9pSXJNVEFsSWl3aWJtRnRaU0k2SXVhYXRPV0h1K2VPaHlKOVhYMHNJbkJzWVhsbGNrNWxZMnNpT25zaWJI
WWlPakVzSW1sMFpXMVVlWEJsSWpvaWJtVmpheUlzSW5GMVlXeHBkSGtpT25zaWJtRnRaU0k2SXVlZ3RPYVhweUlzSW5GMVlXeHBkSGxEYjJWbVptbGphV1Z1ZENJNk1DNDNMQ0p3Y205aVlXSnBiR2wwZ
VNJNklqQXVNalVpTENKamIyeHZjaUk2SWlOaE1XRXhZVEVpTENKbGVIUnlZVVZ1ZEhKNVRuVnRJam94ZlN3aWRIbHdaU0k2ZXlKdVlXMWxJam9pNXBhdzVvbUw2YUc1NVoyZ0lpd2laR1Z6SWpvaTVMaU
E1TGlxNXBtdTZZQ2E1NXFFNW95SDU0NnZJaXdpYVdOdmJsTnlZeUk2SWk0dmFXTnZibk12UVdOZk15NXdibWNpTENKbGJuUnllU0k2VzNzaWRtRnNRMjlsWm1acFkybGxiblFpT2pBdU9Td2lkbUZzZFd
VaU9qSXdMQ0p6YUc5M1ZtRnNJam9pS3pJd0lpd2lkSGx3WlNJNklraFFJaXdpYm1GdFpTSTZJdWVVbitXUnZlV0F2Q0o5WFgwc0ltVjRkSEpoUlc1MGNua2lPbHQ3SW5SNWNHVWlPaUpEVWtsVUlpd2lk
bUZzZFdVaU9qRXdMQ0p6YUc5M1ZtRnNJam9pS3pFd0pTSXNJbTVoYldVaU9pTG1tclRsaDd2bmpvY2lmVjE5ZlN3aVltRmphM0JoWTJ0RmNYVnBjRzFsYm5RaU9sdDdmU3g3ZlN4N2ZTeDdmU3g3ZlN4N
2ZTeDdmU3g3ZlN4N2ZTeDdmU3g3ZlN4N2ZTeDdmU3g3ZlN4N2ZTeDdmU3g3ZlN4N2ZTeDdmU3g3ZlN4N2ZTeDdmU3g3ZlN4N2ZTeDdmU3g3ZlN4N2ZTeDdmU3g3ZlN4N2ZTeDdmU3g3ZlYwc0lteDJJam
94TENKbmIyeGtJam93TENKbGJtUnNaWE56VEhZaU9qQXNJbkpCSWpwN0lraFFJam93TENKQlZFc2lPakFzSWtOU1NWUWlPakFzSWtOU1NWUkVUVWNpT2pBc0lrUkZSaUk2TUN3aVFreFBReUk2TUN3aVR
VOVdSVk5RUlVWRUlqb3dMQ0pDUVZSVVRFVlRVRVZGUkNJNk1IMHNJbklpT25zaVkyOTFiblFpT2pBc0luQnZhVzUwSWpvd2ZYMD0=`;
return data;
}
function setLocalStorageSD(str) {
localStorage.removeItem("_sd");
localStorage.setItem("_sd", str);
}
function decoded(sd) {
const base = Base64.decode(sd);
const str = Base64.decode(base);
return JSON.parse(str);
}
function encoded(config) {
const str = JSON.stringify(config);
const base = Base64.encode(str);
return Base64.encode(base);
}
function closeConfigDom() {
document.querySelector("#hly-save").removeEventListener("click", saveConfig);
document.querySelector("#hly-close").removeEventListener("click", closeConfigDom);
const dom = document.getElementById("hly-box");
document.body.removeChild(dom);
}
function showConfigDom() {
const sd = getLocalStorageSD();
const config = decoded(sd);
createDom(config);
}
function createDom(config) {
const dom = document.getElementById("hly-box");
if (dom) return false;
const template = `
<div id="hly-box">
<form class="pure-form pure-form-aligned">
<fieldset>
<div class="pure-control-group">
<label for="aligned-lv">等级</label>
<input type="text" id="aligned-lv" placeholder="${config.lv}" />
</div>
<div class="pure-control-group">
<label for="aligned-gold">金币</label>
<input type="text" id="aligned-gold" placeholder="${config.gold}" />
</div>
<div class="pure-control-group">
<label for="aligned-HP">生命值</label>
<input type="text" id="aligned-HP" placeholder="${config.rA.HP}" />
</div>
<div class="pure-control-group">
<label for="aligned-ATK">攻击力</label>
<input type="text" id="aligned-ATK" placeholder="${config.rA.ATK}" />
</div>
<div class="pure-control-group">
<label for="aligned-CRIT">暴击率</label>
<input type="text" id="aligned-CRIT" placeholder="${config.rA.CRIT}" />
</div>
<div class="pure-control-group">
<label for="aligned-CRITDMG">暴击伤害</label>
<input type="text" id="aligned-CRITDMG" placeholder="${config.rA.CRITDMG}" />
</div>
<div class="pure-control-group">
<label for="aligned-DEF">护甲</label>
<input type="text" id="aligned-DEF" placeholder="${config.rA.DEF}" />
</div>
<div class="pure-control-group">
<label for="aligned-BLOC">格挡</label>
<input type="text" id="aligned-BLOC" placeholder="${config.rA.BLOC}" />
</div>
<div class="pure-control-group">
<label for="aligned-MOVESPEED">副本行进速度</label>
<input type="text" id="aligned-MOVESPEED" placeholder="${config.rA.MOVESPEED}" />
</div>
<div class="pure-control-group">
<label for="aligned-BATTLESPEED">副本战斗速度</label>
<input type="text" id="aligned-BATTLESPEED" placeholder="${config.rA.BATTLESPEED}" />
</div>
<div class="pure-control-group">
<label for="aligned-point">转生点数</label>
<input type="text" id="aligned-point" placeholder="${config.r.point}" />
</div>
<div class="pure-controls">
<button class="pure-button pure-button-primary" id="hly-save">保存</button>
<button class="pure-button pure-button-primary" id="hly-close">关闭</button>
</div>
</fieldset>
</form>
</div>
`;
const doc = new DOMParser().parseFromString(template, "text/html");
const div = doc.querySelector('#hly-box');
document.body.appendChild(div);
document.querySelector("#hly-save").addEventListener("click", saveConfig, false);
document.querySelector("#hly-close").addEventListener("click", closeConfigDom, false);
const css = `
#hly-box{
background-color: #fff;
position: absolute;
right: 0;
padding: 10px;
}
`;
GM_addStyle(css);
}
function saveConfig() {
const sd = getLocalStorageSD();
const config = decoded(sd);
const lv = document.getElementById("aligned-lv").value;
const lv2 = document.getElementById("aligned-lv").placeholder;
config.lv = Number(lv) || Number(lv2);
const gold = document.getElementById("aligned-gold").value;
const gold2 = document.getElementById("aligned-gold").placeholder;
config.gold = Number(gold) || Number(gold2);
const HP = document.getElementById("aligned-HP").value;
const HP2 = document.getElementById("aligned-HP").placeholder;
config.rA.HP = Number(HP) || Number(HP2);
const ATK = document.getElementById("aligned-ATK").value;
const ATK2 = document.getElementById("aligned-ATK").placeholder;
config.rA.ATK = Number(ATK) || Number(ATK2);
const CRIT = document.getElementById("aligned-CRIT").value;
const CRIT2 = document.getElementById("aligned-CRIT").placeholder;
config.rA.CRIT = Number(CRIT) || Number(CRIT2);
const CRITDMG = document.getElementById("aligned-CRITDMG").value;
const CRITDMG2 = document.getElementById("aligned-CRITDMG").placeholder;
config.rA.CRITDMG = Number(CRITDMG) || Number(CRITDMG2);
const DEF = document.getElementById("aligned-DEF").value;
const DEF2 = document.getElementById("aligned-DEF").placeholder;
config.rA.DEF = Number(DEF) || Number(DEF2);
const BLOC = document.getElementById("aligned-BLOC").value;
const BLOC2 = document.getElementById("aligned-BLOC").placeholder;
config.rA.BLOC = Number(BLOC) || Number(BLOC2);
const MOVESPEED = document.getElementById("aligned-MOVESPEED").value;
const MOVESPEED2 = document.getElementById("aligned-MOVESPEED").placeholder;
config.rA.MOVESPEED = Number(MOVESPEED) || Number(MOVESPEED2);
const BATTLESPEED = document.getElementById("aligned-BATTLESPEED").value;
const BATTLESPEED2 = document.getElementById("aligned-BATTLESPEED").placeholder;
config.rA.BATTLESPEED = Number(BATTLESPEED) || Number(BATTLESPEED2);
const point = document.getElementById("aligned-point").value;
const point2 = document.getElementById("aligned-point").placeholder;
config.r.point = Number(point) || Number(point2);
const str = encoded(config);
setLocalStorageSD(str);
setTimeout(() => {
window.location.reload(true);
});
}
function createBtn() {
const dom = document.querySelector("#hly-helper");
if (dom) return;
const template = `
<div class="c-tooltip" id="hly-helper" style="cursor: pointer;">
<div class="c-tooltip-content">
<div class="Backpack">
<img width="34" height="34" src="">
</div>
</div>
</div>
`;
const doc = new DOMParser().parseFromString(template, "text/html");
const div = doc.querySelector('#hly-helper');
div.addEventListener('click', showConfigDom, false)
const menu = document.querySelector(".menu");
menu.appendChild(div);
return true;
}
window.addEventListener("load", () => {
const pure = GM_getResourceText("PURE");
GM_addStyle(pure);
createBtn();
});
})()
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment