设为首页 收藏本站
查看: 1644|回复: 0

Windows Phone 8初学者开发—第12部分:改进视图模型和示例数据

[复制链接]

尚未签到

发表于 2015-5-22 12:28:39 | 显示全部楼层 |阅读模式
第12部分:改进视图模型和示例数据
  原文地址:http://channel9.msdn.com/Series/Windows-Phone-8-Development-for-Absolute-Beginners/Part-12-Improving-the-View-Model-and-Sample-Data
  系列地址:http://channel9.msdn.com/Series/Windows-Phone-8-Development-for-Absolute-Beginners
  源代码: http://aka.ms/absbeginnerdevwp8
PDF版本: http://aka.ms/absbeginnerdevwp8pdf
  我们已经完成了基本的工作,接下来我们将关注应用程序的核心:数据模型。这就要求我们将上一课的实体模型转换成可行的数据模型,该模型应能够代表数据和数据间的层次结构。
  以下是我们本课的计划:

  • 我们将简要分析我们的需求(实体模型是目前我们的全部)并快速绘制出将在应用程序中实现的数据模型。
  • 我们将用代码实现数据模型。
  • 我们将在一个XML文件中创建数据以便在设计时在MainPage的XAML设计器中对它进行显示。
  • 修改MainPage.xaml的绑定表达式以指向数据模型中类的实例和属性。
1. 分析实体模型并设计数据模型
  在查看了实体模型并思考如何最优地委派任务给不同的类之后,我设计了一个基本的类模型,应用程序类模型的数据结构如下:
DSC0000.png
  SoundModel类包含对应用程序中五个声音分组的引用。请注意这些属性是SoundGroup类型。
  SoundGroup类代表我之前称为的“视图”或“类型”。我一直在寻找一个正确的术语用以描述它,但本质上它是一个分组而不是一个视图或类型。(视图仅指出了用于显示声音的磁贴的视觉效果而类型在.NET中有特殊的内涵) SoundGroup有一个标题(它被用于在MainPage.xaml的Pivot控件中作为PivotItem的标题)和一个SoundData的泛型集合。
  SoundData类代表声音本身。每个SoundData的实例将包含一个标题,通过点击标题将会播放与SoundData关联的声音,它存储在SoundData的FilePath属性中。
  接着我们将通过代码来实现图中的功能并且在实现的过程中还会有一些补充。
2. 为应用程序创建新的数据模型类
  根据我们的计划和数据模型图,我们将实现这个新的数据模型。
  右键单击ViewModels文件夹,选择添加|新建项:
DSC0001.png
  打开添加新项对话框:
DSC0002.png

  • 确认您位于Visual C#文件模板
  • 选择类文件模板
  • 重命名为SoundData.cs
  • 单击添加按钮
  SoundData.cs文件被创建并加载到主区域中:
DSC0003.png
  我们将添加两个公共属性:Title和FilePath:
DSC0004.png
  使用刚才描述的方法添加另一个新项到ViewModels文件夹中。我们将创建另一个称为SoundGroup.cs的类:
DSC0005.png
  在SoundGroup.cs中我们将创建两个公共属性和一个构造函数:
DSC0006.png

  • 创建Title属性和Items属性。Items将是一个SoundData的泛型列表。
  • 在构造函数中,我们对Items进行初始化,将它设置为List的一个新实例。
  我们将向ViewModels文件夹添加另一个称为SoundModel的类文件。SoundModel中每种类别的声音以一个SoundGroup类型变量表示。该类还将实现判断数据是否加载到新的数据模型中的逻辑,其中绝大多数代码将为应用程序中的每个声音创建一个SoundData类的实例。
  我们将从简单的开始并在本课中不断扩展这个重要的类:
DSC0007.png

  • 在第11行至15行我们将创建代表每类声音的SoundGroup(即类别)属性。
  • 我们将使用IsDataLoaded属性来判断是否需要执行LoadData()方法来创建SoundGroup和SoundData的实例。
  • 我们将使用很多私有的辅助方法来将数据加载到模型中,我们待会儿将讨论如何实现这些方法。
3. 修改App.xaml.cs以使用新的数据模型
  在我们完成LoadData()方法中的大量工作以及创建辅助方法前,我想用我们的刚才创建的新数据模型替换来自项目模板中的数据模型,替换的方法是修改App.xaml.cs中的ViewModel属性。
  首先我将在App.xaml中注释掉对旧模型的引用。我通常在删除项目中不需要的东西前会首先将其注释掉。这是我这些年来养成的一个习惯。我以前会一上来就删除这些代码,因为我觉得会替换这些代码,但很快会发现缺少一些微小的细节。然而由于已经删除掉的代码不能再次被引用,因此判断我在哪里出错将是一件耗时和痛苦的事情。
  这里我注释掉MainViewModel属性的实现,包括一个私有字段和一个公共的属性。
DSC0008.png
  接下来我将利用类型为SoundModel的新数据模型来实现新版的ViewModel:
DSC0009.png
  这就是需要的全部操作。对SoundModel的IsDataLoaded属性和LoadData()方法的引用应该能够正常工作。
  现在我们已经将旧的数据模型从应用程序中删除,我肯定应用程序中有些东西将不能正常工作。此刻我最关心的是XAML视图。绑定表达式指向的属性已经不存在。此外,在XAML设计器中设计时的数据未能显示,并且在运行时也没有数据。
4. 创建示例/设计时显示的数据
  需要一些时间来解决目前存在的所有问题,所以我们一点一点地来解决。我首先解决设计时数据不能显示的问题,我们将对XAML视图进行编辑以便能正确显示新模型中的数据。
  右键单击SampleData文件夹,从上下文菜单中选择添加|新建项:
DSC00010.png
  这将打开添加新项对话框:
DSC00011.png

  • 确认您位于Windows Phone文件模板
  • 选择Windows Phone纵向页面文件模板
  • 将文件重命名为:SampleData.xaml
  • 单击添加
  我将使用该文件保存示例数据而不把它作为XAML页面使用,因此我需要删除模板文件中的所有内容。
  当在主区域中打开SampleData.xaml文件时,我将删除文件中的所有XAML:
DSC00012.png
  在解决方案资源管理器中,我将通过右键单击与新的SampleData.xaml文件关联的代码隐藏文件并在上下文菜单中选择删除以删除该代码隐藏文件。
DSC00013.png
  回到SampleData.xaml,我隐藏了可视化XAML设计器。该文件仅包含数据,因此没有可以在设计器中进行显示:
  我在SampleData.xaml文件中添加了相当多的代码:
DSC00014.png
  请注意前缀为”vm”的XAML命名空间,它引用了公共语言运行时命名空间SoundBoard.ViewModels,我们刚刚创建的新的数据模型就位于该命名空间。我们希望文档中的XAML创建SoundModel,SoundGroup和SoundData类的实例。
5. 使用MainPage.xaml中的新示例数据
  接着我将修改MainPage.xaml文件以更改XAML设计器加载和显示的设计时数据(即在设计时加载的数据):
DSC00015.png
  现在我们有了数据模型和“假”数据,我们可以看到在LongListSelector的DataTemplate中进行更改所产生的影响。我将对每个TextBlock的绑定表达式进行更改:
DSC00016.png

  • 我将LongListSelector的ItemSource的绑定设置为Animals.Items。Animals是SoundModel的一个公共属性,SoundModel是在SampleData.xaml文件中定义的Animals的父类。
  • 因为LongListSelector.ItemsSource被设置为Animals.Items,并且Items是一个List,我们可以在DataTemplate中引用SoundData类的任意属性。所以我将Text绑定到(SoundData类的)Title属性,并且
  • 我将Text绑定到(SoundData类的)FilePath属性。
  • 我还将PivotItem的Header绑定到Animals.Title。这里我可以再次引用Animals,因为它的父类SoundModel被设置为整个MainPage.xaml的DataContext(数据上下文)。
  在XAML设计器中,我们应该可以看到示例数据了:
DSC00017.png
  希望您可以看到MainPage.xaml中的控件和Animals示例数据之间的相关性:
DSC00018.png
  我们对第一个PivotItem进行了更改,现在我们将对第二个PivotItem进行更改以显示SoundGroup中的Cartoons。这与上面针对Animals进行的修改几乎相同。我只需要简单地用Cartoons替代Animals就可以了。
DSC00019.png
  当我将鼠标光标放置在第二个PivotItem的XAML定义中时,XAML设计器将更改PivotItem对应的视图。
DSC00020.png
回顾
  综上所述,本课的重点是如何将数据透视项目中缺省的数据模型和示例数据替换为新的声音分组数据模型并通过修改MainPage.xaml页面和控件声明绑定到上述新的示例数据。我们学习了数据上下文以及它们如何在页面中被设置和访问。
  

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-69568-1-1.html 上篇帖子: Windows Phone 8 In app purchase 应用内购买 / 应用内支付 下篇帖子: Windows 8 开发31日
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表