Unity UGUI实现分段式血条
我们可以看到像英雄联盟等游戏里英雄头顶的血条显示并非是纯色的,而是根据血量的多少而显示一定量的格子,这种方式明显是比较友好、比较美观的,事实上我们的游戏里面也想实现这样的效果,那该怎么办呢?根据血量的多少同时创建N多个小格子图片?这明显不合理;根据血量多少同时创建N多个分割线来拆分图片?这也不合理。
所以我今天将以一种很简单的方式实现这种效果,当然没什么难度,只对UGUI的Slider做一些修改就可以了。
一、首先,我们创建一个Slider,删除他的Handle,勾选Whole Numbers(按整型数改变值),大概就是这样:
二、给Fill Rect目标添加我们的脚本BloodImage,并删除原本的Image组件,为BloodImage指定一个纹理,纹理必须是Texture类型:
BloodImage继承至RawImage,所以只能接收Texture类型的图片源,他主要负责的就是根据血条的长度对图片进行循环排版。
using UnityEngine;
using UnityEngine.UI; public class BloodImage : RawImage { private Slider _BloodSlider; protected override void OnRectTransformDimensionsChange()
{
base.OnRectTransformDimensionsChange(); //获取血条
if (_BloodSlider == null)
_BloodSlider = transform.parent.parent.GetComponent<Slider>(); //获取血条的值
if (_BloodSlider != null)
{
//刷新血条的显示
float value = _BloodSlider.value;
uvRect = new Rect(0,0,value,1);
}
}
}
到这里,基本上就OK了,你想要血条显示为多少个小格子,就更改slider的Max Value属性(最大值)就可以了。
效果图如下:
当然如果你有更好的素材,这个血条会更加美观。
三、我已经将BloodSlider发包成一个插件,导入该插件,便可以直接在场景创建BloodSlider。
插件链接:http://download.csdn.net/detail/qq992817263/9660453
Unity UGUI实现分段式血条的更多相关文章
- Unity UGUI HUD 怪物血条实现
		首先做一个血条,创建一个名为Follow3DObject的脚本添加到血条控件上. Follow3DObject.cs的代码如下: using UnityEngine; using System.Col ... 
- unity如何显示血条(不使用NGUI)
		用unity本身自带的功能,如何显示血条? 显示血条,从资源最小化的角度,只要把一个像素的色点放大成一个矩形就足够,三个不同颜色的矩形,分别显示前景色,背景色,填充色,这样会消耗最少的显存资源. un ... 
- Unity NGUI弧形血条的制作
		unity版本:4.6 NGUI版本:3.6. (转载请注明参考链接及作者) 参考链接:http://www.cnblogs.com/louissong/p/3841656.html,作者:博客园 L ... 
- unity制作简单血条
		学习Unity已经10天了,也没发现有什么长进,真的急.昨天仿着官方Demo做了个射击游戏轮廓,其中需要给每个怪做一个血条. 搜了一些,挺复杂的,用NGUI或者UGUI,外加很长的代码...不过还是找 ... 
- Unity NGUI 血条制作
		NGUI 血条制作步骤 实现过程: 模拟血条的变化当点击按钮Button是血条会实时发生变化. 1.向Unity中导入NGUI2.6.3.unitypackage 点击create your ui 后 ... 
- 【FairyGUI & Unity】实现血条UI扣血与加血的缓动效果
		组件设计 创建一个进度条组件,作为血条. bar是实际血量条 DownBar是扣血缓动背景图层 UpBar是加血缓动背景图层 LowBar是低血量变色(和控制器配合,本文不讲) n11组合是血量参考线 ... 
- UGUI血条跟随
		定义常量 public class Content { //当前UI分辨率 public const float UI_Width = 1366f; public const float UI_Hei ... 
- 关于Unity中NGUI的3D角色血条的实现
		首先要到Unity的Assets Store里面去下载一个扩展的Package叫NGUI HUD Text v1.13(81),注意如果没有安装NGUI就必须先安装NGUI插件,否则会用不了,因为HU ... 
- UGUI之Slider使用,制作血条
		用Slider来控制Cube旋转 Slider是滑动条. 
随机推荐
- [LeetCode] IP to CIDR 将IP地址转为CIDR无类别域间路由
			Given a start IP address ip and a number of ips we need to cover n, return a representation of the r ... 
- [LeetCode] Subarray Product Less Than K 子数组乘积小于K
			Your are given an array of positive integers nums. Count and print the number of (contiguous) subarr ... 
- 字符串的一些常用方法 string
			##字符串## 字符串: 由0个或多个字符组成,被成对的英文单引号或双引号包含起来的. 字符编码: 每一个字符在计算机存储的编号. 计算机会保存有一套或几套用于标注编号与字符对应关系的字典.(字符集) ... 
- java--Iterator迭代问题:集合并发访问异常
			用Iterator对数组进行迭代后,如果在迭代过程中对数组进行增加元素操作(这里iterator本身没有提供增加操作方法)时,就会抛出并发访问异常: 异常如下: Exception in thread ... 
- Centos常用命令之:压缩与解压缩
			在Linux中,压缩文件的扩展名主要是:[*.tar,*.tar.gz,*.tgz,*.gz,*.Z,*.bz2],虽然,我们知道,在LInux中,文件的扩展名没有什么作用,但是由于在Linux中支持 ... 
- 计蒜客NOIP模拟赛4 D1T2小X的密室
			小 X 正困在一个密室里,他希望尽快逃出密室. 密室中有 N 个房间,初始时,小 X 在 1 号房间,而出口在 N 号房间. 密室的每一个房间中可能有着一些钥匙和一些传送门,一个传送门会单向地创造一条 ... 
- 51Nod 1781 跑的比谁都快
			香港记者跑的比谁都快是众所周知的常识. 现在,香港记者站在一颗有 n 个点的树的根结点上(即1号点),编号为 i 的点拥有权值 a[i] ,数据保证每个点的编号都小于它任意孩子结点的别号. 我们假定这 ... 
- bzoj4447[Scoi2015]小凸解密码
			4447: [Scoi2015]小凸解密码 Time Limit: 20 Sec Memory Limit: 128 MBSubmit: 150 Solved: 58[Submit][Status ... 
- POJ-2299 Ultra-QuickSort---树状数组求逆序对+离散化
			题目链接: https://vjudge.net/problem/POJ-2299 题目大意: 本题要求对于给定的无序数组,求出经过最少多少次相邻元素的交换之后,可以使数组从小到大有序. 两个数(a, ... 
- intellij配置hibernate自动生成hbm.xml文件
			1.首先创建一个Java web项目,这里因为已经在整个项目中配置好tomcat了,所以我是直接创建module的,其实和创建project的配置方法一样,创建的时候选择Web Application ... 
