UWP gridview项目选择样式

时间:2016-02-29 15:52:45

标签: gridview selection win-universal-app

我想更改gridview项的选择样式或颜色。当选择一个项目时,我想要显示更粗的边框或高亮颜色或任何类型的更改。什么是实现这个的最简单的方法

1 个答案:

答案 0 :(得分:0)

请查看此示例:

我的页面是这样的:

<Page x:Class="App3.MainPage"
  xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
  xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
  xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
  xmlns:local="using:App3"
  xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
  mc:Ignorable="d">
<Grid>
    <ListView x:Name="MyList">
        <ListView.ItemTemplate>
            <DataTemplate>
                <Grid x:Name="MyGrid">
                    <TextBlock Text="Test1" />
                </Grid>
            </DataTemplate>
        </ListView.ItemTemplate>
    </ListView>
</Grid>

我填写了我的清单:

 protected override void OnNavigatedTo(NavigationEventArgs e)
    {
        base.OnNavigatedTo(e);
        MyList.SelectionChanged += MyList_SelectionChanged;
        var list = new List<string>();
        list.Add("1");
        list.Add("2");
        MyList.ItemsSource = list;
    }

最后,我获得了所选项目并更改了背景

 private void MyList_SelectionChanged(object sender, SelectionChangedEventArgs e)
    {

       var item= MyList.ContainerFromItem(e.AddedItems.FirstOrDefault());
        var selectedItem = item as ListViewItem;

        if (selectedItem != null)
        {
            var grid = selectedItem.ContentTemplateRoot as Grid;
            grid.Background = new SolidColorBrush(Colors.Yellow);

        }


    }

如果您看到我将ContentTemplateRoot与此属性一起使用,则可以访问我的ItemTemplate的主要容器。

enter image description here

请标记此答案如果它对您有用!