gpt4 book ai didi

c# - 边框内的按钮

转载 作者:行者123 更新时间:2023-11-30 15:41:11 26 4
gpt4 key购买 nike

我对边框内的按钮有疑问。我希望按钮填充边框内的按钮空间,但按钮位于边框上方而不是边框​​下方。通过这种方式,它隐藏了边界形成的 corder 半径。

这是我的问题的图片:

enter image description here

有人知道如何将按钮放在边框下方吗?

这是我的按钮的 xaml:

<Button Name="filterCustomerBtn" 
Command="{Binding Path=UpdateDepartments}"
Style="{StaticResource defaultButtonStyle}"
Width="200"
Margin="0, 15, 0, 0"
HorizontalAlignment="Center">Filter now</Button>

这里是相关的xaml代码:

<Window.Resources>
<Style x:Key="defaultButtonStyle" TargetType="Button">
<Setter Property="Margin" Value="2"></Setter>
</Style>
</Window.Resources>


<StackPanel Orientation="Vertical" DockPanel.Dock="Top">
<Border Style="{StaticResource MainBorderStyle}" Margin="2" Background="LightBlue">
<StackPanel Orientation="Vertical" VerticalAlignment="Center">
<Button Name="filterCustomerBtn" Command="{Binding Path=UpdateDepartments}" Style="{StaticResource defaultButtonStyle}" Width="200" Margin="0, 15, 0, 0" HorizontalAlignment="Center" Panel.ZIndex="-1">Filter now</Button>
</StackPanel>
</Border>
</StackPanel>

结果图片

enter image description here

最佳答案

由于您的边框有圆角半径,因此在按钮的默认样式上下文中您无能为力,无法将其圆角圆化以使其看起来与边框无缝衔接。我用几个不同的控件(包括按钮)遇到过这个问题。您的问题的解决方案是为按钮创建一个 ControlTemplate。在此模板中,您可以将按钮底角的半径或所有 4 个角的半径设置为边框的匹配角半径。点击here一个创建圆形按钮模板的好例子。下面我试图通过删除悬停动画来简化博客代码。专注于边框部分,因为它们是主要模板。

<Style x:Key="RoundedButton" TargetType="{x:Type Button}">
<Setter Property="Background" Value="{TemplateBinding Background}"/>
<Setter Property="Foreground" Value="{TemplateBinding Foreground}"/>
<Setter Property="BorderThickness" Value="1"/>
<Setter Property="HorizontalContentAlignment" Value="Center"/>
<Setter Property="VerticalContentAlignment" Value="Center"/>
<Setter Property="Padding" Value="0,0,1,1"/>
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="{x:Type Button}">
<Border
CornerRadius="5,5,5,5"
BorderThickness="1,1,1,1"
RenderTransformOrigin="0.5,0.5"
x:Name="border"
BorderBrush="#000000">
<Border.RenderTransform>
<TransformGroup>
<ScaleTransform ScaleX="1" ScaleY="1"/>
<SkewTransform AngleX="0" AngleY="0"/>
<RotateTransform Angle="0"/>
<TranslateTransform X="0" Y="0"/>
</TransformGroup>
</Border.RenderTransform>
<Border
Background="{TemplateBinding Background}"
CornerRadius="5,5,5,5"
x:Name="border1">
<Grid>
<Grid.RowDefinitions>
<RowDefinition Height="0.5*"/>
<RowDefinition Height="0.5*"/>
</Grid.RowDefinitions>
<Border Grid.Row="0" CornerRadius="5,5,0,0">
<Border.Background>
<LinearGradientBrush
EndPoint="0.5,1"
StartPoint="0.5,0">
<GradientStop
Color="#00FFFFFF"
Offset="0"/>
<GradientStop
Color="#7EFFFFFF"
Offset="1"/>
</LinearGradientBrush>
</Border.Background>
</Border>
<ContentPresenter
VerticalAlignment="Center"
Grid.RowSpan="2"
HorizontalAlignment="Center"
x:Name="contentPresenter"/>
</Grid>
</Border>
</Border>
<ControlTemplate.Triggers>
<Trigger Property="IsEnabled" Value="False">
<Setter
Property="Opacity"
TargetName="border1"
Value="0.5"/>
<Setter
Property="Opacity"
TargetName="border"
Value="1"/>
<Setter
Property="Opacity"
TargetName="contentPresenter"
Value="0.5"/>
</Trigger>
<Trigger
Property="IsPressed"
Value="True">
<Setter
Property="RenderTransform"
TargetName="border">
<Setter.Value>
<TransformGroup>
<ScaleTransform
ScaleX="0.9"
ScaleY="0.9"/>
<SkewTransform
AngleX="0"
AngleY="0"/>
<RotateTransform
Angle="0"/>
<TranslateTransform
X="0"
Y="0"/>
</TransformGroup>
</Setter.Value>
</Setter>
</Trigger>
</ControlTemplate.Triggers>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>

另外,这里有一个链接到 MSDN有关此主题的页面。

关于c# - 边框内的按钮,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8645984/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com