【解决】Layout 下创建槽位后,执行 Image 同步槽位位置后表现错误的问题。

开发平台:Unity 6.0

编程语言:CSharp

编程平台:Visual Studio 2022

一、问题背景 | 开发库存系统


|----------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|
| 图1 位置同步失败问题 | 图2 位置正常同步效果表现 |

黑框 作用于 UnityEngine.UI.GridLayoutGruop ,形成 4x6 布局,如图1所示。
图标 同步至 黑框位置。

csharp 复制代码
public class Example : MonoBehaivour
{
	//...
	void Start() {
		
		this.m_InventoryUI = FindFirstObjectByType<InventoryUI>();
		this.m_InventoryUI.InitEnvironment();
		this.m_InventoryUI.InitInventory(4, 6);
		
		// 添加图标
		this.m_InventoryUI.Add(ItemType.Capsule);
		this.m_InventoryUI.Add(ItemType.Cube);
		this.m_InventoryUI.Add(ItemType.Sphere);
	}
}

二、问题原因


在执行添加物品时,UnityEngine.UI.GridLayoutGruop 并未完成对 黑框 布局的调整任务。

三、解决方法


3.1 延迟帧/秒 执行添加任务

csharp 复制代码
Utils.TimeCoroutine.Delay(1, ()=> { // 添加操作 })

即 使用 StartCoroutine 推迟添加的操作。

3.2 在执行添加任务前,强制刷新


csharp 复制代码
Canvas.ForceUpdateCanvases();

这是强制 Canvas 所有UI更新信息。在仅针对少量 UI 上是有效,但 UI 量一旦增大。则应该考虑下类执行代码:

csharp 复制代码
LayoutRebuilder.ForceRebuildLayoutImmediate(RectTranform rt);

其中 rt 为布局组件对象上的 RectTransform 组件。即 手动强制更新。

其他

尝试过直接使用 layout.SetHorizontalLayout() 等来自继承类的方法来更新布局,但实际上,问题表现仍然存在。

相关推荐
平行云5 小时前
实时云渲染预启动技术解析:UE数字孪生应用的延迟优化机制(二)
linux·unity·ue5·webgl·实时云渲染·云桌面·像素流
心前阳光12 小时前
Unity之PhotonServer使用注意
unity·游戏引擎
Mark White15 小时前
行为树(Behavior Tree):从 ROS 机器人到 Unity 游戏 AI 的统一决策范式
游戏·unity·机器人
小贺儿开发16 小时前
Unity UGUI 可视化热区编辑与交互系统
unity·编辑器·游戏引擎·交互·工具·适配·ugui
郝学胜-神的一滴18 小时前
中级OpenGL教程 007:解决背面光照异常高光问题
c++·unity·游戏引擎·three.js·opengl·unreal
RReality18 小时前
【Unity Shader URP】水面效果 实战教程
unity·游戏引擎·图形渲染
游乐码19 小时前
c#基础(七)延迟函数
开发语言·unity·c#·游戏引擎
LONGZETECH19 小时前
Unity 3D+C/S架构无人机数字孪生实训室:破解实训“三高”难题的底层技术实现
c语言·开发语言·3d·unity·架构·无人机
万岳科技系统开发1 天前
外卖系统小程序开发趋势:即时零售与同城配送的融合升级
unity·游戏引擎·零售
十贺1 天前
【Unity开发字典】分包、黏包基本概念和处理逻辑实现
unity·游戏引擎