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

Unity 使用Horizontal Layout Group和Toggle制作多个水平开关按钮实现自动排列和单个点击放大后的自动排列。

Unity的布局组件Horizontal Layout Group是很好用的,当然也包括其它布局组件也一样好用。

比如要实现多按钮开关自动水平排列,那么就可以使用它了。

首先我们为按钮创建个父物体(我这里使用了Scroll View中的Content作为父物体),并添加Horizontal Layout Group组件,如下图:

然后在下面创建了多个按钮组件,每个组件都使用Toggle,方便可以实现点击交互。设置Horizontal Layout Group的参数如上,那么就可以实现自主排列了。(其中Horizontal Layout Group的配置可以参考:Unity UGUI控件之Horizontal Layout Group-CSDN博客)

效果如下:

但是这样远远不够的,比如我们用代码控制点击当前按钮时会放大1.2倍,效果就变成下面这样了:

这明显不是我们想要的效果,按钮与按钮之间都交接在一起了。

大家会不会有个疑问,我们都使用了Horizontal Layout Group并勾选了Use Child Scale,按理应该会按子对象的大小自动排列好呀。但实际上这里并没有如我们所想。

解决办法就是重新再设置下Use Child Scale选项,那么问题就可迎刃而解了。具体使用如下代码:

transform.parent.GetComponent<HorizontalLayoutGroup>().childScaleWidth = false;
transform.parent.GetComponent<HorizontalLayoutGroup>().childScaleWidth = true;

这里要先设置childScaleWidth 为false,再设置为True,就相当于重新刷新下组件的设置,最终效果如下:

这应该就是我们想要的效果了。

Unity 使用Horizontal Layout Group和Toggle制作多个水平开关按钮实现自动排列和单个点击放大后的自动排列。_哔哩哔哩_bilibili

http://www.lryc.cn/news/253002.html

相关文章:

  • Python实现FA萤火虫优化算法优化BP神经网络回归模型(BP神经网络回归算法)项目实战
  • 灯塔ARL-NPoC全面教程
  • λ表达式、智能指针
  • PHP基础知识和操作
  • 系列十三、SpringBoot的自动配置原理分析
  • soapui报错: CXF directory must be set in global preferences
  • Netty02-基础概念
  • 计算机毕业设计 基于SpringBoot的敬老院管理系统的设计与实现 Java实战项目 附源码+文档+视频讲解
  • 精调llama模型
  • 【C语言】深入理解C语言中的数学运算和类型转换
  • 基于javaweb的宠物服务商城系统设计与开发
  • LeetCode-470. 用 Rand7() 实现 Rand10()【数学 拒绝采样 概率与统计 随机化】
  • 通达信指标公式19:龙虎榜股票池——主力控盘度的计算方法
  • 手搓图片滑动验证码_JavaScript进阶
  • Linux服务器超级实用的脚本
  • IntelliJ IDEA安装使用教程#intellij idea
  • 【组合数学】容斥鸽巢原理
  • 视频后期特效处理软件 Motion 5 mac中文版
  • 【智能家居】一、工厂模式实现继电器灯控制
  • 第三节:提供者、消费者、Eureka
  • Leetcode刷题详解——等差数列划分
  • 导出主机上所有docker 镜像并导入到其它主机
  • HTML5+CSS3+JS小实例:焦点图波浪切换动画特效
  • Mac电脑如何安装git
  • macOS本地调试k8s源码
  • JS 实现一键复制文本内容
  • 【Linux】echo命令使用
  • Day03 嵌入式---中断
  • wpf devexpress 使用IDataErrorInfo实现input验证
  • shell_81.Linux在命令行中创建使用函数