Skip to content

Instantly share code, notes, and snippets.

@j0rd1s3rr4n0
Created December 3, 2024 13:15
Show Gist options
  • Save j0rd1s3rr4n0/535702487cb3287d325430a3554c463a to your computer and use it in GitHub Desktop.
Save j0rd1s3rr4n0/535702487cb3287d325430a3554c463a to your computer and use it in GitHub Desktop.
AntiAFK Using JavaScript
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