Skip to content

Commit

Permalink
w extensions
Browse files Browse the repository at this point in the history
  • Loading branch information
cesderp14 authored Oct 14, 2023
1 parent 9aed8de commit 66b1c64
Show file tree
Hide file tree
Showing 5 changed files with 1,956 additions and 0 deletions.
36 changes: 36 additions & 0 deletions src/lib/libraries/extensions/index.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -163,6 +163,42 @@ const menuItems = [
description: 'Use the magic of 3D to spice up your project.',
featured: true
},
{
name: 'Monitors Plus',
extensionId: 'https://snail-ide.github.io/Monitors-Plus.js',
iconURL: defaultExtensionIcon,
collaborator: 'SharkPool',
tags: ['penguinmod'],
description: 'W.I.P Description',
featured: true
},
{
name: 'Lazy Collisions',
extensionId: 'https://snail-ide.github.io/Lazy-Collisions.js',
iconURL: defaultExtensionIcon,
collaborator: 'SharkPool',
tags: ['penguinmod'],
description: 'W.I.P Description',
featured: true
},
{
name: 'Newgrounds Audio',
extensionId: 'https://snail-ide.github.io/Newgrounds-Audio.js',
iconURL: defaultExtensionIcon,
collaborator: 'SharkPool',
tags: ['penguinmod'],
description: 'W.I.P Description',
featured: true
},
{
name: 'Tile Grids',
extensionId: 'https://snail-ide.github.io/Tile-Grids.js',
iconURL: defaultExtensionIcon,
collaborator: 'SharkPool',
tags: ['penguinmod'],
description: 'W.I.P Description',
featured: true
},
{
name: 'AdaBrowser',
extensionId: 'adabrowser',
Expand Down
348 changes: 348 additions & 0 deletions static/Lazy-Collisions.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,348 @@
// Name: Lazy Collisions
// ID: LZcollisionsSP
// Description: Easy and Simple To Use Collision System for Sprites
// By: SharkPool <https://github.com/SharkPool-SP>

// Version V.1.0.0

(function (Scratch) {
"use strict";

if (!Scratch.extensions.unsandboxed) {
throw new Error("Lazy Collisions must run unsandboxed");
}

const vm = Scratch.vm;
const runtime = vm.runtime;

const menuIconURI =
"";

class LZcollisionsSP {
getInfo() {
return {
id: "LZcollisionsSP",
name: "Lazy Collisions",
color1: "#5cb1d6",
color2: "#539fc1",
color3: "#4a8eab",
menuIconURI,
blocks: [
{
opcode: "isOnSprite",
blockType: Scratch.BlockType.BOOLEAN,
text: "is [SPRITE2] on [SIDE] of [SPRITE1] offset [OFFSET]?",
arguments: {
SIDE: {
type: Scratch.ArgumentType.STRING,
menu: "POSITION2",
defaultValue: "top",
},
SPRITE1: {
type: Scratch.ArgumentType.STRING,
menu: "TARGETS",
},
SPRITE2: {
type: Scratch.ArgumentType.STRING,
menu: "TARGETS",
},
OFFSET: {
type: Scratch.ArgumentType.NUMBER,
defaultValue: 0,
},
},
},
{
opcode: "isOnSpriteSide",
blockType: Scratch.BlockType.BOOLEAN,
text: "is [SPRITE2] near the [SIDE] of [SPRITE1] offset [OFFSET]?",
arguments: {
SIDE: {
type: Scratch.ArgumentType.STRING,
menu: "POSITION2",
defaultValue: "top",
},
SPRITE1: {
type: Scratch.ArgumentType.STRING,
menu: "TARGETS",
},
SPRITE2: {
type: Scratch.ArgumentType.STRING,
menu: "TARGETS",
},
OFFSET: {
type: Scratch.ArgumentType.NUMBER,
defaultValue: 0,
},
},
},
{
opcode: "isSpriteLocation",
blockType: Scratch.BlockType.BOOLEAN,
text: "is [SPRITE2] [SIDE] [SPRITE1]?",
arguments: {
SIDE: {
type: Scratch.ArgumentType.STRING,
menu: "POSITION3",
defaultValue: "above",
},
SPRITE1: {
type: Scratch.ArgumentType.STRING,
menu: "TARGETS",
},
SPRITE2: {
type: Scratch.ArgumentType.STRING,
menu: "TARGETS",
},
},
},
{
opcode: "setOnSprite",
blockType: Scratch.BlockType.COMMAND,
text: "put [SPRITE2] on [SIDE] of [SPRITE1] offset [OFFSET]",
arguments: {
SIDE: {
type: Scratch.ArgumentType.STRING,
menu: "POSITION",
defaultValue: "top",
},
SPRITE1: {
type: Scratch.ArgumentType.STRING,
menu: "TARGETS",
},
SPRITE2: {
type: Scratch.ArgumentType.STRING,
menu: "TARGETS",
},
OFFSET: {
type: Scratch.ArgumentType.NUMBER,
defaultValue: 0,
},
},
}
],
menus: {
TARGETS: {
acceptReporters: true,
items: "_getTargets",
},
POSITION: {
acceptReporters: true,
items: [
"top",
"bottom",
"left side",
"right side",
"same top level",
"same bottom level",
"same left level",
"same right level"
],
},
POSITION2: {
acceptReporters: true,
items: [
"top",
"bottom",
"left side",
"right side"
],
},
POSITION3: {
acceptReporters: false,
items: [
"above",
"below",
"beside left",
"beside right"
],
}
}
};
}

_getTargets() {
const spriteNames = [];
const targets = Scratch.vm.runtime.targets;

for (let index = 1; index < targets.length; index++) {
const target = targets[index];
if (target.isOriginal) {
const targetName = target.getName();
const targetId = target.id;
spriteNames.push({
text: targetName,
value: targetName,
});
}
}
if (spriteNames.length > 0) {
return spriteNames;
} else {
return [""];
}
}

isOnSprite(args) {
let offset = Scratch.Cast.toNumber(args.OFFSET);
const spriteAtt = this.getAttribute(args.SPRITE1);
const target1 = runtime.getSpriteTargetByName(args.SPRITE1);
const target = runtime.getSpriteTargetByName(args.SPRITE2);
let x = [target1.x - (spriteAtt[0] / 2), target1.x + (spriteAtt[0] / 2)];
let y = [target1.y - (spriteAtt[1] / 2), target1.y + (spriteAtt[1] / 2)];
const spriteAtt2 = this.getAttribute(args.SPRITE2);
const myX = [target.x - (spriteAtt2[0] / 2), target.x + (spriteAtt2[0] / 2)];
const myY = [target.y - (spriteAtt2[1] / 2), target.y + (spriteAtt2[1] / 2)];
offset = offset + Math.round(spriteAtt[2] + spriteAtt2[2]);
switch (args.SIDE) {
case "top":
y = Math.round(myY[0] - spriteAtt[1] / 2);
return (y - offset === Math.round(target1.y) && myX[1] > x[0] && myX[0] < x[1]);
case "bottom":
y = Math.round(myY[1] + spriteAtt[1] / 2);
return (y + offset === Math.round(target1.y) && myX[1] > x[0] && myX[0] < x[1]);
case "left side":
x = Math.round(myX[1] + spriteAtt[1] / 2);
return (x + offset === Math.round(target1.x) && myY[1] > y[0] && myY[0] < y[1]);
case "right side":
x = Math.round(myX[0] - spriteAtt[1] / 2);
return (x - offset === Math.round(target1.x) && myY[1] > y[0] && myY[0] < y[1]);
default:
break;
}
}

isOnSpriteSide(args) {
let offset = Scratch.Cast.toNumber(args.OFFSET);
const spriteAtt = this.getAttribute(args.SPRITE1);
const target1 = runtime.getSpriteTargetByName(args.SPRITE1);
const target = runtime.getSpriteTargetByName(args.SPRITE2);
let x = [target1.x - (spriteAtt[0] / 2), target1.x + (spriteAtt[0] / 2)];
let y = [target1.y - (spriteAtt[1] / 2), target1.y + (spriteAtt[1] / 2)];
const spriteAtt2 = this.getAttribute(args.SPRITE2);
const myX = [target.x - (spriteAtt2[0] / 2), target.x + (spriteAtt2[0] / 2)];
const myY = [target.y - (spriteAtt2[1] / 2), target.y + (spriteAtt2[1] / 2)];
offset = offset + Math.round(spriteAtt[2] + spriteAtt2[2]);
switch (args.SIDE) {
case "top":
y = Math.round(myY[0] - spriteAtt[1] / 2);
return (y - offset === Math.round(target1.y));
case "bottom":
y = Math.round(myY[1] + spriteAtt[1] / 2);
return (y + offset === Math.round(target1.y));
case "left side":
x = Math.round(myX[1] + spriteAtt[1] / 2);
return (x + offset === Math.round(target1.x));
case "right side":
x = Math.round(myX[0] - spriteAtt[1] / 2);
return (x - offset === Math.round(target1.x));
default:
break;
}
}

isSpriteLocation(args) {
const sprite1 = runtime.getSpriteTargetByName(args.SPRITE1);
const sprite2 = runtime.getSpriteTargetByName(args.SPRITE2);
const attr1 = this.getAttribute(args.SPRITE1);
const attr2 = this.getAttribute(args.SPRITE2);
const target = [(attr1[1] / 2) * ((sprite2.size / 100) -1), (attr1[0] / 2) * ((sprite2.size / 100) -1)];
const target2 = [(attr2[1] / 2) * ((sprite1.size / 100) -1), (attr2[0] / 2) * ((sprite1.size / 100) -1)];
switch (args.SIDE) {
case "below":
return sprite2.y - target[0] < sprite1.y - target2[0];
case "above":
return sprite2.y + target[0] > sprite1.y + target2[0];
case "beside right":
return sprite2.x + target[0] > sprite1.x + target2[0];
case "beside left":
return sprite2.x - target[0] < sprite1.x - target2[0];
default:
break;
}
}

setOnSprite(args) {
let offset = Scratch.Cast.toNumber(args.OFFSET);
const spriteAtt = this.getAttribute(args.SPRITE1);
const target1 = runtime.getSpriteTargetByName(args.SPRITE1);
const target = runtime.getSpriteTargetByName(args.SPRITE2);
let x;
let y;
const spriteAtt2 = this.getAttribute(args.SPRITE2);
const x2 = spriteAtt2[0] / 2;
const y2 = spriteAtt2[1] / 2;
offset = offset + Math.round(spriteAtt[2] + spriteAtt2[2]);
switch (args.SIDE) {
case "top":
x = target1.x;
y = target1.y + (spriteAtt[1] / 2) + y2;
target.setXY(x, y + offset);
break;
case "bottom":
x = target1.x;
y = target1.y - (spriteAtt[1] / 2) - y2;
target.setXY(x, y - offset);
break;
case "left side":
x = target1.x - (spriteAtt[0] / 2) - x2;
y = target1.y;
target.setXY(x - offset, y);
break;
case "right side":
x = target1.x + (spriteAtt[0] / 2) + x2;
y = target1.y;
target.setXY(x + offset, y);
break;
case "same top level":
x = target.x;
y = target1.y + (spriteAtt[1] / 2) + y2;
target.setXY(x, y + offset);
break;
case "same bottom level":
x = target.x;
y = target1.y - (spriteAtt[1] / 2) - y2;
target.setXY(x, y - offset);
break;
case "same left level":
x = target1.x - (spriteAtt[0] / 2) - x2;
y = target.y;
target.setXY(x - offset, y);
break;
case "same right level":
x = target1.x + (spriteAtt[0] / 2) + x2;
y = target.y;
target.setXY(x + offset, y);
break;
default:
break;
}
}

getAttribute(sprite) {
const target = runtime.getSpriteTargetByName(sprite);
const costumeNum = target.currentCostume + 1;
const costumeIndex = this.getCostumeInput(costumeNum, target);
const costume = target.sprite.costumes[costumeIndex];
const width = Scratch.Cast.toNumber(costume.size[0]);
const height = Scratch.Cast.toNumber(costume.size[1]);
const size = (Math.round(target.size) - 100) / 2.1;
const costumeInfo = [Math.ceil(width), Math.ceil(height), size];
return costumeInfo;
}

getCostumeInput(costume, target) {
if (typeof costume === "number") {
costume = Math.round(costume - 1);
if (costume === Infinity || costume === -Infinity || !costume) {
costume = 0;
}
return costume;
} else {
return target.getCostumeIndexByName(Scratch.Cast.toString(costume));
}
}
}

Scratch.extensions.register(new LZcollisionsSP());
})(Scratch);
Loading

0 comments on commit 66b1c64

Please sign in to comment.