NGUI学习笔记(一)UILabel介绍
来个前言:
作为一个U3D程序员,自然要写一写U3D相关的内容了。想来想去还是从UI开始搞起,可能这也是最直观同时也最重要的部分之一了。U3D自带的UI系统,也许略坑,也没有太多介绍的价值,那么从今天开始就记录一下主流的UI插件-NGUI吧。
NGUI版本:
v3.6.8
学习笔记一
假定大家都已经将ngui导入到了项目中,这里需要注意,插件(.package)的存放路径不能有中文,否则会导致解压失败。
导入之后可以看到几个文件夹咯,Editor,Examples,Resources,Scripts,辣么,作为刚刚接触U3D或者NGUI的小伙伴们,就可以去Examples的Scenes目录下去看看相应的例子,都是一些完成好的场景哦~
打开场景之后,可以看到已经完成的UI,但是这时候默认的都是3D场景,而一般的UI都是2D的,所以记得在Scene视窗中把2D选项点上。这样看起来就是2D的UI了。
创建UIRoot
OK,光说不练假把式,下面我们自己来创建一个Scene,来制作自己的第一个UI。
创建好新的场景之后,在菜单栏的NGUI选项中可以发现Options-->Reset Prefab Toolbar,点击之,可以发现NGUI预设的一些控件出现了。这就是方便我们创建UI控件的地方。
那么为了满足承载NGUI的UI的需求,我们需要一个UIRoot来作为承载UI容器。那么如何创建呢?很简单,直接把Prefab Toolbar中的控件拖入场景中,你会发现在Hierarchy中出现了一个UIRoot。UIRoot创建成功,打开可以发现其自带了一个Camera,作为UI的摄像机来渲染UI元素。
选中Scene中的UIRoot,右键,可以看到菜单上出现了Create用来创建各种UI元素的选项,Attach添加滚动视野,属性绑定等的选项,Tween添加动画选项。
创建UILabel
UILabel,顾名思义,用来显示文字。右键UIRoot,Create,UILabel。注意,如果右键UIRoot控件,没有菜单弹出,则看下右侧UIRoot的Inspector中的脚本是否没有展开,若没有展开则无法运行相应的功能。
创建玩Label之后,点中它,可以看到在屏幕右侧的Inspector。我们的关注点就在Inspector中UILabel脚本中的各个属性。
Font:
首先是字体属性Font,可以看到有2种字体第一种是NGUI第二种是Unity,选择NGUI则意味着使用的是我们通过NGUI创建的字体(在菜单栏NGUI下拉菜单中选择Open->FontMaker来创建NGUI字体,之后会介绍),

选择Unity,可以发现默认情况下其只有一个Arial字体,辣么一目了然咯,Unity字体其实就是动态字体.TTF。我们可以通过下载TTF字体放到项目目录,再通过Unity字体来使用。
Font Size:
下面介绍下Font Size咯,就是字号,默认20。那么我们将字号设为100,为何发现字体没有相应的变大呢?这是由于Label控件本身还有一个Size的问题,就是一个容器和容器内容的关系,容器内容不可能比承载它的容器大。那么只要设置Widget的Size属性就可以调节大小了。当Label控件的尺寸足够大,则字体会按照设定的Font Size来显示。当然字体显示的方式,还与下面介绍的Overflow属性有关。
Overflow:

和字体显示相关一个属性,相当于一个字体显示的策略。包括4种策略,即ShrinkContent, ClampContent, ResizeFreely, ResizeHeight4种。下面来分别介绍。
ShrinkContent:即默认的策略,文字显示的大小与Label的Size自动适应,Label控件的Size不足以显示字体的大小时,字体的尺寸会去适应Label控件的大小。
ClampContent:如字面意思,就是裁剪掉无法显示的字体内容。字体内容会按照Font Size设定的大小来显示,但是当Label控件的大小不足以盛放字体内容时,相应的字体内容被裁剪掉不会显示。
ResizeFreely:与第一种策略相对应,这时是Label控件的大小去适应字体内容的大小。
ResizeHeight:同字面意思,Label控件的高度无法手动调节,而是随着字体内容的大小需求去适配字体内容,只能手动调节Label控件的宽度。
Alignment:

对齐方式选项。包括5种策略,比如常见的自动对齐,左中右对齐,还有一个较为特殊的Justified对齐方式。
Justified:即自动扩展,使文字与Label控件的宽度保持一致。不过有一点需要注意,该对齐方式只对英文有效。中文就不要使用了。。。
Gradient:
字体颜色渐变的设置。包括Top和Bottom,即从Top色变到Bottom色。
Effect:
效果,无需赘述,包括描边(outline)和阴影(Shadow)。
Color Tint:
字体渲染的颜色。
好啦,今天就先总结到这里了。
NGUI学习笔记(一)UILabel介绍的更多相关文章
- NGUI 学习笔记实战之二——商城数据绑定(Ndata)
上次笔记实现了游戏商城的UI界面,没有实现动态数据绑定,所以是远远不够的.今天采用NData来做一个商城. 如果你之前没看过,可以参考上一篇博客 NGUI 学习笔记实战——制作商城UI界面 ht ...
- NGUI学习笔记汇总
NGUI学习笔记汇总,适用于NGUI2.x,NGUI3.x 一.NGUI的直接用法 1. Attach a Collider:表示为NGUI的某些物体添加碰撞器,如果界面是用NGUI做的,只能这样添加 ...
- NGUI 学习笔记实战——制作商城UI界面
http://www.cnblogs.com/chongxin/p/3876575.html Unity3D的uGUI听说最近4.6即将推出,但是目前NGUI等UI插件大行其道并且已经非常成熟,所以我 ...
- HTML+CSS学习笔记(1) - Html介绍
HTML+CSS学习笔记(1) - Html介绍 1.代码初体验,制作我的第一个网页 <!DOCTYPE HTML> <html> <head> <meta ...
- Typescript 学习笔记一:介绍、安装、编译
前言 整理了一下 Typescript 的学习笔记,方便后期遗忘某个知识点的时候,快速回忆. 为了避免凌乱,用 gitbook 结合 marketdown 整理的. github地址是:ts-gitb ...
- cocos2d-x入门学习笔记,主要介绍cocos2d-x的基本结构,并且介绍引擎自带的示例
cocos2d-x 3.0 制作横版格斗游戏 http://philon.cn/post/cocos2d-x-3.0-zhi-zuo-heng-ban-ge-dou-you-xi http://blo ...
- InterSystems Ensemble学习笔记(一) Ensemble介绍及安装
系列目录 InterSystems Ensemble学习笔记(一) Ensemble介绍及安装InterSystems Ensemble学习笔记(二) Ensemble创建镜像, 实现自动故障转移 一 ...
- vue.js 2.0 官方文档学习笔记 —— 01. vue 介绍
这是我的vue.js 2.0的学习笔记,采取了将官方文档中的代码集中到一个文件的形式.目的是保存下来,方便自己查阅. !官方文档:https://cn.vuejs.org/v2/guide/ 01. ...
- Apache Ignite 学习笔记(一): Ignite介绍、部署安装和REST/SQL客户端使用
Apache Ignite 介绍 Ignite是什么呢?先引用一段官网关于Ignite的描述: Ignite is memory-centric distributed database, cachi ...
随机推荐
- Jquery mobiscroll 移动设备(手机)wap日期时间选择插件以及滑动、滚动插件
Jquery Mobiscroll是一个用于触摸设备(Android phones, iPhone, iPad, Galaxy Tab)的日期和时间选择器jQuery插件.以及各种滑动插件 可以让用户 ...
- webapi - 模型验证
本次要和大家分享的是webapi的模型验证,讲解的内容可能不单单是做验证,但都是围绕模型来说明的:首先来吐槽下,今天下午老板为自己买了套新办公家具,看起来挺好说明老板有钱,不好的是我们干技术的又成了搬 ...
- RMS:不能对生产服务器使用测试清单
问题说明:在使用office软件RMS加密时报:不能对生产服务器使用测试清单,或者使用 rmsbulk.exe进行RMS加密时,报不能连接到RMS服务器. 解决办法: 请到https://suppor ...
- Android中开发工具Android Studio修改created用户(windows环境)
最近经常有朋友反馈说我的安卓项目中,在一些类中会出现Created by panchengjia on 2016/12/30的字样,是如何自动实现的(默认一般为Administrator),如下图: ...
- sql 删除表中的重复记录
嗯,遇见了表中存在重复的记录的问题,直接写sql删除时最快的,才不要慢慢的复制到excel表中慢慢的人工找呢.哼. 如下sql,找出重复的记录,和重复记录中ID值最小的记录(表中ID为自增长) sel ...
- [Hadoop in Action] 第5章 高阶MapReduce
链接多个MapReduce作业 执行多个数据集的联结 生成Bloom filter 1.链接MapReduce作业 [顺序链接MapReduce作业] mapreduce-1 | mapr ...
- Linux实战教学笔记03:操作系统发展历程及系统版本选择
标签(空格分隔): Linux实战教学笔记-陈思齐 第1章 Linux简介 1.1 什么是操作系统? 简单讲:操作系统就是一个人与计算机硬件的中介. 操作系统,英文名称Operating System ...
- BZOJ 3894: 文理分科 [最小割]
3894: 文理分科 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 674 Solved: 392[Submit][Status][Discuss] ...
- jQuery.data() 使用方法
data() 方法向被选元素附加数据,或者从被选元素获取数据.在实际开发中,可以用来记录上一步操作某一对象的值,来给下一步操作做一些判断 $("#btn1").click(func ...
- ASP.NET 5运行时升级到Beta5
在Visual Studio 2015 RTM和Windows 10正式发布之前,微软把开源.NET升级到了beta5,带来了一些增强和改变.和Visual Studio 2015 RC一起安装的AS ...