UGUI中不規(guī)則形狀按鈕的碰撞檢測

在制作功能時,偶爾會遇到使用不規(guī)則的按鈕,碰撞檢測當(dāng)然也要做到與按鈕的形狀一致,但是我們的圖片都是矩形的,所以需要我們單獨設(shè)置與按鈕形狀一致的碰撞檢測區(qū)域。

使用的組件:Button,Polygon Collider 2D,UguiImagePlus(繼承Image)

UguiImagePlus.cs (Image擴展類)

using UnityEngine;
using UnityEngine.UI;

public class UguiImagePlus : Image
{
    //聲明多邊形碰撞器組件
    private PolygonCollider2D mCollider;

    protected override void Awake()
    {
        base.Awake();
        mCollider = GetComponent<PolygonCollider2D>();
    }

    public override bool IsRaycastLocationValid(Vector2 screenPoint, Camera eventCamera)
    {
        //判斷觸摸是否在圈出的多邊形區(qū)域內(nèi)
        var inside = mCollider.OverlapPoint(screenPoint);
        return inside;
    }
}

創(chuàng)建一個Button刪除Image組件,添加UguiImagePlus,拖動圖片設(shè)置。

image.png

添加Polygon Collider 2D組件,然后設(shè)置不規(guī)則的區(qū)域。

編輯說明

經(jīng)過以上設(shè)置,你已經(jīng)制作一個與圖片像素區(qū)域一致的碰撞檢測區(qū)域了。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容