Created
December 3, 2024 13:15
-
-
Save j0rd1s3rr4n0/535702487cb3287d325430a3554c463a to your computer and use it in GitHub Desktop.
AntiAFK Using JavaScript
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
try{ | |
// Selecciona el elemento sobre el que deseas realizar scroll | |
var element = document.querySelector("#message-pane-layout-a11y > div.ui-flex.a.cb.cc.cd.ci.cj.cl.cm.cn.co > div > div > div.fui-Primitive.___vw6lhn0.f1yrx710.f1l02sjl.f1115ve7.fp1ilsu.f1uhpfwc.fpk1gq1.f12t0xb8.f1gobicx.fl27ibc.f8k3ltm.f1qrc9k7.fmyufbi.fswk967"); | |
// Query Selector de Chat de Microsoft Teams. Cambiar a voluntad. | |
// Variables para controlar la dirección del scroll | |
var scrollingDown = true; // Indica si está bajando o subiendo | |
var scrollSpeed = 20; // Velocidad del scroll en píxeles por paso (ajusta según necesidad) | |
// Función para manejar el scroll | |
function scrollLoop() { | |
if (scrollingDown) { | |
// Si está bajando | |
element.scrollTop += scrollSpeed; | |
// Verifica si alcanzó el fondo | |
if (element.scrollTop + element.clientHeight >= element.scrollHeight) { | |
scrollingDown = false; // Cambia la dirección | |
} | |
} else { | |
// Si está subiendo | |
element.scrollTop -= scrollSpeed; | |
// Verifica si alcanzó la parte superior | |
if (element.scrollTop <= 0) { | |
scrollingDown = true; // Cambia la dirección | |
} | |
} | |
// Llama a la función de nuevo lo más rápido posible | |
requestAnimationFrame(scrollLoop); | |
} | |
// Inicia el bucle | |
scrollLoop(); | |
}catch(error){console.error(error);} | |
try{ | |
// Crear un elemento para representar el cursor emulado | |
const virtualCursor = document.createElement('div'); | |
virtualCursor.style.position = 'absolute'; | |
virtualCursor.style.width = '16pt'; // Ajusta el ancho del cursor | |
virtualCursor.style.height = '16pt'; // Ajusta la altura del cursor | |
virtualCursor.style.pointerEvents = 'none'; // Permitir interacción con otros elementos | |
virtualCursor.style.zIndex = '10000'; // Asegurarse de que esté visible sobre otros elementos | |
// Establecer la imagen del cursor (el URL que proporcionaste) | |
virtualCursor.style.backgroundImage = 'url("")'; | |
virtualCursor.style.backgroundSize = 'contain'; // Ajustar la imagen al tamaño del div | |
virtualCursor.style.backgroundRepeat = 'no-repeat'; // Evitar que se repita la imagen | |
document.body.appendChild(virtualCursor); | |
// Función para generar coordenadas aleatorias | |
function getRandomCoordinates() { | |
// Obtener el tamaño de la ventana | |
const maxWidth = window.innerWidth; | |
const maxHeight = window.innerHeight; | |
return { | |
x: Math.random() * (maxWidth - 32), // Restar el ancho del cursor para evitar desbordamiento | |
y: Math.random() * (maxHeight - 32), // Restar la altura del cursor para evitar desbordamiento | |
}; | |
} | |
// Función para mover el cursor de forma aleatoria | |
function moveCursorRandomly(duration = 1000) { | |
const { x: endX, y: endY } = getRandomCoordinates(); // Generar coordenadas finales | |
const startX = parseFloat(virtualCursor.style.left) || 0; | |
const startY = parseFloat(virtualCursor.style.top) || 0; | |
const steps = 25; // Número de pasos para el movimiento suave | |
const interval = duration / steps; // Tiempo por paso | |
const deltaX = (endX - startX) / steps; | |
const deltaY = (endY - startY) / steps; | |
let currentX = startX; | |
let currentY = startY; | |
for (let i = 0; i <= steps; i++) { | |
setTimeout(() => { | |
currentX += deltaX; | |
currentY += deltaY; | |
// Mover el cursor emulado | |
virtualCursor.style.left = `${currentX}px`; | |
virtualCursor.style.top = `${currentY}px`; | |
// Emitir eventos de mousemove | |
const event = new MouseEvent('mousemove', { | |
clientX: currentX, | |
clientY: currentY, | |
bubbles: true, | |
cancelable: true, | |
view: window | |
}); | |
document.dispatchEvent(event); | |
// Al finalizar el movimiento, iniciar otro | |
if (i === steps) { | |
moveCursorRandomly(); // Llama de nuevo para movimiento infinito | |
} | |
}, i * interval); | |
} | |
} | |
// Iniciar el movimiento aleatorio infinito | |
moveCursorRandomly(); | |
}catch(errortwo){console.error(errortwo);} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment