Unity 不规则图形点击

分享一个项目中用的着的小功能(Unity不规则图形点击)

在使用UGUI组件时,`通常会遇到一下不规则图形点击。如图

在这里插入图片描述

现有的UGUI Button时间没办法处理重叠部分的点击事件。所以查了下资料,利用Polygon Collider2D检测实现重叠部分的点击效果。实现效果如下

请添加图片描述

实现方式如下

1.创建的Button按钮Image不勾选RaycastTarget
在这里插入图片描述
2. 在Button按钮下创建空物体Click,并添加脚本PolygonClick.cs。空物体的大小要大于不规则图形的大小。通过PolygonCollider2D 的Edit Collider编辑自己需要的不规则多边形点击区域。然后就完事了
在这里插入图片描述

核心脚本PolygonClick.cs代码如下,比较简单,也都写了注释。不规则点击的事件就完事了,比较简单的一个功能,给需要的童鞋一个参考。路过的且用的着的童鞋麻烦给个赞,多谢。
using UnityEngine;
using UnityEngine.UI;

[RequireComponent(typeof(PolygonCollider2D))]
public class PolygonClick : Image
{
    private new Collider2D collider;

    protected override void Start()
    {
        var c2d = GetComponent<Collider2D>();
        if (c2d != null)
            collider = c2d;
        base.Start();
    }

    public override bool IsRaycastLocationValid(Vector2 sp, Camera eventCamera)
    {
        if (!raycastTarget)
            return false;
        if (collider != null)
        {
            var worldPoint = Vector3.zero;
            //将屏幕空间点转换为世界空间中给定RectTransform平面上的位置
            //返回值:如果RectTransform的平面被击中,则返回true,而不管这个点是否在矩形内。
            var isInside = RectTransformUtility.ScreenPointToWorldPointInRectangle(
                rectTransform,
                sp,
                eventCamera,
                out worldPoint);
            if (isInside)
                isInside = collider.OverlapPoint(worldPoint);   //判断是否在多边形包围区域内
            return isInside;
        }
        else
        {
            return base.IsRaycastLocationValid(sp, eventCamera);
        }
    }
}

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值