Skip to content

Commit

Permalink
ok
Browse files Browse the repository at this point in the history
  • Loading branch information
hammouda101010 committed Oct 8, 2024
1 parent 62684dc commit ccf3668
Showing 1 changed file with 80 additions and 75 deletions.
155 changes: 80 additions & 75 deletions extensions/Hammouda101010/mousespeed.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,101 +4,106 @@
// By: Hammouda101010 <https://scratch.mit.edu/users/hammouda101010/>
// License: MIT

(function(Scratch) {
'use strict';

if (!Scratch.extensions.unsandboxed) {
throw new Error('This Hello World example must run unsandboxed');
}
// Block Icon
const blockIconURI = ""
const menuIconURI = ""
(function (Scratch) {
"use strict";

// Scratch's VM
const vm = Scratch.vm;
if (!Scratch.extensions.unsandboxed) {
throw new Error("This Hello World example must run unsandboxed");
}
// Block Icon
const blockIconURI =
"";
const menuIconURI =
"";

// Scratch's VM
const vm = Scratch.vm;

class MouseSpeed {
class MouseSpeed {
constructor() {
this.mouseX = 0; // Current mouse X position
this.mouseY = 0; // Current mouse Y position
this.lastX = 0; // Previous mouse X position
this.lastY = 0; // Previous mouse Y position
this.lastTime = performance.now(); // Last time the mouse was updated
this.speed = 0; // Speed of the mouse
this.mouseX = 0; // Current mouse X position
this.mouseY = 0; // Current mouse Y position
this.lastX = 0; // Previous mouse X position
this.lastY = 0; // Previous mouse Y position
this.lastTime = performance.now(); // Last time the mouse was updated
this.speed = 0; // Speed of the mouse

// Bind this to the event listener to track mouse movement
vm.renderer.canvas.addEventListener("mousemove",this.handleMouseMove.bind(this));
// Bind this to the event listener to track mouse movement
vm.renderer.canvas.addEventListener(
"mousemove",
this.handleMouseMove.bind(this)
);

// Start a continuous update interval to constantly track mouse speed
setInterval(() => this.updateMouseSpeed(), 50); // Updates every 50ms
// Start a continuous update interval to constantly track mouse speed
setInterval(() => this.updateMouseSpeed(), 50); // Updates every 50ms
}

getInfo() {
return {
id: 'mousespeed',
name: 'Mouse Speed',
menuIconURI: menuIconURI,
blockIconURI: blockIconURI,
docsURI: 'https://extensions.turbowarp.org/Hammouda101010/mousespeed',
color1: "#38C3E5",
color2: "#33A5C1",
blocks: [
{
opcode: 'getMouseSpeed',
blockType: Scratch.BlockType.REPORTER,
text: 'mouse speed'
},
{
opcode: 'mouseFaster',
blockType: Scratch.BlockType.BOOLEAN,
text: 'is mouse faster than [SPEED]?',
arguments: {
SPEED:{
type: Scratch.ArgumentType.NUMBER,
defaultValue: 50
}
}
},
]
};
}
return {
id: "mousespeed",
name: "Mouse Speed",
menuIconURI: menuIconURI,
blockIconURI: blockIconURI,
docsURI: "https://extensions.turbowarp.org/Hammouda101010/mousespeed",
color1: "#38C3E5",
color2: "#33A5C1",
blocks: [
{
opcode: "getMouseSpeed",
blockType: Scratch.BlockType.REPORTER,
text: "mouse speed",
},
{
opcode: "mouseFaster",
blockType: Scratch.BlockType.BOOLEAN,
text: "is mouse faster than [SPEED]?",
arguments: {
SPEED: {
type: Scratch.ArgumentType.NUMBER,
defaultValue: 50,
},
},
},
],
};
}

// Handles Mouse Speed
// Handles Mouse Speed
handleMouseMove(event) {
this.mouseX = event.clientX;
this.mouseY = event.clientY;
this.mouseX = event.clientX;
this.mouseY = event.clientY;
}

//Updates Mouse Speed:
updateMouseSpeed() {
const currentTime = performance.now();
const timeElapsed = (currentTime - this.lastTime) / 1000; // Time in seconds
const currentTime = performance.now();
const timeElapsed = (currentTime - this.lastTime) / 1000; // Time in seconds

if (timeElapsed > 0) {
const dx = this.mouseX - this.lastX;
const dy = this.mouseY - this.lastY;
if (timeElapsed > 0) {
const dx = this.mouseX - this.lastX;
const dy = this.mouseY - this.lastY;

// Calculate the distance traveled by the mouse
const distance = Math.sqrt(dx * dx + dy * dy);
// Calculate the distance traveled by the mouse
const distance = Math.sqrt(dx * dx + dy * dy);

// Calculate speed in pixels per second
this.speed = distance / timeElapsed;
}
// Calculate speed in pixels per second
this.speed = distance / timeElapsed;
}

// Update the last known mouse position and time
this.lastX = this.mouseX;
this.lastY = this.mouseY;
this.lastTime = currentTime;
// Update the last known mouse position and time
this.lastX = this.mouseX;
this.lastY = this.mouseY;
this.lastTime = currentTime;
}

getMouseSpeed() { //Gets Mouse Speed
return Math.round(this.speed / 50); // Return the rounded speed
}
mouseFaster(args) { // Checks if mouse speed is greater than the SPEED arg
return this.getMouseSpeed() > args.SPEED;
getMouseSpeed() {
//Gets Mouse Speed
return Math.round(this.speed / 50); // Return the rounded speed
}
}
Scratch.extensions.register(new MouseSpeed());
mouseFaster(args) {
// Checks if mouse speed is greater than the SPEED arg
return this.getMouseSpeed() > args.SPEED;
}
}
Scratch.extensions.register(new MouseSpeed());
})(Scratch);

0 comments on commit ccf3668

Please sign in to comment.