C#更改背景颜色特定行

时间:2013-03-12 08:20:22

标签: c# wpf silverlight xaml

我已经从Grid App(XAML)模板(C#Windows Store)创建了一个新项目。 到目前为止,我在模板中没有更改任何内容,但我想从网格中的特定行更改backgroundcolor。

<!--
    This grid acts as a root panel for the page that defines two rows:
    * Row 0 contains the back button and page title
    * Row 1 contains the rest of the page layout
-->
<Grid Style="{StaticResource LayoutRootStyle}">
    <Grid.RowDefinitions>
        <RowDefinition Height="140"/>
        <RowDefinition Height="*"/>
    </Grid.RowDefinitions>

我想从第0行(包含页面标题)更改backgroundcolor。 有任何想法吗??提前谢谢!

这一行构成:

    <!-- Back button and page title -->
    <Grid>
        <Grid.ColumnDefinitions>
            <ColumnDefinition Width="Auto"/>
            <ColumnDefinition Width="*"/>
        </Grid.ColumnDefinitions>
        <Button x:Name="backButton" Click="GoBack" IsEnabled="{Binding Frame.CanGoBack, ElementName=pageRoot}" Style="{StaticResource BackButtonStyle}"/>
        <TextBlock x:Name="pageTitle" Text="{StaticResource AppName}" Grid.Column="1" IsHitTestVisible="false" Style="{StaticResource PageHeaderTextStyle}"/>
    </Grid>

2 个答案:

答案 0 :(得分:17)

您无法在Grid.Row本身上设置背景颜色,而是在占据此行的任何内容上设置Background属性。

例如

<Grid Style="{StaticResource LayoutRootStyle}">
  <Grid.RowDefinitions>
    <RowDefinition Height="140"/>
    <RowDefinition Height="*"/>
  </Grid.RowDefinitions>
  <Grid Background="Red" Grid.Row="0">
    <TextBlock>Test</TextBlock>
  </Grid>
</Grid>

编辑: 针对Silverlight进行了更新; TextBlock没有Background,因此您必须将控件放在另一个具有背景的Border或grid容器中。代码已更新以反映此情况。

答案 1 :(得分:2)

如何在您需要的地方插入边框

<Grid Style="{StaticResource LayoutRootStyle}">
  <Grid.RowDefinitions>
    <RowDefinition Height="140"/>
    <RowDefinition Height="*"/>
  </Grid.RowDefinitions>
    <Border Background="Red" Grid.ColumnSpan="1"></Border>
    <TextBlock>Test</TextBlock>
    <Border Background="blue" Grid.Row="1" Grid.ColumnSpan="1"></Border>
    <TextBlock Grid.Row="1">Test2</TextBlock>
 </Grid>

请注意,如果包含更多列

,您可以指定列跨度