Three.js开发之Fog组件知识整理

 更新时间:2025年07月05日 10:44:27   作者:泫凝  
在Threejs中Fog类用于创建线性雾的效果,雾效果常用于模拟真实世界中视觉深度递减的效果,也可以用于创建某些艺术效果,这篇文章主要介绍了Three.js Fog 组件知识的相关资料,需要的朋友可以参考下

1. Fog 组件简介

Fog(雾)用于在 Three.js 场景中创建大气效果,模拟远处物体在雾中的模糊感。它可以增强景深,提高场景的真实感,并优化性能(远处物体可被雾隐藏,减少渲染压力)。

Three.js 提供了 两种雾效

  • THREE.Fog - 线性雾,随距离均匀加深。
  • THREE.FogExp2 - 指数雾,随距离指数增长,更自然。

2. 线性雾(THREE.Fog)

2.1 语法

const fog = new THREE.Fog(color, near, far);
scene.fog = fog;
  • color:雾的颜色(例如 0xaaaaaa)。
  • near:开始出现雾的距离(从摄像机开始计算)。
  • far:雾达到完全覆盖的距离(超出此距离的物体完全被雾遮挡)。

2.2 示例

const scene = new THREE.Scene();
scene.fog = new THREE.Fog(0xaaaaaa, 5, 20);
  • 5 以内无雾,5-20 之间物体逐渐被雾覆盖,20 以外完全被雾遮挡。

2.3 线性雾特点

✅ 适合大场景(如森林、城市、山脉)。
✅ 可控性高(可以精确设定雾的范围)。
❌ 较生硬(雾的变化是线性的,可能不够真实)。

3. 指数雾(THREE.FogExp2)

3.1 语法

const fogExp2 = new THREE.FogExp2(color, density);
scene.fog = fogExp2;
  • color:雾的颜色。
  • density:雾的浓度(数值越大,雾越浓)。

3.2 示例

scene.fog = new THREE.FogExp2(0xaaaaaa, 0.05);
  • density = 0.05:随着距离增加,物体逐渐被雾覆盖,越远雾越浓。

3.3 指数雾特点

✅ 更真实(雾的浓度随距离指数增加)。
✅ 适合小型场景(如烟雾、尘雾、室内霾)。
❌ 难以控制(没有 near 和 far,只能调整 density)。

4. Fog 与材质

  • 雾的颜色会影响受雾影响的物体
  • 大多数材质支持雾(如 MeshStandardMaterial)。
  • 特殊材质不受雾影响
    • MeshBasicMaterial(基础材质,不受灯光和雾影响)
    • ShaderMaterial(自定义着色器时需手动实现雾效)

4.1 开启雾影响

const material = new THREE.MeshStandardMaterial({ color: 0xff0000, fog: true });

4.2 禁用雾影响

const material = new THREE.MeshStandardMaterial({ color: 0xff0000, fog: false });

fog: false 时,该物体不会被雾影响。

5. 动态调整雾

可以使用 dat.GUI 控制雾的参数:

const gui = new dat.GUI();
const fog = new THREE.Fog(0xaaaaaa, 5, 20);
scene.fog = fog;

gui.addColor(fog, 'color');
gui.add(fog, 'near', 1, 50);
gui.add(fog, 'far', 1, 100);

这样可以在运行时实时调整雾的颜色和范围。

6. 结合天空(Sky)和雾

如果场景有 Sky 组件,雾的颜色应匹配天空颜色:

scene.fog = new THREE.Fog(0x87CEEB, 10, 50); // 颜色接近天空

这样可以让雾和天空融合,减少突兀感。

7. 结合灯光和阴影

  • 方向光(DirectionalLight):雾会影响远处光照,远处物体更暗。
  • 点光源(PointLight)/聚光灯(SpotLight):灯光在雾中会形成光束效果(如雾灯)。
  • 阴影:如果雾太浓,阴影可能会变得不明显。
const light = new THREE.DirectionalLight(0xffffff, 1);
light.position.set(10, 10, 10);
scene.add(light);

在雾中添加灯光,可以制造神秘的光束效果。

8. 结合后处理(PostProcessing)

后处理可以增强雾效果,如体积光、景深(DOF)

  • 使用 UnrealBloomPass 增强雾中的光照:
const bloomPass = new UnrealBloomPass(new THREE.Vector2(window.innerWidth, window.innerHeight), 0.5, 0.4, 0.85);
composer.addPass(bloomPass);
  • 使用 BokehPass 增强远处的虚化效果:
const bokehPass = new BokehPass(scene, camera, {
    focus: 10.0,
    aperture: 0.025,
    maxblur: 0.01
});
composer.addPass(bokehPass);

结合后处理,可以让雾更加真实,增强沉浸感。

9. 可能遇到的问题

9.1 雾没有效果

  • 检查是否已赋值给 scene.fog
console.log(scene.fog);
  • 确保使用支持雾的材质
console.log(material.fog);  // true 才会受雾影响

9.2 雾影响过强/过弱

  • 线性雾:调整 near 和 far 之间的比例。
  • 指数雾:调整 density 以适应场景大小。

10. 总结

类型

适用场景

控制参数

适用材质

优缺点

Fog

(线性雾)

大型场景(森林、城市、山脉)

near

far

大多数材质(除 MeshBasicMaterial

✅ 可控性强,❌ 变化较生硬

FogExp2

(指数雾)

小型场景(烟雾、尘埃、室内)

density

大多数材质

✅ 真实感强,❌ 难以精确控制

最佳实践

  • 远景雾FogExp2 更真实,适合小范围雾霾。
  • 大气效果Fog 适合模拟远景雾,如大雾天气。
  • 结合后处理:配合 BokehPassUnrealBloomPass 让雾更自然。

到此这篇关于Three.js开发之Fog组件知识整理的文章就介绍到这了,更多相关Three.js Fog组件知识内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 前端使用国密sm2和sm4进行加解密代码示例

    前端使用国密sm2和sm4进行加解密代码示例

    在前端实现加密算法时,需要特别注意密钥的安全存储和管理,不应将敏感的密钥硬编码在前端代码中,这篇文章主要介绍了前端使用国密sm2和sm4进行加解密的相关资料,需要的朋友可以参考下
    2025-04-04
  • angular之ng-template模板加载

    angular之ng-template模板加载

    本篇文章主要介绍了angular之ng-template模板加载,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-11-11
  • IE浏览器PNG图片透明效果代码

    IE浏览器PNG图片透明效果代码

    平常,我们经常使用Gif格式的图片以保持图片在浏览器中透明,以支持底色。但由于IE浏览器本身的原因,我们无法使透明的PNG图片透明起来。那么,如何将它在IE浏览器下变得透明呢?
    2008-09-09
  • Echarts实现多条折线可拖拽效果

    Echarts实现多条折线可拖拽效果

    这篇文章主要为大家详细介绍了Echarts实现多条折线可拖拽效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-12-12
  • JS实现图片高斯模糊切换效果的焦点图实例

    JS实现图片高斯模糊切换效果的焦点图实例

    这篇文章主要给大家介绍了利用原生JS如何实现图片高斯模糊切换效果的焦点图,文中给出了完整的实例代码,相信对大家的理解和学习具有一定的参考借鉴价值,下面来一起看看吧。
    2017-01-01
  • javascript 闭包详解及简单实例应用

    javascript 闭包详解及简单实例应用

    这篇文章主要介绍了javascript 闭包详解及应用的相关资料,需要的朋友可以参考下
    2016-12-12
  • VS Code转换大小写、修改选中文字或代码颜色的方法

    VS Code转换大小写、修改选中文字或代码颜色的方法

    最近在使用VS Code,发现了不少使用的小技巧,觉着有必要给大家分享下,下面这篇文章主要给大家介绍了关于VS Code转换大小写、修改选中文字或代码颜色的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考借鉴,下面来一起看看吧。
    2017-12-12
  • JS+HTML5 FileReader对象用法示例

    JS+HTML5 FileReader对象用法示例

    这篇文章主要介绍了JS+HTML5 FileReader对象用法,结合具体实例形式分析了FileReader对象的常用方法及简单使用技巧,需要的朋友可以参考下
    2017-04-04
  • js change,propertychange,input事件小议

    js change,propertychange,input事件小议

    github上关于mootools一个issue的讨论很有意思,所以就想测试记录下。感兴趣的可以点击原页面看看
    2011-12-12
  • 浅谈layer弹出层按钮颜色修改方法

    浅谈layer弹出层按钮颜色修改方法

    今天小编就为大家分享一篇浅谈layer弹出层按钮颜色修改方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-09-09

最新评论