unity不规则碰撞体

PolygonCollider2D

这里写图片描述
我们的地图是这样的不规则形状,最开始简单用Box Collider处理点击,但是点击地图边缘时命中率很差。今天查到Unity有多边形Collider可以支持不规则形状,PolygonCollider2D

给地图【变异的开端】加上PolygonCollider2D,然后根据地图形状编辑Collider多边形,编辑好之后下图这样子。
这里写图片描述

点击实现

需要注意的是NGUI中检测射线碰撞用的是Physics.RayCast,不支持2D Collider,也就是无法响应touch/click等事件。需要自己用Physics2D.Raycast来检测碰撞。可以参考NGUI的UICamera::Raycast写。

void Update() {
    bool btnDown = Input.GetMouseButtonDown(0);
    bool btnUp = Input.GetMouseButtonUp(0);
    if (btnDown || btnUp) {
        UICamera uicam = UISystem.Instance.uiCamera;
        Camera cam = uicam.camera;
        int mask = cam.cullingMask & (int)uicam.eventReceiverMask;
        float dist = uicam.rangeDistance;
        if (dist < 0.000001f)
            dist = cam.farClipPlane-cam.nearClipPlane;

        Ray ray = cam.ScreenPointToRay(Input.mousePosition);
        RaycastHit2D hit = Physics2D.Raycast(ray.origin, ray.direction, dist, mask);
        if (hit.collider != null) {
            GameObject obj = hit.collider.gameObject;
            UISprite spr = obj.transform.GetComponentInChildren<UISprite>();
            if (btnDown) {
                spr.color = Color.gray;
                DebugLog.Log("click " + obj.name);
            }
            else {
                spr.color = Color.white;
                DebugLog.Log("release " + obj.name);
            }
        }
    }
}
   
   
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27

另一种方法

除了使用引擎支持的多边形Collider,还可以根据颜色来处理点击。先根据地图,预生成一个颜色块图,游戏中根据点击点的像素颜色来判断。比如,地图是下面这样的:
这里写图片描述

生成的颜色块图
这里写图片描述

张伟

(function () {('pre.prettyprint code').each(function () { var lines = (this).text().split(\n).length;var numbering = $('
    ').addClass('pre-numbering').hide(); (this).addClass(hasnumbering).parent().append( numbering); for (i = 1; i
    • 3
      点赞
    • 9
      收藏
      觉得还不错? 一键收藏
    • 0
      评论
    评论
    添加红包

    请填写红包祝福语或标题

    红包个数最小为10个

    红包金额最低5元

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

    抵扣说明:

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

    余额充值