WASD控制UI界面血条加减

using UnityEngine;
using System.Collections;
using UnityEngine.UI;

public class HealthController : MonoBehaviour {

    //当前对象是血条还是蓝条
    public bool isHealth = false;
    //虚拟轴,横轴,纵轴
    private float hor,ver;
    //血条的最大宽度
    private float healthMaxWidth = 470;
    //蓝条的最大宽度
    private float powerMaxWidth = 425;
    //当前的虚拟轴
    private float currentAxis;
    //当前的最大宽度
    private float currentMaxWidth;
    //RectTransform组件
    private RectTransform rectTr;
    //速度
    public float speed = 100;
    //血条文本
    public Text healthText;
    //蓝条文本
    public Text powerText;
    //血条蓝条的最大值
    public float healthMaxValue = 1000f;
    public float powerMaxValue = 500f;
    //当前的条的最大值
    private float currentMaxValue;
    //当前修改的文本显示框
    private Text currentText;

    void Start()
    {
        rectTr = GetComponent<RectTransform> ();
    }

    void Update()
    {
        hor = Input.GetAxis ("Horizontal");
        ver = Input.GetAxis ("Vertical");
        //如果是血条
        if (isHealth) {
            currentAxis = hor;
            currentMaxWidth = healthMaxWidth;
            currentText = healthText;
            currentMaxValue = healthMaxValue;
        }
        //如果是蓝条
        else {
            currentAxis = ver;
            currentMaxWidth = powerMaxWidth;
            currentText = powerText;
            currentMaxValue = powerMaxValue;
        }
        //根据用户的操作,计算当前条的宽度
        float newWidth = rectTr.sizeDelta.x +
            currentAxis * Time.deltaTime * speed;
        //限制宽度
        float realWidth = Mathf.Clamp (newWidth, 0, currentMaxWidth);
        //赋值到RectTransform
        rectTr.sizeDelta = new Vector2(realWidth,rectTr.sizeDelta.y);
        //计算当前数值
        float currentValue = (realWidth / currentMaxWidth) * currentMaxValue;
        //转整数操作
        currentValue = Mathf.Round (currentValue);
        //将数值信息显示到Text
        currentText.text = currentValue.ToString () + "/"
            + currentMaxValue.ToString ();
    }
}

血条,蓝条对象上都挂上此脚本

时间: 2024-11-24 23:29:39

WASD控制UI界面血条加减的相关文章

Android——控制UI界面

一.使用XML布局文件控制UI界面 res\layout\activity_main.xml代码如下: <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:id="@+id/FrameLayout1" android:layout_width

android基础(1):控制UI界面

一:xml布局文件控制UI界面 activity_main.xml <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="fill_parent" > <TextView android:layout_width="

控制UI界面

在android中,一共有四种方式. 第一种:使用XML布局文件控制UI界面 关键步骤有2个: 1.在Android应用的res/layout目录下编写,创建一个项目,eclipse会自动生成一个xml文件.同时在gen/目录中会自动生成R.javaw. 2.在Activity中使用以下代码: setContentView(R.layout.activity_main); 第二种:使用Java代码来控制UI界面. 关键步骤如下: 1.创建布局管理器,可以是帧布局,表格布局,线性布局,相对布局,并

Android控制UI界面

⒈使用XML布局文件控制UI界面[推荐] Android推荐使用XML布局文件来控制视图,这样不仅简单.明了,而且可以将应用的视图控制逻辑从Java或Kotlin代码中分离出来,放入XML文件中控制,从而更好的体现MVC原则. Android把用户界面放在XML文档中定义,就可以让XML文档专门负责用户UI设置,而Java程序则专门负责业务实现,这样可以降低程序的耦合性. 当我们在Android应用的\res\layout目录下定义一个主文件名任意的XML布局文件之后(R.java会自动收录该布

家庭记账本app进度之ui相关概念控制ui界面与布局管理

ui就是用户界面设计的意思. 首先是view,view相当于窗户上的玻璃. 1.android:id属性.android:id="@+id/user".他的id是user前面的@+id是固定的写法. 2.android.background.当应用图片资源的时候这样写需要经名字为bg的相关图片般存在mi pmap这个里面才可以使用. 这样是设置背景颜色.后边是16进制的颜色 3.android.padding属性设置上下左右四个方向的内边距 这样写就是上下左右都一样这是分别进行设置的.

Android有感(9):10.使用XML文件和Java代码控制UI界面

Android推荐使用XML文件设置UI界面,然后用Java代码控制逻辑部分,这体现了MVC思想. MVC全名是Model View Controller,是模型(model)-视图(view)-控制器(controller)的缩写,一种软件设计典范,用一种业务逻辑.数据.界面显示分离的方法组织代码,将业务逻辑聚集到一个部件里面,在改进和个性化定制界面及用户交互的同时,不需要重新编写业务逻辑. 我们可以在app\src\main\res\layout目录下定义一个XML文件(R.java文件会自

使用xml和java代码混合控制UI界面

main.xml.................... <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"     android:orientation="horizontal"     android:layout_width=&qu

用代码控制UI界面

       1 public class MainActivity extends Activity { 2 //当第一次创建Activity时回调该方法 3 @Override 4 protected void onCreate(Bundle savedInstanceState) { 5 super.onCreate(savedInstanceState); 6 //创建一个线性布局管理器 7 LinearLayout layout = new LinearLayout(this); 8

Android Studio开发基础之使用XML和Java代码混合控制UI界面

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:paddingLeft