序言
本章将使页面中的loading实现自动切换。
目录结构
资源目录里面的结构不变,点击传送门快速查看。
|__src
|__assets
|__js
| |__base 基础类文件夹
| |__Camera.js 相机类
| |__geometries 定制的物体类文件夹
| |__materials 材质类文件夹
| |__Floor.js 地面材质
| |__passes 合成器通道文件夹
| |__Blur.js 模糊着色器
| |__Glows.js 发光着色器
| |__utils 工具类文件夹
| |__Sizes.js 画布大小控制类
| |__EventEmitter.js 基础事件处理器
| |__Time.js 动画刷新
| |__world 精灵类文件夹
| |__index.js 精灵类 【新增--start贴图,loading与start的基本切换】
| |__Floor.js 地面类
| |__Application.js 初始化游戏的文件
|__index.js 入口
|__index.css 小项目,样式一丢丢
新增依赖
gsap: GSAP 是一个强大的 JavaScript 工具集,可将开发人员变成动画超级英雄。构建适用于所有主流浏览器的高性能动画。动画 CSS、SVG、画布、React、Vue、WebGL、颜色 balabalabala…
总之呢~~简单好用,gsap有完整的文档,可自行翻阅。
代码一览
world/index.js代码
...
import gsap from "gsap";
export default class {
...
setStartingScreen() {
this.startingScreen = {};
this.startingScreen.loadingLabel = {};
//创建loading展示的矩形区域
this.startingScreen.loadingLabel.geometry = new THREE.PlaneBufferGeometry(2.5, 2.5/4);
//加载图片
this.startingScreen.loadingLabel.image = new Image();
this.startingScreen.loadingLabel.image.src = '';
//生成纹理贴图
this.startingScreen.loadingLabel.texture = new THREE.Texture(this.startingScreen.loadingLabel.image);
//当一个纹素覆盖大于一个像素时,贴图采样方式
this.startingScreen.loadingLabel.texture.magfilter = THREE.NearestFilter;
//当一个纹素覆盖小于一个像素时,贴图采样方式
this.startingScreen.loadingLabel.texture.minFilter = THREE.LinearFilter;
//下次使用纹理时触发一次更新
this.startingScreen.loadingLabel.texture.needsUpdate = true;
//创建材质
this.startingScreen.loadingLabel.material = new THREE.MeshBasicMaterial({
transparent: true,
depthWrite: false,
color: 0xffffff,
alphaMap: this.startingScreen.loadingLabel.texture
});
//组装
this.startingScreen.loadingLabel.mesh = new THREE.Mesh(
this.startingScreen.loadingLabel.geometry,
this.startingScreen.loadingLabel.material
);
//不计算每一帧
this.startingScreen.loadingLabel.mesh.matrixAutoUpdate = false;
this.container.add(this.startingScreen.loadingLabel.mesh);
//start的贴图
this.startingScreen.startLabel = {};
this.startingScreen.startLabel.geometry = new THREE.PlaneBufferGeometry(2.5, 2.5/4);
this.startingScreen.startLabel.image = new Image();
this.startingScreen.startLabel.image.src = '';
this.startingScreen.startLabel.texture = new THREE.Texture(this.startingScreen.startLabel.image);
this.startingScreen.startLabel.texture.magfilter = THREE.NearestFilter;
this.startingScreen.startLabel.texture.minFilter = THREE.LinearFilter;
this.startingScreen.startLabel.texture.needsUpdate = true;
this.startingScreen.startLabel.material = new THREE.MeshBasicMaterial({
transparent: true,
depthWrite: false,
color: 0xffffff,
alphaMap: this.startingScreen.startLabel.texture
})
this.startingScreen.startLabel.material.opacity = 0;
this.startingScreen.startLabel.mesh = new THREE.Mesh(
this.startingScreen.startLabel.geometry,
this.startingScreen.startLabel.material
);
this.startingScreen.startLabel.mesh.matrixAutoUpdate = false;
this.container.add(this.startingScreen.startLabel.mesh);
//状态切换
window.requestAnimationFrame(() => {
gsap.to(this.startingScreen.loadingLabel.material, {duration: 0.3, opacity: 0});
gsap.to(this.startingScreen.startLabel.material, {duration: 0.3, opacity: 1, delay:0.3});
})
}
...
}
代码解读
world/index.js在setStartingScreen(),loading下面新增了start,除了图片内容与透明度不一致,其它都一样。
整体过程让loading显示,start先透明。
之后在requestAnimationFrame中,将loading透明,start显示。
如果你运行了代码,切换是不是猝不及防0.0
这里只是简单的loading切换,下一步将在资源加载完毕的情况下进行状态切换。