EasyTouch 5.0.17 最新版本扩展方法

简介: 具体使用方法看自带的文档就可以了,我对相应的组建稍微封装了下,方便动态加载EasyTouch下载链接using System.Collections;using System.

具体使用方法看自带的文档就可以了,我对相应的组建稍微封装了下,方便动态加载

EasyTouch下载链接

using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.Events;
using System;

using HedgehogTeam.EasyTouch;


public static class EasyTouchHandle
{
    /// <summary>
    /// 添加拖拽组件
    /// </summary>
    /// <param name="root"></param>
    /// <param name="DragStart">开始拖拽触发事件</param>
    /// <param name="Drag">拖拽过程中触发事件</param>
    /// <param name="dargEnd">拖拽结束时触发事件</param>
    /// <returns></returns>
    public static QuickDrag  AddQuickDrag( this GameObject root,UnityAction<Gesture> DragStart = null, UnityAction<Gesture> Drag = null, UnityAction<Gesture> DragEnd = null)
    {

        QuickDrag tempQuickDrag = root.AddComponent<QuickDrag>();
        tempQuickDrag.axesAction = QuickBase.AffectedAxesAction.XYZ;//拖拽轴向
        tempQuickDrag.enablePickOverUI = false; //其他UI上拖拽和此拖拽物体叠加时可同时触发(false不触发)

        tempQuickDrag.onDragStart = new QuickDrag.OnDragStart();
        tempQuickDrag.onDrag = new QuickDrag.OnDrag();
        tempQuickDrag.onDragEnd = new QuickDrag.OnDragEnd();

        if (DragStart != null)
        {
            tempQuickDrag.onDragStart.AddListener(DragStart);
        }
        if (Drag != null)
        {
            tempQuickDrag.onDrag.AddListener(Drag);
        }
        if (DragEnd != null)
        {
            tempQuickDrag.onDragEnd.AddListener(DragEnd);
        }

        return tempQuickDrag;
    }
    /// <summary>
    /// 添加触控组件
    /// </summary>
    /// <param name="root"></param>
    /// <param name="TouchStart">点击开始触发事件</param>
    /// <param name="TouchDown">点击中触发事件</param>
    /// <param name="TouchUp">点击结束时触发事件</param>
    public static void AddQuickTouch(this GameObject root, UnityAction<Gesture> TouchStart=null, UnityAction<Gesture> TouchDown = null, UnityAction<Gesture> TouchUp = null)
    {
        if (TouchStart != null)
        {
            QuickTouch tempQuickTouch = root.AddComponent<QuickTouch>();
            tempQuickTouch.quickActionName = "QucikTouchStart";
            tempQuickTouch.is2Finger = false;//是否双指触发
            tempQuickTouch.actionTriggering = QuickTouch.ActionTriggering.Start;
            //if (tempQuickTouch == null)
            //{
            //    Debug.Log("<color=#ffff00ff><b>AddQuickDrag参数为Null</b></color>");
            //}

            //tempQuickTouch.onTouch
            tempQuickTouch.onTouch = new QuickTouch.OnTouch();
            tempQuickTouch.onTouch.AddListener(TouchStart);
        }

        if (TouchDown != null)
        {
            QuickTouch tempQuickTouch = root.AddComponent<QuickTouch>();
            tempQuickTouch.quickActionName = "QucikTouchStart";
            tempQuickTouch.is2Finger = false;//是否双指触发
            tempQuickTouch.actionTriggering = QuickTouch.ActionTriggering.Down;
            tempQuickTouch.onTouch = new QuickTouch.OnTouch();
            tempQuickTouch.onTouch.AddListener(TouchDown);
        }
        if (TouchUp != null)
        {
            QuickTouch tempQuickTouch = root.AddComponent<QuickTouch>();
            tempQuickTouch.quickActionName = "QucikTouchStart";
            tempQuickTouch.is2Finger = false;//是否双指触发
            tempQuickTouch.actionTriggering = QuickTouch.ActionTriggering.Up;
            tempQuickTouch.onTouch = new QuickTouch.OnTouch();
            tempQuickTouch.onTouchNotOverMe = new QuickTouch.OnTouchNotOverMe();
            tempQuickTouch.onTouch.AddListener(TouchStart);
            tempQuickTouch.onTouchNotOverMe.AddListener(TouchUp);
        }
    }

    /// <summary>
    /// 添加滑动组建
    /// </summary>
    /// <param name="root"></param>
    /// <param name="Swipe"></param>
    /// <param name="SwipeDirection">滑动方向</param>
    /// <param name="DirectAction">触发效果位置 角度 或 缩放</param>
    /// <param name="AffectedAxesAction">影响对应的轴向( X Y Z )</param>
    /// <param name="SensibilitySpeed">滑动所影响效果的速率</param>
    /// <param name="inverseAxisValue">是否与滑动方向相反</param>
    public static QuickSwipe AddQuickSwip(this GameObject root, UnityAction<Gesture> Swipe = null, 
        QuickSwipe.SwipeDirection SwipeDirection = QuickSwipe.SwipeDirection.Horizontal, 
        QuickBase.DirectAction DirectAction = QuickBase.DirectAction.RotateLocal,
        QuickBase.AffectedAxesAction AffectedAxesAction = QuickBase.AffectedAxesAction.Y,
        float SensibilitySpeed = 1.0f,bool inverseAxisValue = false)
    {
        QuickSwipe tempQuickSwipe = root.AddComponent<QuickSwipe>();
        tempQuickSwipe.quickActionName = "QuickSwipe";
        tempQuickSwipe.allowSwipeStartOverMe = false; //作用在root上时无效
        tempQuickSwipe.actionTriggering = QuickSwipe.ActionTriggering.InProgress;
        tempQuickSwipe.swipeDirection = SwipeDirection;
        tempQuickSwipe.enableSimpleAction = true;
        tempQuickSwipe.directAction = DirectAction;
        tempQuickSwipe.axesAction = AffectedAxesAction;
        tempQuickSwipe.sensibility = SensibilitySpeed;
        tempQuickSwipe.inverseAxisValue = inverseAxisValue;//顺时针逆时针
        tempQuickSwipe.onSwipeAction = new QuickSwipe.OnSwipeAction();
        if (Swipe != null)
        {
            tempQuickSwipe.onSwipeAction.AddListener(Swipe);
        }
        return tempQuickSwipe;
    }


    public static void AddQuickLongTap(this GameObject root,UnityAction<Gesture> Start = null, UnityAction<Gesture> InProgess = null, UnityAction<Gesture> End = null)
    {
        if (Start != null)
        {
            QuickLongTap tempQuickLongTap = root.AddComponent<QuickLongTap>();
            tempQuickLongTap.quickActionName = "QuickLongTapStart";
            tempQuickLongTap.actionTriggering = QuickLongTap.ActionTriggering.Start;
            tempQuickLongTap.onLongTap = new QuickLongTap.OnLongTap();
            tempQuickLongTap.onLongTap.AddListener(Start);
        }
        if (InProgess != null)
        {
            QuickLongTap tempQuickLongTap = root.AddComponent<QuickLongTap>();
            tempQuickLongTap.quickActionName = "QuickLongTapInProgess";
            tempQuickLongTap.actionTriggering = QuickLongTap.ActionTriggering.InProgress;
            tempQuickLongTap.onLongTap = new QuickLongTap.OnLongTap();
            tempQuickLongTap.onLongTap.AddListener(InProgess);
        }
        if (End != null)
        {
            QuickLongTap tempQuickLongTap = root.AddComponent<QuickLongTap>();
            tempQuickLongTap.quickActionName = "QuickLongTapEnd";
            tempQuickLongTap.actionTriggering = QuickLongTap.ActionTriggering.End;
            tempQuickLongTap.onLongTap = new QuickLongTap.OnLongTap();
            tempQuickLongTap.onLongTap.AddListener(End);
        }
    }
}

相关文章
|
资源调度 前端开发 算法
前端依赖版本重写指南
感谢神奇的 Semver 动态规则,npm 社区经常会发生依赖包更新后引入破坏变更的情况(应用没有使用依赖锁的话),而应用开发者就要在自己的依赖声明里先临时绕过,避免安装到有问题的版本,如果是一级依赖,只需要改 package.json 的声明就可以了,但如果是子依赖,就需要进行版本重写(overrides/resolution)了。本文是一篇针对版本重写功能的指南性文章,当你遇到如下的问题时,就可以按照对应的依赖重写语法,解决这些依赖问题了。
4066 1
前端依赖版本重写指南
|
10月前
VC 不同版本代码注入的区别
VC 不同版本代码注入的区别
39 0
|
10月前
VC 不同版本代码注入的改进
在上篇文章中 《VC 不同版本代码注入的区别》 ,我们想要对目标进程进行代码的注入,由于 Debug 版编译生成的代码和 Release 版编译生成的代码有些不同(Debug 版编译后,调用函数时会有一条 jmp 指令,而 Release 没有),因此,通过 #ifdef 这样的宏来区别 VC 是以 Debug 版方式编译,还是通过 Release 版方式编译,从而编译不同的代码来针对不同的版本进行了处理。
55 0
|
API C# 图形学
Unity 关于低版本是否可以引用高版本构建内容的可行性验证
本篇内容以Unity的一个相对较低的版本(2017.4.40)和一个相对较高的版本(2020.3.33),来验证在低版本中是否可以使用高版本中构建的内容。
221 1
Unity 关于低版本是否可以引用高版本构建内容的可行性验证
|
PHP 开发工具
【开发工具】Composer设置忽略版本匹配的方法
【开发工具】Composer设置忽略版本匹配的方法
626 0
【开发工具】Composer设置忽略版本匹配的方法
|
.NET 容器 开发框架
[UWP]依赖属性1:概述
原文:[UWP]依赖属性1:概述 1. 概述 依赖属性(DependencyProperty)是UWP的核心概念,它是有DependencyObject提供的一种特殊的属性。由于UWP的几乎所有UI元素都是集成于DependencyObject的FramewordElement,并且这些UI元素的几乎所有属性及它们出现在XAML中的几乎所有属性都是依赖属性,所以可以说依赖属性是专门为UI设计的属性系统。
1010 0