IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 游戏开发 -> Unity3d Ugui 25 拖拽自动吸附功能 -> 正文阅读

[游戏开发]Unity3d Ugui 25 拖拽自动吸附功能

一:前言

针对上一节讲解的事件机制https://blog.csdn.net/HexianWHH/article/details/119741189,这节练习一个实际应用。基于IDragHandler事件做一个在指定区域拖动松手自动吸附的功能。

二:效果演示

拖动滑块只能在指定区域内滑动,不能超出边界。松开鼠标以后自动吸附到最近的格子。

?

?

三:制作过程

  1. 添加一个图片作为拖动区域。
  2. 制作一个每一个格子的预制体。
  3. 给第一步的拖动区域添加GridLayoutGroup组件和自己写的GridWindow组件,并设置参数。
  4. 新建一个图片作为滑动块,并且挂上DragMove组件,并设置参数。

四:代码讲解

GridWindow负责创建格子,拥有所有的格子对象。

using System.Collections.Generic;
using UnityEngine;

/// <summary>
/// 所有格子的窗体
/// </summary>
public class GridWindow : MonoBehaviour
{
    /// <summary>
    /// 挂载每一个格子的父物体
    /// </summary>
    [SerializeField]
    Transform parentTrans;
    /// <summary>
    /// 格子的个数
    /// </summary>
    [SerializeField]
    int gridItemCount;
    /// <summary>
    /// 格子物体
    /// </summary>
    [SerializeField]
    GameObject childObj;
    /// <summary>
    /// 所有格子
    /// </summary>
    List<RectTransform> allChildGrid = new List<RectTransform>();
    void Start()
    {
        for (int i = 0; i < gridItemCount; i++)
        {
            var obj = Instantiate(childObj);
            obj.transform.SetParent(parentTrans);
            allChildGrid.Add(obj.GetComponent<RectTransform>());
        }
    }
    private void OnDestroy()
    {
        //删除所有创建的格子
        foreach (var item in allChildGrid)
        {
            Destroy(item.gameObject);
        }
        allChildGrid.Clear();
    }
    /// <summary>
    /// 得到距离指定位置最近的一个格子位置
    /// </summary>
    /// <param name="pos">指定位置</param>
    /// <returns>最近的格子位置</returns>
    public Vector3 GetNearestPos(Vector3 pos)
    {
        float minDis = float.MaxValue;
        Vector3 returnPos = Vector3.zero;
        foreach (var child in allChildGrid)
        {
            var dis = Vector3.Distance(child.position, pos);
            if (dis < minDis)
            {
                minDis = dis;
                returnPos = child.position;
            }
        }
        return returnPos;
    }
}

DragMove拖动的滑块,里面涉及到的变量具体意思

eventData.delta这次滑动的距离

rectTrans.rect和rectTrans.anchoredPosition,以及最小最大边界为什么是这样计算的。可以参照我之前写的文章有详细的解析https://blog.csdn.net/HexianWHH/article/details/118881151

Mathf.Clamp把值限定在最小和最大值范围之内。

using UnityEngine;
using UnityEngine.EventSystems;
/// <summary>
/// 可以拖动的物体
/// </summary>
public class DragMove : MonoBehaviour, IDragHandler,IEndDragHandler
{
    /// <summary>
    /// 可以拖拽的区域
    /// </summary>
    [SerializeField]
    RectTransform dragRangeRect;
    /// <summary>
    /// 所有格子的窗体
    /// </summary>
    [SerializeField]
    GridWindow gridWindow;
    /// <summary>
    /// 当前物体自己的矩形组件
    /// </summary>
    RectTransform rectTrans;
    private void Awake()
    {
        rectTrans = this.GetComponent<RectTransform>();
    }
    public void OnDrag(PointerEventData eventData)
    {
        //拖动区域的最小边界
        var minPos = 0.5f * (rectTrans.rect.size - dragRangeRect.rect.size);
        //拖动区域的最大边界
        var maxPos = 0.5f * (dragRangeRect.rect.size - rectTrans.rect.size);
        //拖动以后的距离
        var movePos = rectTrans.anchoredPosition + eventData.delta;
        //把滑块限定在拖动区域内部
        var curPos = new Vector2(Mathf.Clamp(movePos.x, minPos.x, maxPos.x), Mathf.Clamp(movePos.y, minPos.x, maxPos.y));
        rectTrans.anchoredPosition = curPos;
    }

    public void OnEndDrag(PointerEventData eventData)
    {
        //查找距离该点最近的格子的位置
        var pos = gridWindow.GetNearestPos(rectTrans.position);
        rectTrans.position = pos;
    }
}

  游戏开发 最新文章
6、英飞凌-AURIX-TC3XX: PWM实验之使用 GT
泛型自动装箱
CubeMax添加Rtthread操作系统 组件STM32F10
python多线程编程:如何优雅地关闭线程
数据类型隐式转换导致的阻塞
WebAPi实现多文件上传,并附带参数
from origin ‘null‘ has been blocked by
UE4 蓝图调用C++函数(附带项目工程)
Unity学习笔记(一)结构体的简单理解与应用
【Memory As a Programming Concept in C a
上一篇文章      下一篇文章      查看所有文章
加:2021-08-27 12:12:28  更:2021-08-27 12:13:06 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/28 12:02:01-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码