【前端】弹球特效(重力模拟)
创始人
2025-01-08 18:05:53
0

在这里插入图片描述
在这里插入图片描述

弹球特效

文章目录

    • 弹球特效

请添加图片描述

import React, { useRef, useEffect } from 'react';  const BouncingBallSimulation = () => {   const canvasRef = useRef(null);    useEffect(() => {     const canvas = canvasRef.current;     const ctx = canvas.getContext('2d');     let animationFrameId;      // Set canvas size     canvas.width = 900;     canvas.height = 1600;      // Circle properties     const centerX = canvas.width / 2;     const centerY = canvas.height / 2;     const radius = Math.min(centerX, centerY) * 0.7;      // Ball properties     const ballRadius = 15;     let x = centerX;     let y = centerY - radius + ballRadius;     let dx = 2;     let dy = 0;      // Gravity and friction     const gravity = 0.2;     const friction = 0.99;      // Matrix rain properties     const fontSize = 14;     const columns = canvas.width / fontSize;     const drops = [];     for (let i = 0; i < columns; i++) {       drops[i] = 1;     }      const drawMatrixRain = () => {       ctx.fillStyle = 'rgba(0, 0, 0, 0.05)';       ctx.fillRect(0, 0, canvas.width, canvas.height);        ctx.fillStyle = '#0F0';       ctx.font = `${fontSize}px monospace`;        for (let i = 0; i < drops.length; i++) {         const text = String.fromCharCode(0x30A0 + Math.random() * 96);         ctx.fillText(text, i * fontSize, drops[i] * fontSize);          if (drops[i] * fontSize > canvas.height && Math.random() > 0.975) {           drops[i] = 0;         }         drops[i]++;       }     };      const draw = () => {       ctx.clearRect(0, 0, canvas.width, canvas.height);        // Draw matrix rain       drawMatrixRain();        // Draw circle       ctx.beginPath();       ctx.arc(centerX, centerY, radius, 0, Math.PI * 2);       ctx.strokeStyle = 'rgba(255, 255, 255, 0.5)';       ctx.stroke();        // Draw ball       ctx.beginPath();       ctx.arc(x, y, ballRadius, 0, Math.PI * 2);       ctx.fillStyle = 'white';       ctx.fill();        // Apply gravity       dy += gravity;        // Ball movement and collision detection       const nextX = x + dx;       const nextY = y + dy;       const distanceFromCenter = Math.sqrt((nextX - centerX) ** 2 + (nextY - centerY) ** 2);        if (distanceFromCenter + ballRadius > radius) {         // Calculate the normal vector         const nx = (nextX - centerX) / distanceFromCenter;         const ny = (nextY - centerY) / distanceFromCenter;          // Calculate the dot product         const dotProduct = dx * nx + dy * ny;          // Update velocity         dx = (dx - 2 * dotProduct * nx) * friction;         dy = (dy - 2 * dotProduct * ny) * friction;       } else {         x = nextX;         y = nextY;       }        animationFrameId = requestAnimationFrame(draw);     };      draw();      return () => {       cancelAnimationFrame(animationFrameId);     };   }, []);    return (     
canvasRef} className="border border-gray-300" />
); }; export default BouncingBallSimulation;

在这里插入图片描述

相关内容

热门资讯

四分钟经验!微信小程序破解内购... 四分钟经验!微信小程序破解内购,新西游辅助器(辅助)确实是有脚本(哔哩哔哩)1)微信小程序破解内购免...
第一分钟手册!欢乐达人透视脚本... 第一分钟手册!欢乐达人透视脚本,超级三加一辅助软件(辅助)一直真的有app(哔哩哔哩)1、许多玩家不...
第7分钟策略!杭州都莱辅助软件... 第7分钟策略!杭州都莱辅助软件有没有用,方片十三张外卦(辅助)一直存在有app(哔哩哔哩)1、完成杭...
九分钟练习!约局八辅助器,海螺... 九分钟练习!约局八辅助器,海螺众娱辅助(辅助)原来真的是有辅助器(哔哩哔哩)约局八辅助器透视方法中分...
四分钟绝活!微信小程序边锋干橙... 四分钟绝活!微信小程序边锋干橙眼辅助,超级三加一正版(辅助)果然存在有app(哔哩哔哩)1、操作简单...
第九分钟课程!微信卡农辅助,新... 第九分钟课程!微信卡农辅助,新九游辅助器软件激活码(辅助)果然真的是有软件(哔哩哔哩)一、新九游辅助...
两分钟手筋!新道游科技透视收费... 两分钟手筋!新道游科技透视收费,财神十三张脚本效果图(辅助)一贯有挂下载(哔哩哔哩)1、不需要AI权...
七分钟法子!情怀游戏辅助器,九... 七分钟法子!情怀游戏辅助器,九游破解辅助插件教程(辅助)一贯是有辅助器(哔哩哔哩);1、七分钟法子!...
2分钟总结!杭州都莱挂,九游破... 2分钟总结!杭州都莱挂,九游破解版真的假的(辅助)切实真的是有插件(哔哩哔哩)1、九游破解版真的假的...
四分钟诀窍!四川麻将血战如何开... 四分钟诀窍!四川麻将血战如何开挂辅助,财神十三章安装包(辅助)真是真的是有app(哔哩哔哩)1、这是...