打开窗口激活不起作用与菜单中的按钮

本文关键字:按钮 菜单 开窗口 激活 不起作用 | 更新日期: 2023-09-27 17:57:12

我有一个非常奇怪的行为,我希望有人可以帮助我。

我有以下 XAML 布局:

<StackPanel Orientation="Horizontal">
    <Menu>
        <Menu.Items>
            <MenuItem Padding="2,0,2,0">
                <MenuItem.Header>
                    <Button Content="Details"
                            Click="Details_Click" />
                </MenuItem.Header>
            </MenuItem>
        </Menu.Items>
    </Menu>
    <Button Content="Details"
            Click="Details_Click" />
</StackPanel>

请注意,这两个按钮都注册了相同的事件。Details_Click事件如下所示:

private void Details_Click(object sender, RoutedEventArgs e)
{
    var viewer = new DictionaryViewer();
    viewer.ShowActivated = true;
    viewer.Show();
    viewer.Topmost = true;
    viewer.Topmost = false;
    viewer.Activate();
    viewer.Focus();
    e.Handled = true;
    return;
}

现在我遇到了这个问题,即使上面的所有代码,当我按下Menu内的按钮时,窗口也不会显示激活,但在它外面只用.Activate();。(我怎么知道窗口未激活:需要单击2次才能关闭/最小化/最大化它)

为什么我的 XAML 布局会破坏DictionaryViewer();窗口的激活,按钮位于Menu

(据您所知,词典查看器完全是空的,这是一个尚未实现的新窗口)

编辑:

是的,我知道有MenuItem_Click事件可能会使其工作,但我需要/想要菜单中的按钮如何解决此问题?

打开窗口激活不起作用与菜单中的按钮

发生这种情况

的原因是因为菜单项中的按钮在窗口打开后获得焦点。

如果在 MenuItem 中设置按钮的 Focusable 属性,则可以解决此问题。

例如

<StackPanel Orientation="Horizontal">
    <Menu>
        <Menu.Items>
            <MenuItem Padding="2,0,2,0">
                <MenuItem.Header>
                    <Button Content="Details"
                            Click="Details_Click"
                            Focusable="False" />
                </MenuItem.Header>
            </MenuItem>
        </Menu.Items>
    </Menu>
    <Button Content="Details"
            Click="Details_Click" />
</StackPanel>