0

我在中HeaderTemplate定义了以下内容App.xaml

<DataTemplate x:Key="ListViewGroupHeaderTemplate">
    <TextBlock Foreground="Black" Text="Something" />
</DataTemplate>

我在我的ListViewRenderer

listView.ItemTemplate = App.Current.Resources["ListViewItemTemplate"] as Windows.UI.Xaml.DataTemplate;
var gs = new GroupStyle();
gs.HeaderTemplate = App.Current.Resources["ListViewGroupHeaderTemplate"] as Windows.UI.Xaml.DataTemplate;
listView.GroupStyle.Add(gs);

我的来源ListViewCollectionViewSource

CollectionViewSource cvs = new CollectionViewSource();
cvs.IsSourceGrouped = true;

cvs.Source = ((SourceListView)Element).Items;
if (listView.ItemsSource == null)
  listView.ItemsSource = cvs.View;

ItemTemplate效果很好。

这就是我的ListView样子(白色部分是组标题):

在此处输入图像描述

我应该设置什么来使标题工作?

更新

我根据答案修改了我的来源(将分组应用于一个简单的列表):

    CollectionViewSource cvs = new CollectionViewSource();
    cvs.IsSourceGrouped = true;
    var items = ((MyListView)Element).Items;
    var itemsAsOC = items as ObservableCollection<GroupListItem>;
    List<ListItem> list = new List<ListItem>();
    foreach (var item in itemsAsOC)
    {
      list.AddRange(item);
    }
    var group = from item in list group item by item.Value into grp orderby grp.Key select grp;                
    cvs.Source = group;

标头没有任何变化,所以我猜数据源是正确的,但是模板处理中存在一些严重的 Xamarin UWP 错误:

在此处输入图像描述

更新 2:

我在没有 Xamarin 渲染器的情况下对其进行了测试,它显示了标题项。

在此处输入图像描述

但是,当我使用 Xamarin 渲染器时,标题不见了

在此处输入图像描述

您可以下载并实际测试它。

4

2 回答 2

0

基本上我在您的代码中找不到任何明显的问题,这是我将GroupHeader模板添加到ListView.

在 App.xaml 中:

<Application.Resources>
    <DataTemplate x:Key="ListViewGroupHeaderTemplate">
        <TextBlock Foreground="Red" Text="{Binding Key}" />
    </DataTemplate>
    <DataTemplate x:Key="ListViewTemplate">
        <TextBlock Foreground="Black" Text="{Binding DateTimeProperty}" />
    </DataTemplate>
</Application.Resources>

这是我的项目类和我的SourceListView

public class ListItem
{
    public DateTime DateTimeProperty { get; set; }
}

public class SourceListView
{
    public SourceListView()
    {
        Element = from x in Collection group x by x.DateTimeProperty.Year into grp orderby grp.Key select grp;
    }

    public IList<ListItem> Collection { get; set; } = new List<ListItem>()
    {
        new ListItem() {DateTimeProperty = DateTime.Parse("2011-08-01") },
        new ListItem() {DateTimeProperty = DateTime.Parse("2011-08-21") },
        new ListItem() {DateTimeProperty = DateTime.Parse("2012-04-03") },
        new ListItem() {DateTimeProperty = DateTime.Parse("2012-04-01") },
        new ListItem() {DateTimeProperty = DateTime.Parse("2013-05-15") },
        new ListItem() {DateTimeProperty = DateTime.Parse("2013-05-06") },
        new ListItem() {DateTimeProperty = DateTime.Parse("2013-05-01") },
        new ListItem() {DateTimeProperty = DateTime.Parse("2013-06-01") },
        new ListItem() {DateTimeProperty = DateTime.Parse("2013-06-09") },
        new ListItem() {DateTimeProperty = DateTime.Parse("2014-10-02") },
        new ListItem() {DateTimeProperty = DateTime.Parse("2014-10-11") },
        new ListItem() {DateTimeProperty = DateTime.Parse("2015-12-03") },
        new ListItem() {DateTimeProperty = DateTime.Parse("2016-07-01") },
        new ListItem() {DateTimeProperty = DateTime.Parse("2016-07-06") },
    };

    public IEnumerable<object> Element { get; }
}

这是这个分组的实现代码ListView

ListView listView = new ListView();
listView.ItemTemplate = App.Current.Resources["ListViewTemplate"] as Windows.UI.Xaml.DataTemplate;
var gs = new GroupStyle();
gs.HeaderTemplate = App.Current.Resources["ListViewGroupHeaderTemplate"] as Windows.UI.Xaml.DataTemplate;
listView.GroupStyle.Add(gs);

CollectionViewSource cvs = new CollectionViewSource();
cvs.IsSourceGrouped = true;
cvs.Source = new SourceListView().Element;
if (listView.ItemsSource == null)
    listView.ItemsSource = cvs.View;
rootGrid.Children.Add(listView);

这是渲染图像:

在此处输入图像描述

于 2016-09-29T03:34:43.593 回答
0

好的,经过一天半的努力解决这个问题,我终于找到了解决方案。如果有一天有人遇到和我一样的问题,我会在这里发布。其实这是一个很奇怪的问题,我不知道这是一个错误,未实现的功能还是什么......

解决方案:

在您的 UWP 自定义渲染器中,您需要执行以下操作:

 protected override void OnElementChanged(ElementChangedEventArgs<Xamarin.Forms.ListView> e)
    {
        base.OnElementChanged(e);

        if (e.NewElement != null)
        {
            e.NewElement.GroupHeaderTemplate = new Xamarin.Forms.DataTemplate(() =>
            {
                var label = new Label();

                label.SetBinding(Label.TextProperty, "Country");

                return new ViewCell { View = label };
            });
        }
    }

其中“国家/地区”是代表您的组/标题的类中的属性名称。

于 2016-12-21T15:35:43.087 回答