您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Automatically craft by inputting a lineage.
当前为
// ==UserScript== // @name IC Auto Crafter // @namespace http://tampermonkey.net/ // @version 1.0 // @license MIT // @description Automatically craft by inputting a lineage. // @icon https://i.imgur.com/WlkWOkU.png // @author @activetutorial on discord // @match https://neal.fun/infinite-craft/ // @run-at document-end // @grant none // ==/UserScript== (function() { 'use strict'; (window.AT ||= {}).autocrafterdata = { iconthing: "", infinitecraft: null, autocraftButton: null, anticheat: true, processLineage: async function () { const rawlineage = await this.getUserInput(); const recipes = this.parseRecipes(rawlineage); // Get the lineage //console.log(recipes); for (let i = 0; i < recipes.length; i++) { // Craft all recipes const [string1, string2] = recipes[i]; const element1Exists = this.infinitecraft.elements.some(el => el.text === string1); // Anti cheat const element2Exists = this.infinitecraft.elements.some(el => el.text === string2); if (!this.anticheat || (element1Exists && element2Exists)) { await this.infinitecraft.craft({text: string1}, {text: string2}); this.infinitecraft.instances.pop(); } else { await this.showToast(`Skipping craft: You don't have one of these elements: "${string1}", "${string2}"`); } } }, parseRecipes: function (lineage) { const recipes = []; lineage.split('\n').forEach(line => { line = line.trim(); if (!line || !line.includes(' = ')) return; const [ingredients, result] = line.split(' = '); if (!ingredients || !result) return; const ingredientList = ingredients.trim().split(' + '); if (ingredientList.length < 2) return; recipes.push(ingredientList.map(ingredient => ingredient.trim())); }); return recipes; }, getUserInput: async function () { return new Promise((resolve) => { let popup = window.open('', '', 'width=400,height=300'); popup.document.write('<textarea id="userInput" rows="10" cols="40" placeholder="Enter your lineage..."></textarea><br>'); popup.document.write('<button id="submitButton">Submit</button>'); popup.document.getElementById('submitButton').addEventListener('click', function() { let userInput = popup.document.getElementById('userInput').value; popup.close(); resolve(userInput); }); }); }, showToast: function(message) { const toast = document.createElement('div'); toast.textContent = message; Object.assign(toast.style, { position: 'fixed', left: '50%', transform: 'translateX(-50%)', padding: '10px 20px', backgroundColor: '#333', color: '#fff', borderRadius: '5px', fontSize: '16px', opacity: '0', transition: 'opacity 0.5s ease, bottom 0.3s ease', marginTop: '10px' }); const existingToasts = document.querySelectorAll('.toast'); const offset = existingToasts.length * (toast.offsetHeight + 40); toast.style.bottom = `${30 + offset}px`; toast.classList.add('toast'); document.body.appendChild(toast); (async () => { await new Promise(resolve => setTimeout(resolve, 10)); toast.style.opacity = '1'; await new Promise(resolve => setTimeout(resolve, 3000)); toast.style.opacity = '0'; await new Promise(resolve => setTimeout(resolve, 500)); toast.remove(); const remainingToasts = document.querySelectorAll('.toast'); remainingToasts.forEach((t, index) => { t.style.bottom = `${30 + index * (toast.offsetHeight + 40)}px`; }); })(); return new Promise(resolve => setTimeout(resolve, 50)); // 0.05 delay }, addUiOption: function () { this.autocraftButton = document.createElement('div'); this.autocraftButton.classList.add('setting'); this.autocraftButton.textContent = 'Autocrafter'; const img = document.createElement('img'); img.src = this.iconthing; this.autocraftButton.appendChild(img); this.autocraftButton.onclick = function () { window.AT.autocrafterdata.processLineage(); }; document.querySelector('.settings-content').appendChild(this.autocraftButton); return true; }, start: function () { if (document.querySelector('.settings-content')) { // Wait for IC Helper this.infinitecraft = window.$nuxt.$root.$children[1].$children[0].$children[0]; this.addUiOption(); } else { setTimeout(this.start.bind(this), 200); } } }; window.AT.autocrafterdata.start(); })();
QingJ © 2025
镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址