Chinar blog :www.chinar.xin

游戏拖动物品/图标位置互换


本文提供全流程,中文翻译。

Chinar 的初衷是将一种简单的生活方式带给世人

使有限时间 具备无限可能

Chinar —— 心分享、心创新!

助力快速用 UGUI 完成图标互换,数据互换

为初学者节省宝贵的时间,避免采坑!

Chinar 教程效果:


文章目录

  • 1
    • Intro —— 简介
  • 2
    • Event Tigger —— 事件触发器组件
  • 3
    • Implementing interface —— 实现接口
  • 4
    • Project —— 项目文件
  • 支持
    • May Be —— 开发者,总有一天要做的事!

全文高清图片,点击即可放大观看 (很多人竟然不知道)


1

Intro —— 简介

我们游戏中非常常见的一个功能:拖动技能图标,互换技能位置和背包中拖动游戏物品到道具栏,互换位置等等…

Chinar 今天带大家通过 UGUI最简单的方式实现该需求

我提供了2个场景,2种实现方法,请自行选择

为了美观,我加上了Dotween的一个动画

删掉动画代码,整体实现代码不超过50行即可实现



2

Event Tigger —— 事件触发器组件

UI怎么搭建设计我就不说了,基本都是格子里放物品,实在不懂就看下图

(贴心的 Chinar 也准备了 Demo 供您参考)

直接看下图标记,我们让物品自己管理自己

设置tag —— 格子=Grid;物品=Good;

用tag便于我们管理与扩展,可自行定义多种标签,执行不同操作

挂上代码,手动添加监听函数,运行即可看到效果


代码

using System;
using DG.Tweening;
using UnityEngine;
using UnityEngine.EventSystems;
using UnityEngine.UI;public class ChinarDragImage : MonoBehaviour
{private Transform beginParentTransform; //记录开始拖动时的父级对象        /// <summary>/// UI界面的顶层,这里我用的是 Canvas/// (这个变量在开发中设置到单例中较好,不然每一个物品都会初始化查找/// GameObject.Find("Canvas").transform;)/// </summary>private Transform topOfUiT;void Start(){topOfUiT = GameObject.Find("Canvas").transform;}/// <summary>/// 开始拖动时/// </summary>public void Begin(BaseEventData data){if (transform.parent == topOfUiT) return;beginParentTransform = transform.parent;transform.SetParent(topOfUiT);}/// <summary>/// 拖动中/// </summary>/// <param name="_">UI事件数据</param>public void OnDrag(BaseEventData _){transform.position = Input.mousePosition;if (transform.GetComponent<Image>().raycastTarget) transform.GetComponent<Image>().raycastTarget = false;}/// <summary>/// 结束时/// </summary>public void End(BaseEventData data){PointerEventData _ = data as PointerEventData;if (_ == null) return;GameObject go = _.pointerCurrentRaycast.gameObject;if (go.tag == "Grid") //如果当前拖动物体下是:格子 -(没有物品)时{SetPosAndParent(transform, go.transform);transform.GetComponent<Image>().raycastTarget = true;}else if (go.tag == "Good") //如果是物品{SetPosAndParent(transform, go.transform.parent);                              //将当前拖动物品设置到目标位置go.transform.SetParent(topOfUiT);                                             //目标物品设置到 UI 顶层if (Math.Abs(go.transform.position.x - beginParentTransform.position.x) <= 0) //以下 执行置换动画,完成位置互换 (关于数据的交换,根据自己的工程情况,在下边实现){go.transform.DOMoveY(beginParentTransform.position.y, 0.3f).OnComplete(() =>{go.transform.SetParent(beginParentTransform);transform.GetComponent<Image>().raycastTarget = true;}).SetEase(Ease.InOutQuint);}else{go.transform.DOMoveX(beginParentTransform.position.x, 0.2f).OnComplete(() =>{go.transform.DOMoveY(beginParentTransform.position.y, 0.3f).OnComplete(() =>{go.transform.SetParent(beginParentTransform);transform.GetComponent<Image>().raycastTarget = true;}).SetEase(Ease.InOutQuint);});}}else //其他任何情况,物体回归原始位置{SetPosAndParent(transform, beginParentTransform);transform.GetComponent<Image>().raycastTarget = true;}}/// <summary>/// 设置父物体,UI位置归正/// </summary>/// <param name="t">对象Transform</param>/// <param name="parent">要设置到的父级</param>private void SetPosAndParent(Transform t, Transform parent){t.SetParent(parent);t.position = parent.position;}
}

3

Implementing interface —— 实现接口

第二种做法,我预留了很高的扩展性,直接继承自 Button,为扩展留足了接口

拖动效果,我们通过三个 接口来实现
IBeginDragHandler
IDragHandler
IEndDragHandler

其实是上边2中的事件,只是通过继承接口的方式代码来实现

设置tag —— 格子=Grid;物品=Good;

代码几乎与2是一样的。只是无需绑定,挂到物品上即可使用

// ========================================================
// 描述:Demo 02 —— 通过继承 + 接口实现 图片拖动替换位置。
// 作者:Chinar
// 创建时间:2019-04-29 16:39:11
// 版 本:1.0
// ========================================================
using DG.Tweening;
using System;
using UnityEngine;
using UnityEngine.EventSystems;
using UnityEngine.UI;namespace QmDreamer.UI
{/// <summary>/// 管理UI元素排序:使UI可通过拖动进行位置互换/// </summary>public class ChinarDragSwapImage : Button, IDragHandler, IBeginDragHandler, IEndDragHandler{private Transform beginParentTransform; //记录开始拖动时的父级对象        /// <summary>/// UI界面的顶层,这里我用的是 Canvas/// (这个变量在开发中设置到单例中较好,不然每一个物品都会初始化查找/// GameObject.Find("Canvas").transform;)/// </summary>private Transform topOfUiT;protected override void Start(){base.Start();topOfUiT = GameObject.Find("Canvas").transform;}public void OnBeginDrag(PointerEventData _){if (transform.parent == topOfUiT) return;beginParentTransform = transform.parent;transform.SetParent(topOfUiT);}public void OnDrag(PointerEventData _){transform.position = Input.mousePosition;if (transform.GetComponent<Image>().raycastTarget) transform.GetComponent<Image>().raycastTarget = false;}public void OnEndDrag(PointerEventData _){GameObject go = _.pointerCurrentRaycast.gameObject;if (go.tag == "Grid") //如果当前拖动物体下是:格子 -(没有物品)时{SetPosAndParent(transform, go.transform);transform.GetComponent<Image>().raycastTarget = true;}else if (go.tag == "Good") //如果是物品{SetPosAndParent(transform, go.transform.parent);                              //将当前拖动物品设置到目标位置go.transform.SetParent(topOfUiT);                                             //目标物品设置到 UI 顶层if (Math.Abs(go.transform.position.x - beginParentTransform.position.x) <= 0) //以下 执行置换动画,完成位置互换 (关于数据的交换,根据自己的工程情况,在下边实现){go.transform.DOMoveY(beginParentTransform.position.y, 0.3f).OnComplete(() =>{go.transform.SetParent(beginParentTransform);transform.GetComponent<Image>().raycastTarget = true;}).SetEase(Ease.InOutQuint);}else{go.transform.DOMoveX(beginParentTransform.position.x, 0.2f).OnComplete(() =>{go.transform.DOMoveY(beginParentTransform.position.y, 0.3f).OnComplete(() =>{go.transform.SetParent(beginParentTransform);transform.GetComponent<Image>().raycastTarget = true;}).SetEase(Ease.InOutQuint);});}}else //其他任何情况,物体回归原始位置{SetPosAndParent(transform, beginParentTransform);transform.GetComponent<Image>().raycastTarget = true;}}/// <summary>/// 设置父物体,UI位置归正/// </summary>/// <param name="t">对象Transform</param>/// <param name="parent">要设置到的父级</param>private void SetPosAndParent(Transform t, Transform parent){t.SetParent(parent);t.position = parent.position;}}
}

4

Project —— 项目文件

Unity 版本:2018.3.12

项目文件为 unitypackage 文件包:

下载导入 Unity 即可使用

提取码:9449



支持

May Be —— 开发者,总有一天要做的事!

拥有自己的服务器,无需再找攻略

Chinar 提供一站式《零》基础教程

使有限时间 具备无限可能!


先点击领取 —— 阿里全产品优惠券 (享受最低优惠)

Chinar 免费服务器、建站教程全攻略!( Chinar Blog )



END

本博客为非营利性个人原创,除部分有明确署名的作品外,所刊登的所有作品的著作权均为本人所拥有,本人保留所有法定权利。违者必究

对于需要复制、转载、链接和传播博客文章或内容的,请及时和本博主进行联系,留言,Email: ichinar@icloud.com

对于经本博主明确授权和许可使用文章及内容的,使用时请注明文章或内容出处并注明网址

Unity拖动背包物品/技能图标位置互换相关推荐

  1. Unity背包系统-2:数据库存储方法ScriptableObject和显示背包物品InventoryManager

    1. 数据库脚本 1.1 元素(item)代码: using System.Collections; using System.Collections.Generic; using UnityEngi ...

  2. Q Inventory System unity背包物品插件 使用笔记

    Q Inventory System 一个非常不错的背包物品插件 功能很完整,用起来简单.但是作者好像很久没更新了 网上相关教程也比较少,用户手册上的内容版本对不太上了.我在此记录一下学习摸索的过程, ...

  3. Unity中简单冲刺技能,加技能图标倒计时UI制作

    首先,在Canvas下创建一个image1,改名 然后把image1的source image换成技能图片,或者随便一张图片都行 接着,在image1下创建子类image2 接着,按照下面图片调整 s ...

  4. Unity3D UGUI实现冷却时间的技能图标

    哟哟哟,UGUI实现这个功能特别的简单.利用了Image组件的功能,接下来就为大家一步步实现这个小技能. 先为大家介绍一下Image组件的ImageType属性. (1)Simple:         ...

  5. [Unity3D] 技能图标的冷却效果和时间显示

    基本原理:利用 ImageType 中的Filled方法,通过代码控制FillAmount来实现图标的冷却效果. 主要步骤: 1 在Canvas中创建一个Image,起个名字比如"Offen ...

  6. 【Unity实现背包拖拽功能 】

    Unity实现背包拖拽功能 可以实现背包拖拽交换位置.合成 等一系列功能的实现 using System; using System.Collections; using System.Collect ...

  7. 计算机word文本段落位置互换,用word怎么使两个段落互换位置

    公告: 为响应国家净网行动,部分内容已经删除,感谢读者理解. 话题:用word怎么使两个段落互换位置回答:方法一:1.选中要变换位置的段落:2.单击开始----剪切按钮:img src="https: ...

  8. NGUI 中,长技能图标显示技能Tips的核心代码

    需要将技能图标对应的位置Pos赋给Tips即可.下面是计算 Pos 的核心代码: using UnityEngine;public class LgsTest : MonoBehaviour {[Se ...

  9. Unity如何设计一个技能系统

    一.技能系统的设计思路 技能系统是游戏中非常重要的一部分,因此在设计技能系统时需要考虑以下几个方面: 对啦!这里有个游戏开发交流小组里面聚集了一帮热爱学习游戏的零基础小白,也有一些正在从事游戏开发的技 ...

最新文章

  1. 记录某项目中的踩坑与解决(持续更新)
  2. Linux中netfilter模块编程实践
  3. java dto是什么_java项目中VO和DTO以及Entity,各自是在什么情况下应用的
  4. spring中注解无法修饰静态变量
  5. Lotus 下部门间用户的移动操作
  6. 学习API HOOK,编写了一个winsock 的封包抓取程序,可免费使用;
  7. 国家邮政局公布一项数据 春节期间快递数量依旧很猛!
  8. SingToken全球首款区块链智能AI音乐钱包
  9. Linux命令iconv
  10. word目录及图表目录的自动生成
  11. logit回归怎么看显著性_spss logistic回归分析结果如何分析
  12. 博客线下推广的小技巧
  13. 那些你该知道的CSS颜色代码大全都在这里了,点击查阅
  14. 减一技术实现求a的n次幂
  15. 大数据中心系统集成资质
  16. 国产紫光FPGA实现DDS信号发生器
  17. eks安装kubectl
  18. 标准C语言day02
  19. 计算机老师教育叙事,信息技术教育叙事
  20. 嘉立创元器件导入AD20

热门文章

  1. E都市圈地 三维地图搜索的商业模式在哪里
  2. 这些是源自几米的句子,让人满心感触……
  3. 中国4K和8K超高清电视市场现状研究分析与发展前景预测报告
  4. flash media server和kv3000之间的矛盾。
  5. (升级版)构建狂拽炫酷屌的MySQL监控平台
  6. 网优谷表示这是程序员最讨厌的11句话,戳你心了吗?
  7. 磨砂串口服务器型号,moxa串口服务器3180配置
  8. SEM 同台展现实例
  9. 工程计算——不动点迭代法
  10. 错误720:被远程计算机终止 | 宽带拨号上网报错720 | windows