UGUI 不规则UI点击

本文探讨如何在Unity中使用PolygonCollider2D实现精确的碰撞检测,同时介绍了通过alphaHitTestMinimumThreshold处理Image的透明度问题,以及MeshType选择对性能的影响。特别提到了透明度处理可能导致的内存开销和点击区域偏移的bug解决方案。

使用碰撞器

继承Image,重新实现IsRaycastLocationValid

需要使用碰撞器来实现,需要手动去调整碰撞器的范围

using UnityEngine;
using UnityEngine.UI;

[RequireComponent(typeof(PolygonCollider2D))]
public class ImagePolygon : Image
{

    PolygonCollider2D poly2d;

    void Awake()
    {
        poly2d = GetComponent<PolygonCollider2D>();
    }

    /// <summary>
    /// 判断点击是否有效
    /// </summary>
    /// <param name="sp"></param>
    /// <param name="eventCamera"></param>
    /// <returns></returns>

    override public bool IsRaycastLocationValid(Vector2 sp, Camera eventCamera)
    {
        return poly2d.OverlapPoint(Input.mousePosition);
    }
}

判断透明度

优点:不用给图片添加碰撞器

缺点:需要设置图片开启Readable/Write Enable,这样会使运行时贴图大小翻倍,内存中会额外存储一份贴图数据,增大内存开销。

缺点:图片不能被打入图集

 Image类的alphaHitTestMinimumThreshold是一个浮点值,Raycast检测时只有图片中高于该值的部分会抛出点击事件

这个方式有明显的bug,点击区域会偏下透明地方会响应,上面不透明的地方反而没反应

需要设置MeshType-FullRect

用Tight模式的话,如果你的图片周围有空白像素,它会帮你压缩掉减小面积,以减少DrawCall,但是会增加Sprite的面数。如果用Full Rect模式不会压缩,也不会增加面数,直接创建一个quab,然后把图片扔上去 

using UnityEngine;
using UnityEngine.UI;

public class AlphaButton : MonoBehaviour
{
    public float alphaThreshold = 0.1f;

    void Start() {
        GetComponent<Image>().alphaHitTestMinimumThreshold = alphaThreshold;
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

贪小心

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值