Working on multiple instance and multiple application layout of taskbar.
This commit is contained in:
parent
e623101f8c
commit
2104f401ec
7 changed files with 98 additions and 34 deletions
|
@ -171,16 +171,35 @@ namespace SafeExamBrowser.Core.Behaviour
|
||||||
|
|
||||||
private void InitializeBrowser()
|
private void InitializeBrowser()
|
||||||
{
|
{
|
||||||
var browserButton = uiFactory.CreateApplicationButton(browserInfo);
|
|
||||||
|
|
||||||
logger.Info("Initializing browser.");
|
logger.Info("Initializing browser.");
|
||||||
splashScreen.UpdateText(Key.SplashScreen_InitializeBrowser);
|
splashScreen.UpdateText(Key.SplashScreen_InitializeBrowser);
|
||||||
|
|
||||||
|
var browserButton = uiFactory.CreateApplicationButton(browserInfo);
|
||||||
|
|
||||||
browserController.RegisterApplicationButton(browserButton);
|
browserController.RegisterApplicationButton(browserButton);
|
||||||
|
|
||||||
// TODO
|
// TODO
|
||||||
|
|
||||||
taskbar.AddButton(browserButton);
|
taskbar.AddButton(browserButton);
|
||||||
|
taskbar.AddButton(uiFactory.CreateApplicationButton(browserInfo));
|
||||||
|
taskbar.AddButton(uiFactory.CreateApplicationButton(browserInfo));
|
||||||
|
taskbar.AddButton(uiFactory.CreateApplicationButton(browserInfo));
|
||||||
|
taskbar.AddButton(uiFactory.CreateApplicationButton(browserInfo));
|
||||||
|
taskbar.AddButton(uiFactory.CreateApplicationButton(browserInfo));
|
||||||
|
taskbar.AddButton(uiFactory.CreateApplicationButton(browserInfo));
|
||||||
|
taskbar.AddButton(uiFactory.CreateApplicationButton(browserInfo));
|
||||||
|
taskbar.AddButton(uiFactory.CreateApplicationButton(browserInfo));
|
||||||
|
taskbar.AddButton(uiFactory.CreateApplicationButton(browserInfo));
|
||||||
|
taskbar.AddButton(uiFactory.CreateApplicationButton(browserInfo));
|
||||||
|
taskbar.AddButton(uiFactory.CreateApplicationButton(browserInfo));
|
||||||
|
taskbar.AddButton(uiFactory.CreateApplicationButton(browserInfo));
|
||||||
|
taskbar.AddButton(uiFactory.CreateApplicationButton(browserInfo));
|
||||||
|
taskbar.AddButton(uiFactory.CreateApplicationButton(browserInfo));
|
||||||
|
taskbar.AddButton(uiFactory.CreateApplicationButton(browserInfo));
|
||||||
|
taskbar.AddButton(uiFactory.CreateApplicationButton(browserInfo));
|
||||||
|
taskbar.AddButton(uiFactory.CreateApplicationButton(browserInfo));
|
||||||
|
taskbar.AddButton(uiFactory.CreateApplicationButton(browserInfo));
|
||||||
|
taskbar.SetPosition(500, 500);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void FinishInitialization()
|
private void FinishInitialization()
|
||||||
|
|
|
@ -4,15 +4,20 @@
|
||||||
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
|
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
|
||||||
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
|
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
|
||||||
xmlns:local="clr-namespace:SafeExamBrowser.UserInterface.Controls"
|
xmlns:local="clr-namespace:SafeExamBrowser.UserInterface.Controls"
|
||||||
|
xmlns:s="clr-namespace:System;assembly=mscorlib"
|
||||||
mc:Ignorable="d"
|
mc:Ignorable="d"
|
||||||
d:DesignHeight="40" d:DesignWidth="50">
|
d:DesignHeight="40" d:DesignWidth="50">
|
||||||
<Grid>
|
<Grid>
|
||||||
<Popup x:Name="InstancePopup" IsOpen="False" Placement="Top" PlacementTarget="{Binding ElementName=Button}" AllowsTransparency="True">
|
<Popup x:Name="InstancePopup" IsOpen="False" Placement="Top" PlacementTarget="{Binding ElementName=Button}" AllowsTransparency="True">
|
||||||
<StackPanel x:Name="InstanceStackPanel">
|
<ScrollViewer x:Name="InstanceScrollViewer" VerticalScrollBarVisibility="Auto">
|
||||||
<StackPanel.Background>
|
<ScrollViewer.Background>
|
||||||
<SolidColorBrush Color="Black" Opacity="0.8"/>
|
<SolidColorBrush Color="Black" Opacity="0.8"/>
|
||||||
</StackPanel.Background>
|
</ScrollViewer.Background>
|
||||||
</StackPanel>
|
<ScrollViewer.Resources>
|
||||||
|
<s:Double x:Key="{x:Static SystemParameters.VerticalScrollBarWidthKey}">5</s:Double>
|
||||||
|
</ScrollViewer.Resources>
|
||||||
|
<StackPanel x:Name="InstanceStackPanel" />
|
||||||
|
</ScrollViewer>
|
||||||
</Popup>
|
</Popup>
|
||||||
<Button x:Name="Button" BorderThickness="0" Click="Button_Click" Width="50">
|
<Button x:Name="Button" BorderThickness="0" Click="Button_Click" Width="50">
|
||||||
<Button.Template>
|
<Button.Template>
|
||||||
|
|
|
@ -8,6 +8,7 @@
|
||||||
|
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
using System.Windows;
|
using System.Windows;
|
||||||
using System.Windows.Controls;
|
using System.Windows.Controls;
|
||||||
using SafeExamBrowser.Contracts.Configuration;
|
using SafeExamBrowser.Contracts.Configuration;
|
||||||
|
@ -38,11 +39,6 @@ namespace SafeExamBrowser.UserInterface.Controls
|
||||||
instances.Add(instance);
|
instances.Add(instance);
|
||||||
instanceButton.Click += (id) => OnClick?.Invoke(id);
|
instanceButton.Click += (id) => OnClick?.Invoke(id);
|
||||||
InstanceStackPanel.Children.Add(instanceButton);
|
InstanceStackPanel.Children.Add(instanceButton);
|
||||||
|
|
||||||
if (instances.Count > 1)
|
|
||||||
{
|
|
||||||
InstancePopup.IsOpen = true;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void UnregisterInstance(Guid id)
|
public void UnregisterInstance(Guid id)
|
||||||
|
@ -57,13 +53,20 @@ namespace SafeExamBrowser.UserInterface.Controls
|
||||||
Button.Content = ApplicationIconResourceLoader.Load(info.IconResource);
|
Button.Content = ApplicationIconResourceLoader.Load(info.IconResource);
|
||||||
|
|
||||||
InstancePopup.MouseLeave += (o, args) => InstancePopup.IsOpen = false;
|
InstancePopup.MouseLeave += (o, args) => InstancePopup.IsOpen = false;
|
||||||
|
InstanceStackPanel.SizeChanged += (o, args) =>
|
||||||
|
{
|
||||||
|
if (instances.Count > 9)
|
||||||
|
{
|
||||||
|
InstanceScrollViewer.MaxHeight = InstanceScrollViewer.ActualHeight;
|
||||||
|
}
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
private void Button_Click(object sender, RoutedEventArgs e)
|
private void Button_Click(object sender, RoutedEventArgs e)
|
||||||
{
|
{
|
||||||
if (instances.Count <= 1)
|
if (instances.Count <= 1)
|
||||||
{
|
{
|
||||||
OnClick?.Invoke();
|
OnClick?.Invoke(instances.FirstOrDefault()?.Id);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
|
|
@ -39,7 +39,7 @@ namespace SafeExamBrowser.UserInterface.Controls
|
||||||
panel.Children.Add(ApplicationIconResourceLoader.Load(info.IconResource));
|
panel.Children.Add(ApplicationIconResourceLoader.Load(info.IconResource));
|
||||||
panel.Children.Add(new TextBlock { Text = instance.Name, Foreground = Brushes.White, Padding = new Thickness(5, 0, 5, 0) });
|
panel.Children.Add(new TextBlock { Text = instance.Name, Foreground = Brushes.White, Padding = new Thickness(5, 0, 5, 0) });
|
||||||
|
|
||||||
Button.ToolTip = info.Tooltip;
|
Button.ToolTip = $"{instance.Name} - {info.Tooltip}";
|
||||||
Button.Content = panel;
|
Button.Content = panel;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -4,6 +4,7 @@
|
||||||
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
|
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
|
||||||
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
|
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
|
||||||
xmlns:local="clr-namespace:SafeExamBrowser.UserInterface.Controls"
|
xmlns:local="clr-namespace:SafeExamBrowser.UserInterface.Controls"
|
||||||
|
xmlns:s="clr-namespace:System;assembly=mscorlib"
|
||||||
mc:Ignorable="d"
|
mc:Ignorable="d"
|
||||||
Title="Taskbar" Height="40" Width="750" WindowStyle="None" AllowsTransparency="True" Topmost="True" Icon="./Images/Icon.ico">
|
Title="Taskbar" Height="40" Width="750" WindowStyle="None" AllowsTransparency="True" Topmost="True" Icon="./Images/Icon.ico">
|
||||||
<Window.Background>
|
<Window.Background>
|
||||||
|
@ -16,7 +17,12 @@
|
||||||
<ColumnDefinition Width="75" />
|
<ColumnDefinition Width="75" />
|
||||||
<ColumnDefinition Width="40" />
|
<ColumnDefinition Width="40" />
|
||||||
</Grid.ColumnDefinitions>
|
</Grid.ColumnDefinitions>
|
||||||
<StackPanel x:Name="ApplicationAreaStackPanel" Orientation="Horizontal" />
|
<ScrollViewer Grid.Column="0" x:Name="ApplicationScrollViewer" VerticalScrollBarVisibility="Disabled" HorizontalScrollBarVisibility="Auto" PreviewMouseWheel="ApplicationScrollViewer_PreviewMouseWheel">
|
||||||
|
<ScrollViewer.Resources>
|
||||||
|
<s:Double x:Key="{x:Static SystemParameters.HorizontalScrollBarHeightKey}">5</s:Double>
|
||||||
|
</ScrollViewer.Resources>
|
||||||
|
<StackPanel x:Name="ApplicationStackPanel" Orientation="Horizontal" />
|
||||||
|
</ScrollViewer>
|
||||||
<local:DateTimeControl Grid.Column="2" />
|
<local:DateTimeControl Grid.Column="2" />
|
||||||
</Grid>
|
</Grid>
|
||||||
</Window>
|
</Window>
|
||||||
|
|
|
@ -22,7 +22,7 @@ namespace SafeExamBrowser.UserInterface
|
||||||
{
|
{
|
||||||
if (button is UIElement)
|
if (button is UIElement)
|
||||||
{
|
{
|
||||||
ApplicationAreaStackPanel.Children.Add(button as UIElement);
|
ApplicationStackPanel.Children.Add(button as UIElement);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -37,5 +37,36 @@ namespace SafeExamBrowser.UserInterface
|
||||||
Width = width;
|
Width = width;
|
||||||
Height = height;
|
Height = height;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void ApplicationScrollViewer_PreviewMouseWheel(object sender, System.Windows.Input.MouseWheelEventArgs e)
|
||||||
|
{
|
||||||
|
var scrollAmount = 20;
|
||||||
|
|
||||||
|
if (ApplicationScrollViewer.IsMouseOver)
|
||||||
|
{
|
||||||
|
if (e.Delta < 0)
|
||||||
|
{
|
||||||
|
if (ApplicationScrollViewer.HorizontalOffset + scrollAmount > 0)
|
||||||
|
{
|
||||||
|
ApplicationScrollViewer.ScrollToHorizontalOffset(ApplicationScrollViewer.HorizontalOffset + scrollAmount);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ApplicationScrollViewer.ScrollToLeftEnd();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (ApplicationScrollViewer.ExtentWidth > ApplicationScrollViewer.HorizontalOffset - scrollAmount)
|
||||||
|
{
|
||||||
|
ApplicationScrollViewer.ScrollToHorizontalOffset(ApplicationScrollViewer.HorizontalOffset - scrollAmount);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ApplicationScrollViewer.ScrollToRightEnd();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -62,25 +62,6 @@ namespace SafeExamBrowser
|
||||||
base.OnExit(e);
|
base.OnExit(e);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void InitializeApplication()
|
|
||||||
{
|
|
||||||
instances.BuildObjectGraph();
|
|
||||||
|
|
||||||
var success = instances.StartupController.TryInitializeApplication();
|
|
||||||
|
|
||||||
if (success)
|
|
||||||
{
|
|
||||||
MainWindow = instances.Taskbar;
|
|
||||||
MainWindow.Show();
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
Shutdown();
|
|
||||||
}
|
|
||||||
|
|
||||||
instances.SplashScreen?.Dispatcher.InvokeAsync(instances.SplashScreen.Close);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void ShowSplashScreen()
|
private void ShowSplashScreen()
|
||||||
{
|
{
|
||||||
instances.BuildModulesRequiredBySplashScreen();
|
instances.BuildModulesRequiredBySplashScreen();
|
||||||
|
@ -104,5 +85,24 @@ namespace SafeExamBrowser
|
||||||
|
|
||||||
splashReadyEvent.WaitOne();
|
splashReadyEvent.WaitOne();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void InitializeApplication()
|
||||||
|
{
|
||||||
|
instances.BuildObjectGraph();
|
||||||
|
|
||||||
|
var success = instances.StartupController.TryInitializeApplication();
|
||||||
|
|
||||||
|
if (success)
|
||||||
|
{
|
||||||
|
MainWindow = instances.Taskbar;
|
||||||
|
MainWindow.Show();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Shutdown();
|
||||||
|
}
|
||||||
|
|
||||||
|
instances.SplashScreen?.Dispatcher.InvokeAsync(instances.SplashScreen.Close);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue