Unity 金币翻动效果

目前使用NGUI进行界面开发,请在测试前加入NGUI插件。

using UnityEngine;
using System.Collections;

public class NumberAnimation : MonoBehaviour
{
   
    public UILabel ValueText;

    float mNumUpdateTime = 0;

    float mAnimTotalTime = 1.5f;

    int mStartValue = 0;
    int mFinalValue = 0;
    int _CurrentValue;

    bool mUpdating = false;
    
    void Start()
    {
        ValueText = GetComponent<UILabel>();
    }
    //开始播放动画
    public void Play(int _StartValue, int _finalValue)
    {
        if (_StartValue == _finalValue) return;
        mStartValue = _StartValue;
        mFinalValue = _finalValue;
        mNumUpdateTime = 0;
        mUpdating = true;
    }

    int CurrentValue
    {
        get
        {
            return _CurrentValue;
        }
        set
        {
            _CurrentValue = value;
            ValueText.text = _CurrentValue+""; //string.Format("{0:N0}", value);
        }
    }

    void Update()
    {
        if (mUpdating)
        {
            mNumUpdateTime += Time.deltaTime;
            if (mNumUpdateTime >= mAnimTotalTime)
            {
                CurrentValue = mFinalValue;
                mUpdating = false;
            }
            else
            {
                CurrentValue = t_GetLocomotorValue(mStartValue, mFinalValue, mNumUpdateTime / this.mAnimTotalTime);
            }
        }
    }
    //根据比例显示当前的数值
    private int t_GetLocomotorValue(int p_StartValue, int p_EndValue, float p_Ratio)
    {
        int returnValue;
        if (p_Ratio <= 0)
        {
            returnValue = p_StartValue;
        }
        else if (p_Ratio >= 1)
        {
            returnValue = p_EndValue;
        }
        else
        {
            returnValue = (int)(p_StartValue + (p_EndValue - p_StartValue) * p_Ratio);
        }
        return returnValue;
    }
}

//使用方法

 //void PlayNumberAnamiaton(int nowAmount, int oldAmount, UILabel target)
 //   {
 //       if (nowAmount - oldAmount > 0)
 //       {

 //           CClientApp.get().getUiMgr().setPropChangeLab(target.gameObject, nowAmount - oldAmount, true);
 //       }
 //       else if (nowAmount - oldAmount < 0)
 //       {
 //           CClientApp.get().getUiMgr().setPropChangeLab(target.gameObject, nowAmount - oldAmount, false);
 //       }

 //       //播放动画
 //       NumberAnimation numAnim = target.GetComponent<NumberAnimation>();
 //       if (numAnim == null)
 //           numAnim = target.gameObject.AddComponent<NumberAnimation>();
 //       numAnim.Play(oldAmount, nowAmount);

 //       oldAmount = nowAmount;
 //   }
时间: 2024-10-14 01:57:09

Unity 金币翻动效果的相关文章

关于Unity中粒子效果的使用

粒子效果1: 游戏中会有很炫酷的特效,比如爆炸,水花,火焰等;2: unity提供粒子编辑器,方便特效人员来开发很炫酷的特效;3.粒子效果一般有专门的粒子特效师来做,我们只需要拿来用就好了,很多参数没必要掌握. Particle System组件面板 1: 粒子系统主体;2: 喷射(Emission);3: 形态(shape);4: 生命周期内的速度偏移(velocity over lifetime);5: 生命周期内的限制速度(limit velocity over lifetime);6:

unity传送门类似效果实现

简述 在传送门中,核心的玩法是在地上或者墙上打开2个可以联通的洞来实现传送的效果.以此扩展加入解谜要素构成游戏的核心. 这里尝试使用unity来实现传送门的核心功能,具体功能分析如下: 1.传送门的模型 2.传送门的贴图 3.传送门的传送功能 这里我们需要以下软件:3dmax 2014,unity3d 5.4.0,visual studio 2015 一.传送门的模型和uv        打开3dmax,确认系统单位和显示单位都为米,如果不为米,改成米         建立一个圆柱体,高度段数1

unity,荧光效果(bloom)实现过程

两个月前,刚接触unity的时候费了半天劲儿做了个荧光效果(见:http://www.cnblogs.com/wantnon/p/4430749.html),今天终于抽空整理了一下,把过程写下来. 荧光效果如图:   一,接口: 整理完以后得到三个东西:AE_GroupBloom.cs,Camera_renderBloomRT.prefab,bloomEmitter.shader. 使用方法: 1,将AE_GroupBloom.cs添加到Main Camera上. 2,将Camera_rende

Unity 实现橡皮擦效果

我所实现的橡皮擦效果是设置图片某点的像素的透明度为0,来简单实现擦除效果的: 下面是效果 首先需要注意两点:1:设置 Main Camera 的 projection 属性为Orthographic 2:设置Canvas 的Render Mode 为 Screen Space - Camera 然后找一张图片,导入Unity 中并修改它的读写权限,创建Raw Imager 这样启动之后就可以测试效果了. 附上代码:(代码中有解释) 1 using AYUI.UIFrame; 2 using DG

Unity 摄像机抖动效果

以下是摄像机抖动效果源码: using UnityEngine; using System.Collections; public class SC_shakeCamera : MonoBehaviour{         private float shakeTime = 0.0f;         private float fps = 20.0f;         private float frameTime = 0.0f;         private float shakeDelt

Unity Shader 广告牌效果

广告牌效果指的是,一个二维平面的法线方向始终与视线(摄像机的观察方向)相同.广泛运用于渲染烟雾,云朵,闪光等. 它的本质在于构建旋转矩阵,此时我们可以选择三个基向量来构建此矩阵. 指向→的方向(X轴) 指向↑的方向(Y轴) 平面的法线方向(Z轴) 计算方法通常是: 1.根据当前摄像机的方向确定法线方向(广告牌效果的本质),并归一化 normal=normalize(viewDir); 2.根据得到的法线方向和初始的向上方向(在本地空间中即为float3(0,1,0))计算向右的方向,并归一化 r

Unity UGUI——遮罩效果(Mask)

Show Mask Graphic

鼠标滚轮控制侧边div上下翻动效果

css部分: <style> * { margin: 0; padding: 0;} .wrap { width: 1000px; margin: 0 auto; overflow: hidden; zoom: 1;} .left { float: left; width: 800px; height: 500px; overflow: hidden;} .right { float: right; width: 200px; height: 500px; background-color:

Unity Shader 效果学习

Unity上对于图像的处理,假设单纯使用代码.那么非常遗憾,程序基本会跑死,毕竟是直接对像素的操作,读取写入都是比較耗费CPU和内存的. 所以.这次由于项目须要想实现类似哈哈镜的效果.想来想去,还是认为用unity的Shader比較好,毕竟不须要CPU做什么,仅仅用GPU就能够了. 话说GPU也是非常强大的. 以下简单说一下Shader(事实上我也是新手,学习的话,參考http://blog.csdn.net/poem_qianmo/article/details/40723789 )这是位大牛