UI3D转2D平面显示UI3DTo2D血条显示
UI3D转2D平面显示UI3DTo2D血条显示:
using UnityEngine;
using System.Collections;
public class UI3DTo2D : MonoBehaviour
{
private GameObject _TargetEnemyObj; //目标物体
private Camera worldcamera; //世界相机
private Camera guiCamera; //UI相机
private Slider uiSlider; //敌人的血条
public float FloHPPrefabsLength = 2F; //血条预设长度
public float FloHpPrefabsHeight = 1F; //血条预设高度
public float FloHpHeightPosset = 1.5F; //血条高度偏移量
//敌人生命数值
private float _FloCurrentHP = -999; //当前生命数值
private float _FloMaxHP = -999; //最大生命数值
// 设置目标敌人
public void SetTargetEnemy(GameObject goEnemy)
{
_TargetEnemyObj = goEnemy;
}
//初始化目标对象变量
void Start()
{
//本UI Label 对象尺寸
this.transform.localScale = new Vector3(FloHPPrefabsLength, FloHpPrefabsHeight, 0);
//得到UI Slider 控件
uiSlider = this.gameObject.GetComponent<Slider>();
//世界摄像机(主摄像机)
worldcamera = Camera.main.gameObject.GetComponent<Camera>();
//带标签Tag_UICamera的UI摄像机
guiCamera = GameObject.FindGameObjectWithTag(Tag.Tag_UICamera).GetComponent<Camera>();
//参数检查
if (_TargetEnemyObj == null)
{
return;
}
}
// 计算敌人血量
void Update()
{
//判断帧数
if (Time.frameCount % 2 == 0)
{
try
{
//当前与最大生命值
_FloCurrentHP = _FloCurrentHP; //变化的生命值(实时更新)
_FloMaxHP = _FloMaxHP; //变化的生命值(实时更新)
//计算敌人血量
uiSlider.value = _FloCurrentHP / _FloMaxHP;
//本UI Label 对象尺寸
this.transform.localScale = new Vector3(FloHPPrefabsLength, FloHpPrefabsHeight, 0);
if (_FloCurrentHP <= (_FloMaxHP * 0.05))
{
//死亡销毁
Destroy(this.gameObject);
}
}
catch (System.Exception)
{
throw;
}
}
}
// 敌人血量计算后,实时的把_TargetEnemyObj的世界坐标转换为UI世界坐标,通过世界摄像机,转屏幕坐标,再把3D敌人(世界摄像机)屏幕坐标,转UI摄像机的屏幕坐标
void LateUpdate()
{
if (_TargetEnemyObj != null)
{
if (Time.frameCount % 2 == 0)
{
//获取目标物体的屏幕坐标
Vector3 pos = worldcamera.WorldToScreenPoint(_TargetEnemyObj.transform.position);
//将屏幕坐标转换为UI的世界坐标
pos = guiCamera.ScreenToWorldPoint(pos);
//由于NGUI 2D界面的Z轴都为0,只取其X,Y坐标
pos.z = 0;
//将修改过的坐标赋给UI界面
transform.position = new Vector3(pos.x - 0.1f, pos.y + FloHpHeightPosset, pos.z);
}
}
}
}
注:void LateUpdate()方法为摄像机转换坐标,是具体实现的过程,此方法为世界坐标和平面坐标之间的转换,可逆向操作实现
UI3D转2D平面显示UI3DTo2D血条显示的更多相关文章
- unity如何显示血条(不使用NGUI)
用unity本身自带的功能,如何显示血条? 显示血条,从资源最小化的角度,只要把一个像素的色点放大成一个矩形就足够,三个不同颜色的矩形,分别显示前景色,背景色,填充色,这样会消耗最少的显存资源. un ...
- Unity3D人物头顶名称与血条更新与绘制
using UnityEngine; using System.Collections; public class NPC : MonoBehaviour { //主摄像机对象 private Cam ...
- Unity UGUI实现分段式血条
我们可以看到像英雄联盟等游戏里英雄头顶的血条显示并非是纯色的,而是根据血量的多少而显示一定量的格子,这种方式明显是比较友好.比较美观的,事实上我们的游戏里面也想实现这样的效果,那该怎么办呢?根据血量的 ...
- pygame 笔记-7 生命值/血条处理
通常游戏中的角色都有所谓的生命值,而且头顶上会有一个血条显示.生命值无非就是一个属性而已,很容易在Player.py类中增加,头顶上的血条其实就是绘制二个矩形,叠加在一起. 以上节的Player.py ...
- unity3d-游戏实战突出重围,第二天 制作血条
using UnityEngine; using System.Collections; public class xt : MonoBehaviour { //红色血条 public Texture ...
- 制作Unity中的单位血条
本文章用于记录Unity的学习过程,如有疑问,欢迎交流. 1.血条的显示 在Unity场景中创建空物体,然后新建两个Image(图片),当然只用一个也行,一个作为填充来显示血量,一个作为血条的外框. ...
- NGUI研究之3D模型坐标转2D屏幕坐标-血条
刚好今天有朋友问我,比較典型的样例就是游戏里面人物的血条. 原理非常easy就是把3D点换算成2D的点.可是因为NGUI自身是3D所以我们须要先把NGUI下的点转成2D点.然后在把他转成3D的点 ...
- Shader实例:NGUI制作网格样式血条
效果: 思路: 1.算出正确的uv去采样过滤图,上一篇文章说的很明白了.Shader实例:NGUI图集中的UISprite正确使用Shader的方法 2.用当前血量占总血量的百分比来设置shader中 ...
- Unity NGUI弧形血条的制作
unity版本:4.6 NGUI版本:3.6. (转载请注明参考链接及作者) 参考链接:http://www.cnblogs.com/louissong/p/3841656.html,作者:博客园 L ...
随机推荐
- LeetCode第136题:只出现一次的数字
问题描述 给定一个非空整数数组,除了某个元素只出现一次以外,其余每个元素均出现两次.找出那个只出现了一次的元素. 说明: 你的算法应该具有线性时间复杂度. 你可以不使用额外空间来实现吗? 示例 1: ...
- STL源码剖析--迭代器(转)
一.为什么需要traits编程技术 前面说了很多关于traits的光荣事迹,但是却一直没有介绍traits究竟是个什么东西,究竟是用来干什么的?traits在英文解释中就是特性,下面将会引入trait ...
- 解决Visiual Studio2012 CLR20r3问题
解决办法: 步骤1:开始-->所有程序-->Microsoft Visual Studio 2012-->Visual Studio Tools-->VS2012 开发人员命令 ...
- java 学习第零篇JDK安装和记事本编辑JAVA(2)
上面说了如何安装JDK那么这把就是来说怎么用记事本编写java 桌面上新建一个记事本 之后编写: public class a{ public static void main(String [ ...
- python logging日志库
项目中使用的日志库是使用python官方库logging封装的,但是居然一直么有设置日志自动滚动,经常会受到告警说哪台机器磁盘空间又满,清理一下,于是研究一下,解决这个问题. 参考:https://d ...
- [poj 2456] Aggressive cows 二分
Description Farmer John has built a new long barn, with N (2 <= N <= 100,000) stalls. The stal ...
- 从零开始安装 Ambari (4) -- 通过 Ambari 部署 hadoop 集群
1. 打开 http://192.168.242.181:8080 登陆的用户名/密码是 : admin/admin 2. 点击 “LAUNCH INSTALL WIZARD”,开始创建一个集群 3 ...
- P4332 [SHOI2014]三叉神经树
\(\color{#0066ff}{ 题目描述 }\) 计算神经学作为新兴的交叉学科近些年来一直是学术界的热点.一种叫做SHOI 的神经组织因为其和近日发现的化合物 SHTSC 的密切联系引起了人们的 ...
- Tarjan+树形DP【洛谷P2515】[HAOI2010]软件安装
[洛谷P2515][HAOI2010]软件安装 题目描述 现在我们的手头有N个软件,对于一个软件i,它要占用Wi的磁盘空间,它的价值为Vi.我们希望从中选择一些软件安装到一台磁盘容量为M计算机上,使得 ...
- luogu3911 最小公倍数之和(莫比乌斯反演)
link 给定\(A_1,A_2,\dots,A_N\),求\(\sum_{i=1}^N\sum_{j=1}^Nlcm(A_i,A_j)\) \(1\le N\le 50000;1\le A_i\le ...