SEBWIN-117: Corrected implementation of browser window to automatically resize itself on display rotation. Decided to use WPF's SystemParameters nonetheless by only accessing it after the working area has been initialized.
This commit is contained in:
parent
13832cb65c
commit
5ad8a8a2fb
8 changed files with 46 additions and 57 deletions
|
@ -324,8 +324,8 @@ namespace SafeExamBrowser.Client
|
||||||
logger.Info("Reinitializing working area...");
|
logger.Info("Reinitializing working area...");
|
||||||
displayMonitor.InitializePrimaryDisplay(taskbar.GetAbsoluteHeight());
|
displayMonitor.InitializePrimaryDisplay(taskbar.GetAbsoluteHeight());
|
||||||
logger.Info("Reinitializing shell...");
|
logger.Info("Reinitializing shell...");
|
||||||
|
actionCenter.InitializeBounds();
|
||||||
taskbar.InitializeBounds();
|
taskbar.InitializeBounds();
|
||||||
actionCenter.UpdateTaskbarHeight(taskbar.GetRelativeHeight());
|
|
||||||
logger.Info("Desktop successfully restored.");
|
logger.Info("Desktop successfully restored.");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -369,8 +369,8 @@ namespace SafeExamBrowser.Client
|
||||||
logger.Info("Reinitializing working area...");
|
logger.Info("Reinitializing working area...");
|
||||||
displayMonitor.InitializePrimaryDisplay(taskbar.GetAbsoluteHeight());
|
displayMonitor.InitializePrimaryDisplay(taskbar.GetAbsoluteHeight());
|
||||||
logger.Info("Reinitializing shell...");
|
logger.Info("Reinitializing shell...");
|
||||||
|
actionCenter.InitializeBounds();
|
||||||
taskbar.InitializeBounds();
|
taskbar.InitializeBounds();
|
||||||
actionCenter.UpdateTaskbarHeight(taskbar.GetRelativeHeight());
|
|
||||||
logger.Info("Desktop successfully restored.");
|
logger.Info("Desktop successfully restored.");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -106,7 +106,6 @@ namespace SafeExamBrowser.Client.Operations
|
||||||
{
|
{
|
||||||
logger.Info("Initializing action center...");
|
logger.Info("Initializing action center...");
|
||||||
actionCenter.InitializeText(text);
|
actionCenter.InitializeText(text);
|
||||||
actionCenter.UpdateTaskbarHeight(taskbar.GetRelativeHeight());
|
|
||||||
|
|
||||||
InitializeAboutNotificationForActionCenter();
|
InitializeAboutNotificationForActionCenter();
|
||||||
InitializeClockForActionCenter();
|
InitializeClockForActionCenter();
|
||||||
|
|
|
@ -51,6 +51,11 @@ namespace SafeExamBrowser.Contracts.UserInterface.Shell
|
||||||
/// </summary>
|
/// </summary>
|
||||||
void Hide();
|
void Hide();
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Moves the action center to the left of the screen and resizes it accordingly.
|
||||||
|
/// </summary>
|
||||||
|
void InitializeBounds();
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Initializes all text elements in the action center.
|
/// Initializes all text elements in the action center.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
@ -61,11 +66,6 @@ namespace SafeExamBrowser.Contracts.UserInterface.Shell
|
||||||
/// </summary>
|
/// </summary>
|
||||||
void Register(IActionCenterActivator activator);
|
void Register(IActionCenterActivator activator);
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Informs the action center about the relative height (i.e. height in logical pixels) of the taskbar.
|
|
||||||
/// </summary>
|
|
||||||
void UpdateTaskbarHeight(int height);
|
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Makes the action center visible.
|
/// Makes the action center visible.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
|
|
@ -52,12 +52,7 @@ namespace SafeExamBrowser.Contracts.UserInterface.Shell
|
||||||
int GetAbsoluteHeight();
|
int GetAbsoluteHeight();
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Returns the relative height of the taskbar (i.e. in logical pixels).
|
/// Moves the taskbar to the bottom of the screen and resizes it accordingly.
|
||||||
/// </summary>
|
|
||||||
int GetRelativeHeight();
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Moves the taskbar to the bottom of and resizes it according to the current working area.
|
|
||||||
/// </summary>
|
/// </summary>
|
||||||
void InitializeBounds();
|
void InitializeBounds();
|
||||||
|
|
||||||
|
|
|
@ -17,8 +17,6 @@ namespace SafeExamBrowser.UserInterface.Desktop
|
||||||
{
|
{
|
||||||
public partial class ActionCenter : Window, IActionCenter
|
public partial class ActionCenter : Window, IActionCenter
|
||||||
{
|
{
|
||||||
private int taskbarHeight = 40;
|
|
||||||
|
|
||||||
public bool ShowClock
|
public bool ShowClock
|
||||||
{
|
{
|
||||||
set { Dispatcher.Invoke(() => Clock.Visibility = value ? Visibility.Visible : Visibility.Collapsed); }
|
set { Dispatcher.Invoke(() => Clock.Visibility = value ? Visibility.Visible : Visibility.Collapsed); }
|
||||||
|
@ -66,6 +64,16 @@ namespace SafeExamBrowser.UserInterface.Desktop
|
||||||
Dispatcher.Invoke(HideAnimated);
|
Dispatcher.Invoke(HideAnimated);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void InitializeBounds()
|
||||||
|
{
|
||||||
|
Dispatcher.Invoke(() =>
|
||||||
|
{
|
||||||
|
Height = SystemParameters.WorkArea.Height;
|
||||||
|
Top = 0;
|
||||||
|
Left = -Width;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
public void InitializeText(IText text)
|
public void InitializeText(IText text)
|
||||||
{
|
{
|
||||||
QuitButton.ToolTip = text.Get(TextKey.Shell_QuitButton);
|
QuitButton.ToolTip = text.Get(TextKey.Shell_QuitButton);
|
||||||
|
@ -84,11 +92,6 @@ namespace SafeExamBrowser.UserInterface.Desktop
|
||||||
Dispatcher.Invoke(ShowAnimated);
|
Dispatcher.Invoke(ShowAnimated);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void UpdateTaskbarHeight(int height)
|
|
||||||
{
|
|
||||||
taskbarHeight = height;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void HideAnimated()
|
private void HideAnimated()
|
||||||
{
|
{
|
||||||
var storyboard = new Storyboard();
|
var storyboard = new Storyboard();
|
||||||
|
@ -130,13 +133,6 @@ namespace SafeExamBrowser.UserInterface.Desktop
|
||||||
storyboard.Begin();
|
storyboard.Begin();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void InitializeBounds()
|
|
||||||
{
|
|
||||||
Height = SystemParameters.PrimaryScreenHeight - taskbarHeight;
|
|
||||||
Top = 0;
|
|
||||||
Left = -Width;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void ShowAnimation_Completed(object sender, EventArgs e)
|
private void ShowAnimation_Completed(object sender, EventArgs e)
|
||||||
{
|
{
|
||||||
Activate();
|
Activate();
|
||||||
|
|
|
@ -129,6 +129,7 @@ namespace SafeExamBrowser.UserInterface.Desktop
|
||||||
}
|
}
|
||||||
|
|
||||||
RegisterEvents();
|
RegisterEvents();
|
||||||
|
InitializeBounds();
|
||||||
ApplySettings();
|
ApplySettings();
|
||||||
LoadIcons();
|
LoadIcons();
|
||||||
LoadText();
|
LoadText();
|
||||||
|
@ -154,6 +155,14 @@ namespace SafeExamBrowser.UserInterface.Desktop
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void SystemParameters_StaticPropertyChanged(object sender, PropertyChangedEventArgs e)
|
||||||
|
{
|
||||||
|
if (e.PropertyName == nameof(SystemParameters.WorkArea))
|
||||||
|
{
|
||||||
|
Dispatcher.InvokeAsync(InitializeBounds);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private void UrlTextBox_GotMouseCapture(object sender, MouseEventArgs e)
|
private void UrlTextBox_GotMouseCapture(object sender, MouseEventArgs e)
|
||||||
{
|
{
|
||||||
if (UrlTextBox.Tag as bool? != true)
|
if (UrlTextBox.Tag as bool? != true)
|
||||||
|
@ -185,6 +194,7 @@ namespace SafeExamBrowser.UserInterface.Desktop
|
||||||
MenuPopup.Opened += (o, args) => MenuButton.Background = Brushes.LightGray;
|
MenuPopup.Opened += (o, args) => MenuButton.Background = Brushes.LightGray;
|
||||||
KeyUp += BrowserWindow_KeyUp;
|
KeyUp += BrowserWindow_KeyUp;
|
||||||
ReloadButton.Click += (o, args) => ReloadRequested?.Invoke();
|
ReloadButton.Click += (o, args) => ReloadRequested?.Invoke();
|
||||||
|
SystemParameters.StaticPropertyChanged += SystemParameters_StaticPropertyChanged;
|
||||||
UrlTextBox.GotKeyboardFocus += (o, args) => UrlTextBox.SelectAll();
|
UrlTextBox.GotKeyboardFocus += (o, args) => UrlTextBox.SelectAll();
|
||||||
UrlTextBox.GotMouseCapture += UrlTextBox_GotMouseCapture;
|
UrlTextBox.GotMouseCapture += UrlTextBox_GotMouseCapture;
|
||||||
UrlTextBox.LostKeyboardFocus += (o, args) => UrlTextBox.Tag = null;
|
UrlTextBox.LostKeyboardFocus += (o, args) => UrlTextBox.Tag = null;
|
||||||
|
@ -197,14 +207,30 @@ namespace SafeExamBrowser.UserInterface.Desktop
|
||||||
}
|
}
|
||||||
|
|
||||||
private void ApplySettings()
|
private void ApplySettings()
|
||||||
|
{
|
||||||
|
UrlTextBox.IsEnabled = WindowSettings.AllowAddressBar;
|
||||||
|
|
||||||
|
ReloadButton.IsEnabled = WindowSettings.AllowReloading;
|
||||||
|
ReloadButton.Visibility = WindowSettings.AllowReloading ? Visibility.Visible : Visibility.Collapsed;
|
||||||
|
|
||||||
|
BackwardButton.IsEnabled = WindowSettings.AllowBackwardNavigation;
|
||||||
|
BackwardButton.Visibility = WindowSettings.AllowBackwardNavigation ? Visibility.Visible : Visibility.Collapsed;
|
||||||
|
|
||||||
|
ForwardButton.IsEnabled = WindowSettings.AllowForwardNavigation;
|
||||||
|
ForwardButton.Visibility = WindowSettings.AllowForwardNavigation ? Visibility.Visible : Visibility.Collapsed;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void InitializeBounds()
|
||||||
{
|
{
|
||||||
if (isMainWindow)
|
if (isMainWindow)
|
||||||
{
|
{
|
||||||
if (WindowSettings.FullScreenMode)
|
if (WindowSettings.FullScreenMode)
|
||||||
{
|
{
|
||||||
MaxHeight = SystemParameters.WorkArea.Height;
|
Top = 0;
|
||||||
|
Left = 0;
|
||||||
|
Height = SystemParameters.WorkArea.Height;
|
||||||
|
Width = SystemParameters.WorkArea.Width;
|
||||||
ResizeMode = ResizeMode.NoResize;
|
ResizeMode = ResizeMode.NoResize;
|
||||||
WindowState = WindowState.Maximized;
|
|
||||||
WindowStyle = WindowStyle.None;
|
WindowStyle = WindowStyle.None;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -219,17 +245,6 @@ namespace SafeExamBrowser.UserInterface.Desktop
|
||||||
Height = SystemParameters.WorkArea.Height;
|
Height = SystemParameters.WorkArea.Height;
|
||||||
Width = SystemParameters.WorkArea.Width / 2;
|
Width = SystemParameters.WorkArea.Width / 2;
|
||||||
}
|
}
|
||||||
|
|
||||||
UrlTextBox.IsEnabled = WindowSettings.AllowAddressBar;
|
|
||||||
|
|
||||||
ReloadButton.IsEnabled = WindowSettings.AllowReloading;
|
|
||||||
ReloadButton.Visibility = WindowSettings.AllowReloading ? Visibility.Visible : Visibility.Collapsed;
|
|
||||||
|
|
||||||
BackwardButton.IsEnabled = WindowSettings.AllowBackwardNavigation;
|
|
||||||
BackwardButton.Visibility = WindowSettings.AllowBackwardNavigation ? Visibility.Visible : Visibility.Collapsed;
|
|
||||||
|
|
||||||
ForwardButton.IsEnabled = WindowSettings.AllowForwardNavigation;
|
|
||||||
ForwardButton.Visibility = WindowSettings.AllowForwardNavigation ? Visibility.Visible : Visibility.Collapsed;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void LoadIcons()
|
private void LoadIcons()
|
||||||
|
|
|
@ -44,8 +44,6 @@ namespace SafeExamBrowser.UserInterface.Desktop
|
||||||
|
|
||||||
InitializeComponent();
|
InitializeComponent();
|
||||||
InitializeRuntimeWindow();
|
InitializeRuntimeWindow();
|
||||||
|
|
||||||
Loaded += RuntimeWindow_Loaded;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void BringToForeground()
|
public void BringToForeground()
|
||||||
|
@ -146,11 +144,5 @@ namespace SafeExamBrowser.UserInterface.Desktop
|
||||||
Topmost = false;
|
Topmost = false;
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
private void RuntimeWindow_Loaded(object sender, RoutedEventArgs e)
|
|
||||||
{
|
|
||||||
Left = (SystemParameters.WorkArea.Right / 2) - (Width / 2);
|
|
||||||
Top = (SystemParameters.WorkArea.Bottom / 2) - (Height / 2);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -49,8 +49,6 @@ namespace SafeExamBrowser.UserInterface.Desktop
|
||||||
|
|
||||||
InitializeComponent();
|
InitializeComponent();
|
||||||
InitializeSplashScreen();
|
InitializeSplashScreen();
|
||||||
|
|
||||||
Loaded += SplashScreen_Loaded;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void BringToForeground()
|
public void BringToForeground()
|
||||||
|
@ -130,11 +128,5 @@ namespace SafeExamBrowser.UserInterface.Desktop
|
||||||
InfoTextBlock.Inlines.Add(new Run(appConfig.ProgramCopyright) { FontSize = 10 });
|
InfoTextBlock.Inlines.Add(new Run(appConfig.ProgramCopyright) { FontSize = 10 });
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void SplashScreen_Loaded(object sender, RoutedEventArgs e)
|
|
||||||
{
|
|
||||||
Left = (SystemParameters.WorkArea.Right / 2) - (Width / 2);
|
|
||||||
Top = (SystemParameters.WorkArea.Bottom / 2) - (Height / 2);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue