diff --git a/src/Ryujinx.Graphics.Metal/Window.cs b/src/Ryujinx.Graphics.Metal/Window.cs index 7d9a51a9e1..1823c0b9a6 100644 --- a/src/Ryujinx.Graphics.Metal/Window.cs +++ b/src/Ryujinx.Graphics.Metal/Window.cs @@ -22,13 +22,15 @@ class Window : IWindow, IDisposable private int _requestedWidth; private int _requestedHeight; - - // private bool _vsyncEnabled; + private AntiAliasing _currentAntiAliasing; private bool _updateEffect; private IPostProcessingEffect _effect; private IScalingFilter _scalingFilter; private bool _isLinear; + + public bool IsVSyncEnabled => _metalLayer.DisplaySyncEnabled; + // private float _scalingFilterLevel; private bool _updateScalingFilter; private ScalingFilter _currentScalingFilter; @@ -40,7 +42,7 @@ public Window(MetalRenderer renderer, CAMetalLayer metalLayer) _metalLayer = metalLayer; } - private unsafe void ResizeIfNeeded() + private void ResizeIfNeeded() { if (_requestedWidth != 0 && _requestedHeight != 0) { @@ -54,7 +56,7 @@ private unsafe void ResizeIfNeeded() } } - public unsafe void Present(ITexture texture, ImageCrop crop, Action swapBuffersCallback) + public void Present(ITexture texture, ImageCrop crop, Action swapBuffersCallback) { if (_renderer.Pipeline is Pipeline pipeline && texture is Texture tex) { @@ -141,15 +143,7 @@ public void SetSize(int width, int height) public void ChangeVSyncMode(VSyncMode vSyncMode) { - switch (vSyncMode) - { - case VSyncMode.Unbounded: - _metalLayer.DisplaySyncEnabled = false; - break; - case VSyncMode.Switch: - _metalLayer.DisplaySyncEnabled = true; - break; - } + _metalLayer.DisplaySyncEnabled = vSyncMode is VSyncMode.Switch; } public void SetAntiAliasing(AntiAliasing effect)