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;
目录
相关文章
|
12月前
|
XML 安全 定位技术
无人船水下地形测量作业流程
无人船水下地形测量作业流程
247 0
|
2月前
|
存储 算法 开发者
黑神话:悟空中的动态光照与阴影效果
【8月更文第26天】在《黑神话:悟空》这款游戏中,高质量的光照和阴影效果对于营造出逼真的游戏环境至关重要。为了达到这种效果,游戏开发团队采用了先进的实时渲染技术,包括动态光照和阴影技术。本文将详细介绍这些技术如何被用来增强场景的真实感。
84 3
|
2月前
|
算法
互动游戏解决遇到问题之基于射线投射寻路算法的问题如何解决
互动游戏解决遇到问题之基于射线投射寻路算法的问题如何解决
|
机器学习/深度学习 人工智能 算法
将有色液体图像转换成透明液体,CMU教机器人准确掌控向杯中倒多少水
将有色液体图像转换成透明液体,CMU教机器人准确掌控向杯中倒多少水
102 0
Threejs实现宇宙中地球动态展示和卫星绕地运动
Threejs实现宇宙中地球动态展示和卫星绕地运动
953 0
Threejs实现宇宙中地球动态展示和卫星绕地运动
|
前端开发 JavaScript
【中秋】模拟太阳系行星的公转
【中秋】模拟太阳系行星的公转
194 0
【中秋】模拟太阳系行星的公转
|
人工智能 算法 vr&ar
「缸中之脑」成真?动态电极绕过眼睛直接刺激大脑,在盲人脑海画出字母
最新研究绕过眼睛,通过动态电极刺激大脑,直接让天生的盲人脑海中出现字母!「智子倒计时」、「缸中之脑」、「黑客帝国」,让人分不清虚拟还是现实的直接意识输入,或许真的离我们不远了。
251 0
「缸中之脑」成真?动态电极绕过眼睛直接刺激大脑,在盲人脑海画出字母
|
数据采集 人工智能 数据挖掘
解读明略数据的“猎鹰重型”——2018“行星计划”
解读明略数据的“猎鹰重型”——2018“行星计划”
153 0
解读明略数据的“猎鹰重型”——2018“行星计划”
左手握技术,右手握需求,但声纹识别依旧当不了“独行侠”
作为生物识别技术的一种,声纹识别是“低调”的,也是经受磨难较多的。
405 0