Three.js/Shader墙体流光特效

Three.js墙体流光效果

基于ShaderMaterial,通过两张贴图实现流动效果,配置不同的贴图可以有不同效果
在这里插入图片描述

  • 通过使用不同的背景贴图(bgTexture)可以渲染不同墙体效果
  • 通过使用不同的流动贴图(flowTexture)可以实现不同的流动效果
  • 可与前文提到的不规则路径生产的墙体Mesh结合使用

生成方法

     /**
       * 创建流体墙体材质
       * option =>
       * params bgUrl flowUrl
       * **/
      const createFlowWallMat = ({ bgUrl, flowUrl }) => {
        // 顶点着色器
        const vertexShader = `
            varying vec2 vUv;
            varying vec3 fNormal;
            varying vec3 vPosition;
            void main(){
                    vUv = uv;
                    vPosition = position;
                    vec4 mvPosition = modelViewMatrix * vec4( position, 1.0 );
                    gl_Position = projectionMatrix * mvPosition;
            }
        `;
        // 片元着色器
        const fragmentShader = `
            uniform float time;
            varying vec2 vUv;
            uniform sampler2D flowTexture;
            uniform sampler2D bgTexture;
            void main( void ) {
                vec2 position = vUv;
                vec4 colora = texture2D( flowTexture, vec2( vUv.x, fract(vUv.y - time )));
                vec4 colorb = texture2D( bgTexture , position.xy);
                gl_FragColor = colorb + colorb * colora;
            }
        `;
        const bgTexture = new THREE.TextureLoader().load(
          bgUrl || "./img/opacityWall.png"
        );
        const flowTexture = new THREE.TextureLoader().load(
          flowUrl ||
            "https://model.3dmomoda.com/models/da5e99c0be934db7a42208d5d466fd33/0/gltf/F3E2E977BDB335778301D9A1FA4A4415.png"
          // "https://model.3dmomoda.com/models/47007127aaf1489fb54fa816a15551cd/0/gltf/116802027AC38C3EFC940622BC1632BA.jpg"
        );
        // 允许平铺
        flowTexture.wrapS = THREE.RepeatWrapping;
        return new THREE.ShaderMaterial({
          uniforms: {
            time: {
              value: 0,
            },
            flowTexture: {
              value: flowTexture,
            },
            bgTexture: {
              value: bgTexture,
            },
          },
          transparent: true,
          depthWrite: false,
          depthTest: false,
          side: THREE.DoubleSide,
          vertexShader: vertexShader,
          fragmentShader: fragmentShader,
        });
      };

使用

	const path = [
          [80, 0, -40],
          [10, 0, 0],
          [60, 0, 50],
          [0, 10, 0],
          [10, 10, 10],
          [-60, 0, 50],
          [-50, 0, -30],
          [80, 0, -40],
        ];
        const wallMat = createFlowWallMat({});
        const wallMesh = creatWallByPath({
          material: wallMat,
          path,
          height: 20,
        });

        animateList.push(() => {
          wallMat.uniforms.time.value += 0.01;
        });
        scene.add(wallMesh);
  • 7
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 13
    评论
### 回答1: 下面是一个简单的 three.js 烟雾 shader 示例,可以作为参考: ``` const smokeVertexShader = ` varying vec3 vWorldPosition; void main() { vec4 worldPosition = modelMatrix * vec4(position, 1.0); vWorldPosition = worldPosition.xyz; gl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0); }`; const smokeFragmentShader = ` uniform vec3 color; uniform float opacity; varying vec3 vWorldPosition; void main() { float depth = gl_FragCoord.z / gl_FragCoord.w; float fogFactor = smoothstep(100.0, 300.0, depth); gl_FragColor = vec4(color, opacity) * fogFactor; }`; const smokeMaterial = new THREE.ShaderMaterial({ uniforms: { color: { value: new THREE.Color(0xaaaaaa) }, opacity: { value: 0.5 } }, vertexShader: smokeVertexShader, fragmentShader: smokeFragmentShader, transparent: true }); const smokeGeometry = new THREE.PlaneGeometry(1000, 1000); const smokeMesh = new THREE.Mesh(smokeGeometry, smokeMaterial); smokeMesh.position.set(0, 0, -500); scene.add(smokeMesh); ``` 这个 shader 通过计算深度值来模拟烟雾效果。在顶点着色器中,我们通过将顶点位置乘以模型矩阵得到世界坐标系下的位置,然后将它传递给片元着色器。在片元着色器中,我们计算每个像素的深度值,并根据深度值计算烟雾因子,最后将它乘以颜色和不透明度来得到最终的颜色。 你可以根据需要调整烟雾的颜色、不透明度、大小和位置。 ### 回答2: three.js是一个功能强大的JavaScript库,它提供了一套易于使用的工具和功能,用于在Web上创建交互式的3D图形。其中一个功能是烟雾shader,它允许我们在我们的场景中添加逼真的烟雾效果。 three.js的烟雾shader通过在场景中创建一个气体云层,并向其应用特定的效果来实现。这个效果通常是通过使用Perlin噪声来模拟烟雾的动态外观的。这种噪声会根据时间和空间的变化来生成一个连续的、无缝的云状图案。 通过使用three.jsShaderMaterial和自定义着色器,我们可以将烟雾效果应用于物体或整个场景。使用这个材质,我们可以设置烟雾的颜色、透明度、密度等参数,以实现我们想要的效果。 烟雾shader可以使我们的场景更加生动和逼真。它可以在火焰、蒸汽机、爆炸等各种场景中添加真实的烟雾效果。在游戏开发、虚拟现实和建筑可视化等领域,烟雾shader都可以发挥重要的作用,提高用户体验和视觉效果。 尽管实现烟雾shader可能需要一些编程和图形学的知识,但由于three.js库已经提供了许多封装好的功能和模块,我们可以轻松地集成和使用它们。此外,three.js的官方文档和社区也提供了大量的教程和示例代码,帮助我们快速上手和理解相关概念。 总的来说,three.js的烟雾shader是一个强大的工具,它为我们提供了在Web上创建逼真烟雾效果的能力。它可以为我们的场景增加动态和真实感,提高用户体验和视觉效果。对于对3D图形感兴趣的开发者来说,three.js的烟雾shader是一个不可忽视的资源。
评论 13
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值