• 可拖动FPS显示框(UGUI)


    简介

    本来是想往上找一个可拖动FPS显示框的(我记得以前有人写过),然而搜了一个多小时都没搜到,索性自己写了一个,花费不到20分钟,看来还是自己动手丰衣足食啊 o(╯□╰)o 
    

    效果

    上下的Toast不在本blog介绍范围,我点他们只是为了证明按钮事件不冲突而已~~
    

    这里写图片描述

    思路

    虽然超级简单,还是说一下嘛
    1.按钮点下的时候设置物体缩放(好看点而已),并重置锚点为中心(方便拖动对齐)
    2.拖动过程中,让物体位置等于鼠标位置即可(由于用的UGUI,有Canvas,不用考虑Z轴)
    3.鼠标抬起时还原各项参数即可
    (锚点可以不还原,因为你一旦拖动了物体,原来的对齐其实已经偏了,当然有后续操作的可以考虑还原)
    

    项目配置

    1.一步完成,直接看图吧
    

    这里写图片描述

    代码

    
    using UnityEngine;
    using UnityEngine.UI;
    
    public class LTFPSPanel : MonoBehaviour
    {
    
        public Text fpsText;
    
        private float mUpdateInterval = 1f;//设定更新帧率的时间间隔为1秒  
        private float mAccum = .0f;//累积时间  
        private int mFrames = 0;//在_updateInterval时间内运行了多少帧  
        private float mTimeLeft;
    
        private static Vector3 ON_DRAG_SCALE = new Vector3(1.2f, 1.2f, 1.2f);
    
        private static Vector3 NORMAL_SCALE = Vector3.one;
    
        private static Vector2 ON_DRAG_PIVOT = new Vector2(0.5f, 0.5f);
    
        private RectTransform mRectTransform;
    
        void Awake()
        {
            mRectTransform = GetComponent<RectTransform>();
        }
    
        void Start()
        {
            if (null == fpsText)
            {
                throw new System.Exception("没有绑定Text组件");
            }
            mTimeLeft = mUpdateInterval;
        }
    
        void Update()
        {
            mTimeLeft -= Time.deltaTime;
            //Time.timeScale可以控制Update 和LateUpdate 的执行速度,  
            //Time.deltaTime是以秒计算,完成最后一帧的时间  
            //相除即可得到相应的一帧所用的时间  
            mAccum += Time.timeScale / Time.deltaTime;
            ++mFrames;//帧数  
    
            if (mTimeLeft <= 0)
            {
                float fps = mAccum / mFrames;
                string fpsFormat = System.String.Format("{0:F2}", fps);//保留两位小数  
                fpsText.text = fpsFormat;
    
                mTimeLeft = mUpdateInterval;
                mAccum = .0f;
                mFrames = 0;
            }
        }
    
        public void OnPointerDown()
        {
            mRectTransform.pivot = ON_DRAG_PIVOT;
            transform.position = Input.mousePosition;
            this.transform.localScale = ON_DRAG_SCALE;
        }
    
        public void OnPointerUp()
        {
            this.transform.localScale = NORMAL_SCALE;
            transform.position = Input.mousePosition;
        }
    
        public void OnDrag()
        {
            transform.position = Input.mousePosition;
        }
    }
    
    

    总结

    null
  • 相关阅读:
    php 数组转xml 数组转json xml转数组 json转数组
    SEO新手必须掌握的七个基本功
    zen cart主要文件说明
    十二个月内,仅仅依靠Google打造成功网站,《SEO界的圣经》
    Zencart 忘记管理员密码怎么办?
    zencart后台设置指南
    zen cart模板怎么进行二次开发修改
    增加反向链接的35个技巧
    ZenCart目录说明
    Zen Cart 添加新页面的四种方法
  • 原文地址:https://www.cnblogs.com/coldcode/p/5521089.html
Copyright © 2020-2023  润新知