NGUI 在Panel使用soft clip时,滚动显示异常问题

本文介绍在NGUI中遇到的滚动列表裁剪问题及其解决方案。问题表现为使用UIDraggablePanel时,滚动列表在拖动后Item无法正确显示。原因是UIPanel的localScale值不统一。解决方法是统一所有相关UIPanel的缩放值。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在NGUI中,常常需要制作滚动列表的界面,这时候通常需要用到UIPanel的Soft Clip,对Item列表进行裁剪,类似于遮罩只显示指定区域的Item。

问题简介:

我之前在使用过程中遇到了一个问题,在挂载UIDraggable Panel的UIPanel下提示:Clipped panels must have a uniform scale, or clipping won't work properly,如下图所示:
这里写图片描述

导致的结果:

出现了滚动列表初次加载时,能够正常显示列表内容,如下图:
这里写图片描述
但只要拖动滚动列表,发现列表的Item就看不到了,如下图:
这里写图片描述
但是切换到Scene场景下或者直接看Hierachy面板,发现Item有正常创建和刷新,只是无法在UIDraggable Panel中显示出来:
这里写图片描述
这就是提示后半句所说的:clipping won't work properly滚动时动态裁剪会出现了错误。

导致错误原因剖析:

正如错误所提示的,被裁剪的UIPanel子节点以及其父节点中包含UIPanel的都必须保持localScale的数值是一致的,而我出现这个问题正是数值不一致导致的,如下:
这里写图片描述

解决方案: 最为直接方便的方法就是将改预制的所有UIPanel的缩放数值改为一致。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值