您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
none
- // ==UserScript==
- // @name scratch extesion: math by rssaromeo
- // @version 4
- // @description none
- // @run-at document-start
- // @author rssaromeo
- // @license GPLv3
- // @tag lib
- // @match *://*/*
- // @include *
- // @icon 
- // @grant none
- // @namespace https://greasyfork.org/users/1184528
- // ==/UserScript==
- ;(async () => {
- await loadlib("libloader").waitforlib("scratchextesnsionmanager")
- const {
- newext,
- newmenu,
- newblock,
- bt,
- inp,
- gettarget,
- totype,
- scratch_math,
- projectid,
- canvas,
- scratchvar,
- scratchlist,
- } = loadlib("scratchextesnsionmanager")
- var vm
- loadlib("libloader")
- .waitforlib("scratch")
- .then(() => (vm = loadlib("scratch").vm))
- newext(
- "math",
- "rssaromeo",
- class {
- power({ x, y }) {
- x = totype(x, "number", true)
- y = totype(y, "number", true)
- return Math.pow(x, y)
- }
- tern({ cond, a, s }) {
- cond = totype(cond, "bool")
- return cond ? a : s
- }
- invert({ a }) {
- a = totype(a, "bool") ?? totype(a, "string")
- return !a
- }
- tobool({ a }) {
- a = totype(a, "bool") ?? totype(a, "string")
- return !!a
- }
- toplaces({ num, before, after }) {
- var [start = "", end = ""] = String(num).split(".")
- if (totype(before, "number") !== undefined) {
- start = start.substring(start.length - before)
- while (start.length < before) start = "0" + start
- }
- if (totype(after, "number") !== undefined) {
- end = end.substring(0, after)
- // log(end, end.length, after, end.length < after)
- while (end.length < after) end += "0"
- }
- return start + "." + end
- }
- distance2points({ x1, y1, x2, y2 }) {
- x1 = totype(x1, "number", true)
- y1 = totype(y1, "number", true)
- x2 = totype(x2, "number", false)
- y2 = totype(y2, "number", false)
- return Math.sqrt(Math.pow(x1 - x2, 2) + Math.pow(y1 - y2, 2))
- }
- distancebetweenspriteandpoint({ sprite, x2, y2 }) {
- var x1 = totype(gettarget(sprite).x, "number")
- var y1 = totype(gettarget(sprite).y, "number")
- x2 = totype(x2, "number")
- y2 = totype(y2, "number")
- return Math.sqrt(Math.pow(x1 - x2, 2) + Math.pow(y1 - y2, 2))
- }
- distancebetween2sprites({ sprite1, sprite2 }) {
- var x1 = totype(gettarget(sprite1).x, "number")
- var y1 = totype(gettarget(sprite1).y, "number")
- var x2 = totype(gettarget(sprite2).x, "number")
- var y2 = totype(gettarget(sprite2).y, "number")
- return Math.sqrt(Math.pow(x1 - x2, 2) + Math.pow(y1 - y2, 2))
- }
- pointtopoint({ sprite, x, y }) {
- x = totype(x, "number")
- y = totype(y, "number")
- return gettarget(sprite).setDirection(
- scratch_math(
- "atan",
- (gettarget(sprite).x - x) / (gettarget(sprite).y - y)
- ) +
- (gettarget(sprite).y >= y) * 180
- )
- }
- pointtosprite({ sprite1, sprite2 }) {
- var x = totype(gettarget(sprite2).x, "number")
- var y = totype(gettarget(sprite2).y, "number")
- return gettarget(sprite1).setDirection(
- scratch_math(
- "atan",
- (gettarget(sprite1).x - x) / (gettarget(sprite1).y - y)
- ) +
- (gettarget(sprite1).y >= y) * 180
- )
- }
- type({ data }) {
- //number, string, list, object, json, bool
- data = String(data)
- if (data == "true" || data == "false") return "bool"
- if (/^-?[0-9]*\.?[0-9]+$/.test(data)) return "number"
- if (data === "NaN" || data == "nan") return "NaN"
- try {
- var temp = JSON.parse(
- inp.replaceAll("'", '"').replaceAll("`", '"')
- )
- return Array.isArray(temp) ? "jsonarray" : "jsonobject"
- } catch (e) {}
- }
- totype({ data, type }) {
- return totype(data, type)
- }
- },
- [
- newblock(bt.ret, "type", "type[data]"),
- newblock(bt.ret, "totype", "[data]totype[type]", [
- inp.str,
- newmenu("totype", {
- items: ["string", "number", "array", "object", "bool"],
- }),
- ]),
- newblock(bt.ret, "power", "[x]^[y]", [
- [inp.num, "3"],
- [inp.num, "7"],
- ]),
- newblock(bt.ret, "tern", "if [cond] then [a] else [s]", [
- inp.str,
- [inp.str, "it was true"],
- [inp.str, "it was false"],
- ]),
- newblock(bt.bool, "invert", "![a]", [inp.bool]),
- newblock(bt.bool, "tobool", "!![a]", [inp.bool]),
- newblock(
- bt.ret,
- "toplaces",
- "toplaces [num], before: [before], after: [after]",
- [
- { type: inp.int, defaultValue: 156165156156156 },
- { type: inp.int, defaultValue: 5 },
- { type: inp.int, defaultValue: 2 },
- ]
- ),
- newblock(
- bt.cmd,
- "pointtosprite",
- "make [sprite1] face sprite [sprite2]",
- [
- newmenu("spritelistwithoutglobal", { defaultValue: "" }),
- newmenu("spritelistwithoutglobal", { defaultValue: "" }),
- ]
- ),
- newblock(
- bt.cmd,
- "pointtopoint",
- "make [sprite] face point at [x], [y]",
- [
- newmenu("spritelistwithoutglobal", { defaultValue: "" }),
- [inp.num, "6"],
- [inp.num, "200"],
- ]
- ),
- newblock(
- bt.ret,
- "distancebetween2sprites",
- "distance between [sprite1] and [sprite2]",
- [
- newmenu("spritelistwithoutglobal", { defaultValue: "" }),
- newmenu("spritelistwithoutglobal", { defaultValue: "" }),
- ]
- ),
- newblock(
- bt.ret,
- "distancebetweenspriteandpoint",
- "distance between [sprite] and [x2], [y2]",
- [
- newmenu("spritelistwithoutglobal", { defaultValue: "" }),
- [inp.num, "6"],
- [inp.num, "200"],
- ]
- ),
- newblock(
- bt.ret,
- "distance2points",
- "distance between [x1], [y1] and [x2], [y2]",
- [
- [inp.num, "4"],
- [inp.num, "400"],
- [inp.num, "6"],
- [inp.num, "200"],
- ]
- ),
- ],
- "12B312",
- ""
- )
- })()