aboutsummaryrefslogtreecommitdiff
path: root/Ryujinx.Ava/Ui/Backend/Vulkan/VulkanPlatformInterface.cs
diff options
context:
space:
mode:
Diffstat (limited to 'Ryujinx.Ava/Ui/Backend/Vulkan/VulkanPlatformInterface.cs')
-rw-r--r--Ryujinx.Ava/Ui/Backend/Vulkan/VulkanPlatformInterface.cs70
1 files changed, 0 insertions, 70 deletions
diff --git a/Ryujinx.Ava/Ui/Backend/Vulkan/VulkanPlatformInterface.cs b/Ryujinx.Ava/Ui/Backend/Vulkan/VulkanPlatformInterface.cs
deleted file mode 100644
index ff8d9328..00000000
--- a/Ryujinx.Ava/Ui/Backend/Vulkan/VulkanPlatformInterface.cs
+++ /dev/null
@@ -1,70 +0,0 @@
-using Avalonia;
-using Ryujinx.Ava.Ui.Vulkan.Surfaces;
-using Ryujinx.Graphics.Vulkan;
-using Silk.NET.Vulkan;
-using System;
-
-namespace Ryujinx.Ava.Ui.Vulkan
-{
- internal class VulkanPlatformInterface : IDisposable
- {
- private static VulkanOptions _options;
-
- private VulkanPlatformInterface(VulkanInstance instance)
- {
- Instance = instance;
- Api = instance.Api;
- }
-
- public VulkanPhysicalDevice PhysicalDevice { get; private set; }
- public VulkanInstance Instance { get; }
- public Vk Api { get; private set; }
- public VulkanSurfaceRenderTarget MainSurface { get; set; }
-
- public void Dispose()
- {
- Instance?.Dispose();
- Api?.Dispose();
- }
-
- private static VulkanPlatformInterface TryCreate()
- {
- _options = AvaloniaLocator.Current.GetService<VulkanOptions>() ?? new VulkanOptions();
-
- var instance = VulkanInstance.Create(_options);
-
- return new VulkanPlatformInterface(instance);
- }
-
- public static bool TryInitialize()
- {
- var feature = TryCreate();
- if (feature != null)
- {
- AvaloniaLocator.CurrentMutable.Bind<VulkanPlatformInterface>().ToConstant(feature);
- return true;
- }
-
- return false;
- }
-
- public VulkanSurfaceRenderTarget CreateRenderTarget(IVulkanPlatformSurface platformSurface)
- {
- var surface = VulkanSurface.CreateSurface(Instance, platformSurface);
-
- if (PhysicalDevice == null)
- {
- PhysicalDevice = VulkanPhysicalDevice.FindSuitablePhysicalDevice(Instance, surface, _options.PreferDiscreteGpu, _options.PreferredDevice);
- }
-
- var renderTarget = new VulkanSurfaceRenderTarget(this, surface);
-
- if (MainSurface == null && surface != null)
- {
- MainSurface = renderTarget;
- }
-
- return renderTarget;
- }
- }
-}