2017-07-19 14:43:54 +02:00
|
|
|
|
/*
|
2019-01-09 11:25:21 +01:00
|
|
|
|
* Copyright (c) 2019 ETH Zürich, Educational Development and Technology (LET)
|
2017-07-19 14:43:54 +02:00
|
|
|
|
*
|
|
|
|
|
* 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/.
|
|
|
|
|
*/
|
|
|
|
|
|
2017-07-27 11:46:31 +02:00
|
|
|
|
using System;
|
2018-07-06 15:57:38 +02:00
|
|
|
|
using SafeExamBrowser.Contracts.Monitoring.Events;
|
2017-07-27 11:46:31 +02:00
|
|
|
|
|
2017-07-19 14:43:54 +02:00
|
|
|
|
namespace SafeExamBrowser.Contracts.Monitoring
|
|
|
|
|
{
|
2018-03-06 11:38:12 +01:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Monitors the windows associated with the current desktop and provides window-related functionality.
|
|
|
|
|
/// </summary>
|
2017-07-19 14:43:54 +02:00
|
|
|
|
public interface IWindowMonitor
|
|
|
|
|
{
|
2017-07-27 11:46:31 +02:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Event fired when the window monitor observes that the foreground window has changed.
|
|
|
|
|
/// </summary>
|
2017-08-02 08:31:12 +02:00
|
|
|
|
event WindowChangedEventHandler WindowChanged;
|
2017-07-27 11:46:31 +02:00
|
|
|
|
|
2017-07-27 13:57:12 +02:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Forcefully closes the specified window.
|
|
|
|
|
/// </summary>
|
|
|
|
|
void Close(IntPtr window);
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Hides the specified window. Returns <c>true</c> if the window was successfully hidden, otherwise <c>false</c>.
|
|
|
|
|
/// </summary>
|
|
|
|
|
bool Hide(IntPtr window);
|
|
|
|
|
|
2017-07-24 08:56:39 +02:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Starts monitoring application windows by subscribing to specific system events.
|
|
|
|
|
/// If a window is shown which is not supposed to do so, it will be automatically hidden.
|
|
|
|
|
/// </summary>
|
|
|
|
|
void StartMonitoringWindows();
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Stops monitoring windows and deregisters from any subscribed system events.
|
|
|
|
|
/// </summary>
|
|
|
|
|
void StopMonitoringWindows();
|
2017-07-19 14:43:54 +02:00
|
|
|
|
}
|
|
|
|
|
}
|