canvas实现数字毛发生长动画效果代码

代码语言:html

所属分类:动画

代码描述:canvas实现数字毛发生长动画效果代码,毛发生长形成一个数字。

代码标签: 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