Unity实战问题--Loading更好的实现方式(场景进度条问题) 转+原

yield return new WaitForEndOfFrame();

}

}

最后进度条的效果显示如下:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

进度条并没有连续的显示加载的进度,而是停顿一下切换一个数字,再停顿一下切换一个数子,最后在没有显示100%就情况下就切换到主场景了。究其原因在于Application.LoadLevelAsync并不是真正的后台加载,它在每一帧加载一些游戏资源,并给出一个progress值,所以在加载的时候还是会造成游戏卡顿,AsyncOperation.progress的值也不够精确。当主场景加载完毕后Unity就自动切换场景,所以上述代码中的while循环体内的代码是不会被调用的,导致进度条不会显示100%。

修补——100%完成


为了让进度条能显示100%,取巧一点的办法是将AsyncOperation.progress的值乘上2,这样当加载到50%的时候界面上就显示100%了。缺点是当界面上显示100%的时候,用户还要等待一段时间才会进入游戏。其实Unity提供了手动切换场景的方法,把AsyncOperation.allowSceneActivation设为false就可以禁止Unity加载完毕后自动切换场景,修改后的StartLoading_2代码如下:

// this function is not work

private IEnumerator StartLoading_2(int scene) {

AsyncOperation op = Application.LoadLevelAsync(scene);

op.allowSceneActivation = false;

while(!op.isDone) {

SetLoadingPercentage(op.progress * 100);

yield return new WaitForEndOfFrame();

}

op.allowSceneActivation = true;

}

最后的效果如下:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

打磨——增加动画


上述的进度条虽然解决了100%显示的问题,但由于进度条的数值更新不是连续的,所以看上去不够自然和美观。为了看上去像是在连续加载,可以每一次更新进度条的时候插入过渡数值。这里我采用的策略是当获得AsyncOperation.progress的值后,不立即更新进度条的数值,而是每一帧在原有的数值上加1,这样就会产生数字不停滚动的动画效果了,迅雷中显示下载进度就用了这个方法。

private IEnumerator StartLoading_4(int scene) {

int displayProgress = 0;

int toProgress = 0;

AsyncOperation op = Application.LoadLevelAsync(scene);

op.allowSceneActivation = false;

while(op.progress < 0.9f) {

toProgress = (int)op.progress * 100;

while(displayProgress < toProgress) {

++displayProgress;

SetLoadingPercentage(displayProgress);

yield return new WaitForEndOfFrame();

}

}

toProgress = 100;

while(displayProgress < toProgress){

++displayProgress;

SetLoadingPercentage(displayProgress);

yield return new WaitForEndOfFrame();

}

op.allowSceneActivation = true;

}

displayProgress用来记录要显示在进度条上的数值,最后进度条的动画如下:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

对比第一种的进度条

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

总结


如果在加载游戏主场景之前还需要解析数据表格,生成对象池,进行网络连接等操作,那么可以给这些操作赋予一个权值,利用这些权值就可以计算加载的进度了。如果你的场景加载速度非常快,那么可以使用一个假的进度条,让玩家看上几秒钟的loading动画,然后再加载场景。总之进度条虽然小,但要做好也是不容易的。

-----------------------华丽丽的分割线--------------------

我的实现(有点取巧的意思):

using UnityEngine;

using System.Collections;

using UnityEngine.UI;

public class UI_loading : MonoBehaviour {

public string next2Load;

public Slider slider;

private AsyncOperation op;

private float progress;

private float speed = 1.5f;

void Start()

{

Debug.Log(next2Load);

最后

对于很多初中级Android工程师而言,想要提升技能,往往是自己摸索成长,不成体系的学习效果低效漫长且无助。整理的这些架构技术希望对Android开发的朋友们有所参考以及少走弯路,本文的重点是你有没有收获与成长,其余的都不重要,希望读者们能谨记这一点。

同时我经过多年的收藏目前也算收集到了一套完整的学习资料以及高清详细的Android架构进阶学习导图及笔记分享给大家,希望对想成为架构师的朋友有一定的参考和帮助。

下面是部分资料截图,诚意满满:特别适合有开发经验的Android程序员们学习。

不论遇到什么困难,都不应该成为我们放弃的理由!

如果你看到了这里,觉得文章写得不错就给个赞呗?如果你觉得那里值得改进的,请给我留言,一定会认真查询,修正不足,谢谢。

对想成为架构师的朋友有一定的参考和帮助。

下面是部分资料截图,诚意满满:特别适合有开发经验的Android程序员们学习。

[外链图片转存中…(img-fDiO8qDI-1720100726296)]

不论遇到什么困难,都不应该成为我们放弃的理由!

如果你看到了这里,觉得文章写得不错就给个赞呗?如果你觉得那里值得改进的,请给我留言,一定会认真查询,修正不足,谢谢。

  • 5
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值