ThreeJS开发的火焰贴图动画和水波贴图动画着色器源码【Shader-animation动画】
本源码演示了使用Threejs结合WebGL的着色器编程实现火焰贴图材质的燃烧动感材质和水波流动的贴图材质动画, 场景中包括两个正方形平面,分别显示了火焰和水波,贴图采用着色器绘制具有动画质感,并且具有半透明质感;.包括全部源码,可以自行后续开发;可用于WEBGL互动开发学习,非常值得学习。部分源码
//载入贴图
var noiseTexture = new THREE.ImageUtils.loadTexture( 'images/cloud.png' );
noiseTexture.wrapS = noiseTexture.wrapT = THREE.RepeatWrapping;
var lavaTexture = new THREE.ImageUtils.loadTexture( 'images/lava.jpg' );
lavaTexture.wrapS = lavaTexture.wrapT = THREE.RepeatWrapping;
// use "this." to create global object
this.customUniforms = {
baseTexture: { type: "t", value: lavaTexture },
baseSpeed: { type: "f", value: 0.05 },
noiseTexture: { type: "t", value: noiseTexture },
noiseScale: { type: "f", value: 0.5337 },
alpha: { type: "f", value: 1.0 },
time: { type: "f", value: 1.0 }
};
// create custom material from the shader code above
// that is within specially labeled script tags
var customMaterial = new THREE.ShaderMaterial(
{
uniforms: customUniforms,
vertexShader: document.getElementById( 'vertexShader' ).textContent,
fragmentShader: document.getElementById( 'fragmentShader' ).textContent
} );
// other material properties
customMaterial.side = THREE.DoubleSide;
// apply the material to a surface
var flatGeometry = new THREE.PlaneGeometry( 100, 100 );
var surface = new THREE.Mesh( flatGeometry, customMaterial );
surface.position.set(-60,50,150);
scene.add( surface );
/////////////////////////////////
// again, but for water!
var waterTexture = new THREE.ImageUtils.loadTexture( 'images/water.jpg' );
waterTexture.wrapS = waterTexture.wrapT = THREE.RepeatWrapping;
注:threejs/WebGL开发,非常值得学习。本地预览建议部署WEB服务器,配置运行服务器等网络访问地址运行,建议用火狐浏览器,谷歌浏览器等。
WEBGL学习网(WebGLStudy.COM)专注提供WebGL 、ThreeJS、BabylonJS等WEB3D开发案例源码下载。
声明信息:
1. 本站部分资源来源于用户上传和网络,如有侵权请邮件联系站长:1218436398@qq.com!我们将尽快处理。
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源打赏售价用于赞助本站提供的服务支出(包括不限服务器、网络带宽等费用支出)!
7.欢迎加QQ群学习交流:549297468 ,或者搜索微信公众号:WebGL学习网
WEBGL学习网 » ThreeJS开发的火焰贴图动画和水波贴图动画着色器源码【Shader-animation动画】
WEBGL学习网 » ThreeJS开发的火焰贴图动画和水波贴图动画着色器源码【Shader-animation动画】