regl实现多色方块粒子组成数字翻转动画效果
代码语言:html
所属分类:三维
代码描述:regl实现多色方块粒子组成数字翻转动画效果
下面为部分代码预览,完整代码请点击下载或在bfwstudio webide中打开
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <style> html, body { height: 100%; } body { background-image: radial-gradient(ellipse at center, #2c0c00 8.0%, #000 100.0%); background-size: 160% 160%; background-position: 50% 50%; overflow: hidden; } h1 { position: relative; z-index: 1; color: rgb(255, 94, 30); font-family: 'Luckiest Guy', sans-serif; font-size: min(8vw, 64px); text-align: center; top: 65vh; } img { display: none; } </style> </head> <body translate="no"> <h1>Followers!</h1> <img src="" /> <script type="text/javascript" src="http://repo.bfw.wiki/bfwrepo/js/regl.min.js"></script> <script type="text/javascript" src="http://repo.bfw.wiki/bfwrepo/js/gl-matrix-min.js"></script> <script> console.clear(); //////////// // CONFIG // //////////// // Affects number of cubes generated const DENSITY = 1; const LAYERS = 5; // Colors are in rgb format const COLORS = [ [1.000, 0.655, 0.231], [1.000, 0.365, 0.114], [0.898, 0.078, 0.392], [0.424, 0.5, 0.114] ]; const GAMMA = 1.8; const CLEAR_COLOR = [0, 0, 0, 0]; // Time in seconds for all cubes to wrap around once. const SCROLL_TIME = 10; // Radians per second const ROTATE_MIN = 0.5; const ROTATE_MAX = 4.2; // Meters const SIZE_MIN = 0.032; const SIZE_MAX = 0.064; // Randomize placement (meters) const OFFSET_JITTER = 0.025; // Camera controls const CAMERA_DISTANCE = 3.5; const CAMERA_FOV = 0.7; const CAMERA_NEAR = 1; const CAMERA_FAR = 100; //////////////////////// // COMPUTED CONSTANTS // //////////////////////// // Number of cubes on each axis const COUNT_X = Math.floor(32 * DENSITY); const COUNT_Y = Math.floor(16 * DENSITY); const COUNT_Z = Math.floor(LAYERS); const COUNT_TOTAL = COUNT_X * COUNT_Y * COUNT_Z; // Bounding volume dimensions (meters) const BOUND_WIDTH = 2; const BOUND_HEIGHT = COUNT_Y / COUNT_X * BOUND_WIDTH; const BOUND_DEPTH = COUNT_Z / COUNT_X * BOUND_WIDTH; ////////////////// // MATH HELPERS // ////////////////// const TAU = Math.PI * 2; const random = (min, max) => Math.random() * (max - min) + min; const interpolate = (a, b, mix) => (b - a) * mix + a; ///////////////// // APPLICATION // ///////////////// const regl = createREGL({ extensions: ['angle_instanced_arrays'] }); const textTexture = regl.texture({ format: 'rgb', data: document.querySelector('img'), mag: 'linear', min: 'linear' }); const viewMatrix = mat4.fromTranslation([], [0, 0.25, -CAMERA_DISTANCE]); const projectionMatrix = []; const projectionViewMatrix = []; // Gamma correct colors COLORS.forEach(c => { c[0] = Math.pow(c[0], GAMMA); c[1] = Math.pow(c[1], GAMMA); c[2] = Math.pow(c[2], GAMMA); }); // Color of each cube const colors = new Float32Array(3 * COUNT_TOTAL); // Position of each cube const offsets = new Float32Array(3 * COUNT_TOTAL); // Base scale of each cube const scales = new Float32Array(COUNT_TOTAL); // Axis of rotation for each cube const rotationAxes = new Float32Array(3 * COUNT_TOTAL); // Rotation angle for each cube const angles = new Float32Array(COUNT_TOTAL); // Rotation speed for each cube (radi.........完整代码请登录后点击上方下载按钮下载查看
网友评论0