您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Making the pixels speak
// ==UserScript== // @name PixelCat // @namespace https://github.com/pixelcattt/core // @version 0.0.1 // @description Making the pixels speak // @author Timothy Lau // @match https://www.bilibili.com/video/* // @match https://www.youtube.com/watch?v=* // @license MIT // @icon  // @grant none // ==/UserScript== // canvas width & height const width = 640; const height = 360; // ==! DO NOT CHANGE !== const sigma = 10; const rho = 28; const beta = 8 / 3; // ==! DO NOT CHANGE !== /** * Equivalent to the key * !! You should ensure that the variable of x,y,z is in the range of 0-1. */ let x = 0.1; let y = 0; let z = 0; const chaoticSequence = []; // Generate chaoticSequence const simulateLorenzAttractor = () => { const dt = 0.01; const dx = sigma * (y - x) * dt; const dy = (x * (rho - z) - y) * dt; const dz = (x * y - beta * z) * dt; x = x + dx; y = y + dy; z = z + dz; chaoticSequence.push(Math.abs(x)); }; for (let i = 0; i < width * height * 4; i++) { simulateLorenzAttractor(); } function decrypt(imageData, seq) { let index = imageData.data.length / 4; let pixel_count = imageData.data.length; for (let i = imageData.data.length; i > 0; i -= 4) { const newIndex = Math.floor((Math.floor(seq[index] * pixel_count) % pixel_count) / 4) * 4; [imageData.data[i], imageData.data[newIndex]] = [imageData.data[newIndex], imageData.data[i]]; [imageData.data[i + 1], imageData.data[newIndex + 1]] = [imageData.data[newIndex + 1], imageData.data[i + 1]]; [imageData.data[i + 2], imageData.data[newIndex + 2]] = [imageData.data[newIndex + 2], imageData.data[i + 2]]; index--; } } function injectBilibili() { var observer = new MutationObserver(mutations => { const video = document.querySelector('video'); const canvas = document.querySelector('#canvas'); if (video != null && canvas == null) { let _c = document.createElement('canvas'); _c.id = 'canvas'; _c.style = 'display: block;z-index: 0;position: absolute;right: 0px;bottom: 0px; width: 100%; height: 100%'; video.parentElement.appendChild(_c); video.style = 'display: none'; video.addEventListener('play', () => { const _ctx = _c.getContext('2d'); _c.width = width; _c.height = height; const loop = function () { if (!video.paused && !video.ended) { _ctx.drawImage(video, 0, 0, video.videoWidth, video.videoHeight, 0, 0, _c.width, _c.height); const imageData = _ctx.getImageData(0, 0, _c.width, _c.height); decrypt(imageData, chaoticSequence); _ctx.putImageData(imageData, 0, 0); requestAnimationFrame(loop); } }; loop(); }); } }); observer.observe(document.body, { childList: true, subtree: true }); } function injectYoutube() { // Todo } (function () { 'use strict'; var strategy = { 0: injectBilibili, 1: injectYoutube }[ GM_info.script.matches .map(rule => rule.replace(/\.|\*|\/|\?/g, match => ({ '.': '\\.', '*': '.*', '/': '\\/', '?': '\\?' }[match]))) .map(rule => new RegExp(rule)) .map((regExp, index) => (regExp.test(window.location.href) ? index : null)) .filter(index => index != null) .join() ]; strategy(); })();