Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/.net/21.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# 如何使按钮的透明部分在WPF中可单击?_C#_.net_Wpf - Fatal编程技术网

C# 如何使按钮的透明部分在WPF中可单击?

C# 如何使按钮的透明部分在WPF中可单击?,c#,.net,wpf,C#,.net,Wpf,我在WPF中有一系列透明背景的toolstrip按钮。当用户将鼠标移到按钮的外部时,什么也不会发生,因为按钮的那一部分是透明的。一旦用户将鼠标移到按钮的一个不透明区域上,“悬停”行为将更改边框和背景颜色。背景不再是透明的,因此悬停行为将持续一个比以前大得多的区域。我希望按钮的透明区域的行为就像按钮在那里是不透明的一样 也就是说,现在我有了这样一种行为,即尽管鼠标明显位于按钮区域内,但按钮未被选中: 我试图让按钮像这样被选中,即使用户之前没有在按钮的前景“白色”部分上鼠标: 我试着在按钮本身上

我在WPF中有一系列透明背景的toolstrip按钮。当用户将鼠标移到按钮的外部时,什么也不会发生,因为按钮的那一部分是透明的。一旦用户将鼠标移到按钮的一个不透明区域上,“悬停”行为将更改边框和背景颜色。背景不再是透明的,因此悬停行为将持续一个比以前大得多的区域。我希望按钮的透明区域的行为就像按钮在那里是不透明的一样

也就是说,现在我有了这样一种行为,即尽管鼠标明显位于按钮区域内,但按钮未被选中:

我试图让按钮像这样被选中,即使用户之前没有在按钮的前景“白色”部分上鼠标:

我试着在按钮本身上设置
ishitestvisible
,但似乎没有任何区别

有没有办法让WPF考虑按钮的透明区域有意义?

XAML当前看起来像这样:

<Button Style="{StaticResource MainToolstripButtonStyle}" Margin="5,0,0,0"
ToolTip="{StaticResource OpenButtonText}"
AutomationProperties.Name="{StaticResource OpenButtonText}"
Command="{StaticResource Open}"
Content="{StaticResource OpenIcon}" />

<Style x:Key="MainToolstripButtonStyle" TargetType="Button">
    <Setter Property="Width" Value="24" />
    <Setter Property="Height" Value="24" />
    <Setter Property="Background" Value="{x:Null}" />
    <Setter Property="Foreground" Value="White" />
    <Setter Property="Padding" Value="0" />
    <!-- If users want to use keyboard navigation, they use the menu instead. -->
    <Setter Property="IsTabStop" Value="False" />
    <Setter Property="Focusable" Value="False"/>
    <Setter Property="Template">
        <Setter.Value>
            <ControlTemplate TargetType="{x:Type Button}">
                <Border Name="Border"
              BorderThickness="1"
              BorderBrush="{x:Null}">
                    <ContentPresenter HorizontalAlignment="Center"
                          VerticalAlignment="Center" 
                          RecognizesAccessKey="True" />
                </Border>
                <ControlTemplate.Triggers>
                    <!-- Low contrast triggers for selection / focus / enabled: -->
                    <MultiDataTrigger>
                        <MultiDataTrigger.Conditions>
                            <Condition Binding="{Binding Source={x:Static vvm:SystemParametersBindingTarget.Instance}, Path=HighContrast}" Value="False" />
                            <Condition Binding="{Binding RelativeSource={RelativeSource Self}, Path=IsMouseOver}" Value="True" />
                            <Condition Binding="{Binding RelativeSource={RelativeSource Self}, Path=IsEnabled}" Value="True" />
                        </MultiDataTrigger.Conditions>
                        <Setter TargetName="Border"
                  Property="Background"
                  Value="{StaticResource HotToolbarButtonBrush}" />
                        <Setter TargetName="Border"
                  Property="BorderBrush"
                  Value="{StaticResource HotToolbarButtonBorderBrush}" />
                    </MultiDataTrigger>

                    <MultiDataTrigger>
                        <MultiDataTrigger.Conditions>
                            <Condition Binding="{Binding Source={x:Static vvm:SystemParametersBindingTarget.Instance}, Path=HighContrast}" Value="False" />
                            <Condition Binding="{Binding RelativeSource={RelativeSource Self}, Path=IsEnabled}" Value="False" />
                        </MultiDataTrigger.Conditions>
                        <Setter Property="Foreground"
                  Value="{StaticResource DisabledToolbarButtonBrush}" />
                    </MultiDataTrigger>

                    <!-- High contrast triggers omitted -->
                </ControlTemplate.Triggers>
            </ControlTemplate>
        </Setter.Value>
    </Setter>
</Style>  

更换

<Setter Property="Background" Value="{x:Null}" />


并使用ControlTemplate中的Background属性:

<ControlTemplate TargetType="{x:Type Button}">
    <Border Name="Border" Background="{TemplateBinding Background}" ...>
        ...
    </Border>
</ControlTemplate>

...
更换

<Setter Property="Background" Value="{x:Null}" />


并使用ControlTemplate中的Background属性:

<ControlTemplate TargetType="{x:Type Button}">
    <Border Name="Border" Background="{TemplateBinding Background}" ...>
        ...
    </Border>
</ControlTemplate>

...

我试过了。没有任何区别。(编辑后:我没有更改ControlTemplate。将给它一个快照…)使用TemplateBinding位。谢谢(你可以在4分钟内接受答案……)我试过了。没有任何区别。(编辑后:我没有更改ControlTemplate。将给它一个快照…)使用TemplateBinding位。谢谢(您可以在4分钟内接受答案……)“这是对可访问性最佳实践的公然违反@heltonbiker:如果你能给我看一个能让键盘焦点放在工具栏上的应用程序,我会非常乐意尝试模仿这种行为。不幸的是,我没有允许用户这样做的示例应用程序。通过按
Alt
和其他两个字母来选择指定的操作,toolstrip所做的一切都同样可以访问。”“这公然违反了可访问性最佳实践@heltonbiker:如果你能给我看一个能让键盘焦点放在工具栏上的应用程序,我会非常乐意尝试模仿这种行为。不幸的是,我没有允许用户这样做的示例应用程序。通过按
Alt
和其他两个字母选择指定的操作,toolstrip所做的一切都可以访问。