ugui拖拽
整理了下以前写的
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.EventSystems; [RequireComponent(typeof(CanvasGroup))]
public class ItemDrag : MonoBehaviour, IBeginDragHandler, IDragHandler, IEndDragHandler, IPointerClickHandler, IPointerEnterHandler, IPointerExitHandler
{
private CanvasGroup canvasGroup;
private Transform originalGrid;//拖出的格子
public GameObject bagFrame;//拖出格子的父级
Vector2 originGridSize;//原始大小 // Start is called before the first frame update
void Start()
{
originGridSize = (transform as RectTransform).sizeDelta;
canvasGroup = GetComponent<CanvasGroup>();
} public void OnBeginDrag(PointerEventData eventData)
{
//让eventTrigger无法检测到物体,让他去检测物体后面的格子
canvasGroup.blocksRaycasts = false;
originalGrid = gameObject.transform.parent;
gameObject.transform.SetAsLastSibling();//设置ui最上层
} public void OnDrag(PointerEventData eventData)
{
//把物体设置到背景上的字节点上,是为了防止格子挡住物品
transform.SetParent(bagFrame.transform);
//跟随鼠标移动
transform.position = Input.mousePosition;
} public void OnEndDrag(PointerEventData eventData)
{
//结束拖拽时,鼠标所碰撞的点的物品
GameObject curEnter = eventData.pointerEnter;
//满足条件,正确地放入格子里面
if (curEnter != null && curEnter.tag == "bagGrid")
{
//设置格子的父节点
transform.SetParent(curEnter.transform, false);
//设置预制物的位置
(transform as RectTransform).localPosition = Vector3.zero;
(transform as RectTransform).localRotation = Quaternion.identity;
(transform as RectTransform).localScale = Vector3.one;
//设置成原来的大小
(transform as RectTransform).sizeDelta = originGridSize;
}
//没有满足条件
else
{
//设置格子的父节点
transform.SetParent(originalGrid.transform);
//设置预制物的位置
(transform as RectTransform).localPosition = Vector3.zero;
(transform as RectTransform).localRotation = Quaternion.identity;
(transform as RectTransform).localScale = Vector3.one;
//设置成原来的大小
(transform as RectTransform).sizeDelta = originGridSize;
print("没有满足条件");
} //eventTrigger可以检测到物体
canvasGroup.blocksRaycasts = true;
} //点击
public void OnPointerClick(PointerEventData eventData)
{
print("点击");
} //鼠标进入
public void OnPointerEnter(PointerEventData eventData)
{
print("进入");
} //鼠标退出
public void OnPointerExit(PointerEventData eventData)
{
print("退出");
}
}
ugui拖拽的更多相关文章
- 使用UGUI实现拖拽功能(拼图小游戏)
实现方式 1.引入UGUI自带的事件系统 UnityEngine.EventSystems 2.为我们的类添加接口 IBeginDragHandler, IDragHandler, IEndDragH ...
- Unity3D UGUI窗口拖拽
在开发UGUI时 我们时常需要做一个窗口拖拽的功能 先上代码 using UnityEngine; using UnityEngine.EventSystems; public class DragW ...
- Unity UGUI 实现简单拖拽功能
说到拖拽,那必然离不开坐标,UGUI 的坐标有点不一样,它有两种坐标,一种是屏幕坐标,还有一种就是 UI 在Canvas内的坐标(暂时叫做ugui坐标),这两个坐标是不一样的,所以拖拽就需要转换. 因 ...
- 使用NGUI实现拖拽功能(拼图小游戏)
上一次用UGUI实现了拼图小游戏,这次,我们来用NGUI来实现 实现原理 NGUI中提供了拖拽的基类UIDragDropItem,所以我们要做的就是在要拖拽的图片上加一个继承于该类的脚本,并实现其中的 ...
- Unity输出PC端(Windows) 拖拽文件到app中
需求:给策划们写一个PC端(Window)的Excel导表工具.本来用OpenFile打开FileExplorerDialog后让他们自己选择想要添加的Excel文件就行了,结果有个需求是希望能拖拽E ...
- 在屏幕拖拽3D物体移动
3D物体的拖拽不同于2D的.因为3D物体有x,y,z当然.实际拖拽还是在XZ平面.只是多了几个转换 using UnityEngine; using System.Collections; publi ...
- NGUI拖拽简介
挂上UIDragDropItem就可以实现拖拽,按钮监听Drop消息即可实现对拖放的监听. UIDragDropItem有一个Clone On Drag选项,勾上可以克隆,但会被ScrollView遮 ...
- Unity实现放大缩小以及相机位置平移实现拖拽效果
放大缩小功能是游戏开发中用到的功能,今天就来讲一下Unity中放大缩小怎么实现. 1.IDragHandler, IBeginDragHandler, IEndDragHandler这三个接口是Uni ...
- JavaScript动画-拖拽改变元素大小
▓▓▓▓▓▓ 大致介绍 拖拽改变元素大小是在模拟拖拽上增加了一些功能 效果:拖拽改变元素大小 ▓▓▓▓▓▓ 拖拽改变元素大小原理 首先这个方块得知道我们想要改变这个它的大小,所以我给它设定一个范围,当 ...
随机推荐
- for 循环,range()函数和导入模块
(一)for语句构成: for i in range(5): print('My name is') for i in range(5): print('Jimmy Five Times ('+str ...
- element 表单校验失败自动聚焦到失败的input框
1.在对应的input框上添加ref属性,直接根据ref就可精确地获取到元素 <el-form-item label="课程名称" :label-width="fo ...
- Java中InputStream和String之间的转换方法
1.InputStream转化为String1.1 JDK原生提供方法一:byte[] bytes = new byte[0];bytes = new byte[inputStream.availab ...
- 【SaltStack官方版】—— MANAGING THE JOB CACHE
MANAGING THE JOB CACHE The Salt Master maintains a job cache of all job executions which can be quer ...
- maven 三个仓库表
https://search.maven.org ,http://www.mvnrepository.com/ http://maven.apache.org
- 从1G到5G发展史(3GPP是个什么组织 为啥5G标准离不开它)
1.“3GPP”组织建立的来龙去脉 3GPP一直以来在人们心中是一个神秘的组织,很多用户对于它的理解和认知,说不清,道不明.最近关于5G网络的诸多报道,都陈述了“5G网络”的标准是由“3GPP”来规定 ...
- html caption标签 语法
html caption标签 语法 caption是什么标签? 作用:定义表格标题. 说明:caption 标签必须紧随 table 标签之后.您只能对每个表格定义一个标题.通常这个标题会被居中于表格 ...
- 微信长按识别二维码,在 vue 项目中的实现
微信长按识别二维码是 QQ 浏览器的内置功能,该功能的基础一定要使用 img 标签引入图片,其他方式的二维码无法识别. 在 vue 中使用 QrcodeVue 插件 demo1 在 template ...
- wordcloud:让你的词语像云朵一样美
介绍 对文本中出现频率较高的关键词给予视觉化的显示 使用 python import jieba import codecs import wordcloud file = r"C:\U ...
- zabbix配置通过远程命令来发送邮件
1.安装好zabbix后,在/var/log/zabbix可以查看日志. 2.主机通过zabbix-get检查 yum install zabbix-get -y zabbix-get -s 客户主 ...