1. 基本内容
  1. UGUI部分控件支持检测控件值改变,入参Singlefloat类型,选择最上方Dynamic中的方法
  2. 按下ALT键再选择适配UI方式,即可将子物体适应到父物体对应合适位置与大小
  3. 拖动子物体四花瓣位置直到容纳该物体,即可实现子物体大小与父物体位置、大小保持相对比例
  4. 在检查器右方 : 处切换DEBUG模式,可以查看物体相对坐标,锚点坐标。
    相对坐标:物体相对于锚点的坐标
    锚点坐标:锚点相对于父物体的坐标
    因此修改UI位置时,相对坐标修改尽量使用锚点坐标进行修改。
  5. 获取UI组件宽高:transform.GetComponent<RectTransform>().rect.width
  6. 左为蓝图模式:物体操纵大小不会受到缩放影响
    右为原始编辑模式:改变物体轴心点时,不再修改轴心点而是改为修改物体位置代替
2. 基本内容
  1. Canvas三种类型:界面顶部、摄像机指定位置、世界空间显示(需指定渲染它的摄像机)
  2. Canvas Scaler:
    恒定像素大小时,缩放系数表示画布的整体缩放大小
    屏幕大小缩放时,根据参考分辨率配置屏幕。屏幕匹配:依赖宽高、向外扩展,向内收缩。
    每单位参考像素越小,UI设置成原生大小时渲染的大小越小
  3. GraphicRaycaster用于UI层的射线检测。
    忽略保留图形启用时,如果UI图像已经正反翻转了,那么它将不再射线检测。
    阻塞对象选定时,决定UI在 摄像机指定位置、世界空间显示 情况下,当2D、3D有碰撞体的物体在UI层之上时,哪种不允许射线穿透点击。
    阻塞遮罩决定了阻塞对象发生时,阻塞物体的条件层级。
  4. CanvasGroup组件功能分别为:透明度、按钮可用性、射线检测、忽略父级的CanvasGroup组件
3. 功能控件
  1. Button控件
    Unity的按钮获取焦点后,点击空格或回车键,也可以调用按钮监控事件,这是因为Button组件的navigation被默认为Automatic,若改成None可禁止该行为。
    Navigation(按钮导航):

在EventSystem中,存在一个当前被选中按钮,我们可以通过代码按下的上下左右,使被选中按钮进行更改。

方法

描述

None(关闭)

关闭导航。

Automatic(自动导航)

自动识别最近的一个控件并导航到下一个控件。

Horizontal(水平导航)

水平方向导航到下一个控件。

Vertical(垂直导航)

垂直方向导航到下一个控件。

Explicit(指定导航)

特别指定在按下特定方向键时从此按钮导航到哪一个控件。

方法

描述

onClick.AddListener()

添加监听点击的事件

  1. Slider控件

方法

描述

onValueChanged.AddListener(float)

添加监听值改变的事件

minvalue、maxvalue 设置最大、最小值
整数决定是否仅限整数

  1. Dropdown控件

方法

描述

onValueChanged.AddListener(int)

添加监听值改变的事件

Dropdown的选项列表中可以设置每个选项的对应的图像。

需在Dropdown子对象中新建一个image放在标题图像上,再在Template对象中新建一个image放在项图像上

unity 设置3d物体的锚点 unity改变物体锚点_游戏引擎

  1. Toggle控件

方法

描述

onValueChanged.AddListener(bool)

添加监听值改变的事件

ToggleGroup组件
Allow Switch Off:允许管理的开关列表中一个也未被点击。

  1. RawImage控件
    允许图像局部显示,即只显示图像的一小部分。
    UV矩形:x,y偏移比,wh宽高显示比
    资源中右键新建渲染器纹理,在摄像机中赋值该纹理,再为 RawImage 也赋值该纹理,即可实现在UI面板中显示摄像机画面的效果。该功能可用于实现在UI面板中显示3D模型
  2. InputField控件
    内容自定义时的验证:
    直线类型:单行、回车键提交、回车键换行
    输入类型:主要区分是否为密码
    键盘类型:用于移动端提示系统这里输入的类型来弹出输入框
    角色验证:输入规则限制
  3. 布局组件
    子力扩展会在空间内自动平分内部元素
    控制子对象大小会令子对象充满内容,必须与子力扩展共同使用
    为子对象添加LayoutElement,这样就可让子对象不在受控于父对象的布局组件
    LayoutElement(依赖于布局组件):最小宽高(底线,优先于父组件的宽高布局)、优先选择的宽高(次级)、扩展倍率(最低级)
  4. AspectRatioFitter 宽高比适配器
    控制图像宽高比为固定值
    纵横模式:通过宽、高度控制高宽度、在父物体内、外部的宽高比
  5. Selectable 选择(聚焦)控件
    可实现接口ISelectHandler, IDeselectHandler, IUpdateSelectedHandlerI,IScrollHandler, ISubmitHandler, ICancelHandler, IMoveHandler 完成对选择控件的使用
    IScrollHandler 滚轮
    ISubmitHandler 提交
    ICancelHandler 取消
    IMoveHandler 移动
  6. LayoutRebuilder.ForceRebuildLayoutImmediate 重新计算布局
4. 事件系统
  1. 若要使用此系统,需先引用:using UnityEngine.EventSystems;,并继承接口。
    IPointerEnterHandler:指针进入
    IPointerExitHandler:指针离开
    IDragHandler:拖拽中
    IInitializePotentialDragHandler:开始拖拽(点击时)
    IBeginDragHandler:开始拖拽(拖动时)
  2. 若想非UI也可以使用这些系统,那么需要给摄像机挂载Physics RaycasterPhysics 2D Raycaster
  3. EventSystem.current.IsPointerOverGameObject() 当鼠标在UGUI上时,该数值为True,如果取消射线勾选,那么该UI不会被判定,
  4. EventSystem.current.SetSelectedGameObject() 设置选中的对象

方法

描述

需要继承类

OnPointerDown(PointerEventData)

鼠标落下事件

IPointerDownHandler

OnPointerUp(PointerEventData)

鼠标抬起事件

IPointerUpHandler

OnPointerEnter(PointerEventData)

鼠标进入事件

IPointerEnterHandler

OnPointerExit(PointerEventData)

鼠标离开事件

IPointerExitHandler

OnPointerClick(PointerEventData)

鼠标点击事件

IPointerClickHandler

注:如果父物体实现了Up、Down接口,而子物体没有实现。点击子物体时会调用父物体的Up、Down函数

  1. 代码添加事件
// 初始化列表
EventTrigger trigger = gameObject.AddComponent<EventTrigger>();
trigger.triggers = new List<EventTrigger.Entry>();
// 新建一个点击事件,并添加callback
EventTrigger.Entry entry = new EventTrigger.Entry();
entry.eventID = EventTriggerType.PointerClick;
entry.callback = new EventTrigger.TriggerEvent();
entry.callback.AddListener((data) => Debug.Log("点击了"));
// 添加到列表
trigger.triggers.Add(entry);
  1. 通过点击的位置获取世界坐标
public void OnPointerClick(PointerEventData eventData)
{
    var rect = GetComponent<RectTransform>();
    Vector3 v3;
    RectTransformUtility.ScreenPointToWorldPointInRectangle(rect, eventData.position, eventData.enterEventCamera, out v3);
    Debug.Log(v3);
}
5. 决定UI渲染层级的四种因素
  1. Camera层级
  2. 排序图层
  3. 图层顺序
  4. 自然层级

注意,如果为子对象添加Canvas组件,并添加GraphicRaycaster,即可覆盖原本排序图层逻辑,当想要对象无视自然层级排列时,可采用此方法解决。