Windows Phone 7 使用数据模板DataTemplate进行数据绑定

简介:

一、DataTemplate

DataTemplate 类 描述数据对象的可视结构。
命名空间: System.Windows

XAML
<DataTemplate ...>
templateContent
</DataTemplate>

XAML 值
templateContent 
定义此 DataTemplate 的对象树。该树必须有一个根元素,而该根元素可以有零个或更多的子元素。

通常使用 DataTemplate 指定数据的直观表示。将 ItemsControl(如 ListBox)绑定到整个集合时,DataTemplate 对象尤其有用。可以使用 DataTemplate 定义数据对象的外观。DataTemplate 的内容变成数据对象的可视结构。

可以在 DataTemplate 中使用数据绑定。例如,假定 ListBox 绑定到 Customer 对象的集合,并且将 ItemTemplate 属性设置为 DataTemplate。创建 ListBox 时,将为集合中的每个 Customer 创建一个 ListBoxItem,并将 ListBoxItem 的 DataContext 设置为相应的客户。也就是说,第一个 ListBoxItem 的 DataContext 设置为第一个客户,第二个 ListBoxItem 的 DataContext 设置为第二个客户,依此类推。可以将 DataTemplate 中的元素绑定到 Customer 对象的属性。

定义用于创建数据模板的内容的 XAML 用法不作为可设置的属性公开。这是内置于 DataTemplate 对象元素的 XAML 处理的特殊行为。

示例
--------------------------------------------------------------------------------

下面的示例使用 DataTemplate 显示 ListBox 的项。在此示例中,ListBox 绑定到 Customer 对象的集合。DataTemplate 包含 TextBlock 控件,这些控件绑定到 FirstName、LastName 和 Address 属性。

XAML 
<Grid>
<Grid.Resources>
<src:Customers x:Key="customers"/>
</Grid.Resources>

<ListBox ItemsSource="{StaticResource customers}" Width="350" Margin="0,5,0,10">
<ListBox.ItemTemplate>
<DataTemplate>
<StackPanel Orientation="Horizontal">
<TextBlock Padding="5,0,5,0"
Text="{Binding FirstName}" />
<TextBlock Text="{Binding LastName}" />
<TextBlock Text=", " />
<TextBlock Text="{Binding Address}" />
</StackPanel>
</DataTemplate>
</ListBox.ItemTemplate>
</ListBox>
</Grid>


下面的示例演示 Customer 类和 ListBox 绑定到的集合。
public class Customer
{
public String FirstName { get; set; }
public String LastName { get; set; }
public String Address { get; set; }

public Customer(String firstName, String lastName, String address)
{
this.FirstName = firstName;
this.LastName = lastName;
this.Address = address;
}

}

public class Customers : ObservableCollection<Customer>
{
public Customers()
{
Add(new Customer("Michael", "Anderberg",
"12 North Third Street, Apartment 45"));
Add(new Customer("Chris", "Ashton",
"34 West Fifth Street, Apartment 67"));
Add(new Customer("Cassie", "Hicks",
"56 East Seventh Street, Apartment 89"));
Add(new Customer("Guido", "Pica",
"78 South Ninth Street, Apartment 10"));
}

}

二、DataTemplateSelector

DataTemplateSelector 类
提供一种方式来根据数据对象和数据绑定元素选择 DataTemplate。 
命名空间: System.Windows.Controls

通常,如果有多个 DataTemplate 可用于同一类型的对象,并且您希望根据每个数据对象的属性提供自己的逻辑来选择要应用的 DataTemplate,则应创建 DataTemplateSelector。

若要创建模板选择器,请创建继承自 DataTemplateSelector 的类并重写 SelectTemplate 方法。 在定义您的类后,就可以将类的实例分配到您的元素的模板选择器属性。

示例
--------------------------------------------------------------------------------

在此示例中,绑定源是 Task 对象的列表。 Task 对象的属性之一为 Priority。 有两个已定义的数据模板:myTaskTemplate 和 importantTaskTemplate。

若要提供逻辑以根据数据对象的 Priority 值选择要使用的 DataTemplate,请创建 DataTemplateSelector 的子类并重写 SelectTemplate 方法。 在下面的示例中,SelectTemplate 方法提供逻辑以根据 Priority 属性的值返回适当的模板。 可以在封装 Window 元素的资源中找到要返回的模板。

using System.Windows;
using System.Windows.Controls;

namespace SDKSample
{
public class TaskListDataTemplateSelector : DataTemplateSelector
{
public override DataTemplate
SelectTemplate(object item, DependencyObject container)
{
if (item != null && item is Task)
{
Task taskitem = item as Task;
Window window = Application.Current.MainWindow;

if (taskitem.Priority == 1)
return
window.FindResource("importantTaskTemplate") as DataTemplate;
else
return
window.FindResource("myTaskTemplate") as DataTemplate;
}

return null;
}
}
}


然后,我们可以将 TaskListDataTemplateSelector 声明为资源:

XAML 复制 
<Window.Resources>


...


<local:TaskListDataTemplateSelector x:Key="myDataTemplateSelector"/>


...


</Window.Resources>


若要使用模板选择器资源,请将其分配到 ListBox 的 ItemTemplateSelector 属性。 ListBox 为基础集合中的每一项调用 TaskListDataTemplateSelector 的 SelectTemplate 方法。 该调用会将数据对象作为项参数来传递。 然后,将该方法返回的 DataTemplate 应用于该数据对象。

XAML 
<ListBox Width="400" Margin="10"
ItemsSource="{Binding Source={StaticResource myTodoList}}"
ItemTemplateSelector="{StaticResource myDataTemplateSelector}"
HorizontalContentAlignment="Stretch"/>

三、ContentControl

ContentControl 可以包含任何类型的公共语言运行库对象(如字符串或 DateTime 对象)或 UIElement 对象(如 Rectangle 或 Panel)。 这使您能够向控件(如 Button 和 CheckBox)中添加丰富的内容。

ContentControl 具有有限的默认样式。 如果要增强该控件的外观,可以创建新的 DataTemplate

四、实例

 

 

 

 
  1. <Grid x:Name="ContentPanel" Grid.Row="1" Margin="12,0,12,0"> 
  2.               
  3.             <ListBox x:Name="listBox" HorizontalContentAlignment="Stretch"> 
  4.                 <ListBox.ItemTemplate> 
  5.                     <DataTemplate> 
  6.                         <local:FoodTemplateSelector Content="{Binding}"> 
  7.                             <local:FoodTemplateSelector.Healthy> 
  8.                                 <DataTemplate> 
  9.                                     <StackPanel Orientation="Horizontal" Background="YellowGreen" Width="400" Margin="10"> 
  10.                                         <Image Source="{Binding IconUri}" Stretch="None"/> 
  11.                                         <TextBlock Text="{Binding Name}" FontSize="40" Foreground="Black" Width="280"/> 
  12.                                         <TextBlock Text="healty" /> 
  13.                                     </StackPanel> 
  14.                                 </DataTemplate> 
  15.                                 </local:FoodTemplateSelector.Healthy> 
  16.                             <local:FoodTemplateSelector.UnHealthy> 
  17.                                 <DataTemplate> 
  18.                                     <Border BorderBrush="Red" BorderThickness="2"  Width="400" Margin="10"> 
  19.                                     <StackPanel Orientation="Horizontal"> 
  20.                                         <Image Source="{Binding IconUri}" Stretch="None"/> 
  21.                                             <TextBlock Text="{Binding Name}" FontSize="40" Width="280"/> 
  22.                                         <Image Source="Images/attention.png" Stretch="None" Margin="10,0,0,0"/> 
  23.                                     </StackPanel> 
  24.                                     </Border> 
  25.                                 </DataTemplate> 
  26.                             </local:FoodTemplateSelector.UnHealthy> 
  27.                             <local:FoodTemplateSelector.NotDetermined> 
  28.                                 <DataTemplate> 
  29.                                     <StackPanel Orientation="Horizontal" Background="Gray" Width="400" Margin="10"> 
  30.                                         <Image Source="{Binding IconUri}" Stretch="None"/> 
  31.                                         <TextBlock Text="{Binding Name}" FontSize="40" Width="280"/> 
  32.                                         <Image Source="Images/question.png" Stretch="None" Margin="10,0,0,0"/> 
  33.                                     </StackPanel> 
  34.                                 </DataTemplate> 
  35.                             </local:FoodTemplateSelector.NotDetermined> 
  36.                         </local:FoodTemplateSelector> 
  37.                     </DataTemplate> 
  38.                 </ListBox.ItemTemplate> 
  39.             </ListBox> 
  40.         </Grid> 
  41.     </Grid> 

 

 
  1. using System;  
  2. using System.Collections.Generic;  
  3. using System.Linq;  
  4. using System.Net;  
  5. using System.Windows;  
  6. using System.Windows.Controls;  
  7. using System.Windows.Documents;  
  8. using System.Windows.Input;  
  9. using System.Windows.Media;  
  10. using System.Windows.Media.Animation;  
  11. using System.Windows.Shapes;  
  12. using Microsoft.Phone.Controls;  
  13.  
  14. namespace WP7SampleProject10  
  15. {  
  16.     public class FoodTemplateSelector : DataTemplateSelector  
  17.     {  
  18.         public DataTemplate Healthy  
  19.         {  
  20.             get;  
  21.             set;  
  22.         }  
  23.  
  24.         public DataTemplate UnHealthy  
  25.         {  
  26.             get;  
  27.             set;  
  28.         }  
  29.  
  30.         public DataTemplate NotDetermined  
  31.         {  
  32.             get;  
  33.             set;  
  34.         }  
  35.  
  36.         public override DataTemplate SelectTemplate(object item, DependencyObject container)  
  37.         {  
  38.             Data foodItem = item as Data;  
  39.             if (foodItem != null)  
  40.             {  
  41.                 if (foodItem.Type == "Healthy")  
  42.                 {  
  43.                     return Healthy;  
  44.                 }  
  45.                 else if (foodItem.Type == "NotDetermined")  
  46.                 {  
  47.                     return NotDetermined;  
  48.                 }  
  49.                 else  
  50.                 {  
  51.                     return UnHealthy;  
  52.                 }  
  53.             }  
  54.  
  55.             return base.SelectTemplate(item, container);  
  56.         }  
  57.     }  
  58.  
  59.     public class Data  
  60.     {  
  61.         public string Name  
  62.         {  
  63.             get;  
  64.             set;  
  65.         }  
  66.  
  67.         public string Description  
  68.         {  
  69.             get;  
  70.             set;  
  71.         }  
  72.  
  73.         public string IconUri  
  74.         {  
  75.             get;  
  76.             set;  
  77.         }  
  78.  
  79.         public string Type  
  80.         {  
  81.             get;  
  82.             set;  
  83.         }  
  84.     }  
  85.  
  86.     public partial class MainPage : PhoneApplicationPage  
  87.     {  
  88.         // Constructor  
  89.         public MainPage()  
  90.         {  
  91.             InitializeComponent();  
  92.  
  93.             List<Data> list = new List<Data>();  
  94.             Data item0 = new Data() { Name = "Tomato"IconUri = "Images/Tomato.png"Type = "Healthy" };  
  95.             Data item1 = new Data() { Name = "Beer"IconUri = "Images/Beer.png"Type = "NotDetermined" };  
  96.             Data item2 = new Data() { Name = "Fries"IconUri = "Images/fries.png"Type = "Unhealthy" };  
  97.             Data item3 = new Data() { Name = "Sandwich"IconUri = "Images/Hamburger.png"Type = "Unhealthy" };  
  98.             Data item4 = new Data() { Name = "Ice-cream"IconUri = "Images/icecream.png"Type = "Healthy" };  
  99.             Data item5 = new Data() { Name = "Pizza"IconUri = "Images/Pizza.png"Type = "Unhealthy" };  
  100.             Data item6 = new Data() { Name = "Pepper"IconUri = "Images/Pepper.png"Type = "Healthy" };  
  101.             list.Add(item0);  
  102.             list.Add(item1);  
  103.             list.Add(item2);  
  104.             list.Add(item3);  
  105.             list.Add(item4);  
  106.             list.Add(item5);  
  107.             list.Add(item6);  
  108.  
  109.             this.listBox.ItemsSource = list;  
  110.                   
  111.         }  
  112.  
  113.     }  

 

 
  1. using System;  
  2. using System.Net;  
  3. using System.Windows;  
  4. using System.Windows.Controls;  
  5. using System.Windows.Documents;  
  6. using System.Windows.Ink;  
  7. using System.Windows.Input;  
  8. using System.Windows.Media;  
  9. using System.Windows.Media.Animation;  
  10. using System.Windows.Shapes;  
  11.  
  12. namespace WP7SampleProject10  
  13. {  
  14.     public abstract class DataTemplateSelector : ContentControl  
  15.     {  
  16.         public virtual DataTemplate SelectTemplate(object item, DependencyObject container)  
  17.         {  
  18.             return null;  
  19.         }  
  20.  
  21.         protected override void OnContentChanged(object oldContent, object newContent)  
  22.         {  
  23.             base.OnContentChanged(oldContent, newContent);  
  24.  
  25.             ContentTemplate = SelectTemplate(newContent, this);  
  26.         }  
  27.     }  
  28.       

 


本文转自linzheng 51CTO博客,原文链接:http://blog.51cto.com/linzheng/1078720

相关文章
|
开发工具 Windows
Windows平台RTMP推送|轻量级RTSP服务实现本地摄像头|屏幕|叠加数据预览
大家在做Windows平台RTMP推送或轻量级RTSP服务的时候,不管是采集屏幕还是采集摄像头,亦或屏幕摄像头的叠加模式,总会有这样的诉求,采集到的数据,希望能本地看看具体采集的数据或者图像实际效果,也就是本次介绍的“预览”功能。
222 0
|
18天前
|
计算机视觉 Windows Python
windows下使用python + opencv读取含有中文路径的图片 和 把图片数据保存到含有中文的路径下
在Windows系统中,直接使用`cv2.imread()`和`cv2.imwrite()`处理含中文路径的图像文件时会遇到问题。读取时会返回空数据,保存时则无法正确保存至目标目录。为解决这些问题,可以使用`cv2.imdecode()`结合`np.fromfile()`来读取图像,并使用`cv2.imencode()`结合`tofile()`方法来保存图像至含中文的路径。这种方法有效避免了路径编码问题,确保图像处理流程顺畅进行。
106 1
|
消息中间件 安全 API
C#实现操作Windows窗口句柄:SendMessage/PostMessage发送系统消息、事件和数据【窗口句柄总结之二】
SendMessage/PostMessage API 可以实现发送系统消息,这些消息可以定义为常见的鼠标或键盘事件、数据的发送等各种系统操作......
5054 1
C#实现操作Windows窗口句柄:SendMessage/PostMessage发送系统消息、事件和数据【窗口句柄总结之二】
|
23天前
|
缓存 NoSQL Linux
【Azure Redis 缓存】Windows和Linux系统本地安装Redis, 加载dump.rdb中数据以及通过AOF日志文件追加数据
【Azure Redis 缓存】Windows和Linux系统本地安装Redis, 加载dump.rdb中数据以及通过AOF日志文件追加数据
【Azure Redis 缓存】Windows和Linux系统本地安装Redis, 加载dump.rdb中数据以及通过AOF日志文件追加数据
|
30天前
|
Web App开发 存储 安全
微软警告数百万Windows用户:切勿冒险丢失所有数据
微软警告数百万Windows用户:切勿冒险丢失所有数据
微软警告数百万Windows用户:切勿冒险丢失所有数据
|
24天前
|
JavaScript Java Python
【Azure 应用服务】在Azure App Service for Windows 中部署Java/NodeJS/Python项目时,web.config的配置模板内容
【Azure 应用服务】在Azure App Service for Windows 中部署Java/NodeJS/Python项目时,web.config的配置模板内容
|
1月前
|
编解码 开发工具 C#
Windows电脑如何启动RTSP服务实现本地摄像头数据共享
本文介绍如何利用大牛直播SDK中的轻量级RTSP服务,在Windows平台上轻松采集摄像头数据并生成本地RTSP流。通过SDK提供的SmartPublisherDemo工具,用户能简便地选择摄像头、配置分辨率与帧率,并启动RTSP服务。此外,还支持音频采集、多端口服务以及动态水印等功能。生成的RTSP URL可用于其他终端拉流播放,无需额外部署服务器。该服务适配多种应用场景,如安防监控、电子教室等,并兼容Windows 7及以上版本。对于希望集成此功能的开发者,SDK提供了C++及C#接口,并支持多种编译模式。
|
4月前
|
Windows
如何使用Windows Media Player刻录数据DVD
Windows Media Player是微软Windows系统自带的多媒体播放器,支持多种音频、视频格式及图片查看,也能接收网络广播和刻录CD/DVD。用户可利用它管理媒体文件、创建播放列表。然而,其刻录DVD功能有限,仅适用于数据DVD。若需创建可在DVD播放机上播放的视频DVD,建议使用专业软件如DVDFab DVD Creator。
|
4月前
|
数据库 Windows
第五十章 使用 ^SystemPerformance 监视性能 - Microsoft Windows 平台的 InterSystems IRIS 性能数据报告
第五十章 使用 ^SystemPerformance 监视性能 - Microsoft Windows 平台的 InterSystems IRIS 性能数据报告
36 0
|
4月前
|
存储 Kubernetes 安全
虚拟机测试Windows Server 2016原地升级2019,应用和数据完美保留
Windows Server 2016可以无缝升级到2019版本,确保应用程序和数据在原地升级过程中完整保留。
249 0