123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899 |
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Text;
- using System.Threading.Tasks;
- using UnityEngine;
- namespace SC.XR.Unity.Module_InputSystem.InputDeviceGC {
- public class InputDeviceGCPartEventSliderUpDown : InputDeviceGCPartEventBase {
- InputDevicePartDispatchEventGC inputDevicePartDispatchEventGC;
- public InputDeviceGCPartEventSliderUpDown(InputDevicePartDispatchEventGC inputDevicePartDispatchEventGC) : base(inputDevicePartDispatchEventGC) {
- this.inputDevicePartDispatchEventGC = inputDevicePartDispatchEventGC;
- noise = 12;
- effect = 3;
- samplingTime = 0.03f;
- }
- enum XDirection {
- Up = -1,
- Down = 1,
- }
- List<Vector2> TouchTrendList = new List<Vector2>(new Vector2[6]);
- int DirectionResult = 0;
- int currentNum = 0;
- float timer = 0;
- protected override void OnUpdateEvent() {
- currentEvent = GCEventType.Null;
- timer += Time.deltaTime;
- if(timer >= samplingTime) {
- timer = 0;
- if(inputDevicePartDispatchEventGC.inputDeviceGCPart.inputDataGC.isTpTouch == true) {
- TouchTrendList[currentNum] = inputDevicePartDispatchEventGC.inputDeviceGCPart.inputDataGC.tpPosition;
- } else {
- TouchTrendList[currentNum] = Vector2.zero;
- }
- //int j = 0;
- //DebugMy.Log("trendList * 1000 =========== " + TouchTrendList[currentNum] * 1000 + " ==========", this);
- //foreach(var trend in TouchTrendList) {
- // if(currentNum == j) {
- // DebugMy.Log("trendList * 1000:[" + j++ + "]:" + trend * 1000 + "<===", this);
- // } else {
- // DebugMy.Log("trendList * 1000:[" + j++ + "]:" + trend * 1000, this);
- // }
- //}
- DirectionResult = 0;
- for(int i = TouchTrendList.Count - 1; i >= 0; i--) {
- if(TouchTrendList[i].y > (TouchTrendList[((i - 1) < 0) ? TouchTrendList.Count - 1 : i - 1].y + noise)) {
- DirectionResult += (int)XDirection.Down;
- //DebugMy.Log(" " + XDirection.Down + " " + DirectionResult, this);
- } else if((TouchTrendList[i].y + noise) < TouchTrendList[((i - 1) < 0) ? TouchTrendList.Count - 1 : i - 1].y) {
- DirectionResult += (int)XDirection.Up;
- //DebugMy.Log(" " + XDirection.Up + " " + DirectionResult, this);
- }
- //Debug.Log("xxxx:: "+ i+"::"+(((i - 1) < 0) ? HandTrendList.Count - 1 : i - 1));
- }
- ///此log可用于查看noise大小,正常手不动DirectionResult为0,当不为0时,调大 noise
- //DebugMy.Log("Noise ----- ----- Y---:" + DirectionResult, this);
- if(DirectionResult >= effect) {
- //DebugMy.Log("Event ----- ----- TouchSildeUp---", this);
- for(int i = 0; i < TouchTrendList.Count; i++) {
- TouchTrendList[i] = Vector3.zero;
- }
- currentEvent = GCEventType.TouchSlideUp;
- } else if(DirectionResult <= -effect) {
- //DebugMy.Log("Event ----- ----- TouchSildeDown ---", this);
- for(int i = 0; i < TouchTrendList.Count; i++) {
- TouchTrendList[i] = Vector3.zero;
- }
- currentEvent = GCEventType.TouchSlideDown;
- }
- currentNum++;
- if(currentNum == TouchTrendList.Count) {
- currentNum = 0;
- }
- }
- }
- }
- }
|