csharpc-sharpdotnetxamlavaloniauicross-platformcross-platform-xamlavaloniaguimulti-platformuser-interfacedotnetcore
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
50 lines
1.8 KiB
50 lines
1.8 KiB
using Avalonia.Metadata;
|
|
|
|
namespace Avalonia.Input
|
|
{
|
|
/// <summary>
|
|
/// Manages focus for the application.
|
|
/// </summary>
|
|
[NotClientImplementable]
|
|
public interface IFocusManager
|
|
{
|
|
/// <summary>
|
|
/// Gets the currently focused <see cref="IInputElement"/>.
|
|
/// </summary>
|
|
IInputElement? Current { get; }
|
|
|
|
/// <summary>
|
|
/// Gets the current focus scope.
|
|
/// </summary>
|
|
IFocusScope? Scope { get; }
|
|
|
|
/// <summary>
|
|
/// Focuses a control.
|
|
/// </summary>
|
|
/// <param name="control">The control to focus.</param>
|
|
/// <param name="method">The method by which focus was changed.</param>
|
|
/// <param name="keyModifiers">Any key modifiers active at the time of focus.</param>
|
|
void Focus(
|
|
IInputElement? control,
|
|
NavigationMethod method = NavigationMethod.Unspecified,
|
|
KeyModifiers keyModifiers = KeyModifiers.None);
|
|
|
|
/// <summary>
|
|
/// Notifies the focus manager of a change in focus scope.
|
|
/// </summary>
|
|
/// <param name="scope">The new focus scope.</param>
|
|
/// <remarks>
|
|
/// This should not be called by client code. It is called by an <see cref="IFocusScope"/>
|
|
/// when it activates, e.g. when a Window is activated.
|
|
/// </remarks>
|
|
void SetFocusScope(IFocusScope scope);
|
|
|
|
/// <summary>
|
|
/// Notifies the focus manager that a focus scope has been removed.
|
|
/// </summary>
|
|
/// <param name="scope">The focus scope to be removed.</param>
|
|
/// This should not be called by client code. It is called by an <see cref="IFocusScope"/>
|
|
/// when it deactivates or closes, e.g. when a Window is closed.
|
|
void RemoveFocusScope(IFocusScope scope);
|
|
}
|
|
}
|
|
|