Abstracted type RECT used by native Windows API.
This commit is contained in:
parent
c9a53397a4
commit
32980f9f97
14 changed files with 101 additions and 28 deletions
20
SafeExamBrowser.Configuration/Bounds.cs
Normal file
20
SafeExamBrowser.Configuration/Bounds.cs
Normal file
|
@ -0,0 +1,20 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2017 ETH Zürich, Educational Development and Technology (LET)
|
||||||
|
*
|
||||||
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
||||||
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
||||||
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
||||||
|
*/
|
||||||
|
|
||||||
|
using SafeExamBrowser.Contracts.WindowsApi;
|
||||||
|
|
||||||
|
namespace SafeExamBrowser.Configuration
|
||||||
|
{
|
||||||
|
internal class Bounds : IBounds
|
||||||
|
{
|
||||||
|
public int Left { get; set; }
|
||||||
|
public int Top { get; set; }
|
||||||
|
public int Right { get; set; }
|
||||||
|
public int Bottom { get; set; }
|
||||||
|
}
|
||||||
|
}
|
|
@ -60,6 +60,7 @@
|
||||||
<Reference Include="System.Xml" />
|
<Reference Include="System.Xml" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
|
<Compile Include="Bounds.cs" />
|
||||||
<Compile Include="Settings\BrowserSettings.cs" />
|
<Compile Include="Settings\BrowserSettings.cs" />
|
||||||
<Compile Include="Settings\SettingsImpl.cs" />
|
<Compile Include="Settings\SettingsImpl.cs" />
|
||||||
<Compile Include="WorkingArea.cs" />
|
<Compile Include="WorkingArea.cs" />
|
||||||
|
|
|
@ -11,7 +11,6 @@ using SafeExamBrowser.Contracts.Configuration;
|
||||||
using SafeExamBrowser.Contracts.Logging;
|
using SafeExamBrowser.Contracts.Logging;
|
||||||
using SafeExamBrowser.Contracts.UserInterface;
|
using SafeExamBrowser.Contracts.UserInterface;
|
||||||
using SafeExamBrowser.Contracts.WindowsApi;
|
using SafeExamBrowser.Contracts.WindowsApi;
|
||||||
using SafeExamBrowser.Contracts.WindowsApi.Types;
|
|
||||||
|
|
||||||
namespace SafeExamBrowser.Configuration
|
namespace SafeExamBrowser.Configuration
|
||||||
{
|
{
|
||||||
|
@ -19,7 +18,7 @@ namespace SafeExamBrowser.Configuration
|
||||||
{
|
{
|
||||||
private ILogger logger;
|
private ILogger logger;
|
||||||
private INativeMethods nativeMethods;
|
private INativeMethods nativeMethods;
|
||||||
private RECT? originalWorkingArea;
|
private IBounds originalWorkingArea;
|
||||||
|
|
||||||
public WorkingArea(ILogger logger, INativeMethods nativeMethods)
|
public WorkingArea(ILogger logger, INativeMethods nativeMethods)
|
||||||
{
|
{
|
||||||
|
@ -31,9 +30,9 @@ namespace SafeExamBrowser.Configuration
|
||||||
{
|
{
|
||||||
originalWorkingArea = nativeMethods.GetWorkingArea();
|
originalWorkingArea = nativeMethods.GetWorkingArea();
|
||||||
|
|
||||||
LogWorkingArea("Saved original working area", originalWorkingArea.Value);
|
LogWorkingArea("Saved original working area", originalWorkingArea);
|
||||||
|
|
||||||
var area = new RECT
|
var area = new Bounds
|
||||||
{
|
{
|
||||||
Left = 0,
|
Left = 0,
|
||||||
Top = 0,
|
Top = 0,
|
||||||
|
@ -48,14 +47,14 @@ namespace SafeExamBrowser.Configuration
|
||||||
|
|
||||||
public void Reset()
|
public void Reset()
|
||||||
{
|
{
|
||||||
if (originalWorkingArea.HasValue)
|
if (originalWorkingArea != null)
|
||||||
{
|
{
|
||||||
nativeMethods.SetWorkingArea(originalWorkingArea.Value);
|
nativeMethods.SetWorkingArea(originalWorkingArea);
|
||||||
LogWorkingArea("Restored original working area", originalWorkingArea.Value);
|
LogWorkingArea("Restored original working area", originalWorkingArea);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void LogWorkingArea(string message, RECT area)
|
private void LogWorkingArea(string message, IBounds area)
|
||||||
{
|
{
|
||||||
logger.Info($"{message}: Left = {area.Left}, Top = {area.Top}, Right = {area.Right}, Bottom = {area.Bottom}.");
|
logger.Info($"{message}: Left = {area.Left}, Top = {area.Top}, Right = {area.Right}, Bottom = {area.Bottom}.");
|
||||||
}
|
}
|
||||||
|
|
|
@ -98,8 +98,8 @@
|
||||||
<Compile Include="UserInterface\IWindow.cs" />
|
<Compile Include="UserInterface\IWindow.cs" />
|
||||||
<Compile Include="UserInterface\MessageBoxAction.cs" />
|
<Compile Include="UserInterface\MessageBoxAction.cs" />
|
||||||
<Compile Include="UserInterface\MessageBoxIcon.cs" />
|
<Compile Include="UserInterface\MessageBoxIcon.cs" />
|
||||||
|
<Compile Include="WindowsApi\IBounds.cs" />
|
||||||
<Compile Include="WindowsApi\INativeMethods.cs" />
|
<Compile Include="WindowsApi\INativeMethods.cs" />
|
||||||
<Compile Include="WindowsApi\Types\RECT.cs" />
|
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" />
|
<Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" />
|
||||||
</Project>
|
</Project>
|
18
SafeExamBrowser.Contracts/WindowsApi/IBounds.cs
Normal file
18
SafeExamBrowser.Contracts/WindowsApi/IBounds.cs
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2017 ETH Zürich, Educational Development and Technology (LET)
|
||||||
|
*
|
||||||
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
||||||
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
||||||
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace SafeExamBrowser.Contracts.WindowsApi
|
||||||
|
{
|
||||||
|
public interface IBounds
|
||||||
|
{
|
||||||
|
int Left { get; }
|
||||||
|
int Top { get; }
|
||||||
|
int Right { get; }
|
||||||
|
int Bottom { get; }
|
||||||
|
}
|
||||||
|
}
|
|
@ -9,7 +9,6 @@
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using SafeExamBrowser.Contracts.Monitoring;
|
using SafeExamBrowser.Contracts.Monitoring;
|
||||||
using SafeExamBrowser.Contracts.WindowsApi.Types;
|
|
||||||
|
|
||||||
namespace SafeExamBrowser.Contracts.WindowsApi
|
namespace SafeExamBrowser.Contracts.WindowsApi
|
||||||
{
|
{
|
||||||
|
@ -52,7 +51,7 @@ namespace SafeExamBrowser.Contracts.WindowsApi
|
||||||
/// <exception cref="System.ComponentModel.Win32Exception">
|
/// <exception cref="System.ComponentModel.Win32Exception">
|
||||||
/// If the working area could not be retrieved.
|
/// If the working area could not be retrieved.
|
||||||
/// </exception>
|
/// </exception>
|
||||||
RECT GetWorkingArea();
|
IBounds GetWorkingArea();
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Hides the given window. Returns <c>true</c> if successful, otherwise <c>false</c>.
|
/// Hides the given window. Returns <c>true</c> if successful, otherwise <c>false</c>.
|
||||||
|
@ -105,7 +104,7 @@ namespace SafeExamBrowser.Contracts.WindowsApi
|
||||||
/// <exception cref="System.ComponentModel.Win32Exception">
|
/// <exception cref="System.ComponentModel.Win32Exception">
|
||||||
/// If the working area could not be set.
|
/// If the working area could not be set.
|
||||||
/// </exception>
|
/// </exception>
|
||||||
void SetWorkingArea(RECT bounds);
|
void SetWorkingArea(IBounds bounds);
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Unregisters the system hook for the given keyboard interceptor.
|
/// Unregisters the system hook for the given keyboard interceptor.
|
||||||
|
|
|
@ -10,6 +10,7 @@ using System;
|
||||||
using System.Runtime.InteropServices;
|
using System.Runtime.InteropServices;
|
||||||
using SafeExamBrowser.Contracts.Monitoring;
|
using SafeExamBrowser.Contracts.Monitoring;
|
||||||
using SafeExamBrowser.WindowsApi.Constants;
|
using SafeExamBrowser.WindowsApi.Constants;
|
||||||
|
using SafeExamBrowser.WindowsApi.Types;
|
||||||
|
|
||||||
namespace SafeExamBrowser.WindowsApi.Monitoring
|
namespace SafeExamBrowser.WindowsApi.Monitoring
|
||||||
{
|
{
|
||||||
|
|
|
@ -15,9 +15,9 @@ using System.Runtime.InteropServices;
|
||||||
using System.Text;
|
using System.Text;
|
||||||
using SafeExamBrowser.Contracts.Monitoring;
|
using SafeExamBrowser.Contracts.Monitoring;
|
||||||
using SafeExamBrowser.Contracts.WindowsApi;
|
using SafeExamBrowser.Contracts.WindowsApi;
|
||||||
using SafeExamBrowser.Contracts.WindowsApi.Types;
|
|
||||||
using SafeExamBrowser.WindowsApi.Constants;
|
using SafeExamBrowser.WindowsApi.Constants;
|
||||||
using SafeExamBrowser.WindowsApi.Monitoring;
|
using SafeExamBrowser.WindowsApi.Monitoring;
|
||||||
|
using SafeExamBrowser.WindowsApi.Types;
|
||||||
|
|
||||||
namespace SafeExamBrowser.WindowsApi
|
namespace SafeExamBrowser.WindowsApi
|
||||||
{
|
{
|
||||||
|
@ -99,7 +99,7 @@ namespace SafeExamBrowser.WindowsApi
|
||||||
return string.Empty;
|
return string.Empty;
|
||||||
}
|
}
|
||||||
|
|
||||||
public RECT GetWorkingArea()
|
public IBounds GetWorkingArea()
|
||||||
{
|
{
|
||||||
var workingArea = new RECT();
|
var workingArea = new RECT();
|
||||||
var success = User32.SystemParametersInfo(SPI.GETWORKAREA, 0, ref workingArea, SPIF.NONE);
|
var success = User32.SystemParametersInfo(SPI.GETWORKAREA, 0, ref workingArea, SPIF.NONE);
|
||||||
|
@ -109,7 +109,7 @@ namespace SafeExamBrowser.WindowsApi
|
||||||
throw new Win32Exception(Marshal.GetLastWin32Error());
|
throw new Win32Exception(Marshal.GetLastWin32Error());
|
||||||
}
|
}
|
||||||
|
|
||||||
return workingArea;
|
return workingArea.ToBounds();
|
||||||
}
|
}
|
||||||
|
|
||||||
public bool HideWindow(IntPtr window)
|
public bool HideWindow(IntPtr window)
|
||||||
|
@ -194,9 +194,10 @@ namespace SafeExamBrowser.WindowsApi
|
||||||
User32.SendMessage(window, Constant.WM_SYSCOMMAND, (IntPtr) SystemCommand.CLOSE, IntPtr.Zero);
|
User32.SendMessage(window, Constant.WM_SYSCOMMAND, (IntPtr) SystemCommand.CLOSE, IntPtr.Zero);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void SetWorkingArea(RECT bounds)
|
public void SetWorkingArea(IBounds bounds)
|
||||||
{
|
{
|
||||||
var success = User32.SystemParametersInfo(SPI.SETWORKAREA, 0, ref bounds, SPIF.UPDATEANDCHANGE);
|
var workingArea = new RECT { Left = bounds.Left, Top = bounds.Top, Right = bounds.Right, Bottom = bounds.Bottom };
|
||||||
|
var success = User32.SystemParametersInfo(SPI.SETWORKAREA, 0, ref workingArea, SPIF.UPDATEANDCHANGE);
|
||||||
|
|
||||||
if (!success)
|
if (!success)
|
||||||
{
|
{
|
||||||
|
|
|
@ -60,8 +60,9 @@
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<Compile Include="Constants\Constant.cs" />
|
<Compile Include="Constants\Constant.cs" />
|
||||||
<Compile Include="Constants\HookType.cs" />
|
<Compile Include="Constants\HookType.cs" />
|
||||||
<Compile Include="Constants\KBDLLHOOKSTRUCT.cs" />
|
<Compile Include="Types\Bounds.cs" />
|
||||||
<Compile Include="Constants\KBDLLHOOKSTRUCTFlags.cs" />
|
<Compile Include="Types\KBDLLHOOKSTRUCT.cs" />
|
||||||
|
<Compile Include="Types\KBDLLHOOKSTRUCTFlags.cs" />
|
||||||
<Compile Include="Constants\ShowWindowCommand.cs" />
|
<Compile Include="Constants\ShowWindowCommand.cs" />
|
||||||
<Compile Include="Constants\SystemCommand.cs" />
|
<Compile Include="Constants\SystemCommand.cs" />
|
||||||
<Compile Include="Kernel32.cs" />
|
<Compile Include="Kernel32.cs" />
|
||||||
|
@ -70,6 +71,7 @@
|
||||||
<Compile Include="Properties\AssemblyInfo.cs" />
|
<Compile Include="Properties\AssemblyInfo.cs" />
|
||||||
<Compile Include="Constants\SPI.cs" />
|
<Compile Include="Constants\SPI.cs" />
|
||||||
<Compile Include="Constants\SPIF.cs" />
|
<Compile Include="Constants\SPIF.cs" />
|
||||||
|
<Compile Include="Types\RECT.cs" />
|
||||||
<Compile Include="User32.cs" />
|
<Compile Include="User32.cs" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
|
|
20
SafeExamBrowser.WindowsApi/Types/Bounds.cs
Normal file
20
SafeExamBrowser.WindowsApi/Types/Bounds.cs
Normal file
|
@ -0,0 +1,20 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2017 ETH Zürich, Educational Development and Technology (LET)
|
||||||
|
*
|
||||||
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
||||||
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
||||||
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
||||||
|
*/
|
||||||
|
|
||||||
|
using SafeExamBrowser.Contracts.WindowsApi;
|
||||||
|
|
||||||
|
namespace SafeExamBrowser.WindowsApi.Types
|
||||||
|
{
|
||||||
|
internal class Bounds : IBounds
|
||||||
|
{
|
||||||
|
public int Left { get; set; }
|
||||||
|
public int Top { get; set; }
|
||||||
|
public int Right { get; set; }
|
||||||
|
public int Bottom { get; set; }
|
||||||
|
}
|
||||||
|
}
|
|
@ -9,7 +9,7 @@
|
||||||
using System;
|
using System;
|
||||||
using System.Runtime.InteropServices;
|
using System.Runtime.InteropServices;
|
||||||
|
|
||||||
namespace SafeExamBrowser.WindowsApi.Constants
|
namespace SafeExamBrowser.WindowsApi.Types
|
||||||
{
|
{
|
||||||
/// <remarks>
|
/// <remarks>
|
||||||
/// See http://www.pinvoke.net/default.aspx/Structures/KBDLLHOOKSTRUCT.html.
|
/// See http://www.pinvoke.net/default.aspx/Structures/KBDLLHOOKSTRUCT.html.
|
|
@ -6,7 +6,7 @@
|
||||||
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
namespace SafeExamBrowser.WindowsApi.Constants
|
namespace SafeExamBrowser.WindowsApi.Types
|
||||||
{
|
{
|
||||||
/// <remarks>
|
/// <remarks>
|
||||||
/// See http://www.pinvoke.net/default.aspx/Structures/KBDLLHOOKSTRUCT.html.
|
/// See http://www.pinvoke.net/default.aspx/Structures/KBDLLHOOKSTRUCT.html.
|
|
@ -7,18 +7,30 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
using System.Runtime.InteropServices;
|
using System.Runtime.InteropServices;
|
||||||
|
using SafeExamBrowser.Contracts.WindowsApi;
|
||||||
|
|
||||||
namespace SafeExamBrowser.Contracts.WindowsApi.Types
|
namespace SafeExamBrowser.WindowsApi.Types
|
||||||
{
|
{
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// See https://msdn.microsoft.com/en-us/library/windows/desktop/dd162897(v=vs.85).aspx.
|
/// See https://msdn.microsoft.com/en-us/library/windows/desktop/dd162897(v=vs.85).aspx.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
[StructLayout(LayoutKind.Sequential)]
|
[StructLayout(LayoutKind.Sequential)]
|
||||||
public struct RECT
|
internal struct RECT
|
||||||
{
|
{
|
||||||
public int Left;
|
internal int Left;
|
||||||
public int Top;
|
internal int Top;
|
||||||
public int Right;
|
internal int Right;
|
||||||
public int Bottom;
|
internal int Bottom;
|
||||||
|
|
||||||
|
internal IBounds ToBounds()
|
||||||
|
{
|
||||||
|
return new Bounds
|
||||||
|
{
|
||||||
|
Left = Left,
|
||||||
|
Top = Top,
|
||||||
|
Right = Right,
|
||||||
|
Bottom = Bottom
|
||||||
|
};
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -9,8 +9,8 @@
|
||||||
using System;
|
using System;
|
||||||
using System.Runtime.InteropServices;
|
using System.Runtime.InteropServices;
|
||||||
using System.Text;
|
using System.Text;
|
||||||
using SafeExamBrowser.Contracts.WindowsApi.Types;
|
|
||||||
using SafeExamBrowser.WindowsApi.Constants;
|
using SafeExamBrowser.WindowsApi.Constants;
|
||||||
|
using SafeExamBrowser.WindowsApi.Types;
|
||||||
|
|
||||||
namespace SafeExamBrowser.WindowsApi
|
namespace SafeExamBrowser.WindowsApi
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in a new issue