Unity 判断两个UI是否相交

文章介绍了在Unity中使用Collider2D组件和RectTransform组件以及边界框来判断两个UI元素是否相交的两种方法,并提供了相应的代码示例。
摘要由CSDN通过智能技术生成

今天碰到要判断两个UI是否相交的交互。

尝试了下,发现有两个方法都成功了。

1、使用Collider2D组件

分别创建两个Image组件,并且添加Collider2D组件,其中一个还要添加Rigidbody2D组件,如下图:

然后创建个判断脚本“UIintersect.cs",具体脚本代码如下,把脚本拉到场景中,当物体碰到一起是就能检测到它们是否相交了。

    public Image image1;
    public Image image2;

    private Collider2D collider1;
    private Collider2D collider2;

    // Start is called before the first frame update
    void Start()
    {
        // 获取image1和image2的Collider组件
        collider1 = image1.GetComponent<Collider2D>();
        collider2 = image2.GetComponent<Collider2D>();
    }

    // Update is called once per frame
    void Update()
    {
        // 检测两个Collider是否相交
        if (collider1.IsTouching(collider2))
        {
            Debug.Log("UI相交了!");
        }
        else
        {
            Debug.Log("UI没有相交!");
        }
    }

2、使用RectTransform组件和边界框。

本方法只需要脚本获取UI的RectTransform,然后判断它们的边界是否相交即可。

代码如下:

 public RectTransform uiElement1;
    public RectTransform uiElement2;

    // Start is called before the first frame update
    void Start()
    {
        
    }

    // Update is called once per frame
    void Update()
    {
        if (CheckCollision(uiElement1, uiElement2))
        {
            Debug.Log("UI相交了!");
        }
        else
        {
            Debug.Log("UI没有相交!");
        }

    }

    private bool CheckCollision(RectTransform rectTransform1, RectTransform rectTransform2)
    {
        Rect rect1 = rectTransform1.rect;
        Rect rect2 = rectTransform2.rect;

        Rect worldRect1 = GetWorldRect(rectTransform1);
        Rect worldRect2 = GetWorldRect(rectTransform2);

        return worldRect1.Overlaps(worldRect2);
    }

    private Rect GetWorldRect(RectTransform rectTransform)
    {
        Vector3[] corners = new Vector3[4];
        rectTransform.GetWorldCorners(corners);

        Vector3 bottomLeft = corners[0];
        Vector3 topRight = corners[2];

        return new Rect(bottomLeft.x, bottomLeft.y, topRight.x - bottomLeft.x, topRight.y - bottomLeft.y);
    }

把代码拉到场景中,也能判断UI是否相交。

总的感觉两种方法都不错。

效果:Unity判断两个UI是否相交_哔哩哔哩_bilibili

  • 13
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

不在同一频道上的呆子

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

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

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

打赏作者

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

抵扣说明:

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

余额充值