Я использую Flipview и DataTemplateSelector для определения во время выполнения, которое DataTemplate применяется для отображения элементов в моем элементе управления.
У меня есть два DataTemplate, один - статический, а второй может использоваться неопределенным количеством элементов.
В настоящее время
Появится мое первое представление: - "Это тестовое содержимое"
Followed by 18 other views
, которые выглядят так:
- " http://www.google.com/ 0"
- " http://www.google.com/ 1"
- " http://www.google.com/ 2"
- и так далее до 17
Я хочу
Элементы " http://www.google.com/" сгруппированы как 3 on a view
.
Например, появится второе представление:
Третий вид отобразит:
И так далее..
Ниже показан мой код:
FlipViewDemo.xaml
<Page.Resources>
<DataTemplate x:Key="FirstDataTemplate">
<Grid>
<TextBlock Text="{Binding Content}" Margin="10,0,18,18"></TextBlock>
</Grid>
</DataTemplate>
<DataTemplate x:Key="SecondDataTemplate">
<TextBox Text="{Binding Url}"></TextBox>
</DataTemplate>
<local:MyDataTemplateSelector x:Key="MyDataTemplateSelector"
FirstTextTemplate="{StaticResource FirstDataTemplate}"
SecondTextTemplate="{StaticResource SecondDataTemplate}">
</local:MyDataTemplateSelector>
</Page.Resources>
<Grid Background="{ThemeResource ApplicationPageBackgroundThemeBrush}">
<FlipView x:Name="itemGridView" ItemTemplateSelector="{StaticResource MyDataTemplateSelector}"
Margin="265,220,284,162">
</FlipView>
</Grid>
FlipViewDemo.xaml.cs
public sealed partial class FlipViewDemo : Page
{
public FlipViewDemo()
{
this.InitializeComponent();
var items = new List<BaseClass>();
items.Add(new FirstItem
{
Content="This is a test - Content"
});
for (int i = 0; i < 18; i++)
{
items.Add(new SecondItem
{
Url = "http://www.google.com/ " + i.ToString()
});
}
itemGridView.ItemsSource = items;
}
}
public class BaseClass
{
}
public class FirstItem : BaseClass
{
public string Content { get; set; }
}
public class SecondItem : BaseClass
{
public string Url { get; set; }
}
public class MyDataTemplateSelector : DataTemplateSelector
{
public DataTemplate FirstTextTemplate { get; set; }
public DataTemplate SecondTextTemplate { get; set; }
protected override DataTemplate SelectTemplateCore(object item,
DependencyObject container)
{
if (item is FirstItem)
return FirstTextTemplate;
if (item is SecondItem)
return SecondTextTemplate;
return base.SelectTemplateCore(item, container);
}
}
Я думаю, что это может быть достигнуто с помощью групп и просмотра списка. Но я не уверен, как это можно сделать.
Возможно, это глупый вопрос, но, используя Google, я не могу найти ответ. Также английский не является моим родным языком; пожалуйста, извините ошибки ввода.