当子菜单关闭时,WPF应用程序失去焦点

时间:2016-11-17 12:56:46

标签: c# wpf

我在wpf应用程序中有一个菜单和子菜单,当从子菜单项中删除鼠标指针时,应用程序失去了它的焦点。例如,按钮悬停无法正常工作。但是当我点击应用程序的空白区域时,按钮悬停效果可以正常工作。

预期的行为是,按钮不应该丢失它的风格/动作。

enter image description here

悬停效果:enter image description here

没有悬停效果:enter image description here

控制模板如下

<ControlTemplate x:Key="MenuItemControlTemplate" TargetType="{x:Type MenuItem}">
        <Border x:Name="templateRoot" BorderBrush="{TemplateBinding BorderBrush}" BorderThickness="{TemplateBinding BorderThickness}" Background="{TemplateBinding Background}" SnapsToDevicePixels="True">
            <Grid VerticalAlignment="Center">
                <Grid.ColumnDefinitions>
                    <ColumnDefinition Width="Auto"/>
                    <ColumnDefinition Width="Auto"/>
                </Grid.ColumnDefinitions>
                <ContentPresenter ContentTemplate="{TemplateBinding HeaderTemplate}" Content="{TemplateBinding Header}" Grid.Column="1" ContentStringFormat="{TemplateBinding HeaderStringFormat}" ContentSource="Header" Margin="{TemplateBinding Padding}" RecognizesAccessKey="True" SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}"/>
                <Popup x:Name="PART_Popup" 
                       AllowsTransparency="True"
                       Focusable="True" IsOpen="{Binding IsSubmenuOpen, RelativeSource={RelativeSource TemplatedParent}}" PopupAnimation="{DynamicResource {x:Static SystemParameters.MenuPopupAnimationKey}}" Placement="Bottom">
                    <Border x:Name="SubMenuBorder" BorderBrush="#FF999999" BorderThickness="1" Background="#FFF0F0F0" Padding="2,10,0,0">
                        <ScrollViewer x:Name="SubMenuScrollViewer" Style="{DynamicResource {ComponentResourceKey ResourceId=MenuScrollViewer, TypeInTargetAssembly={x:Type FrameworkElement}}}">
                            <Grid RenderOptions.ClearTypeHint="Enabled">
                                <Canvas HorizontalAlignment="Left" Height="0" VerticalAlignment="Top" Width="0">
                                    <Rectangle x:Name="OpaqueRect" Fill="{Binding Background, ElementName=SubMenuBorder}" Height="{Binding ActualHeight, ElementName=SubMenuBorder}" Width="{Binding ActualWidth, ElementName=SubMenuBorder}"/>
                                </Canvas>
                                <Rectangle Fill="#FFD7D7D7" HorizontalAlignment="Left" Margin="29,2,0,2" Width="1"/>
                                <ItemsPresenter x:Name="ItemsPresenter" KeyboardNavigation.DirectionalNavigation="Cycle" Grid.IsSharedSizeScope="True" SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}" KeyboardNavigation.TabNavigation="Cycle"/>
                            </Grid>
                        </ScrollViewer>
                    </Border>
                </Popup>
            </Grid>
        </Border>
        <ControlTemplate.Triggers>
            <Trigger Property="IsSuspendingPopupAnimation" Value="True">
                <Setter Property="PopupAnimation" TargetName="PART_Popup" Value="None"/>
                <Setter Property="Background" TargetName="templateRoot" Value="#FFFFFF"/>
                <Setter Property="BorderBrush" TargetName="templateRoot" Value="#FFFFFF"/>
            </Trigger>

            <Trigger Property="CanContentScroll" SourceName="SubMenuScrollViewer" Value="False">
                <Setter Property="Canvas.Top" TargetName="OpaqueRect" Value="{Binding VerticalOffset, ElementName=SubMenuScrollViewer}"/>
                <Setter Property="Canvas.Left" TargetName="OpaqueRect" Value="{Binding HorizontalOffset, ElementName=SubMenuScrollViewer}"/>
            </Trigger>

            <Trigger Property="IsHighlighted" Value="True">
                <Setter Property="Background" TargetName="templateRoot" Value="#FF666565"/>
                <Setter Property="BorderBrush" TargetName="templateRoot" Value="#FFE0D3D3"/>
            </Trigger>
            <Trigger Property="IsMouseOver" Value="True" >
                <Setter Property="IsOpen" TargetName="PART_Popup" Value="True"/>
                <Setter Property="Cursor" Value="Hand"/>
            </Trigger>
            <Trigger Property="IsEnabled" Value="False">
                <Setter Property="TextElement.Foreground" TargetName="templateRoot" Value="#FF707070"/>
            </Trigger>
            <Trigger Property="IsMouseOver" Value="False" >
                <Setter Property="Background" TargetName="templateRoot" Value="#FFFFFF"/>
                <Setter Property="BorderBrush" TargetName="templateRoot" Value="#FFDDDDDD"/>
            </Trigger>
        </ControlTemplate.Triggers>
    </ControlTemplate>

1 个答案:

答案 0 :(得分:0)

如果我找对你,你并不是说,应用程序失去焦点(因为它没有,当你点击例如TAB时你可以看到),但只有打开的子菜单和相应的主菜单会对老鼠。

这是打开弹出窗口时WPF应用程序中的标准行为。打开上下文菜单时也是如此。在WinForms应用程序中也是如此。

您也可以在Visual Studio中进行检查。

修改

所以我们有一个app mainmenue

enter image description here

当你点击一个menueitem并在子菜单中移动鼠标(没有按下任何按钮)时你会得到这个

enter image description here

并且在子菜单下方一直向下移动(仍然没有按下按钮,只是移动)

enter image description here

子菜单关闭了吗?如果这是真的,你应该看一下menues定义(也许可以在这里发布),因为这不是标准的menue行为。