当前位置: 首页 > article >正文

Unity 组件学习记录:Aspect Ratio Fitter

  1. 概述
    • Aspect Ratio Fitter是 Unity 中的一个组件,用于控制 UI 元素(如ImageRawImage等)的宽高比。它在处理不同屏幕分辨率和尺寸时非常有用,可以确保 UI 元素按照预期的比例进行显示。
    • 当添加到一个 UI 对象上时,Aspect Ratio Fitter会根据设置的参数来调整 UI 元素的大小,以匹配指定的宽高比。
  2. 属性介绍
    • Aspect Mode(宽高比模式)
      • None(无):这是默认模式。在这种模式下,Aspect Ratio Fitter组件不会对 UI 元素的宽高比进行任何调整。UI 元素会按照常规的布局规则来确定大小,例如根据锚点和拉伸设置。
      • Width Controls Height(宽度控制高度):当选择此模式时,组件会根据指定的宽高比,通过调整 UI 元素的高度来匹配宽度。例如,如果设置宽高比为2:1,当宽度发生变化时,高度会自动调整,使得宽高比始终保持为2:1
      • Height Controls Width(高度控制宽度):与 “Width Controls Height” 模式相反。在这种模式下,会根据宽高比通过调整宽度来匹配高度。
      • Fit In Parent(适配父元素):UI 元素会被缩放,以完全适配父元素,同时保持指定的宽高比。这意味着 UI 元素可能不会填满整个父元素,但会保持正确的比例。如果宽高比与父元素的宽高比不匹配,UI 元素会在父元素内部居中显示,并且在某个方向上会有空白区域。
      • Envelope Parent(包裹父元素):UI 元素会缩放,以覆盖整个父元素,同时保持指定的宽高比。与 “Fit In Parent” 模式不同的是,在这种模式下,UI 元素可能会超出父元素的范围,导致部分内容被裁剪,但能确保完全覆盖父元素并保持宽高比。
    • Aspect Ratio(宽高比):这个属性用于设置期望的宽高比。可以输入一个浮点数,表示宽度与高度的比值。例如,输入1.7777大致表示16:9的宽高比()。
  3. 使用场景示例
    • 保持 UI 元素的固定比例:假设你有一个游戏中的背景图片,你希望它在不同的屏幕分辨率下都能保持16:9的宽高比。你可以将Aspect Ratio Fitter组件添加到这个背景图片的GameObject上,设置Aspect ModeFit In ParentAspect Ratio1.7777(约为16:9)。这样,无论屏幕是宽屏还是窄屏,背景图片都会在保持16:9比例的情况下,尽可能大地显示在屏幕上,并且会在父元素(通常是屏幕的 UI 根元素)内部居中。
    • 自适应屏幕变化:在一个可以在手机和平板电脑上运行的游戏中,对于某些 UI 元素(如角色头像),你可能希望它的高度固定,而宽度根据屏幕比例自适应。你可以添加Aspect Ratio Fitter组件,设置Aspect ModeWidth Controls Height,并设置合适的Aspect Ratio。当游戏在不同设备上运行,屏幕宽度发生变化时,头像的高度保持不变,宽度会根据设置的宽高比自动调整。
  4. 与其他 UI 组件的配合
    • Aspect Ratio Fitter组件与Rect Transform组件密切配合。Rect Transform用于定义 UI 元素的位置、大小和锚点等基本布局属性,而Aspect Ratio Fitter则在这些基础上进一步调整 UI 元素的宽高比。例如,当Aspect Ratio Fitter调整了 UI 元素的大小后,Rect Transform的尺寸属性也会相应地改变,并且 UI 元素在布局系统中的实际位置和大小是这两个组件共同作用的结果。
    • Content Size Fitter组件也可以一起使用。Content Size Fitter主要用于根据内容自动调整 UI 元素的大小,而Aspect Ratio Fitter专注于宽高比的控制。在某些复杂的 UI 布局中,这两个组件可以协同工作,以实现更灵活的布局效果。例如,在一个带有文本和图像的 UI 元素中,Content Size Fitter可以根据文本内容调整元素的高度,而Aspect Ratio Fitter可以根据图像的宽高比来调整元素的宽度,从而使整个 UI 元素的布局更加合理。

http://www.kler.cn/a/443372.html

相关文章:

  • kotlin sortedBy 与sortedWith的区别
  • 如何在 Ubuntu 22.04 上安装 Cassandra NoSQL 数据库教程
  • 操作手册:集成钉钉审批实例消息监听配置
  • STM32Flash读写BUG,坑—————4字对齐
  • maven之插件调试
  • 大数据-268 实时数仓 - ODS层 将 Kafka 中的维度表写入 DIM
  • .NET 9微软新平台 + FastReport .NET:如何提升报告生成效率
  • 鸿蒙Next合理使用状态管理总结
  • 谈一谈大数据流式处理,以Spark Streaming为例详细论述
  • arcgis for js实现地图截图、地图打印
  • react身份证回显
  • 前端:如何在静态目录下显示一张图片
  • OpenCV(python)从入门到精通——运算操作
  • C++ 只出现一次的数字 - 力扣(LeetCode)
  • Golang的向前兼容性和toolchain规则,Go1.21.0
  • SpringBoot3整合FastJSON2如何配置configureMessageConverters
  • RabbitMQ的工作模型
  • DataOps驱动数据集成创新:Apache DolphinScheduler SeaTunnel on Amazon Web Services
  • Spring Boot 中异常日志记录的最佳实践:实时示例
  • .NET Runtime 是什么?
  • DNS协议 是什么?说说DNS 完整的查询过程?
  • 矩阵在资产收益(Asset Returns)中的应用:以资产回报矩阵为例(中英双语)
  • 使用 Django 和 AWS 实现自动同步 ECR 信息
  • 《算法ZUC》题目
  • C++算法第十一天
  • Scala快速入门+示例