0

我在 Expression Blend 4 中创建了一个按钮。我想在运行时动态创建此按钮的实例。

该按钮的代码如下:

    <Button Content="Button" HorizontalAlignment="Left" Height="139" Margin="46,107,0,0" VerticalAlignment="Top" Width="412" Grid.ColumnSpan="2">
        <Button.Background>
            <LinearGradientBrush EndPoint="0.5,1" StartPoint="0.5,0">
                <GradientStop Color="Black"/>
                <GradientStop Color="White" Offset="1"/>
            </LinearGradientBrush>
        </Button.Background>
    </Button>

除了提供代码之外,您还可以在解释您正在做什么时添加注释,以便我可以了解一般原则。

我知道这是一个简单的问题,所以我一直在阅读以下地方:Expression blend & WPF有没有办法“提取”Expression Blend 的 WPF 控件?http://social.msdn.microsoft.com/forums/en-US/wpf/thread/ffa981b8-9bba-43a2-ab5e-8e59bc10fc0d/不幸的是,这些都没有帮助。

4

1 回答 1

1

在您的 WPF 应用程序中,您应该有一个App.xaml文件,您可以在其中添加Styles要在整个 UI 中使用的文件。

例子:

<Application x:Class="WpfApplication8.App"
             xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
             xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
             StartupUri="MainWindow.xaml">
    <Application.Resources>

        <!--The style for all your buttons, setting the background property to your custom brush-->
        <Style TargetType="{x:Type Button}"> <!--Indicate that this style should be applied to Button type-->
            <Setter Property="Background">
                <Setter.Value>
                    <LinearGradientBrush EndPoint="0.5,1" StartPoint="0.5,0">
                        <GradientStop Color="Black"/>
                        <GradientStop Color="White" Offset="1"/>
                    </LinearGradientBrush>
                </Setter.Value>
            </Setter>
        </Style>

    </Application.Resources>
</Application>

或者,如果您不想应用到所有按钮,您可以给您Style的 a Key,这样您就可以应用到 UI 中的某些按钮

<Application x:Class="WpfApplication8.App"
             xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
             xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
             StartupUri="MainWindow.xaml">
    <Application.Resources>

        <!--Add a x:Key value so you can use on certain Buttons not all-->
        <Style x:Key="MyCustomStyle" TargetType="{x:Type Button}"> 
            <Setter Property="Background">
                <Setter.Value>
                    <LinearGradientBrush EndPoint="0.5,1" StartPoint="0.5,0">
                        <GradientStop Color="Black"/>
                        <GradientStop Color="White" Offset="1"/>
                    </LinearGradientBrush>
                </Setter.Value>
            </Setter>
        </Style>

    </Application.Resources>
</Application>

Style在 a 上使用它Button,只需将绑定添加StyleButton

  <Button Style="{StaticResource MyCustomStyle}" />

这将适用Style于这个Button

或者,如果您真的想在后面的代码中执行此操作,只需将Brush您想要的添加到后台

   Button b = new Button
   {
       Background = new LinearGradientBrush(Colors.Black, Colors.White, new Point(0.5, 1), new Point(0.5, 0))
   };

将 xaml 转换为代码非常容易,因为 xaml 使用完全相同的属性名称,例如我在上面发布的代码刷:

new LinearGradientBrush(Colors.Black, Colors.White, new Point(0.5, 1), new Point(0.5, 0)) 

是 ....

Brush(firstColor,secondColor,StartPoint EndPoint)

Xaml 只是访问按钮中的属性,它们在 C# 中都将具有相同的名称。

于 2012-12-24T00:03:39.037 回答