123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269 |
- using UnityEngine;
- using System;
- using System.Collections;
- using System.Runtime.InteropServices;
- class GSXRPluginWin : GSXRPlugin
- {
- public static GSXRPluginWin Create()
- {
- return new GSXRPluginWin ();
- }
- private GSXRPluginWin() { }
- public override bool IsInitialized() { return svrCamera != null; }
- public override bool IsRunning() { return eyes != null; }
- public override IEnumerator Initialize()
- {
- yield return base.Initialize();
- deviceInfo = GetDeviceInfo();
- yield break;
- }
- public override IEnumerator BeginVr(int cpuPerfLevel, int gpuPerfLevel)
- {
- yield return base.BeginVr(cpuPerfLevel, gpuPerfLevel);
- yield break;
- }
-
- public override void SetVSyncCount(int vSyncCount)
- {
- QualitySettings.vSyncCount = vSyncCount;
- }
- Vector2 mouseNDCRotate = Vector2.zero;
- Vector2 mouseNDCPosition = Vector2.zero;
- Vector2 mousePressPointTemp1 = Vector2.zero;
- Vector3 mousePressEuler = Vector3.zero;
- public override int GetHeadPose(ref HeadPose headPose, int frameIndex)
- {
- int poseStatus = 0;
- headPose.orientation = Quaternion.identity;
- headPose.position = Vector3.zero;
- //Debug.Log("Input.mousePosition:"+ Input.mousePosition+" "+ Screen.width+" "+Screen.height);
- //if (Input.GetMouseButton(0)) // 0/Left mouse button
- //{
- // poseStatus |= (int)TrackingMode.kTrackingOrientation;
- // poseStatus |= (int)TrackingMode.kTrackingPosition;
- //}
- //if(Input.GetMouseButtonDown(0) || Input.GetMouseButtonDown(1)) // 1/Right mouse button
- //{
- // mousePressPointTemp1 = Input.mousePosition;
- // mousePressEuler = GSXRManager.Instance.head.eulerAngles;
- //} else if(Input.GetMouseButton(0) || Input.GetMouseButton(1)) {
-
- // mouseNDCRotate.x = 2 * ((Input.mousePosition.x - mousePressPointTemp1.x) / Screen.width) ;
- // mouseNDCRotate.y = 2 * ((Input.mousePosition.y - mousePressPointTemp1.y) / Screen.height) ;
- // poseStatus |= (int)TrackingMode.kTrackingOrientation;
- //}
- //if(Input.GetKey(KeyCode.W)) {
- // mouseNDCPosition.y += Time.deltaTime * 0.2f;
- // poseStatus |= (int)TrackingMode.kTrackingPosition;
- //} else if(Input.GetKey(KeyCode.S)) {
- // mouseNDCPosition.y -= Time.deltaTime * 0.2f;
- // poseStatus |= (int)TrackingMode.kTrackingPosition;
- //} else {
- // mouseNDCPosition.y = 0;
- //}
- //if(Input.GetKey(KeyCode.A)) {
- // mouseNDCPosition.x -= Time.deltaTime * 0.2f;
- // poseStatus |= (int)TrackingMode.kTrackingPosition;
- //} else if(Input.GetKey(KeyCode.D)) {
- // mouseNDCPosition.x += Time.deltaTime * 0.2f;
- // poseStatus |= (int)TrackingMode.kTrackingPosition;
- //} else {
- // mouseNDCPosition.x = 0;
- //}
- ////if(Input.mouseScrollDelta.y != 0) {
- //// mouseNDCPosition.x = 0;
- //// mouseNDCPosition.y = Input.mouseScrollDelta.y * 0.2f;
- //// poseStatus |= (int)TrackingMode.kTrackingPosition;
- ////} else {
- //// mouseNDCPosition = Vector2.zero;
- ////}
- /////复位
- //if(Input.GetKey(KeyCode.Escape) == true) {
- // mouseNDCRotate = Vector2.zero;
- // mouseNDCPosition = Vector2.zero;
- // mousePressPointTemp1 = Vector2.zero;
- // mousePressEuler = Vector3.zero;
- // GSXRManager.Instance.head.position = Vector3.zero;
- // poseStatus |= (int)TrackingMode.kTrackingOrientation;
- // poseStatus |= (int)TrackingMode.kTrackingPosition;
- //}
- headPose.orientation.eulerAngles = mousePressEuler + new Vector3(-mouseNDCRotate.y * 45f, mouseNDCRotate.x * 90f, 0);
- headPose.position = new Vector3(mouseNDCPosition.x,0, mouseNDCPosition.y);
- headPose.position = GSXRManager.Instance.head.TransformPoint(headPose.position);
- return poseStatus;
- }
- public override DeviceInfo GetDeviceInfo()
- {
- DeviceInfo info = new DeviceInfo();
- info.displayWidthPixels = Screen.width;
- info.displayHeightPixels = Screen.height;
- info.displayRefreshRateHz = 60.0f;
- info.targetEyeWidthPixels = Screen.width / 2;
- info.targetEyeHeightPixels = Screen.height;
- info.targetFovXRad = Mathf.Deg2Rad * 47;
- info.targetFovYRad = Mathf.Deg2Rad * 20.1f;
- info.targetFrustumLeft.left = -0.02208847f;
- info.targetFrustumLeft.right = 0.02208847f;
- info.targetFrustumLeft.top = 0.0123837f;
- info.targetFrustumLeft.bottom = -0.0123837f;
- info.targetFrustumLeft.near = 0.0508f;
- info.targetFrustumLeft.far = 100f;
- info.targetFrustumRight.left = -0.02208847f;
- info.targetFrustumRight.right = 0.02208847f;
- info.targetFrustumRight.top = 0.0123837f;
- info.targetFrustumRight.bottom = -0.0123837f;
- info.targetFrustumRight.near = 0.0508f;
- info.targetFrustumRight.far = 100f;
- return info;
- }
- public override void SubmitFrame(int frameIndex, float fieldOfView, int frameType)
- {
- RenderTexture.active = null;
- GL.Clear (false, true, Color.black);
- //float cameraFov = fieldOfView;
- //float fovMarginX = (cameraFov / deviceInfo.targetFovXRad) - 1;
- //float fovMarginY = (cameraFov / deviceInfo.targetFovYRad) - 1;
- //Rect textureRect = new Rect(fovMarginX * 0.5f, fovMarginY * 0.5f, 1 - fovMarginX, 1 - fovMarginY);
- Rect textureRect = new Rect(0, 0, 1, 1);
- Vector2 leftCenter = new Vector2(Screen.width * 0.25f, Screen.height * 0.5f);
- Vector2 rightCenter = new Vector2(Screen.width * 0.75f, Screen.height * 0.5f);
- Vector2 eyeExtent = new Vector3(Screen.width * 0.25f, Screen.height * 0.5f);
- eyeExtent.x -= 10.0f;
- eyeExtent.y -= 10.0f;
- Rect leftScreen = Rect.MinMaxRect(
- leftCenter.x - eyeExtent.x,
- leftCenter.y - eyeExtent.y,
- leftCenter.x + eyeExtent.x,
- leftCenter.y + eyeExtent.y);
- Rect rightScreen = Rect.MinMaxRect(
- rightCenter.x - eyeExtent.x,
- rightCenter.y - eyeExtent.y,
- rightCenter.x + eyeExtent.x,
- rightCenter.y + eyeExtent.y);
- if (eyes != null) for (int i = 0; i < eyes.Length; i++)
- {
- if (eyes[i].isActiveAndEnabled == false) continue;
- if (eyes[i].TexturePtr == null) continue;
- if (eyes[i].imageTransform != null && eyes[i].imageTransform.gameObject.activeSelf == false) continue;
- if (eyes[i].imageTransform != null && !eyes[i].imageTransform.IsChildOf(svrCamera.transform)) continue; // svr only
- var eyeRectMin = eyes[i].clipLowerLeft; eyeRectMin /= eyeRectMin.w;
- var eyeRectMax = eyes[i].clipUpperRight; eyeRectMax /= eyeRectMax.w;
- if (eyes[i].Side == GSXREye.eSide.Left || eyes[i].Side == GSXREye.eSide.Both)
- {
- leftScreen = Rect.MinMaxRect(
- leftCenter.x + eyeExtent.x * eyeRectMin.x,
- leftCenter.y + eyeExtent.y * eyeRectMin.y,
- leftCenter.x + eyeExtent.x * eyeRectMax.x,
- leftCenter.y + eyeExtent.y * eyeRectMax.y);
- Graphics.DrawTexture(leftScreen, eyes[i].TexturePtr, textureRect, 0, 0, 0, 0);
- }
- if (eyes[i].Side == GSXREye.eSide.Right || eyes[i].Side == GSXREye.eSide.Both)
- {
- rightScreen = Rect.MinMaxRect(
- rightCenter.x + eyeExtent.x * eyeRectMin.x,
- rightCenter.y + eyeExtent.y * eyeRectMin.y,
- rightCenter.x + eyeExtent.x * eyeRectMax.x,
- rightCenter.y + eyeExtent.y * eyeRectMax.y);
- Graphics.DrawTexture(rightScreen, eyes[i].TexturePtr, textureRect, 0, 0, 0, 0);
- }
- }
- if (overlays != null) for (int i = 0; i < overlays.Length; i++)
- {
- if (overlays[i].isActiveAndEnabled == false) continue;
- if (overlays[i].TexturePtr == null) continue;
- if (overlays[i].imageTransform != null && overlays[i].imageTransform.gameObject.activeSelf == false) continue;
- if (overlays[i].imageTransform != null && !overlays[i].imageTransform.IsChildOf(svrCamera.transform)) continue; // svr only
- var eyeRectMin = overlays[i].clipLowerLeft; eyeRectMin /= eyeRectMin.w;
- var eyeRectMax = overlays[i].clipUpperRight; eyeRectMax /= eyeRectMax.w;
- textureRect.Set(overlays[i].uvLowerLeft.x, overlays[i].uvLowerLeft.y,
- overlays[i].uvUpperRight.x - overlays[i].uvLowerLeft.x,
- overlays[i].uvUpperRight.y - overlays[i].uvLowerLeft.y);
- if (overlays[i].Side == GSXROverlay.eSide.Left || overlays[i].Side == GSXROverlay.eSide.Both)
- {
- leftScreen = Rect.MinMaxRect(
- leftCenter.x + eyeExtent.x * eyeRectMin.x,
- leftCenter.y + eyeExtent.y * eyeRectMin.y,
- leftCenter.x + eyeExtent.x * eyeRectMax.x,
- leftCenter.y + eyeExtent.y * eyeRectMax.y);
- Graphics.DrawTexture(leftScreen, overlays[i].TexturePtr, textureRect, 0, 0, 0, 0);
- }
- if (overlays[i].Side == GSXROverlay.eSide.Right || overlays[i].Side == GSXROverlay.eSide.Both)
- {
- rightScreen = Rect.MinMaxRect(
- rightCenter.x + eyeExtent.x * eyeRectMin.x,
- rightCenter.y + eyeExtent.y * eyeRectMin.y,
- rightCenter.x + eyeExtent.x * eyeRectMax.x,
- rightCenter.y + eyeExtent.y * eyeRectMax.y);
- Graphics.DrawTexture(rightScreen, overlays[i].TexturePtr, textureRect, 0, 0, 0, 0);
- }
- }
-
- }
- public override void Shutdown()
- {
- base.Shutdown();
- }
- #region Controller
- public override bool GSXR_Is_SupportController() { return true; }
- public override int GSXR_Get_ControllerList(int lr) { return 17; } // 34;
- #endregion Controller
- #region HandTracking
- public override bool GSXR_Is_SupportHandTracking() { return true; }
- #endregion HandTracking
- }
|