canvas实现数字毛发生长动画效果代码
代码语言:html
所属分类:动画
代码描述:canvas实现数字毛发生长动画效果代码,毛发生长形成一个数字。
下面为部分代码预览,完整代码请点击下载或在bfwstudio webide中打开
<!DOCTYPE html> <html lang="en" > <head> <meta charset="UTF-8"> <style> *, *::before, *::after { margin: 0; padding: 0; border: 0; box-sizing: border-box; } *:focus { outline: none; } body { height: 100vh; height: 100dvh; overflow: hidden; } canvas { touch-action: none; } </style> </head> <body translate="no"> <script> const imageSrc = ''; </script> <script id="rendered-js" > //--- 'use strict'; //--- console.clear(); //--- let w = 0; let h = 0; let renderIteration = 0; let animationFrame = null; let isTouchDevice = false; const dpr = Math.max(1, window.devicePixelRatio); const canvas = document.createElement('canvas'); const context = canvas.getContext('2d', { alpha: false, willReadFrequently: true }); let imageSource = null; const canvasSource = document.createElement('canvas'); const contextSource = canvasSource.getContext('2d', { alpha: false, willReadFrequently: true }); const border = { left: 0, top: 0, right: w, bottom: h }; const center = { x: 0, y: 0 }; let imageData = null; let data = null; let imageDataSource = null; let dataSource = null; //--- const sectorTiles = 20; let sectorSizeX = 0; let sectorSizeY = 0; let sectors = new Map(); let sectorsX = 0; let sectorsY = 0; //--- let boidHolder = []; let boidCount = 2048; let boidIndex = 0; const boidRadius = 6; const boidDiameter = boidRadius * 2; const boidDiameterSquared = boidDiameter * boidDiameter; let boidSpeed = 1; const boidSpeedMin = 0; const boidSpeedMax = 2.5; const boidRadialSpeed = Math.PI / 60; const boidVision = 50; const boidVisionSquared = boidVision * boidVision; const boidRadialSpeedMin = Math.PI / 10; const boidRadialSpeedMax = Math.PI / 60; const boidRepulsionDistance = 100; const boidRepulsionDistanceSquared = boidRepulsionDistance * boidRepulsionDistance; let boidCounterMax = 0; let boidOffsetMax = 0; //--- let pointerInitialPos = { x: -boidRepulsionDistance, y: -boidRepulsionDistance }; let pointer = { x: 0, y: 0 }; let pointerPos = { x: 0, y: 0 }; let pointerDownButton = -1; let pointerActive = false; //--- function init() { isTouchDevice = 'ontouchstart' in window || navigator.maxTouchPoints > 0 || navigator.msMaxTouchPoints > 0; //--- if (isTouchDevice === true) { boidCount *= 0.75; canvas.addEventListener('touchmove', cursorMoveHandler, false); canvas.addEventListener('touchend', cursorLeaveHandler, false); canvas.addEventListener('touchcancel ', cursorLeaveHandler, false); } else { canvas.addEventListener('pointermove', cursorMoveHandler, false); canvas.addEventListener('pointerdown', cursorDownHandler, false); canvas.addEventListener('pointerup', cursorUpHandler, false); canvas.addEventListener('pointerleave', cursorLeaveHandler, false); } //--- document.body.appendChild(canvas); //--- // canvasSource.style.pointerEvents = 'none'; // canvasSource.style.position = 'absolute'; // canvasSource.style.top = '0'; // canvasSource.style.left = '0'; // canvasSource.style.opacity = '0.25'; document.body.appendChild(canvasSource); //--- imageSource = new Image(); imageSource.src = imageSrc; imageSource.onload = () => { window.addEventListener('resize', onResize, false); restart(); }; } function onResize(event) { restart(); } function restart() { const innerWidth = window.innerWidth || document.documentElement.clientWidth || document.body.clientWidth; const innerHeight = window.innerHeight || document.documentElement.clientHeight || document.body.clientHeight; //--- w = innerWidth; h = innerHeight; //--- canvas.width = w * dpr; canvas.height = h * dpr; canvasSource.width = w * dpr; canvasSource.height = h * dpr; //--- const imageAspectRatio = imageSource.width / imageSource.height; const canvasAspectRatio = w / h; let drawWidth = 0; let drawHeight = 0; if (canvasAspectRatio > imageAspectRatio) { drawWidth = w; drawHeight = w / imageAspectRatio; } else { drawHeight = h; drawWidth = h * imageAspectRatio; } const offsetX = (w - drawWidth) * 0.5; const offsetY = (h - drawHeight) * 0.5; contextSource.drawImage(imageSource, offsetX, offsetY, drawWidth, drawHeight); //--- imageData = context.getImageData(0, 0, w, h); data = imageData.data; imageDataSource = contextSource.getImageData(0, 0, w, h); dataSource = imageDataSource.data; //--- sectorSizeX = Math.floor(w / sectorTiles); sectorSizeY = Math.floor(h / sectorTiles); sectors = new Map(); sectorsX = Math.ceil(w / sectorSizeX); sectorsY = Math.ceil(h / sectorSizeY); //--- border.right = w - 1; border.bottom = h - 1; center.x = w / 2; center.y = h / 2; pointerPos.x = pointerInitialPos.x; pointerPos.y = pointerInitialPos.y; pointer.x = pointerInitialPos.x; pointer.y = pointerInitialPos.y; //--- boidCounterMax = Math.round(Math.min(w, h) / 48); //--- removeBoids(); createBoids(); //--- if (animationFrame != null) { cancelAnimFrame(animationFrame); } render(); } //--- function removeBoids() { boidIndex = 0; boidHolder = []; } function createBoids() { for (let i = 0; i < boidCount; i++) { const boid = createBoid(0, 0, 0, i); boidHolder.push(boid); } } function createBoid(x, y, heading = Math.random() * 2 * Math.PI - Math.PI, id = 0) { const boid = {}; resetBoid(boid, x, y, heading); boid.id = id; return boid; } function activateBoids() { for (let i = 0; i < 16; i++) { activateBoid(); } } function activateBoid() { const angle = Math.random() * Math.PI * 2; const distance = Math.random() * (Math.min(w, h) * 0.5); const x = center.x + Math.cos(angle) * distance; const y = center.y + Math.sin(angle) * distance; const color = getPixel(x | 0, y | 0); if (color.r < 55 && color.g < 55 && color.b < 55 || distance .........完整代码请登录后点击上方下载按钮下载查看
网友评论0