Threejs实现模拟河流,水面水流,水管水流,海面

简介: Threejs实现模拟河流,水面水流,水管水流,海面

1,介绍


       使用Three.js引入Water.js,实现模拟河流水面,水管流水。


效果图如下:

image.png


参考案例:

three.js webgl - shaders - ocean (threejs.org)

https://threejs.org/examples/webgl_shaders_ocean.html


three.js - water (threejs.org)

https://threejs.org/examples/webgl_water.html


2,实现说明


1,河流实现需要创建一个不规则几何体,然后创建Water对象传入几何体

2,模拟水管水流需要创建两个管子,一根管子模拟水流,一根管子包在外面


// 创建一个平滑的二维样条曲线
const curve = new THREE.SplineCurve([
  new THREE.Vector2(1520, 2850),
  new THREE.Vector2(420, 180),
  new THREE.Vector2(220, 280),
  new THREE.Vector2(100, -380),
  new THREE.Vector2(-500, 780),
]);
// 返回曲线上给定位置的点集合
const points = curve.getPoints(1000);
// 点创建一条平滑的三维样条曲线
const curves = new THREE.CatmullRomCurve3([
  new THREE.Vector3(100, 0, 100),
  new THREE.Vector3(0, 0, 100),
  new THREE.Vector3(0, -100, 100),
]);
// 创建管子几何体
const geometryTube1 = new THREE.TubeGeometry(curves, 200, 10, 50);
const geometryTube = new THREE.TubeGeometry(curves, 200, 9, 50);
// 创建材质
const materialTube = new THREE.MeshBasicMaterial({
  color: "#00aa00", // 管子颜色
  transparent: true, // 管子是否透明
  side: THREE.DoubleSide,
  opacity: 0.5, // 管子透明度
});
// 创建管子物体对象
const meshTube = new THREE.Mesh(geometryTube1, materialTube);
meshTube.position.x = -300;
meshTube.rotation.y = Math.PI;
// 添加到场景
scene.add(meshTube);
water = new Water(geometryTube, {
  textureWidth: 112, // 水浑浊程度,密度
  textureHeight: 112, // 水浑浊程度,密度
  waterNormals: new THREE.TextureLoader().load('assets/textures/waternormals.jpg', function(texture) {
    texture.wrapS = texture.wrapT = THREE.RepeatWrapping;
  }),
  waterColor: "#ffffff",
});
water.position.x = -300;
water.rotation.y = Math.PI;
scene.add(water);
let splineShape = new THREE.Shape(points);
let geometry = new THREE.ShapeGeometry(splineShape);
water1 = new Water(geometry, {
  textureWidth: 1512, // 水浑浊程度,密度
  textureHeight: 1512, // 水浑浊程度,密度
  waterNormals: new THREE.TextureLoader().load('assets/textures/waternormals.jpg', function(texture) {
    texture.wrapS = texture.wrapT = THREE.RepeatWrapping;
  }),
  waterColor: "#ffffff", // 水颜色
});
water1.position.y = -90;
water1.position.x = -200;
water1.rotation.x = Math.PI * -0.5;
scene.add(water1);

最后注意水面是否可以有波动效果,在 render添加如下代码


water.material.uniforms['time'].value += 2.0 / 60.0;
目录
相关文章
Threejs实现模拟管道液体流动
Threejs实现模拟管道液体流动
2850 0
Threejs实现模拟管道液体流动
基于three.js的牛逼轰轰的3D编辑器nunuStudio!
这是一款基于Three.js的3D编辑器,我之前一直喊错,叫人家"牛牛",因为我觉得它真的好牛,其实人家正确拼音喊“努努”! 可以发布web的运行包,直接可以网页端二次开发,真的不要太方便了!
基于three.js的牛逼轰轰的3D编辑器nunuStudio!
Threejs实现下雨,下雪,阴天,晴天,火焰
Threejs实现下雨,下雪,阴天,晴天,火焰
2190 0
Threejs实现下雨,下雪,阴天,晴天,火焰
|
数据可视化 定位技术
three.js实现烟雾缭绕效果
前言 大家好!我是Fly哥,最近接广告的接的有点多, 感谢大家还是一如既往的支持我!respect, 前几天我在朋友圈分享了一个烟雾缭绕的效果。很多小伙伴都表示非常感兴趣,有的同学说用到了噪声, 有的同学说用到了着色器,还有更过分说用到了ps, 胖虎竟然无语凝噎。其实都是就是简单的贴图。配合一点想象力。我们先看下效果: 然后我就发了一条朋友圈,问这个像什么?? 有的说 云层, 有的说云墨,有的说雾霭, 其实都不是, 我想做的是烟雾。好的话不不多说!, 本篇文章阅读大概5分钟。不耽误大家太多时间,主要是介绍思路, 说太多也没啥意义。如果你对three.js 还没有一点了解都没有,
three.js实现烟雾缭绕效果
Threejs实现相机视角切换,平滑过渡,点击模型切换到查看模型视角
Threejs实现相机视角切换,平滑过渡,点击模型切换到查看模型视角
2451 0
Threejs实现相机视角切换,平滑过渡,点击模型切换到查看模型视角
Threejs使用精灵Sprite作为标签,鼠标悬浮精灵上时鼠变小手
Threejs使用精灵Sprite作为标签,鼠标悬浮精灵上时鼠变小手
1780 0
Threejs使用精灵Sprite作为标签,鼠标悬浮精灵上时鼠变小手
|
9月前
Threejs创建天空和太阳
这篇文章讲解了如何使用Three.js中的Sky组件来创建真实的天空与太阳效果,包括调整天空的颜色、太阳的位置以及实现大气散射等技巧。
297 3
|
9月前
ThreeJs制作管道水流效果
这篇文章详细说明了如何在Three.js中创建具有流动水效果的管道模型,通过使用纹理贴图的动态偏移来模拟水流的视觉效果。
492 3
|
9月前
ThreeJs制作管道中水流效果
这篇文章详细介绍了如何在Three.js中创建具有动态水流效果的管道模型,通过纹理贴图的移动来模拟水流的视觉效果。
566 2
ThreeJs制作管道中水流效果
|
9月前
Threejs制作海面效果
这篇文章详细介绍了利用Three.js制作逼真海面效果的过程,包括设置Water材质、调整光照及实现波动动画的步骤。
250 0
Threejs制作海面效果