精品欧美一区二区三区在线观看 _久久久久国色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技術棧公眾號

一区二区精品免费| 男女激情免费视频| 91午夜交换视频| 欧美视频亚洲视频| 亚洲精品动漫100p| 少妇网站在线观看| freexxx性亚洲精品| 久久久久久久久蜜桃| 成人免费观看a| 久久久久久久久久免费视频| 欧美影院三区| 精品福利在线导航| 国产一区二区在线免费播放| sm捆绑调教国产免费网站在线观看| 国产日韩欧美高清| 粉嫩av四季av绯色av第一区| 成年人视频免费| 国产一区二区中文| 中文字幕亚洲欧美一区二区三区| 成人高清在线观看视频| 在线日韩影院| 亚洲一区自拍偷拍| 杨幂一区欧美专区| 蝌蚪视频在线播放| 成年人国产精品| 成人a视频在线观看| 在线观看亚洲天堂| 欧美一区影院| 日韩小视频在线观看| avtt香蕉久久| 风间由美一区二区av101 | 中文字幕亚洲无线码a| 韩国三级在线看| 午夜精品久久久久久毛片| 欧美日韩亚洲激情| av日韩一区二区三区| 国产激情视频在线观看| 欧美国产日韩亚洲一区| 裸体丰满少妇做受久久99精品| 国产同性人妖ts口直男| 男人的j进女人的j一区| 日本成熟性欧美| 中文字幕激情小说| 国产日韩欧美三级| 国内成人精品一区| 欧美一级高潮片| 亚洲网站在线| 欧美精品videos另类日本| 日韩欧美123区| 久久久久久久久久久妇女| 国产一区二区三区丝袜| 亚洲精品国产91| 亚洲精品亚洲人成在线| 亚洲精品国产精品国自产观看浪潮| 熟妇女人妻丰满少妇中文字幕| 亚州欧美在线| 欧美高清视频一二三区| 久热在线视频观看| 91精品视频一区二区| 欧美喷潮久久久xxxxx| 久久久久国产一区| 四虎影视成人精品国库在线观看| 欧美日韩极品在线观看一区| 亚洲这里只有精品| **国产精品| 日韩女优视频免费观看| av漫画在线观看| 精品无人区一区二区| 日韩av在线电影网| 妺妺窝人体色WWW精品| 国产精品亚洲片在线播放| 国产亚洲a∨片在线观看| 手机看片福利视频| 国产精品久久久久久久久妇女| 久久综合电影一区| 国产一级在线播放| 久久久久久一区二区| 国产精品久久久久久一区二区| 国产精品久久欧美久久一区| 国产精品1024| 久久久精品动漫| eeuss影院在线播放| 亚洲人成伊人成综合网小说| 欧美视频在线第一页| 咪咪网在线视频| 欧美性猛片aaaaaaa做受| 午夜一区二区视频| 久久资源综合| 日韩一区二区三区在线播放| 久久久久久免费观看| 性伦欧美刺激片在线观看| 国产精品一区二区久久久| 精品国产av一区二区三区| 91视视频在线观看入口直接观看www| 麻豆久久久9性大片| 三区四区在线视频| 午夜成人免费电影| 久久国产激情视频| 精品福利网址导航| 日韩在线视频二区| 久久成人在线观看| 日本不卡在线视频| 国产精品露出视频| 亚洲成人三级| 欧美性色xo影院| 久久精品一二三四| 欧美伦理在线视频| 国内精久久久久久久久久人| 在线视频 中文字幕| 成年人网站91| 一二三四中文字幕| 国产综合av| 亚洲第一天堂av| 亚洲一区电影在线观看| 美女国产一区| 国产精品久久精品国产 | 美女视频亚洲色图| 久久亚洲精品小早川怜子66| 欧美一级片免费在线观看| 国产精品中文欧美| 亚洲 国产 日韩 综合一区| 98色花堂精品视频在线观看| 欧美日韩国产成人在线91| 2一3sex性hd| 亚洲情侣在线| 国产欧美精品xxxx另类| 黄色av网站在线免费观看| 亚洲va中文字幕| 人妻体体内射精一区二区| 日韩久久综合| 国产精品九九九| 毛片免费在线播放| 粉嫩老牛aⅴ一区二区三区| 国产裸体视频网站| 91成人看片| 欧美最顶级的aⅴ艳星| 免费激情视频网站| 亚洲一区日韩精品中文字幕| 99精品视频国产| 天天综合网91| 91九色视频在线| 五月香视频在线观看| 欧美性高跟鞋xxxxhd| 亚洲av成人片无码| 99精品国产一区二区青青牛奶 | 精品淫伦v久久水蜜桃| 久久国产天堂福利天堂| 国产理论片在线观看| 国产精品九色蝌蚪自拍| 丰满少妇在线观看| jlzzjlzz亚洲女人| 国产精品女主播| 香蕉视频在线播放| 欧美精品国产精品| 天天操天天操天天操天天操天天操| 久久www免费人成看片高清| 亚洲国产精品久久久久久女王| 日韩中文视频| 日韩一区av在线| 91久久久久久久久久久久| 色猫猫国产区一区二在线视频| 另类视频在线观看+1080p| 第一av在线| 亚洲国产精彩中文乱码av| 久久久香蕉视频| 成人av在线网站| 少妇无码av无码专区在线观看| 噜噜噜天天躁狠狠躁夜夜精品| 国内揄拍国内精品| 亚洲 国产 欧美 日韩| 亚洲第一搞黄网站| 国产精品jizz| 久色婷婷小香蕉久久| 潘金莲一级淫片aaaaa免费看| 日本伊人久久| 欧美夜福利tv在线| 3d成人动漫在线| 日韩一区二区在线播放| 日本少妇在线观看| 国产无人区一区二区三区| 天堂av在线8| 亚洲成人直播| 视频一区不卡| 视频一区在线| 国产成人在线一区二区| 久久99精品久久久久久野外| 精品国产网站在线观看| 无码人妻丰满熟妇区五十路| 成人欧美一区二区三区白人| 在线看黄色的网站| 日韩av电影一区| www.av91| 日韩在线看片| 精品日本一区二区三区| 国产伊人久久| 性色av一区二区三区免费| jizz在线观看中文| 欧美精品一区二区三区蜜桃视频| 久久精品五月天| 亚洲专区一二三| 精品成人无码一区二区三区| 国产成人无遮挡在线视频| 国产精品久久久久9999小说| 欧美福利视频| 日韩福利二区| 精品亚洲免a| 成人一区二区电影| 美女写真久久影院| 97精品久久久中文字幕免费| 五月香视频在线观看| 日韩精品欧美激情| 国产www免费观看| 欧美亚洲综合久久| 五月天婷婷丁香| 亚洲日本电影在线| 亚洲女优在线观看| 91丨九色丨黑人外教| 国产又粗又猛又爽又黄| 麻豆成人综合网| 久久精品香蕉视频| 在线综合亚洲| 真人抽搐一进一出视频| 午夜片欧美伦| 亚洲精品在线观看免费| 亚洲资源网站| 久久久久久草| 欧美天堂社区| 国产丝袜不卡| 成人自拍在线| 福利视频久久| 中文字幕一区二区三区中文字幕 | 亚洲欧美日韩国产成人综合一二三区| 丁香婷婷成人| 99re在线观看视频| 超碰国产精品一区二页| 国产精品久久久久久网站| 韩国成人漫画| 青青草精品毛片| 无遮挡爽大片在线观看视频| 久久久久久久久中文字幕| 超碰公开在线| 久热精品在线视频| 成人在线直播| 欧美日韩国产成人高清视频| 超碰porn在线| 欧美成人h版在线观看| 麻豆av在线免费看| 精品国内亚洲在观看18黄 | 亚洲资源网你懂的| 狼狼综合久久久久综合网| 久久人人爽人人爽人人片av不| 国产精品毛片va一区二区三区| 综合欧美亚洲| 国产精品一区二区三区免费观看| caoporn成人免费视频在线| 91在线在线观看| 国产精品nxnn| 看高清中日韩色视频| 国产一区二区三区天码| 午夜视频久久久| 91精品国产视频| 国产在线视频在线| 国产欧美午夜| 国产一级不卡毛片| 毛片av一区二区| 手机在线观看日韩av| 不卡影院免费观看| 国产麻豆天美果冻无码视频| 久久久99久久| 欧美性生交大片| 亚洲精品少妇30p| 国产成人无码精品| 91成人免费在线视频| 亚洲自拍第二页| 日韩美一区二区三区| 天天综合天天综合| 国产一区二区三区毛片| 免费的黄网站在线观看| 欧美精品videossex88| 欧美日韩电影免费看| 91精品国产综合久久久久久久久 | 精品国产aⅴ麻豆| 欧美人与牛zoz0性行为| 国产精品美女在线播放| 激情欧美丁香| 中文字幕网av| 成人黄色a**站在线观看| 美女爆乳18禁www久久久久久 | 丰满白嫩尤物一区二区| 182在线视频| 国产精品久久久久影院| 国产精品9191| 欧美日韩视频在线一区二区 | 精品美女一区| 国产伦精品一区二区| 欧美老女人另类| 大陆av在线播放| 免费成人你懂的| 日本japanese极品少妇| 成人欧美一区二区三区小说| 999这里只有精品| 欧美一区二区二区| а√天堂中文在线资源bt在线| 欧美精品福利在线| 57pao成人永久免费| 久久久www免费人成黑人精品| 亚洲精品网址| 黄色免费网址大全| 不卡视频免费播放| 69xx绿帽三人行| 欧美视频在线一区| 欧美拍拍视频| 国语自产精品视频在线看| 亚洲精品tv| 日韩av高清在线播放| 99在线|亚洲一区二区| 人妻少妇偷人精品久久久任期| 国产亚洲一二三区| 国产小视频在线免费观看| 欧美一级片在线观看| 91美女视频在线| 国产91精品在线播放| 欧美91在线| 蜜臀精品一区二区| 国产一区999| 久久嫩草捆绑紧缚| 色综合色综合色综合| 天堂中文资源在线| 性欧美办公室18xxxxhd| 日韩成人在线观看视频| 一区二区免费电影| 男女男精品视频| 日本一卡二卡在线播放| 大荫蒂欧美视频另类xxxx| 亚洲精品国产精品乱码不卡| 久久精品一偷一偷国产| 91麻豆精品国产91久久久更新资源速度超快| 欧美在线视频一区二区三区| 国产精品久久久久久模特 | 性生活黄色大片| 久久成人亚洲精品| 国产精品1区| mm131午夜| 国产精品一品视频| 久操免费在线视频| 精品久久久久一区二区国产| 性欧美ⅴideo另类hd| www 成人av com| 亚洲视频综合| 国产又黄又粗又猛又爽的视频 | 美日韩精品视频免费看| 99视频有精品高清视频| 中文字幕精品一区日韩| 精品一区二区三区在线视频| 99热99这里只有精品| 91精品一区二区三区久久久久久| 黄av在线播放| 成人av男人的天堂| 在线一区免费观看| 黄色片网站免费| 欧美人与禽zozo性伦| 曰本三级在线| 久久国产精品高清| 日韩av一二三| 色哟哟一一国产精品| 日韩亚洲欧美中文三级| 丁香高清在线观看完整电影视频| 精品欧美一区二区久久久伦 | 妖精视频在线观看| 亚洲成a人v欧美综合天堂| 亚洲欧洲国产综合| 国产日韩欧美在线| 欧美全黄视频| 美女脱光内衣内裤| 欧美日韩mp4| 丁香花高清在线观看完整版| 欧美自拍资源在线| 激情五月婷婷综合| 91看片在线播放| 精品国产拍在线观看| 成人高潮a毛片免费观看网站| 国产精品97在线| 亚洲欧美激情视频在线观看一区二区三区| 国产肥老妇视频| 欧美最顶级的aⅴ艳星| 久久久久蜜桃| theav精尽人亡av| 69成人精品免费视频| 看黄在线观看| 青青草影院在线观看| 91麻豆视频网站| 国产精品视频a| 欧美有码在线观看| 亚洲五月综合| 成人在线一级片| 亚洲第一网站男人都懂| 国产在视频一区二区三区吞精| 国产精品国产对白熟妇| ●精品国产综合乱码久久久久 | 26uuu久久天堂性欧美|