Windows 8 metro应用程序:动态设置按钮样式.C#和Xaml

本文关键字:样式 按钮 Xaml 设置 动态 metro 应用程序 Windows | 更新日期: 2023-09-27 18:21:17

我有一个带有Gridview的xaml页面,它有一个按钮。我使用的是分组的Item页面。按钮是根据返回的数据集生成的。10条记录将显示10个按钮。

        <GridView.ItemTemplate>
                        <DataTemplate>
                            <Grid HorizontalAlignment="Left" Width="Auto" Height="Auto"  >                      
                                <Button  Click="ItemView_ItemClick">
                                        <StackPanel Margin="5" >
                                        <TextBlock Tag="cntCustName" Style="{ThemeResource CntNormalTextBlockStyle}" Text="{Binding CUSTOMERNAME }"/>
                                        <TextBlock Tag="cntCatCode" Style="{ThemeResource CntLrgTextBlockStyle}" Text="{Binding CATEGORYCODE}"/>
                                        <TextBlock Tag="cntDay" Style="{ThemeResource CntNormalTextBlockStyle}" Text="{Binding DAY}"/>                               
                                    </StackPanel>
                                </Button>
                            </Grid>
                        </DataTemplate>
                    </GridView.ItemTemplate>

我在foreach循环中获取数据。我希望能够指定按钮的样式根据我的一些标准动态地。

        foreach (ContactData ContactData in _openContatcs)
                    {
                        if (ContactData.CFLAG)
                        {
                            //this is an example
                            Application.Current.Resources["contactSquare"] = ampStyle;
                        }
                        group.Items.Add(ContactData);
                    }

        Styles are defined like this in a folder: Assests/Resources/BaseAPStyles.xaml
        <Style x:Name="contactSquare" TargetType="Button">
                <Setter Property="BorderBrush" Value="Transparent"/>
                <Setter Property="BorderThickness" Value="0"/>
                <Setter Property="Height" Value="160"/>
                <Setter Property="HorizontalAlignment" Value="Left"/>
                <Setter Property="Margin" Value="5"/>
                <Setter Property="VerticalAlignment" Value="Top"/>
                <Setter Property="Width" Value="160"/>
                <Setter Property="Template">
                    <Setter.Value>
                        <ControlTemplate TargetType="Button">
                            <Grid Background="#ffffc600">
                                <ContentPresenter>
                                </ContentPresenter>
                            </Grid>
                        </ControlTemplate>
                    </Setter.Value>
                </Setter>
            </Style>

我的纽扣没有显示样式。我怎样才能做到这一点?

Windows 8 metro应用程序:动态设置按钮样式.C#和Xaml

使用x:key="contactSqaure"在应用程序资源中查找样式。

然后,访问要设置样式的按钮,并将样式分配给按钮,如下所示。

yourButton.Style = Application.Resources.Current["contactSqaure"] as Style;

您也可以在C#中定义样式,或者编辑按钮的依赖属性。

yourButton.Height = 160;
yourButton.VerticalAlignment = VerticalAlignment.Center;

您可以在加载数据模板时访问该按钮。

<DataTemplate>
    <Button Loaded="Button_Loaded" .../>
....
void Button_Loaded(object sender, RoutedEventArgs args)
{
    (sender as Button).Style = yourStyle;
}