在我的 C#/WPF/.NET 4.5 应用程序中,我有按以下方式实现的带有图像的按钮:
<Button Style="{StaticResource BigButton}">
<StackPanel>
<Image Source="Images/Buttons/bt_big_save.png" />
<TextBlock>save</TextBlock>
</StackPanel>
</Button>
我有一个资源字典UIStyles.xaml,我在其中声明了以下内容:
<Style TargetType="Button" x:Key="BigButton">
<Setter Property="Cursor" Value="Hand" />
<Setter Property="Height" Value="80" />
<Setter Property="Width" Value="80" />
<Setter Property="Foreground" Value="White" />
<Setter Property="FontWeight" Value="Bold" />
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="Button">
<Border x:Name="border"
CornerRadius="5"
Background="#FF415360">
<ContentPresenter x:Name="ButtonContentPresenter"
VerticalAlignment="Center"
HorizontalAlignment="Center">
<ContentPresenter.Resources>
<Style TargetType="TextBlock">
<Setter Property="TextAlignment" Value="Center" />
</Style>
<Style TargetType="Image">
<Setter Property="Width" Value="10" />
<Setter Property="Margin" Value="10" />
</Style>
</ContentPresenter.Resources>
</ContentPresenter>
</Border>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
光标、高度、边框等属性工作正常,但我无法设置TextBlock
和Image
.
具体来说,需要如下所示:
最终看起来像这样(忽略色差):
我之前看到过类似的问题,但解决方案使用了不同的方法(我不想创建自定义用户控件,除了这个之外,我的所有需求都包含在当前代码中,并且重写会很麻烦)。我只需要修复我Style
的,以便TextBlock
居中,Image
居中并变小。
如何重新编写Style
以更正按钮的外观?