精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

分享CodePen上六個酷炫demo特效

開發 前端
將圖像的低分辨率版本放在頂部,并將其擴展以占據與原始圖像相同的大小,使瀏覽器對其進行像素化。然后,懸停時的蒙版(使用 JS 更新位置)完成剩下的工作。巧妙而有效。

最近創作靈感匱乏, 來 CodePen 上找找靈感, 同時也給同樣需要獲取靈感的 coder (程序員們)帶來一點點想象空間。

首先分享一下 CodePen demo 集合網址:

  • https://codepen.io/spark

1、像素背景

這是 Wakana Y.K. 的一個巧妙的技巧:將圖像的低分辨率版本放在頂部,并將其擴展以占據與原始圖像相同的大小,使瀏覽器對其進行像素化。然后,懸停時的蒙版(使用 JS 更新位置)完成剩下的工作。巧妙而有效。

css代碼如下:

@import url("https://fonts.googleapis.com/css2?family=Lexend:wght@400&display=swap");
:root {
  --x: 50%;
  --y: 50%;
  --radius: 30vmin;
  --blur: 3vmax;
}
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
html,
body {
  background-color: black;
  overscroll-behavior-x: none;
  overscroll-behavior-y: none;
  overflow: hidden;
}
body {
  width: 100vw;
  height: 100vh;
  font-family: "Lexend", serif;
  text-align: center;
  line-height: 1;
  display: flex;
  justify-content: center;
  align-items: center;
}
main {
  z-index: 1;
}
h1 {
  font-size: 7vw;
  color: white;
  text-shadow: 1px 1px 1vw rgba(0, 0, 0, 0.3);
}
#bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
}
#bg img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  pointer-events: none;
  -webkit-user-select: none;
  user-select: none;
}
#bg_focus {
  mask-image: radial-gradient(
    circle 50vmin at var(--x) var(--y),
    black var(--radius),
    transparent calc(var(--radius) + var(--blur)),
    transparent
  );
}
#bg_pixelate {
  image-rendering: pixelated;
}
/*
#bg img:nth-of-type(2) {
  filter: hue-rotate(50deg);
  animation-name: animation;
  animation-duration: 0.5s;
  animation-iteration-count: infinite;
  animation-timing-function: linear;
  animation-direction: alternate;
}
@keyframes animation {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
*/

2、煙火特效

圖片

用技術復原童年的煙火味, css代碼:

<css-doodle click-to-update><style>
  @grid: 30 / 60vmin noclip;
  border-radius: 50%;
  background: hsl(@y(* -12), 80%, 60%);
  background: lch(90, 120, @y(*10deg));
  animation: f @once.p(5s, 7.5s) ease infinite;
  animation-delay: $s(-90/@I*@i(-1)*@x/@y);
  @keyframes f {
    0%, 25%, 80% {opacity: 1; scale: .2}
    25%, 75%, 100% {opacity: 0; scale: @r(2, 3)}
  }
 </style></css-doodle>

3、動態模糊

Tom Hinton 的這個演示吸引我的是它看起來多么隨機和奇怪(以一種好的方式)(這在 Tom 的藝術作品中相對常見。ThreeJS 中著色器和網格的組合。

js 代碼如下:

let camera, scene, renderer, clock;
let uniforms;

function init() {
  const container = document.getElementById("shader");

  clock = new THREE.Clock();
  camera = new THREE.Camera();
  camera.position.z = 1;

  scene = new THREE.Scene();

  const geometry = new THREE.PlaneBufferGeometry(2, 2);
  
    const texture = new THREE.TextureLoader().load( 'https://upload.wikimedia.org/wikipedia/commons/8/84/Male_and_female_chicken_sitting_together.jpg' );

  uniforms = {
    u_time: { type: "f", value: 1.0 },
    u_resolution: { type: "v2", value: new THREE.Vector2() },
    uTexture: {
      value: texture
    }
  };

  const material = new THREE.ShaderMaterial({
    uniforms,
    vertexShader: document.getElementById("vertex").textContent,
    fragmentShader: document.getElementById("fragment").textContent
  });
  
  material.transparent = true

  const mesh = new THREE.Mesh(geometry, material);
  scene.add(mesh);

  renderer = new THREE.WebGLRenderer({alpha: true});
  renderer.setPixelRatio(window.devicePixelRatio);

  container.appendChild(renderer.domElement);

  onWindowResize();
  window.addEventListener("resize", onWindowResize);
}

function onWindowResize() {
  renderer.setSize(window.innerWidth, window.innerHeight);
  uniforms.u_resolution.value.x = renderer.domElement.width;
  uniforms.u_resolution.value.y = renderer.domElement.height;
}

function render() {
  uniforms.u_time.value = clock.getElapsedTime();
  renderer.render(scene, camera);
}

function animate() {
  render();
  requestAnimationFrame(animate);
}

init();
animate();

4、雪球圣誕樹

Amit Sheen 在 YouTube 上直播了整個過程(您仍然可以在他的頻道上觀看),讓每個人都了解如何使用 HTML 和 CSS 創建這棵 3D 外觀的圣誕樹。

css代碼:

*, *::before, *::after {
    padding: 0;
    margin: 0 auto;
    box-sizing: border-box;
}

body {
  background-color: #001;
  color: #fff;
  min-height: 100vh;
  display: grid;
  place-items: center;
  perspective: 1000px;
  overflow: hidden;
  
  * {
    transform-style: preserve-3d;
  }
}

$srDuration: 120s;
$flDuration: 12s;

.scene {
  position: relative;
  animation: sceneRotate $srDuration infinite linear;
  
  @keyframes sceneRotate {
    to { rotate: y 1turn; }
  }
  
  * { position: absolute; }
}

.floor {
  inset: -100em;
  background-color: green;
  transform: rotateX(-90deg) translateZ(15em);
  background-image:
    radial-gradient(closest-side, transparent, #001),
    radial-gradient(closest-side, #000, transparent 15em),
    repeating-linear-gradient(#fff2 0, transparent, #fff2 2em),
    repeating-linear-gradient(90deg, #fff2 0, transparent, #fff2 2em)
    ;
}

.snowglobe {
  cursor: pointer;
  animation: var(--animation, snowglobe) $flDuration;
  
  @keyframes snowglobe {
    0%, 100% { pointer-events: none; }
  }

  &:active {
    --animation: none;
  }
}

.text {
  top: -20em;
  animation: sceneRotate $srDuration infinite linear reverse;
  
  i {
    font-size: 3em;  
    width: max-content; 
    translate: -50%;
    animation: var(--animation, text) $flDuration ease-in-out;
    
    @keyframes text {
      0%, 95% { opacity: 0; } 
      100% { opacity: 1; } 
    }  
  }
}

.base {
  transform: translateY(11em);
  
  i {
    inset: -10em -2.7em;
    background-color: maroon;
    background-image: radial-gradient(circle, transparent, 90%, #0007);
    transform: rotateX(-90deg) rotate(var(--angle, 0));
    
    @for $i from 0 to 6 {
      &:nth-child(#{$i + 1}) {
        --angle: #{$i * 30deg};
      }      
    }
    
    &::before, &::after {
      content: '';
      position: absolute;
      width: 100%; height: 4em;
      box-shadow: 0 0 1em #0007 inset;
      background-color: inherit;
      transform-origin: top;
      transform: rotateX(90deg);
    }
    
    &::after { top: 100%; }
  }
}

.glass {
  inset: -15em;
  background-image: radial-gradient(farthest-side at 50% 60%, transparent, 95%, #fff5);
  border-radius: 50%;
  animation: sceneRotate $srDuration infinite linear reverse;
  
  &::after {
    content: '';
    position: absolute;
    inset: 2em;
    border-radius: 50%;
    background-image: radial-gradient(circle at 50% 60%, transparent 65%, #ff7a 85%);
    filter: blur(1em);
    animation: lightblur $srDuration infinite ease-in-out;
    
    @keyframes lightblur {
      0%, 100% { rotate: -45deg; }
      50% { rotate: 45deg; }
    }
  }
}

.tree {
  .trunk {
    inset: -7em -1em;
    transform: translateY(4em);
    background-color: brown;
    border-radius: 50% / 90% 90% 3% 3%;
    animation: sceneRotate $srDuration infinite linear reverse;
  }

  .leafs i {
    top: var(--top, 0);
    width: 8em;
    aspect-ratio: 1;
    background-image: radial-gradient(circle at top left, #000, green);
    border-radius: 0 0 100% 0;
    transform-origin: top left;
    transform: rotateY(var(--ry)) rotateX(45deg) rotateZ(45deg) scale(var(--scale, 1));
    
    $angle: 0;
    @for $i from 0 to 48 {
      &:nth-child(#{$i + 1}) {
        $angle: $angle + 60 + random(60);
        --top: #{-5 + $i * 0.2}em;
        --ry: #{$angle}deg;
        --scale: #{0.25 + $i / 75};
      }      
    }
  }

  .lights i {
    inset: -0.4em;
    background-color: hsl(var(--hue) 100% 50%);
    background-image: radial-gradient(circle at top, transparent, #0007);
    box-shadow: 0 0 0.5em #fff7;
    transform: translatey(var(--ty)) rotateY(var(--ry, 0)) translateZ(var(--tz, 5em));
    border-radius: 50%;
    animation: lightRotate $srDuration infinite linear reverse;
    
    @keyframes lightRotate {
      from { transform: translatey(var(--ty)) rotateY(var(--ry, 0)) translateZ(var(--tz, 5em)) rotateY(calc(0deg - var(--ry))); }
      to { transform: translatey(var(--ty)) rotateY(var(--ry, 0)) translateZ(var(--tz, 5em)) rotateY(calc(360deg - var(--ry))); }
    }

    $angle: 0;
    @for $i from 0 to 48 {
      &:nth-child(#{$i + 1}) {
        $angle: $angle + 60 + random(60);
        --ty: #{-4 + $i * 0.25}em;
        --tz: #{1 + $i * 0.09}em;
        --ry: #{$angle}deg;
        --hue: #{random(360)};
      }      
    }
  }
}

.flakes {
  transform: translateY(11em) rotateX(-90deg);
  animation: var(--animation, flakes) $flDuration ease-in-out;
  
  @keyframes flakes {
    0%, 100% { transform: translateY(11em) rotateX(-90deg); }
    25%, 50% { transform: translateY(0em) rotateX(-90deg); }
  }
  
  i {
    inset: -0.35em;
    background-color: hsl(55 100% var(--light, 100%));
    rotate: var(--rotate1);
    transform: translateX(var(--tx1));
    animation:
      var(--animation, flakeRotate) $flDuration ease-in-out,
      var(--animation, flakeTransform) $flDuration ease-in-out;
    
    @keyframes flakeTransform {
      0% { transform: rotateY(0deg) translateX(var(--tx1)) rotate3d(1, 1, 1, 0deg); } 
      25% { transform: rotateY(var(--ry)) translateX(var(--tx2)) rotate3d(1, 1, 1, calc(var(--r3d) * 0.25)); animation-timing-function: linear; } 
      50% { transform: rotateY(var(--ry)) translateX(var(--tx2)) rotate3d(1, 1, 1, calc(var(--r3d) * 0.5)); } 
      100% { transform: rotateY(0deg) translateX(var(--tx1)) rotate3d(1, 1, 1, var(--r3d)); } 
    }
    
    @keyframes flakeRotate {
      from { rotate: var(--rotate1); }
      to { rotate: var(--rotate2); }
    }

    @for $i from 0 to 256 {
      &:nth-child(#{$i + 1}) {
        $r: random(360);
        --rotate1: #{$r}deg;
        --rotate2: #{$r + 5 * 360}deg;
        --tx1: #{(random(100) / 100) * 5 + 3}em;
        --tx2: #{(random(100) / 100) * 6 + 7}em;
        --light: #{70 + random(30)}%;
        --ry: #{random(120) - 45}deg;
        --r3d: #{random(8) + 8}turn;
      }      
    }
  }
}

.star {
  position: absolute;
  top: -5.5em;

  i {
    position: absolute;
    left: -1.25em;
    width: 2.5em; height: 0.5em;
    background-color: gold;
    background-image: linear-gradient(90deg, transparent, #000a);
    clip-path: polygon(0 0, 100% 0, 50% 100%);
    transform-origin: top;
    transform: 
      rotate(var(--angle))
      translateY(-0.41em)
      rotateX(var(--rx, 35deg));

    &:nth-child(5n + 1) { --angle: 0deg; }
    &:nth-child(5n + 2) { --angle: 72deg; }
    &:nth-child(5n + 3) { --angle: 144deg; }
    &:nth-child(5n + 4) { --angle: 216deg; }
    &:nth-child(5n + 5) { --angle: 288deg; }

    &:nth-child(n + 6) { --rx: -35deg; }
  }
}

5、點狀旋轉加載動畫

圖片

這是 Josetxu 用 HTML 和 CSS 創建的催眠加載器。一個有趣的動畫組合創造了這種效果,點在改變大?。ê?z 索引)的同時移動。

css代碼:

:root {
  --w: #fafafa; 
  --b: #141414; 
  --s: 1s;
  --d: calc(var(--s) / 6);
}

$d: var(--d);

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  padding: 0;
  width: 100vw;
  height: 100vh;
  overflow: hidden;
}

input {
  width: 100vw;
  height: 100vh;
  position: absolute;
  z-index: 4;
  opacity: 0;
  cursor: pointer;
  &:checked ~ div {
    filter: invert(1);
  }
  &:checked + .bg:before {
    content: "CLICK TO DARK";   
  }
}

.bg:before {
  content: "CLICK TO LIGHT";
  position: absolute;
  color: var(--w);
  width: 100%;
  text-align: center;
  bottom: 10vh;
  font-family: Arial, Helvetica, serif;
  font-size: 12px;
  text-shadow: 0 0 1px var(--w);
  opacity: 0.25;
}

body, .dots {
  display: flex;
  align-items: center;
  justify-content: center;
}

.bg {
  width: 100vw;
  height: 100vh;
  position: absolute;
  background: var(--b);
  z-index: -2;
}

.dots {
  width: 50vmin;
  height: 50vmin;
  position: relative;
}

.ring {
  border: 1.5vmin solid var(--w);
  width: 64%;
  height: 64%;
  border-radius: 100%;
  z-index: 0;
  box-shadow: 0 0 0 1vmin var(--b), 0 0 0 1vmin var(--b) inset;
}

.dot {
  width: 50%;
  position: absolute;
  height: 7vmin;
  left: 0;
  transform-origin: 100% 50%;
  z-index: -1;
  animation: 
    over-ring calc(var(--s) * 2) linear 0s infinite, 
    spin calc(var(--s) * 8) linear 0s infinite;
  &:before {
    content: "";
    width: 5.5vmin;
    height: 5.5vmin;
    left: 0;
    box-sizing: border-box;
    border: 1vmin solid var(--b);
    position: absolute;
    background: var(--w);
    border-radius: 100%;
    animation: ball var(--s) ease-in-out 0s infinite alternate;
  }
  @for $i from 1 through 12 { 
    &:nth-child(#{$i}) {
      $n: (($i - 1) * -1);
      $n4: ($n * 4);
      animation-delay: calc(#{$d} * #{$n}), calc(#{$d} * #{$n4});
      &:before {
        animation-delay: calc(#{$d} * #{$n});
      }
    }
  }
}

@keyframes spin {
  100% { transform: rotate(-360deg); }  
}

@keyframes ball {
  100% { left: 12vmin; width: 4vmin; height: 4vmin; } 
}

@keyframes over-ring {
  0%, 50% { z-index: -1; }  
  51%, 100% { z-index: 1; } 
}

6、Wow 冬季毯子

圖片

另一個帶有 ThreeJS 和著色器的演示。這次是安娜·禪恩·清道夫(Anna Zenn Scavenger)的作品。這是 CodePen 每周關于對立面挑戰的一部分。將鼠標移到毯子上以查看其平穩移動。

js代碼:

import * as THREE from 'https://unpkg.com/three@0.118.3/build/three.module.js';

let container, scene, camera, renderer;
let blanket;

// LANDSCAPE / PORTRAIT

let isMobile = /(Android|iPhone|iOS|iPod|iPad)/i.test(navigator.userAgent);
let windowRatio = window.innerWidth / window.innerHeight;
let isLandscape = (windowRatio > 1) ? true : false;

// MOUSE

let isMouseMove = false;
let mouseX = 0;

const clock = new THREE.Clock();

init();
render();

function init() {
  
  container = document.querySelector("#scene-container");

  scene = new THREE.Scene();

  initCamera();
  initLights();
  initRenderer();
  
  initBlanket();
  
  window.addEventListener('resize', onWindowResize, false);
  document.addEventListener('mousemove', onMouseMove);
  document.addEventListener('touchmove', onTouchMove);
  window.addEventListener('mouseout', onMouseLeave);
  
}

function initCamera() {
  
  camera = new THREE.PerspectiveCamera(40, window.innerWidth / window.innerHeight, 1, 1000);
  camera.position.set(0, 2.0, 10.0);
  camera.position.z = (windowRatio > 2) ? ((5 / windowRatio) + 9) : (15 / windowRatio);
  
}

function initLights() {

  const dirLight = new THREE.DirectionalLight(0xffffff, 0.75);
  dirLight.position.set(-0.5, 10, -10);
  scene.add(dirLight);

  const ambientLight = new THREE.AmbientLight(0xffffff, 0.6);
  //ambientLight.position.set(0.5, 10, -5);
  scene.add(ambientLight);

}

function initRenderer() {
    
  renderer = new THREE.WebGLRenderer({alpha: true, antialias: true });
  // renderer.setPixelRatio(window.devicePixelRatio > 1.4 ? Math.min(window.devicePixelRatio, 1.25) : Math.min(window.devicePixelRatio, 1.25));
  renderer.setSize(window.innerWidth, window.innerHeight);
  //renderer.outputColorSpace = THREE.SRGBColorSpace;
  container.appendChild(renderer.domElement);
    
}

function initBlanket() {
  
  const SIZE = 6.5;
  const RESOLUTION = 75;

  const geometry = new THREE.PlaneBufferGeometry(SIZE, SIZE, RESOLUTION, RESOLUTION);
  geometry.rotateX(-0.5 * Math.PI);

  const tartanMaterial = new THREE.ShaderMaterial({
  
    lights: true,
    side: THREE.DoubleSide,
  
    extensions: {
      derivatives: true,
    },

    defines: {
      STANDARD: '',
      PHYSICAL: '',
    },

    uniforms: {
    
      ...THREE.ShaderLib.physical.uniforms,
      roughness: { value: 0.0 },
      diffuse: {value: new THREE.Color(0xffffff)},
      time: { value: 0.0 },
      amplitude: { value: 0.4 },
      frequency: { value: 0.4 },
      speed: { value: 0.3 },
      u_time: { value: 0.0 },
      u_resolution: { value: new THREE.Vector2(window.innerWidth, window.innerHeight) }
    
    },

    vertexShader: monkeyPatch(THREE.ShaderChunk.meshphysical_vert, {
    
      header: `
        uniform float time;
        uniform float amplitude;
        uniform float speed;
        uniform float frequency;
      
        varying vec2 vUv;

        ${noise()}
      
        float displace(vec3 point) {
          return noise(vec3(point.x * frequency, point.z * frequency, time * speed)) * amplitude;
        }
      
        // http://lolengine.net/blog/2013/09/21/picking-orthogonal-vector-combing-coconuts
        vec3 orthogonal(vec3 v) {
          return normalize(abs(v.x) > abs(v.z) ? vec3(-v.y, v.x, 0.0)
        : vec3(0.0, -v.z, v.y));
        }
      `,
      // adapted from http://tonfilm.blogspot.com/2007/01/calculate-normals-in-shader.html
      main: `
        vec3 displacedPosition = position + normal * displace(position);

        float offset = ${SIZE / RESOLUTION};
        vec3 tangent = orthogonal(normal);
        vec3 bitangent = normalize(cross(normal, tangent));
        vec3 neighbour1 = position + tangent * offset;
        vec3 neighbour2 = position + bitangent * offset;
        vec3 displacedNeighbour1 = neighbour1 + normal * displace(neighbour1);
        vec3 displacedNeighbour2 = neighbour2 + normal * displace(neighbour2);

        // https://i.ya-webdesign.com/images/vector-normals-tangent-16.png
        vec3 displacedTangent = displacedNeighbour1 - displacedPosition;
        vec3 displacedBitangent = displacedNeighbour2 - displacedPosition;

        // https://upload.wikimedia.org/wikipedia/commons/d/d2/Right_hand_rule_cross_product.svg
        vec3 displacedNormal = normalize(cross(displacedTangent, displacedBitangent));
      `,

      '#include <defaultnormal_vertex>': THREE.ShaderChunk.defaultnormal_vertex.replace(
      // transformedNormal will be used in the lighting calculations
      'vec3 transformedNormal = objectNormal;',
      `vec3 transformedNormal = displacedNormal;`
      ),

      // transformed is the output position
      '#include <morphtarget_vertex>': `vUv = uv;`,
      '#include <displacementmap_vertex>': `
        transformed = displacedPosition;
      `,
    }),
  
    fragmentShader: monkeyPatch(THREE.ShaderChunk.meshphysical_frag, {
    
      header: `
      
        #define FREQUENCY 40
        #define TILT -60
        #define PATTERN 0.7
      
        varying vec2 vUv;
        uniform vec2 u_resolution;
      
        float coordinateGrid(vec2 r, float lineWidth, float offset, bool doubleLine) {

          float pixel = 0.0;
  
  for(float i = 0.0; i < 2.0; i += PATTERN) {
               
        float x = mod(i, PATTERN * 2.0);
        
        if (doubleLine) {
            
            if (x == 0.0) {
                pixel += 1.0 - step(lineWidth, abs(r.x - i - offset)); //first x line
                pixel += 1.0 - step(lineWidth, abs(r.y - i + offset)); //first y line
            } else {
                pixel += 1.0 - step(lineWidth, abs(r.x - i + offset)); //second x line
                pixel += 1.0 - step(lineWidth, abs(r.y - i - offset)); //second y line
            }
            
        } else {
            pixel += 1.0 - step(lineWidth, abs(r.x - i*2.0 - offset)); //first x line
            pixel += 1.0 - step(lineWidth, abs(r.y - i*2.0 + offset)); //first y line
        }
  }

  return pixel;
}
    `,
    main: ``,
    '#include <logdepthbuf_fragment>': `
    
    vec2 r = vUv;

    vec4 lightred = vec4(220.0/255.0, 23.0/255.0, 10.0/255.0, 1.0);
    vec4 darkRed = vec4(120.0/255.0, 12.0/255.0, 30.0/255.0, 1.0);
    vec4 yellow = vec4(190.0/255.0, 170.0/255.0, 59.0/255.0, 1.0);
    vec4 white = vec4(242.0/255.0, 242.0/255.0, 203.0/255.0, 0.1);
    vec4 blue = vec4(5.0/255.0, 10.0/255.0, 0.0/255.0, 0.8); 
    vec4 purp = vec4(0.0/255.0, 0.0/255.0, 0.0/255.0, 0.9); 

    vec4 pixel = lightred; // bg color
    
    pixel = mix(pixel, darkRed, coordinateGrid(r, 0.15, 0.0, true)); //paired line
    pixel = mix(pixel, white, coordinateGrid(r, 0.01, 0.005, true)); //paired line
    pixel = mix(pixel, white, coordinateGrid(r, 0.01, -0.35, false)); //paired line
    pixel = mix(pixel, purp, coordinateGrid(r, 0.01, -0.4, false)); //single line
    pixel = mix(pixel, purp, coordinateGrid(r, 0.01, -0.3, false)); //single line
    pixel = mix(pixel, blue, coordinateGrid(r, 0.02, 0.15, true)); //paired line
    pixel = mix(pixel, yellow, coordinateGrid(r, 0.01, 0.05, true)); //paired line

    float stripe = fract( dot(r, vec2(FREQUENCY,TILT)));
    pixel = mix(pixel, darkRed, stripe);
  
          diffuseColor = pixel;
    `,
    
  })
});

  blanket = new THREE.Mesh(geometry, tartanMaterial);
  blanket.position.set(0, 2.0, -0.5);
  blanket.rotation.set(Math.PI * 0.1, Math.PI * 0.25, 0);
  scene.add(blanket);

}

function render() {
  
  update();
  renderer.render(scene, camera);
  requestAnimationFrame(render);
  
}

function update() {
  
  let t = clock.getDelta();
  
  if (isMouseMove) {
    
    blanket.material.uniforms.time.value = 0.1 + 3.0 * mouseX;
    
  } else {
    
    blanket.material.uniforms.time.value += 3.0 * t;
  
  }

}

// * UTILS * 

function monkeyPatch(shader, { defines = '', header = '', main = '', ...replaces }) {
  
  let patchedShader = shader;

  const replaceAll = (str, find, rep) => str.split(find).join(rep);
  
  Object.keys(replaces).forEach((key) => {
    
    patchedShader = replaceAll(patchedShader, key, replaces[key])
    
  });

  patchedShader = patchedShader.replace(
    'void main() {',
    `
    ${header}
    void main() {
      ${main}
    `
  );

  return `
    ${defines}
    ${patchedShader}
  `

}

// * EVENTS *

function onWindowResize() {
  
  camera.aspect = window.innerWidth / window.innerHeight;
  camera.updateProjectionMatrix();
  renderer.setSize(window.innerWidth, window.innerHeight);
  
}

function onMouseMove(event) {
  
  mouseX = (event.clientX / window.innerWidth) * 2 - 1;
  isMouseMove = true;
  console.log(mouseX);
    
}

function onTouchMove(event) {
    
  let x = event.changedTouches[0].clientX;
  mouseX = (x / window.innerWidth) * 2 - 1;
  isMouseMove = true;
        
}

function onMouseLeave(event) {
  
  console.log('mouseleft');
  isMouseMove = false;
        
}

最后

下周我會繼續對話一些優秀的開源和獨立開發者。

責任編輯:姜華 來源: 趣談前端
相關推薦

2021-11-16 11:30:10

Linux命令運維

2022-07-05 19:19:11

tcpdumpLinux命令

2022-06-07 09:40:16

Linux應用服務器

2013-08-16 09:21:05

云計算云遷移

2019-03-29 15:34:39

Go框架Web

2023-05-16 16:03:10

2024-02-22 13:55:41

前端動畫庫

2013-08-07 10:35:02

AndroidListView拖拽

2022-08-10 10:57:35

Vue3開發插件

2016-10-13 15:45:42

云計算大數據

2015-12-01 09:52:03

CSS3動畫源碼

2019-07-12 09:18:22

IntelliJ ID插件插件庫

2019-12-19 14:42:40

開源數據科學項目

2022-11-15 16:54:54

2015-01-19 17:44:02

Cocos引擎3D特效

2021-08-19 15:02:32

科技軟件電腦

2015-07-28 10:52:36

DevOps

2015-10-20 15:58:28

彈力菜單android源碼

2024-07-12 09:01:37

404頁面代碼

2022-09-08 09:01:41

CodePenJavaScripCSS
點贊
收藏

51CTO技術棧公眾號

婷婷中文字幕综合| 免费观看日韩av| 日韩国产精品亚洲а∨天堂免| 欧美 日韩 激情| 国产福利在线看| 国产精品一区三区| 欧美一级bbbbb性bbbb喷潮片| 妺妺窝人体色WWW精品| 精品一区二区三区免费看| 欧美日韩国产区| 中文字幕一区二区三区乱码| 亚洲国产精品久久久久爰性色 | 欧美日本高清视频| 国产男男chinese网站| 精品视频在线播放一区二区三区| 精品久久中文字幕久久av| 亚洲精品成人a8198a| 日本久久一级片| 国产在线国偷精品产拍免费yy| 57pao国产成人免费| 2021亚洲天堂| 欧美丝袜丝交足nylons172| 精品国产制服丝袜高跟| 日韩爱爱小视频| www.日韩| 亚洲国产wwwccc36天堂| 午夜啪啪免费视频| 黄色在线免费观看大全| 成人午夜视频免费看| 国产精品免费久久久| 日韩少妇裸体做爰视频| 雨宫琴音一区二区三区| 在线播放日韩专区| 人妻熟女aⅴ一区二区三区汇编| 久久久久久久久成人| 精品视频免费在线| 精品视频一区二区在线| av手机在线观看| 亚洲男同性视频| av动漫免费观看| 免费黄色在线网站| 国产性天天综合网| 欧美日韩一区在线播放| 天天色棕合合合合合合合| 国产成人免费视频一区| 亚洲最大av在线| 国产免费福利视频| 久久精品久久综合| 国产精品久久久久久久久久99 | brazzers在线观看| 亚洲日本在线看| 欧美日韩一级在线| 黄色一级片在线观看| 日韩一区在线看| 在线看视频不卡| 男女啪啪在线观看| 国产精品欧美综合在线| 亚洲精品中文字幕在线| jizz视频在线观看| 中文字幕日韩精品一区| www.黄色网址.com| 欧美性video| 午夜精品爽啪视频| 国产亚洲欧美在线视频| 成人性生活av| 欧美探花视频资源| 天堂av2020| 午夜日韩影院| 亚洲精品成人久久| 91精品人妻一区二区三区蜜桃欧美 | 嫩草在线视频| 亚洲精品成人在线| 99色这里只有精品| a日韩av网址| 欧美老肥妇做.爰bbww| 制服丝袜中文字幕第一页| 国产中文欧美日韩在线| 精品美女在线观看| 成人影视免费观看| 青草国产精品| 欧美精品在线极品| 久久国产黄色片| 日韩综合在线视频| 亚洲va男人天堂| 日本美女一级片| 国产日本欧洲亚洲| 超碰10000| 亚洲色图官网| 777色狠狠一区二区三区| yjizz视频| 国内精品久久久久久久久电影网| 久久韩国免费视频| 国产一级做a爱片久久毛片a| 日本成人中文字幕在线视频| 999精品在线观看| 美国一级片在线免费观看视频 | 日韩亚洲欧美一区二区| 国产一区二区三区四区视频 | 国产sm调教视频| 欧美成人69av| 国产97在线|日韩| 国产黄色一区二区| 国产日韩亚洲欧美综合| 加勒比海盗1在线观看免费国语版| 瑟瑟视频在线看| 91精品国产一区二区三区| 一本色道综合久久欧美日韩精品 | 欧美性大战久久久久xxx| 久久精品超碰| 亚洲精品一区二区久| www日韩在线| 日日欢夜夜爽一区| 精品国产一区二区三区日日嗨| 一级日本在线| 五月天婷婷综合| 亚洲欧美天堂在线| 精品国产一区二区三区小蝌蚪 | 日本精品免费在线观看| 欧美第一在线视频| 日韩在线免费观看视频| 久久精品国产成人av| 国产成人自拍网| 一区二区免费在线观看| 欧美黑人一区| 亚洲精品国产精品乱码不99按摩| 国产免费无码一区二区视频| 三级在线观看一区二区| 久久久久免费网| 1234区中文字幕在线观看| 日韩一级黄色片| 手机免费观看av| 日韩精品一级二级 | 天天做天天爱综合| 国产精品 欧美在线| 外国精品视频在线观看| 亚洲欧美偷拍另类a∨色屁股| 五月婷婷之综合激情| 九九视频精品全部免费播放| 91精品国产精品| 欧美 中文字幕| 亚洲午夜免费福利视频| 亚洲国产欧美91| 亚洲欧美在线专区| 91啪国产在线| 高清免费电影在线观看| 欧美日韩第一区日日骚| 极品尤物一区二区| 免费黄网站欧美| 正在播放一区| 精品成人18| 精品自拍视频在线观看| 午夜精品久久久久久久爽| 亚洲乱码精品一二三四区日韩在线| 国产女同无遮挡互慰高潮91| 五月天综合网站| 91亚洲精品久久久久久久久久久久| 日本在线人成| 日韩一区二区高清| 久久精品www| av一区二区三区黑人| 18岁网站在线观看| 亚洲人成精品久久久| 国产成人亚洲精品| melody高清在线观看| 欧美日本精品一区二区三区| 一区二区三区四区五区| 成人在线视频一区二区| 黄色国产一级视频| 精品国产乱码久久久久久蜜坠欲下| 国产欧美一区二区三区久久| а天堂中文在线官网| 欧美成人一区二区三区在线观看| 精品无码av在线| 久久久久久久久久电影| 精品日韩久久久| 欧美精品首页| 欧美激情国产日韩| 另类一区二区| 国产+人+亚洲| 第一福利在线| 日韩你懂的在线播放| 少妇一级淫片免费放中国| 国产人成亚洲第一网站在线播放| 国产精品爽爽爽爽爽爽在线观看| 99热这里只有精品2| 欧美成人tv| 久久99精品久久久久久秒播放器| 色香欲www7777综合网| 久久色在线播放| 亚洲人在线观看视频| 欧美日韩在线电影| 久久高清免费视频| 国产精品视频免费| 国产51自产区| 激情深爱一区二区| 91好吊色国产欧美日韩在线| 日韩综合网站| 久久99精品久久久久久秒播放器| 在线日韩三级| 青青草一区二区| av黄色在线| 国产亚洲精品成人av久久ww| av小说天堂网| 欧美色图免费看| 日韩 欧美 中文| 亚洲资源中文字幕| 五月婷婷欧美激情| av电影在线观看完整版一区二区| 午夜激情av在线| 国产免费成人| 99热亚洲精品| 91青青国产在线观看精品| 麻豆传媒一区二区| 亚洲天堂中文字幕在线观看 | 日韩一区二区三免费高清在线观看| 欧美激情视频给我| 麻豆系列在线观看| 亚洲人成免费电影| 天天干视频在线| 欧美成人激情免费网| 国产一区二区在线播放视频| 狠狠躁夜夜躁人人躁婷婷91| 欧美成人aaa片一区国产精品| 一区二区三区欧洲区| 日本国产一区二区| 天堂资源在线播放| 亚洲激情五月婷婷| 日本黄色录像视频| 中文字幕av不卡| 亚洲性猛交xxxx乱大交| 91免费看片在线观看| 在线xxxxx| 成人污污视频在线观看| 久久精品一二三四| 国产一区二区在线影院| 亚洲精品午夜在线观看| 日韩电影一区二区三区| 欧美 日韩 国产一区| 亚洲高清不卡| 人人干视频在线| 红桃视频国产一区| 97免费视频观看| 黑人一区二区| 国产手机免费视频| 黄色成人在线网址| 老司机激情视频| 伊人久久亚洲热| 欧美视频在线观看视频| 夜夜嗨av一区二区三区网站四季av| 小泽玛利亚av在线| 韩国av一区| 国产原创中文在线观看 | 性欧美18一19性猛交| 日韩一区二区三区三四区视频在线观看| 国产乱子伦精品无码码专区| 欧美电影一区二区| 精品久久无码中文字幕| 精品国产青草久久久久福利| 欧美少妇bbw| 亚洲精品视频免费在线观看| 欧美日本网站| 伊人av综合网| 国产最新在线| 欧美国产日韩在线| 蜜桃av.网站在线观看| 日本伊人精品一区二区三区介绍| 欧美福利在线播放| 成人激情视频小说免费下载| 日日夜夜精品视频| 麻豆av一区二区三区| 秋霞欧美视频| 乱熟女高潮一区二区在线| 99热这里只有精品8| 宅男噜噜噜66国产免费观看| 精品一区二区日韩| 日本一区二区在线观看视频| 91香蕉视频在线| 久久精品老司机| 综合在线观看色| 久草精品视频在线观看| 在线观看国产91| www.蜜桃av.com| 亚洲美腿欧美激情另类| 免费在线观看黄色网| 欧美精品久久久久久久久久| 黄色成人免费网| 91香蕉国产在线观看| 四虎影视精品| 日本三级福利片| 国产婷婷精品| 日韩 国产 一区| 久久综合av免费| 少妇人妻丰满做爰xxx| 日韩欧美高清视频| 国内精品久久久久久久久久| 亚洲欧美制服综合另类| 91精选在线| 国产精品福利在线观看| 哺乳一区二区三区中文视频 | 午夜视频成人| 欧美一区在线直播| 久久99成人| 日韩精品欧美专区| 亚洲国产激情| 久久精品亚洲天堂| 久久精品夜夜夜夜久久| 久草福利资源在线观看| 欧洲激情一区二区| 天天摸天天碰天天爽天天弄| 另类专区欧美制服同性| 日韩影片中文字幕| 国产精选在线观看91| 婷婷亚洲综合| 免费观看成人在线视频| 不卡电影一区二区三区| 国产成人综合在线视频| 欧美亚洲一区二区在线观看| 天天综合网在线观看| 久久91亚洲精品中文字幕| 深夜日韩欧美| 日韩三级电影免费观看| 国产亚洲高清视频| 亚洲美女精品视频| 中文字幕一区二区三区蜜月 | 天堂√8在线中文| 国产欧美丝袜| 国语精品一区| 久久久久亚洲av片无码v| 中文字幕永久在线不卡| 亚洲毛片一区二区三区| 日韩精品福利网站| 99riav视频在线观看| 国产精品av一区| 欧美女激情福利| 被黑人猛躁10次高潮视频| **网站欧美大片在线观看| 在线观看黄色网| 色吧影院999| 日韩一级特黄| 国产又粗又硬又长| 国产麻豆成人精品| www.av视频| 亚洲的天堂在线中文字幕| 欧美xxxxhdvideosex| 成人免费视频网站| 欧美日韩亚洲一区二区三区在线| 伊人免费视频二| 一区二区三区av电影| 午夜精品久久久久久久第一页按摩 | 九九视频免费在线观看| 欧美一区二区三区小说| 91三级在线| 国产精品久久亚洲7777| 亚洲人www| 人妻少妇一区二区| 欧洲一区在线电影| avtt在线播放| 91精品视频播放| 极品中文字幕一区| 99久久人妻精品免费二区| 色综合一区二区| 91视频在线观看| 91在线观看免费观看| 很黄很黄激情成人| 中文字幕av网址| 欧美三级视频在线观看| 国产福利视频在线观看| 成人欧美一区二区三区视频xxx | 欧美视频在线观看一区二区三区| 69av在线视频| 欧美丝袜丝交足nylons172| 精品综合久久久久| 亚洲国产另类av| 日本在线一二三| 成人免费网视频| 在线国产精品一区| 微拍福利一区二区| 91精品国产入口| 色是在线视频| 中文字幕欧美人与畜| 丁香另类激情小说| 国产精品久久久久久久久夜色| 日韩专区中文字幕| 麻豆一区一区三区四区| 中文字幕永久视频| 亚洲自拍偷拍综合| 国产在线一二三区| 91手机在线视频| 久久亚洲精品伦理| 九九视频免费在线观看| 在线色欧美三级视频| 视频在线一区| 另类小说第一页| 亚洲成国产人片在线观看| 成年人视频免费在线观看| 国产精品免费一区二区三区四区 | 国产69精品久久久久9999apgf| 久久一区二区三区四区五区| 久久久久久久久久网站| 亚洲女成人图区|