Unity之UGUI鼠标进入离开&&拖拽实现

前言:

__小黑最近在写项目的时候就有个疑惑,UGUI中的Button组件,他的点击事件是怎么实现的!?我们自己能不能写一个!?之后在项目中使用自己写出来的Button组件,是不是会超级开心,超级有成就感呢?!!
赶巧正好手中有项目需要:鼠标进入Image之后,出现不同的效果 + 信息的更新,然后上网一查发现Unity有接口可以直接实现,那这不是美滋滋么?!

实现接口

一、鼠标进入&&离开

这一听小伙伴们就知道是两个可实现接口了

1:IPointerEnterHandler

2:IPointerExitHandler

直接给大家上代码,希望客官逛过之后点赞哟~~~

using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.UI;
using UnityEngine.EventSystems; public class EntryorExitUI : MonoBehaviour , IPointerEnterHandler , IPointerExitHandler
{
/// <summary>
/// 当鼠标进入UI后执行的事件执行的
/// </summary>
public void OnPointerEnter(PointerEventData eventData)
{
Debug.Log("鼠标已经进入,请开始你的表演");
} /// <summary>
/// 当鼠标离开UI后执行的事件执行的
/// </summary>
public void OnPointerExit(PointerEventData eventData)
{
Debug.Log("鼠标已经离开,你的表演结束了!");
}
}

二、拖拽

三个可实现接口

1:IDragHandler

2:IBeginDragHandler

3:IEndDragHandler

提醒:小黑亲身试坑的结果:那就是一定要实现IDragHandler,然后实现IBeginDragHandler和IEndDragHandler。
!!!!深坑!!!! 一定要记住,一定要实现IDragHandler。

老规矩,直接给大家上代码!分享出来的知识有没有被小伙伴get到,还有好不好用,就看客官给小黑点不点赞了!

using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.UI;
using UnityEngine.EventSystems;
public class DragUI : MonoBehaviour, IDragHandler, IBeginDragHandler, IEndDragHandler
{
private Vector3 offset; //存储按下鼠标时的图片-鼠标位置差
private Vector3 arragedPos; //保存经过整理后的向量,用于图片移动 /// <summary>
/// 开始拖拽起始
/// </summary>
public void OnBeginDrag(PointerEventData eventData)
{
if (RectTransformUtility.ScreenPointToWorldPointInRectangle(transform.GetComponent<RectTransform>(), Input.mousePosition
, eventData.enterEventCamera, out arragedPos))
{
offset = transform.position - arragedPos;
}
} /// <summary>
/// 拖拽中
/// </summary>
public void OnDrag(PointerEventData eventData)
{
transform.position = offset + Input.mousePosition;
} /// <summary>
/// 拖拽结束
/// </summary>
public void OnEndDrag(PointerEventData eventData)
{
transform.position = transform.parent.transform.position;
}
}

三、合并

都合并了,当然是上面的5个接口啦

客官们,原小黑的懒好吧!脚本名字直接用拖拽的了

using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.UI;
using UnityEngine.EventSystems; public class DragUI : MonoBehaviour, IDragHandler, IBeginDragHandler, IEndDragHandler, IPointerExitHandler, IPointerEnterHandler
{
private Image thisimg;
private Vector3 offset; //存储按下鼠标时的图片-鼠标位置差
private Vector3 arragedPos; //保存经过整理后的向量,用于图片移动 /// <summary>
/// 开始拖拽起始
/// </summary>
public void OnBeginDrag(PointerEventData eventData)
{
if (RectTransformUtility.ScreenPointToWorldPointInRectangle(transform.GetComponent<RectTransform>(), Input.mousePosition
, eventData.enterEventCamera, out arragedPos))
{
offset = transform.position - arragedPos;
}
} /// <summary>
/// 拖拽中
/// </summary>
public void OnDrag(PointerEventData eventData)
{
transform.position = offset + Input.mousePosition;
} /// <summary>
/// 拖拽结束
/// </summary>
public void OnEndDrag(PointerEventData eventData)
{
transform.position = transform.parent.transform.position;
} /// <summary>
/// 当鼠标进入UI后执行的事件执行的
/// </summary>
public void OnPointerEnter(PointerEventData eventData)
{
Debug.Log("鼠标已经进入,请开始你的表演");
} /// <summary>
/// 当鼠标离开UI后执行的事件执行的
/// </summary>
public void OnPointerExit(PointerEventData eventData)
{
Debug.Log("鼠标已经离开,你的表演结束了!");
}
}

四、结语

总之呢,小黑还是没有找到如何自己去编写Button组件,这个东西容我有时间了慢慢研究,不过这个鼠标进入离开 + 拖拽还挺好用的不是么,那么客官您是不是该给小黑 点个赞呐!

接下来还是我们的知识分享环节!

今日分享完毕!

程序的道路上学习永不停止,探索随时进行。
Let’s go. Just do it. We can.

还是来自**小黑**的祝福:祝小伙伴们国庆节快乐,技术多多长进,你们会了来给小黑讲解?

接着祝我们华锐视点生意兴隆,财源滚滚,越来越好?!不得不说我们老板超级Nice!21号吃的螃蟹宴,别提多爽了?

Unity之UGUI鼠标进入离开&&拖拽实现的更多相关文章

  1. CSharpGL(21)用鼠标拾取、拖拽VBO图元内的点、线或本身

    CSharpGL(21)用鼠标拾取.拖拽VBO图元内的点.线或本身 效果图 以最常见的三角形网格(用GL_TRIANGLES方式进行渲染)为例. 在拾取模式为GeometryType.Point时,你 ...

  2. 前端笔记之JavaScript(十一)event&BOM&鼠标/盒子位置&拖拽/滚轮

    一.事件对象event 1.1 preventdefault()和returnValue阻止默认事件 通知浏览器不要执行与事件关联的默认动作. preventdefault()  支持Chrome等高 ...

  3. 超强的纯 CSS 鼠标点击拖拽效果

    背景 鼠标拖拽元素移动,算是一个稍微有点点复杂的交互. 而在本文,我们就将打破常规,向大家介绍一种超强的仅仅使用纯 CSS 就能够实现的鼠标点击拖拽效果. 在之前的这篇文章中 -- 不可思议的纯 CS ...

  4. HTML5深入学习之鼠标跟随,拖拽事件

    知识点(鼠标跟随): mousedown: 当用户用鼠标点击在某一元素上就会触发该事件 mouseover:  当鼠标指针在某一元素上移动就会触发改事件 下面这个例子的效果就是鼠标点击元素后,元素跟着 ...

  5. wpf图片查看器,支持鼠标滚动缩放拖拽

    最近项目需要,要用到一个图片查看器,类似于windows自带的图片查看器那样,鼠标滚动可以缩放,可以拖拽图片,于是就写了这个简单的图片查看器. 前台代码: <Window x:Class=&qu ...

  6. JAVA鼠标屏幕绘制拖拽删除矩形

    import java.awt.Cursor; import java.awt.Graphics; import java.awt.Graphics2D; import java.awt.Point; ...

  7. 原生js及H5模拟鼠标点击拖拽

    一.原生js 1.拖拽的流程动作 鼠标按下 触发onmousedown事件 鼠标移动 触发onmousemove事件 鼠标松开 触发onmouseup事件 2.注意事项: 要防止div移出可视框,要限 ...

  8. 我的Windows日常——鼠标无法进行拖拽的解决方法

    方法1: 鼠标右键单击任务栏 选择属性,进入任务栏和开始菜单属性 点击「开始」菜单  进入分页,单击自定义 找到并勾选启用上下文菜单和拖放 一路确定.... --------------------- ...

  9. Unity中UGUI鼠标穿透UI问题的解决方法

    不过在使用时需要先获取两个红色显示的变量,graphicRaycaster和eventSystem. 这两个变量分别对应的是Canvas中的GraphicRaycaster组件和创建UI时自动生成的“ ...

随机推荐

  1. vue-axios更改操作

    <template> <div class="nav"> <label for="">新部门</label>&l ...

  2. Codeforces Round #802 (Div. 2)C. Helping the Nature(差分)

    题目链接 题目大意: 给你一个有n个元素的数组a,你可以通过一下三种操作使数组的每一个值都为0: 选择一个下标i,然后让a[1],a[2]....a[ i ] 都减一; 选择一个下标i,然后让a[i] ...

  3. android 代码分析

    1.@Override注解 @Override 注解是用来指定方法重写的,只能修饰方法并且只能用于方法重写,不能修饰其它的元素. 作用是告诉编译器检查这个方法,保证父类要包含一个被该方法重写的方法,否 ...

  4. MyBatis&Spring Framrwork

    1. MyBatis 1.1 概述 MyBatis是一款优秀的持久层框架,用于简化JDBC开发 MyBatis本是Apache的一个开源项目iBatis,2010年这个项目迁移到了google cod ...

  5. KMP算法,匹配字符串模板(返回下标)

    //KMP算法,匹配字符串模板 void getNext(int[] next, String t) { int n = next.length; for (int i = 1, j = 0; i & ...

  6. <四>构造函数初始化列表

    示例代码1 点击查看代码 class CDate{ public: CDate(int _year,int _month, int _day){ this->year=_year; this-& ...

  7. 2022-11-02 Acwing每日一题

    逆序对的个数 给定一个长度为 n 的整数数列,请你计算数列中的逆序对的数量. 逆序对的定义如下:对于数列的第 i 个和第 j 个元素,如果满足 i<j 且 a[i]>a[j],则其为一个逆 ...

  8. <四>理解空间配置器allocator, 优化STL 中的Vector

    .在上一节我们实现的 MyVector存在哪些问题? 问题1 现在有Student类 class Student{ public: Student(){cout<<"构造Stud ...

  9. 算法5: LeetCode_单链表_两数相加

    题目: * 给你两个 非空 的链表,表示两个非负的整数.它们每位数字都是按照 逆序 的方式存储的,并且每个节点只能存储 一位 数字. * 请你将两个数相加,并以相同形式返回一个表示和的链表. * 你可 ...

  10. 实践案例:同程艺龙网的 Dubbo 升级经验总结

    本篇为同程艺龙旅行网 Apache Dubbo 的实践案例总结.感兴趣的朋友可以访问官网了解更多详情,或搜索关注官方微信公众号 Apache Dubbo 跟进最新动态. 作者信息: 严浩:同程艺龙高级 ...