上一次用UGUI实现了拼图小游戏,这次,我们来用NGUI来实现

实现原理

NGUI中提供了拖拽的基类UIDragDropItem,所以我们要做的就是在要拖拽的图片上加一个继承于该类的脚本,并实现其中的方法即可

 public class DragOnPic : UIDragDropItem {

     protected override void OnDragDropStart ()
{
base.OnDragDropStart ();
} protected override void OnDragDropRelease (GameObject surface)
{
base.OnDragDropRelease (surface);
}
}

拼图游戏实例

1、准备拼图素材,由于NGUI使用的Atlas为Texture,所以不能用UGUI中裁剪图片的方法,所以偷了一下懒,从网上找了一个小工具把图片裁剪了一下。。

2、给图片命名,为了最后检测简单一点,所以我这里统一命名为f-0~f-15,并制作Atlas

下面的基本操作步骤跟UGUI大同小异,所以我们这里搞一个不一样的方式,Unity中不做任何操作,只在摄像机上挂一个脚本ImageCreater来调用我们的代码

     void Start () {
//调用UIManager中生产图片的方法.
UIManager.Instance.CreatPics();
}

新建一个UIManager类,下面是该类的内容:

 1 public class UIManager  {
2
3 //单例.
4 private static UIManager instance;
5 public static UIManager Instance{
6 get{
7 if(instance == null)
8 {
9 instance = new UIManager();
10 }
11 return instance;
12 }
13 }
14 private UIManager(){}
15
16 //根节点.
17 UIPanel panel;
18
19 public void CreatPics()
20 {
21 panel = NGUITools.CreateUI(false);
22
23 //添加Grid组件用于自动排列图片.
24 UIGrid grid = NGUITools.AddChild<UIGrid>(panel.gameObject);
25
26 //设置grid各个属性.
27 grid.arrangement = UIGrid.Arrangement.Horizontal;
28 grid.maxPerLine = 4;
29 grid.cellWidth = 100;
30 grid.cellHeight = 100;
31 grid.pivot = UIWidget.Pivot.TopLeft;
32 grid.transform.localPosition = new Vector3(-150, 150, 0);
33
34 //从Resources文件夹中动态加载Atlas
35 UIAtlas myAtlas = Resources.Load<UIAtlas>("Atlas/MyAtlas");
36
37 //通过GameManager得到一个随机数数组.
38 int[] randomIndex = GamaManager.RandomArray();
39
40 //生成图片.
41 for (int i = 0; i < 16; i++) {
42 UISprite cell = NGUITools.AddChild<UISprite>(grid.gameObject);
43
44 //设置图片容器的Atlas及图片名称.
45 cell.atlas = myAtlas;
46 cell.spriteName = "box";
47 cell.name = "f-" + i.ToString();
48
49 //添加UIDragDropContainer组件用于接收图片.
50 UIDragDropContainer container = NGUITools.AddMissingComponent<UIDragDropContainer>(cell.gameObject);
51 container.reparentTarget = cell.transform;
52
53 //添加显示图片的sprite.
54 UISprite sprite = NGUITools.AddChild<UISprite>(cell.gameObject);
55 sprite.atlas = myAtlas;
56 sprite.spriteName = "f-" + randomIndex[i];
57
58 sprite.tag = "Cell";
59
60 //设置sprite的depth使其能显示在上方.
61 sprite.depth = cell.depth + 1;
62
63 //为图片添加BoxCollider组件用于鼠标交互,并重新设置它的大小与图片大小一致.
64 NGUITools.AddMissingComponent<BoxCollider>(sprite.gameObject);
65 sprite.autoResizeBoxCollider = true;
66 sprite.ResizeCollider();
67
68 //添加我们自己写的DragOnPic脚本用于实现拖拽功能.
69 NGUITools.AddMissingComponent<DragOnPic>(sprite.gameObject);
70 }
71 }
72
73 }

拖拽脚本:

 public class DragOnPic : UIDragDropItem {

     UISprite _sprite;

     Transform myParent;

     void OnEnable()
{
_sprite = this.GetComponent<UISprite>();
} protected override void OnDragDropStart ()
{
//开始拖拽时增加depth,是其能显示在别的图片上方.
_sprite.depth += ; //开始拖拽时记下自己的父物体.
myParent = this.transform.parent; //父类的方法.
base.OnDragDropStart ();
} protected override void OnDragDropRelease (GameObject surface)
{
//父类的方法.
base.OnDragDropRelease (surface); //松开鼠标时如果是另一张图片,则交换两张图片的位置,否则重置自己的位置.
if(surface.tag == "Cell")
{
this.transform.SetParent(surface.transform.parent);
surface.transform.SetParent(myParent);
this.transform.localPosition = Vector3.zero;
surface.transform.localPosition = Vector3.zero;
}
else {
this.transform.localPosition = Vector3.zero;
} //拖拽结束时判断是否完成拼图.
if(GamaManager.CheckWin())
{
NGUIDebug.Log("Win!!!!");
} //结束拖拽时重置depth.
_sprite.depth -= ;
} }

GameManager中判断是否完成拼图分方法跟UGUI中的类似,这里就不多写了~~~

好了,大功告成!

网页版预览

PC版下载

使用NGUI实现拖拽功能(拼图小游戏)的更多相关文章

  1. 使用UGUI实现拖拽功能(拼图小游戏)

    实现方式 1.引入UGUI自带的事件系统 UnityEngine.EventSystems 2.为我们的类添加接口 IBeginDragHandler, IDragHandler, IEndDragH ...

  2. canvas drag 实现拖拽拼图小游戏

    博主一直心心念念想做一个小游戏-  前端时间终于做了一个小游戏,直到现在才来总结,哈哈- 以后要勤奋点更新博客! 实现原理 1.如何切图? 用之前的方法就是使用photoshop将图片切成相应大小的图 ...

  3. React Editor 应用编辑器(1) - 拖拽功能剖析

    这是可视化编辑器 Gaea-Editor 的第一篇连载分析文章,希望我能在有限的篇幅讲清楚制作这个网页编辑器的动机,以及可能带来的美好使用前景(画大饼).它会具有如下几个特征: 运行在网页 文档流布局 ...

  4. JQuery UI的拖拽功能

    JQuery UI是JQuery官方支持的WebUI 代码库,包含底层交互.动画.特效等API,并且封装了一些Web小部件(Widget).同时,JQuery UI继承了jquery的插件支持,有大量 ...

  5. Js元素拖拽功能实现

    Js元素拖拽功能实现 需要解决的问题 最近项目遇到了一个问题,就是用户某个操作需要弹出一个自定义的内容输入框,但是有个缺点,当浏览太大的时候没办法点击确认和取消按钮,应为这个弹出框是采用绝对定位的,取 ...

  6. (Demo分享)利用JavaScript(JS)实现一个九宫格拖拽功能

    利用JavaScript(JS)实现一个九宫格拖拽功能   Demo实现了对任意方格进行拖拽,可以交换位置,其中Demo-1利用了勾股定理判断距离! Demo-1整体思路: 1.首先div实现自由移动 ...

  7. html5中的拖拽功能

    拖拽元素支持的事件 ondrag 应用于拖拽元素,整个拖拽过程都会调用 ondragstart 应用于拖拽元素,当拖拽开始时调用 ondragleave 应用于拖拽元素,当鼠标离开拖拽元素是调用 on ...

  8. 使用 vue3 的自定义指令给 element-plus 的 el-dialog 增加拖拽功能

    element-plus 提供的 el-dialog 对话框功能非常强大,只是美中不足不能通过拖拽的方式改变位置,有点小遗憾,那么怎么办呢?我们可以通过 vue 的自定义指令来实现一个可以拖拽的对话框 ...

  9. RCP:拖拽功能的实现 Drag and Drop

    SWT中的拖拽是使用的org.eclipse.swt.dnd. 有三个需要密切注意的类: 1.DragSource 2.DropTarget 3.Transfer DragSource封装了需要被拖拽 ...

随机推荐

  1. 一步步优化JVM五:优化延迟或者响应时间

    本节的目标是做一些优化以满足对应用对延迟的需求.这次需要几个步骤,包括完善Java堆大小的配置,评估垃圾回收占用的时间和频率,也许还要尝试切换到不同的垃圾回收器,以及由于使用了不同的垃圾回收器,需要重 ...

  2. Centos7下建立rubymine快捷方式到侧栏或桌面

    gnome桌面的所有菜单项都存储如下位置: /usr/share/applications/ 新建一个菜单项,直接在该目录下新建一个后缀名为.desktop的文件即可. $ vi /usr/share ...

  3. Zookeeper单机版安装(CentOS 7环境下)

    一.环境操作系统和软件版本介绍 1.环境操作系统为CentOS Linux release 7.2.1511 (Core) 可用cat /etc/redhat-release查询 2.软件版本 Zoo ...

  4. HTTP Response Splitting攻击探究 <转>

    第一小节:HTTP Basics:使用Proxy软件(例如Webscarab)来截断浏览器(客户端)和Server之间的HTTP通信,之后任意篡改得到预期结果即可. 第二小节:HTTP Splitti ...

  5. Xsser

    来源:https://www.cqhacker.cn/post-174.html   XSSer使用说明 =============================================== ...

  6. LeetCode 385. Mini Parse

    Given a nested list of integers represented as a string, implement a parser to deserialize it. Each ...

  7. Chapter 16_5 单一方法

    当一个对象只有一个方法时,可以不用创建接口table,但是要将这个单独的方法作为对象来返回.可以参考迭代器那一节,是如何构造一个迭代器函数,那个函数将状态保存为closure. 一个具有状态的迭代器是 ...

  8. <验证码的产生>C语言---验证码的产生和验证

    无论在网页还是软件上登录时候都会遇到验证码的问题,不知道不懂其中奥秘的码友有没有兴趣一起来探讨一下. 其实并没有什么奥秘可言,就是产生随机数,然后让产生的随机数做为字符库(提前做好的数字字母字符串)的 ...

  9. postman+jenkins+newman做接口测试的持续集成

    为何要做接口自动化测试的持续集成? 1. 接口相对稳定,改动少,比起GUI自动化测试来说性价比更加高些,不容易出现GUI自动化那种掉到维护脚本的坑里. 2. 接口测试比较简单,一个规范的接口,测试只需 ...

  10. SweetTips: 快意灵动的Android提示库!

    此文章是我在简书的文章,自行搬到博客园.简书地址:SweetTips: 快意灵动的Android提示库! 源码及所在DEMO已上传至GitHub:SweetTips,欢迎大家提Bug,喜欢的话记得St ...