UGUI拖拽和放下物品

1.让脚本同时继承MonoBehaviour, IBeginDragHandler, IDragHandler, IEndDragHandler这几个类

2.OnBeginDragHandler()是开始拖动时调用。为了使要拖动的ui不被遮挡,先把它的层级改一下,父物体改为Canvas。并且把raycastTarget设为false,为了放下时能检测到该放下的位置。

public void OnBeginDrag(PointerEventData eventData)
    {
        transform.SetParent(UIRoot);//暂时改变渲染层级
        GetComponent<Image>().raycastTarget = false;
    }

3.OnDrag()里面让该物体跟着鼠标位置移动

public void OnDrag(PointerEventData eventData)
    { 
        transform.position = eventData.position;
    }

4.OnEndDrag()里将该ui的父物体设为鼠标松开时的物体,并设置localposition,同时恢复raycastTarget以便下次拖拽。

public void OnEndDrag(PointerEventData eventData)
    {
    	//获取松开停止拖拽时位于鼠标位置的物体
        GameObject go = eventData.pointerCurrentRaycast.gameObject;
        //print(go.tag);
        //这里根据tag来判断拖动是否有效
        if (go!=null&&go.tag == Tags.inventoryItemGrid)
        {
            transform.SetParent(go.transform);
            transform.localPosition = Vector3.zero;
        }
        else
        {
            transform.SetParent(preParent);
            transform.localPosition = Vector3.zero;
        }
        GetComponent<Image>().raycastTarget = true;
    }

完整代码:

using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.UI;
using UnityEngine.EventSystems;

public class InventoryItem : MonoBehaviour, IBeginDragHandler, IDragHandler, IEndDragHandler{
    public Transform UIRoot;//Canvas
    public Transform preParent;//原来的父物体

    private void Awake()
    {
        UIRoot = GameObject.Find("UI Root").transform;
    }
    public void OnBeginDrag(PointerEventData eventData)
    {
    	preParent = transform.parent;//保存原来的父物体
        transform.SetParent(UIRoot);//暂时改变渲染层级
        GetComponent<Image>().raycastTarget = false;
    }

    public void OnDrag(PointerEventData eventData)
    { 
        transform.position = eventData.position;
    }

    public void OnEndDrag(PointerEventData eventData)
    {
        GameObject go = eventData.pointerCurrentRaycast.gameObject;
        //print(go.tag);
        if (go!=null&&go.tag == Tags.inventoryItemGrid)
        {
            transform.SetParent(go.transform);
            transform.localPosition = Vector3.zero;
        }
        else
        {
            transform.SetParent(preParent);
            transform.localPosition = Vector3.zero;
        }
        GetComponent<Image>().raycastTarget = true;
    }
}

效果:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值