aboutsummaryrefslogtreecommitdiff
path: root/Ryujinx.Ava/Ui/Controls/ContentDialogHelper.cs
diff options
context:
space:
mode:
authorEmmanuel Hansen <emmausssss@gmail.com>2022-09-19 18:05:26 +0000
committerGitHub <noreply@github.com>2022-09-19 15:05:26 -0300
commit6f0395538b8e8af3bba7536b44780d57e51e8697 (patch)
tree4d3f4f620dd287fc1ca38ea9ea722b6e022301dd /Ryujinx.Ava/Ui/Controls/ContentDialogHelper.cs
parentb9f1ff3c7748c6a2665e76d17e86c3b7228f44fe (diff)
Avalonia - Use embedded window for avalonia (#3674)1.1.274
* wip * use embedded window * fix race condition on opengl Windows * fix glx issues on prime nvidia * fix mouse support win32 * clean up * addressed review * addressed review * fix warnings * fix sotware keyboard dialog * Update Ryujinx.Ava/Ui/Applet/SwkbdAppletDialog.axaml.cs Co-authored-by: gdkchan <gab.dark.100@gmail.com> * remove double semi Co-authored-by: gdkchan <gab.dark.100@gmail.com>
Diffstat (limited to 'Ryujinx.Ava/Ui/Controls/ContentDialogHelper.cs')
-rw-r--r--Ryujinx.Ava/Ui/Controls/ContentDialogHelper.cs78
1 files changed, 75 insertions, 3 deletions
diff --git a/Ryujinx.Ava/Ui/Controls/ContentDialogHelper.cs b/Ryujinx.Ava/Ui/Controls/ContentDialogHelper.cs
index 15ecaa77..e774a09a 100644
--- a/Ryujinx.Ava/Ui/Controls/ContentDialogHelper.cs
+++ b/Ryujinx.Ava/Ui/Controls/ContentDialogHelper.cs
@@ -1,4 +1,8 @@
+using Avalonia;
using Avalonia.Controls;
+using Avalonia.Controls.ApplicationLifetimes;
+using Avalonia.Controls.Primitives;
+using Avalonia.Media;
using Avalonia.Threading;
using FluentAvalonia.UI.Controls;
using Ryujinx.Ava.Common.Locale;
@@ -27,9 +31,69 @@ namespace Ryujinx.Ava.Ui.Controls
{
UserResult result = UserResult.None;
- ContentDialog contentDialog = new ContentDialog();
+ bool useOverlay = false;
+ Window mainWindow = null;
- await ShowDialog();
+ if (Application.Current.ApplicationLifetime is IClassicDesktopStyleApplicationLifetime al)
+ {
+ foreach (var item in al.Windows)
+ {
+ if (item.IsActive && item is MainWindow window && window.ViewModel.IsGameRunning)
+ {
+ mainWindow = window;
+ useOverlay = true;
+ break;
+ }
+ }
+ }
+
+ ContentDialog contentDialog = null;
+ ContentDialogOverlayWindow overlay = null;
+
+ if (useOverlay)
+ {
+ overlay = new ContentDialogOverlayWindow()
+ {
+ Height = mainWindow.Bounds.Height,
+ Width = mainWindow.Bounds.Width,
+ Position = mainWindow.PointToScreen(new Point())
+ };
+
+ mainWindow.PositionChanged += OverlayOnPositionChanged;
+
+ void OverlayOnPositionChanged(object sender, PixelPointEventArgs e)
+ {
+ overlay.Position = mainWindow.PointToScreen(new Point());
+ }
+
+ contentDialog = overlay.ContentDialog;
+
+ bool opened = false;
+
+ overlay.Opened += OverlayOnActivated;
+
+ async void OverlayOnActivated(object sender, EventArgs e)
+ {
+ if (opened)
+ {
+ return;
+ }
+
+ opened = true;
+
+ overlay.Position = mainWindow.PointToScreen(new Point());
+
+ await ShowDialog();
+ }
+
+ await overlay.ShowDialog(mainWindow);
+ }
+ else
+ {
+ contentDialog = new ContentDialog();
+
+ await ShowDialog();
+ }
async Task ShowDialog()
{
@@ -53,6 +117,14 @@ namespace Ryujinx.Ava.Ui.Controls
});
await contentDialog.ShowAsync(ContentDialogPlacement.Popup);
+
+ overlay?.Close();
+ }
+
+ if (useOverlay)
+ {
+ overlay.Content = null;
+ overlay.Close();
}
return result;
@@ -323,4 +395,4 @@ namespace Ryujinx.Ava.Ui.Controls
return string.Empty;
}
}
-} \ No newline at end of file
+}