-
Notifications
You must be signed in to change notification settings - Fork 4
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Fully remove use of MouseLook for headtracking #59
Comments
Lock on target mode (camera follows your target) works in non-VR mode, but not in VR mode. It just breaks the reticle positioning and the speedeffect (and probably other things) However, I think this should never be used in VR. It will cause sickness and you can always follow the target with your own head instead, which is the whole point of headtracking. We should capture the L key and just ignore it. Any ideas how to do that @Prof-Butts ? |
The HUD is fixed by setting the g_VSMatrixCB.fullViewMat to the inverse of the headtracking pose in DrawHUDVertices() |
The SpeedEffect can be fixed with ViewMatrix = g_VSMatrixCB.fullViewMat * ViewMatrix; in RenderSpeedEffect. |
It turns out you can fix the hyperspace and the reticle in one single place: I have removed the |
I added some hooking points in CockpitLook to fix the External camera. However, the transformation is not ideal. Instead of rotating with your head as a pivot point, the camera "orbits" around the ship so that you always have it in your view. This is bearable but not playable. I will need to patch part of the code that calculates the camera orientation to prevent that behavior. I also fixed the "no cockpit" mode. Now it's possible to play in VR without a cockpit displayed (when you press "."). The map still needs to be fixed, same as the shadows. |
Hangar external camera works by hooking the call to UpdateCameraTransform (0x459AC2) in DrawHangarView (0x4598E0). However, there seems to be some distortion when rotating the head. Maybe the HMD FOV is not correctly applied? |
I "kind of" fixed the map. It now displays something in the HMD in SteamVR (before, WaitGetPoses() was never called). I modified TrackIR mode to use the new hook without MousePositionX,Y. FreePIE should work too but I didn't test it. We need to apply the headtracking transformation to those elements in ddraw. Unfortunately, we don't currently have this matrix in ddraw, and it's not as easy to get as in SteamVR (GetLastPoses()). Also, probably the matrix should include the inertia so that the aiming reticle is accurate when the ship is turning. However, considering the laser "trailing", this may be hardly noticeable. |
With the new hooking method, it is not necessary to use MousePositionX,Y variables in CockpitLookHook to inject the headtracking in the camera, and we can apply the full transform including roll.
However, if we stop updating mouselook variables, there are a number of things that rely on it that will be incorrectly positioned as XWA or ddraw uses mouselook variables to position them in the right place relative to the camera position.
The main benefit is that the fix is just to apply the full headtracking pose transform as offset, instead of having to decompose it and apply only one part in CockpitLook (pitch,yaw) and the rest in ddraw, which makes things complex.
Things to review/fix:
@Prof-Butts did I miss anything?
The text was updated successfully, but these errors were encountered: