簡體   English   中英

在 UWP 應用程序中模擬 Keyup 和 keydown 等鍵盤事件

[英]simulate keyboard events like Keyup and keydown in UWP app

如何在 UWP 應用程序中模擬 Keyup 和 keydown 等鍵盤事件。我不想使用手動鍵盤,而是制作了自己的鍵盤,但我現在想在其中添加鍵盤事件。 我在 uwp 中沒有找到任何方法,SendKeys.Send() 方法也不適用於 UWP。

您可以使用輸入注入 該文檔有一個復雜的示例,但它基本上分解為聲明功能和編寫類似以下代碼的內容:

        _inputInjector = InputInjector.TryCreate();
        var input = new InjectedInputKeyboardInfo();
        input.VirtualKey = value;
        input.KeyOptions = InjectedInputKeyOptions.None;
        _inputInjector.InjectKeyboardInput(new[] { input });

其中valueVirtualKey或可以轉換為 one 的char 以下答案中的更多詳細信息。

我不想使用手動鍵盤,但是我已經制作了自己的鍵盤,但是現在我想在其中添加鍵盤事件。 我在uwp中找不到任何方式,SendKeys.Send()方法也不適用於UWP。

根據您的要求,您可以創建自定義事件處理程序,以在自定義用戶控件中模擬鍵盤KeyDownKeyUp事件。 關鍵是何時調用自定義事件處理程序。 我創建了一個簡單的示例,您可以參考。

CustomKeyBoard.xaml

<UserControl
    x:Class="UIKeyBoardTest.CustomKeyBoard"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    xmlns:local="using:UIKeyBoardTest"
    xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
    xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
    xmlns:control ="using:Microsoft.Toolkit.Uwp.UI.Controls"
    mc:Ignorable="d"
    d:DesignHeight="300"
    d:DesignWidth="400">
    <Grid>
        <GridView  VerticalAlignment="Center" HorizontalAlignment="Center" ItemClick="GridView_ItemClick"  IsItemClickEnabled="True">
            <GridView.ItemsPanel>
                <ItemsPanelTemplate>
                    <VariableSizedWrapGrid  MaximumRowsOrColumns="3" Orientation="Horizontal" />
                </ItemsPanelTemplate>
            </GridView.ItemsPanel>
            <GridView.ItemTemplate>
                <DataTemplate>
                    <StackPanel Background="White"
                BorderBrush="Black"
                BorderThickness="1">
                        <TextBlock Text="{Binding }" HorizontalAlignment="Center" TextAlignment="Center" VerticalAlignment="Center" FontSize="40"  Width="55" />
                    </StackPanel>
                </DataTemplate>
            </GridView.ItemTemplate>
            <x:String>1</x:String>
            <x:String>2</x:String>
            <x:String>3</x:String>
            <x:String>4</x:String>
            <x:String>5</x:String>
            <x:String>6</x:String>
            <x:String>7</x:String>
            <x:String>8</x:String>
            <x:String>9</x:String>
        </GridView>
    </Grid>
</UserControl>

CustomKeyBoard.xaml.cs

public sealed partial class CustomKeyBoard : UserControl
{
    public delegate void BoilerLogHandler(string value);

    public event BoilerLogHandler BoilerEventLog;

    public CustomKeyBoard()
    {
        this.InitializeComponent();
    }

    private void GridView_ItemClick(object sender, ItemClickEventArgs e)
    {
        if (BoilerEventLog != null)
        {
            BoilerEventLog(e.ClickedItem.ToString());
        }
    }
}

用法

 <TextBox x:Name="box" PlaceholderText="Please input something" Margin="0,50,0,60" />
<local:CustomKeyBoard
    HorizontalAlignment="Center"
    VerticalAlignment="Center"
    BoilerEventLog="CustomKeyBoard_BoilerEventLog" />

private void CustomKeyBoard_BoilerEventLog(string value)
{
    box.Text = value;
}

在此處輸入圖片說明

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM