# 认识界面控件
# 作者:境界
UI界面是由一个个界面控件组合而成,常见的控件有按钮、文字板、网格、输入框等。目前MCSTUDIO支持使用界面编辑器来制作UI,同时可以根据不同分辨率来模拟UI在手机、PC电脑、平板上的效果,最大程度去适配不同终端的屏幕。因此本章会通过界面编辑器来带开发者了解界面控件,对于常用的控件能够获得基本的认识。
# 画布
画布可以视为界面的入口,一张画布包含着多个属性,同时将界面放入画布内容中,还可以直接适配异形屏,最大程度地使界面在多种屏幕上都能正常使用。
# 画布属性有以下几种:
①始终支持按键,即这个界面生成时,若玩家按到如移动按键等,人物也会响应按键效果产生移动。
②创建时运行游戏,即这个界面生成时,界面背后的游戏世界是否照常在屏幕上渲染。
③点击穿透,即这个界面生成时,点击后是否会同样在下方的旧界面上响应到这个输入。例如,我们在HUD界面(带有移动键、快捷栏的界面)上生成了另一个新界面,手指点击屏幕时会先点到新界面,而这个属性若勾选起来,则下方的HUD界面也会响应,即可能隔着一个界面还是能点到移动键等。
④代替暂停界面,即这个界面生成后,若在允许弹出暂停界面的情况下,将此属性勾选,则无法弹出暂停界面。
⑤限制光标移动范围,即这个界面生成后,PC电脑上光标只会在界面范围内出现。勾选后非常适合用来将界面与电脑基岩版适配。
⑥强制持续渲染,即这个界面生成后,在电脑资源占用过高时依旧会渲染,不勾选的话,在电脑运算压力过大时,可能不会渲染。
⑦继承基类画布,即界面使用了被绝大多数原版界面使用的画布属性。
# 画板
面板可以视为界面里一个被分割的区块,是一个区域部分。想象一下,在一个画布中,我们希望在左上角横铺四个按钮,让它们紧贴在一起。比较寻常的方法是使用界面编辑器在画布控件下新建四个按钮,并将它们依次移动到左上角。有时我们希望在控件结构里隐藏按钮显示其他区域,或者在代码里隐藏这几个按钮,可能一下子就要多写很多额外的代码。而通过把控件归纳到面板下,移动面板的位置,面板所包含的控件会一并移动,隐藏面板时,也会一并消失。它更像是电脑文件管理系统的文件夹。学会使用面板,可以将一个界面的功能分开成好几个独立的区域,也可能会让控件结构和在后续的代码编写中起到更加简洁、方便的效果噢!
# 按钮
按钮可以被玩家点击,在界面编辑器中,通过设置按钮大小和不同按入状态的贴图,可以做出许多丰富的样式。同时编辑器还为开发者在按钮内包装了一个文本,若开发者选择不将文本画在按钮贴图内时,可以选择使用自定义按钮文本的功能。默认情况下按钮贴图会指向无,即使用原版的常用按钮贴图。若使用原生贴图,则会打开原版textures文件夹,点击ui文件夹后可以看到所有的原版贴图,方便开发者选择自己心仪的原版资源。而若选择自定义的话,则会下方资源管理器中,出现由开发者导入的新贴图。
# 需要注意以下几点:
①按钮使用的贴图一共要用到三种,分别是普通、悬浮、按下,普通即是看到按钮默认下的状态,悬浮是指针放在按钮上的状态,按下则是点击按钮的状态。
②九宫格指九宫格拉伸原理,它是处理贴图纹理在游戏界面减少资源占用中应用到的一种高级方法。更多详细内容可以查看官方教程 (opens new window)。
# 图片
图片控件会显示一张图片。需要将图片类型选择原生或者自定义的方式,来选择需要使用的资源。下方的UV起点和UV尺寸,前者会决定图片从哪个端点开始,尺寸决定从UV起点开始,向下延长宽度,向右延长长度。在上一章自定义粒子的时候,我们使用原版粒子贴图可以看到基岩版将所有常用粒子放在一张128x128的尺寸贴图上,使用uv起点和尺寸就是决定显示它的某一个区域。
# 文本
文本控件顾名思义,就是用来显示文本。文本支持文字投影,文字颜色、字号、行间距、字对齐等功能。所有原版界面显示的文本都依赖它,包括输入框这样的控件,本质上也是将玩家输入的内容以文本的形式呈现出来,是非常重要的控件。
# 文本输入框
文本输入框允许玩家输入文本进入框内,同时通过代码监听绑定输入框交互和绑定输入框内容,可以知道在脚本内获得文本输入框的内容。需要注意的是,一个新的界面若用到了文本输入框,则会阻止其他输入,如主界面的移动、跳跃按钮等。因此使用到文本输入框的界面,我们应将它处理为一个静止游戏界面。就像原版的聊天界面、背包界面一样。
# 开关
开关控件常用来决定一个功能或者状态是开启还是关闭。它只带有真假两种状态,在原版的设置界面中大量用到了开关控件。因此在决定一个新界面是否需要用到这样的控件,就要清楚自己是否需要设置一种开启或者关闭的功能。通过代码监听绑定开关交互和按钮状态,可以知道某个开关的状态。
# 纸娃娃
纸娃娃控件用来渲染一个实体模型到屏幕上。在编辑器中当前只支持显示玩家模型和FBX 三维模型,使用MODSDK可以更加方便地设置模型的缩放大小、实体类型、沿Y轴的旋转角度等。非常适合用来做展示实体生物的界面。
# 物品渲染
物品渲染控件用来渲染一个物品在界面上。在原版界面里,它常被应用在需要显示物品的地方。如背包界面、附魔台界面、铁砧界面等。这些界面中允许玩家放入物品的物品栏,本质上就是一个按钮下挂载了一个物品渲染控件。当按钮被点选时,按钮呈现按住状态,若里面存在物品时,则在它挂载下的物品渲染控件显示一个物品道具。
# 进度条
进度条控件常用来显示某种流程的进度。比如某种机器的工作进度、某个状态的变动程度等等。进度条的贴图一般使用一张完整的长贴图,使用modsdk可以对进度条控件设置切割图片的程度,以1.0为一个完整的长度,若通过接口设置切割程度为0.1,则只会显示10%的进度条。
# 滚动列表
滚动列表常用来滑动一块内容区域,这个内容可以是文本输入框、图片、网格等。想象一下,原版的创造背包栏,物品从头到尾排序下来,显示的按钮数量之多远远超过了屏幕可以容纳的范围。使用滚动列表可以只显示背包栏中间的一块区域,其他部分通过滚动内容区域的形式慢慢向上呈现。
# 网格
网格控件可以帮助开发者将其他画布的控件内容绑定在网格控件上。例如,原版的大箱子界面内置了一个网格控件,网格的格数大小是从左往右数9格,从上往下数6行,并将网格控件里的内容指向物品栏按钮。这方便开发者统一管理一序列重复的控件,而不需要专门为了实现类似的功能,真的去手动新建多个控件并计算它们之间的间隔排列组合。