在unity3d里怎么做进度条
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了在unity3d里怎么做进度条相关的知识,希望对你有一定的参考价值。
一、任意建两个场景,分别命名为testScene1、testScene2,两个场景中分别设置“切换场景”按钮,便于立昂场景之间的相互切换,注意,两个切换按钮加载的的场景均是”loadScene“;建loadScene场景,用于处理加载进度条。
二、导入NGUI资源包,在Unity3D菜单栏中选中NGUI-Open-Prefab Toolbar,在Prefab Toolbar窗口中,选中Control - Colored Progress Bar拖拽至Hierarchy面板,修改名字为”Loading“。
三、在Hierarchy面板,Loading添加子物体Label,Label的Context内容为“loading”,适当调整字体大小。创建脚本LoadingScripts,UI Root的摄像机Camera添加组件LoadingScripts。
四、LoadingScripts脚本代码如图所示。
objProcessBar.GetComponent<UISlider>().value = acOp.progress;
异步加载场景testScene2的速度直接决定了进度条的实际进展速度。
五、加载场景loadScene一闪而过,迅速的就跳转到了场景testScene2。完全无法看到进度条进展的过程。上述代码简单实用性强,非常适合加载大场景大资源等耗时长的情况。
六、为了满足小资源/场景加载时也显示出进度条,使用如下图所示代码。AsyncOperation另一个重要的属性AsyncOperation.allowSceneActivation
acOp.allowSceneActivation = false;
acOp.allowSceneActivation = true;
当acOp.allowSceneActivation = false即使场景已经加载完成,也不会自动跳转,直到acOp.allowSceneActivation = true;
七、实验一下效果,进度条进展效果良好,仔细观察进度条1%、2%、3%到100%,完全按照i++的代码设定执行。这时进度条的额进展速度与异步加载场景的速度无关。
八、之所以能够得到满意的效果,每一个百分比的进度都能展示在眼前,是因为这个脚本中还有一个重要的语句。yield return new WaitForEndOfFrame();
九、将该语句移到while循环语句的大括号外面,再次运行Unity3D,看一下效果,会发现加载场景loadScene再次一闪而过。这是因为这里的while循环只处理了一个判断i 是否小于 100,一个i++,和一个赋值语句,电脑的执行速度非常快,快的有时人眼无法识别。
参考技术A 用NGUI插件,安装后它里面就有示例。 参考技术B新建两个场景,保存为level1和level2
2.将图片素材放进工程文件中,分别作为关卡背景、进度条背景和进度条前景
3.创建C#脚本,取名Life
4.打开脚本,加入如图所示代码
5.将脚本拖拽到摄像机上,将三张图片对号入座到图片变量中
6.按播放键调试
如何用纯CSS3制作进度条
1、写一个样式为.containe的div用来包含进度条,其次是用样式为.title的div来包裹标题。
2、接下来,添加样式为.bar的di来包含填充和未填充的进度条样式。最后,在.bar里添加样式为.bar-unfill 和.bar-fill的span标签。
<div class="container"><div class="title plain">Plain</div>
<div class="bar">
<span class="bar-unfill">
<span class="bar-fill"></span>
</span>
</div>
</div>
3.简单的进度条的CSS代码.container 类里将 width 定义为 30% 使进度条能够自适应。放一些简单的 border-radius 之类的属性在我们的 .title 类里以修改顶部和底部的左边的边框弧度,创建一个简单明了的平板式设计。
.containerwidth:30%;
margin:0 auto
.title
background:#545965;
color:#fff;
padding:15px;
float:left;
position:relative;
-webkit-border-top-left-radius:5px;
-webkit-border-bottom-left-radius:5px;
-moz-border-radius-topleft:5px;
-moz-border-radius-bottomleft:5px;
border-top-left-radius:5px;
border-bottom-left-radius:5px
4.首先建一个白色的背景
.bar-unfill height:15px;display:block;background:#fff;width:100%;border-radius:8px5.定义进度条的样式,先令他的宽度为 100% ,因为这也会应用于定义和未定义的部分。所以在我们的 .bar-fill 的类里,令他的宽度为 0 作为起始的宽度,添加CSS3的 transition 属性使动画效果更加流畅,最后,我们将添加CSS3里的 animation 属性,定义动画的名字,和 duration 和 animation-iteration-count 属性。
.bar-fillheight:15px;
display:block;
background:#45c9a5;
width:0;
border-radius:8px;
-webkit-transition:width .8s ease;
-moz-transition:width .8s ease;
transition:width .8s ease;
-webkit-animation:progressbar 7s infinite;
animation:progressbar 7s infinite
6.使用CSS3里的 @keyframe 规则来设置宽度从 0 变化到 100% 。你也能定制你自己喜欢的变化。
@-webkit-keyframes progressbarfrom
width:0
to
width:100%
/* Standard syntax */
@keyframes progressbar
from
width:0
to
width:100%
7.条纹进度条,应该把 .bar-fill 重新命名为 .bar-fill-stripes 。使用 backgrou-image 属性里的 linear-gradient 同时声明它的颜色。剩余的CSS3动画效果也是和上述相同,看下面的代码:
.bar-fill-stripesheight:15px;
display:block;
background:#e74c3c;
width:0;
border-radius:8px;
background-image:linear-gradient(-45deg,rgba(255,255,255,.2) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.2) 50%,rgba(255,255,255,.2) 75%,transparent 75%,transparent);
-webkit-transition:width .8s ease;
-moz-transition:width .8s ease;
transition:width .8s ease;
-webkit-animation:progressbar 7s infinite;
animation:progressbar 7s infinite
追踪
<div class="container"><div class="title">Tracker</div>
<div class="bar">
<span class="bar-unfill">
<span class="bar-fill-tracker"></span>
<span class="track-wrap">
<span class="track"></span>
</span>
</span>
</div>
</div>
8.最后产生动画效果
position:relative;
top:-18px;
-webkit-animation:progressbar2 7s infinite;
animation:progressbar2 7s infinite
.track
height:20px;
display:block;
background:#e74c3c;
width:20px;
border-radius:10px;
position:relative;
left:-12px
@-webkit-keyframes progressbar2
from
left:0
to
left:100%
/* Standard syntax */
@keyframes progressbar2
from
left:0
to
left:100%
参考技术A 看看这个教程
http://www.w3cplus.com/css3/how-to-create-a-css3-progress-bar.html
使用纯CSS创建一个有平面动画效果的进度条本回答被提问者采纳
以上是关于在unity3d里怎么做进度条的主要内容,如果未能解决你的问题,请参考以下文章