首页 > 代码库 > 快速构建Windows 8风格应用13-SearchContract构建

快速构建Windows 8风格应用13-SearchContract构建

原文:快速构建Windows 8风格应用13-SearchContract构建

本篇博文主要介绍如何在应用中构建SearchContract,相应的原理已经在博文《快速构建Windows 8风格应用12-SearchContract概述及原理》中阐述清楚。

如何在应用中构建SearchContract

这里以常见的构建Search Contract功能为例,具体如下:

设置应用Search权限:

我们在应用中构建SearchContract之前,需要确认应用程序具有相应的Search能力,可以在应用清单文件中查看设置。 

添加标准Search Contract页面:

应用的解决方案中添加Search Contract页面。

查看Search Contract页面默认生成的控件模版:

添加SearchResultPage.xaml页面后,自动会构建出用于页面显示搜索信息的控件模版。例如:

相应XAML设计器显示样式:

Search Contract页面对应cs文件LoadState方法中添加进行搜索数据代码:

SearchResultPage.xaml.cs文件的LoadState方法中根据搜索文本在应用数据中进行搜索,并添加到数据集合中。代码可如下所示:

更改Search Contract页面需要绑定的数据模版:

更改解决方案中Common文件夹下StandardStyles.xaml文件的StandardSmallIcon300x70ItemTemplate数据模版,设置该数据模版中我们要显示的字段控件。例如:

运行应用查看搜索效果:

 

到这里我们就可以利用Search Contract进行搜索信息了,并在添加的Search Contract页面显示搜索出来的结果。效果如图:

以上演示的是在应用程序运行的状态时进行搜索,其实应用程序在关闭状态下可以通过Search Contract启动并进行搜索。

应用程序外部启动:

App.xaml.cs文件中,需要重写OnSearchActivated方法来接收系统发送的搜索激活事件。OnSearchActivated方法在两种情况下进行触发:Search Contract面板中点击Search按钮和点击列表中某一应用时。

OnSearchActivated方法中编写应用程序在外部启动时进行搜索的代码。代码如下:

代码中首先判断当前应用程序状态是否为“NotRunning”、“ClosedByUser”、“Terminated”,若为这三种状态之一,先加载数据、注册SuggestionRequested(搜索建议)事件、最后激活SearchResultPage页面。

注意:可以通过设置SearchPane类GetForCurrentView()方法的PlaceholderText属性值,实现在Search Contract面板输入框中自定义提示文字,可以告诉用户可以输入什么进行搜索,当输入文字后提示文字就会自动消失。代码可如下;

实现效果:

异步搜索建议:

上篇博文提到为了提高用户体验,开发者应该必须在用户输入搜索信息时提供搜索建议。那么在应用中如何实现搜索建议呢?

注册Search Contract面板的搜索建议事件:

OnSuggestionsRequested方法中进行匹配相关的搜索建议。

代码中AppendQuerySuggestion()方法实现提供搜索建议。

注意:通过AppendQuerySuggestion()可以将一个数组信息全部添加到搜索建议中,但是目前搜索面板中最多显示5条搜索建议,这一点需要开发者在开发过程中注意到。

实现效果如图:

我们也可以通过AppendSearchSeparator()方法实现在搜索建议中提供必要的分栏。代码如下:

实现效果:

另外Search Contract中还提供了一种搜索推荐的形式,通过这个搜索推荐方便用户直接跳转到相应信息的详细页面。

实现搜索推荐需要借助SearchSuggestionCollection类的AppendResultSuggestion(string text, string detailText, string tag, IRandomAccessStreamReference image, string imageAlternateText)方法来实现。代码可如下:

代码中AppendResultSuggestion()方法中参数分别为:

  1. text和detaiText分别是搜索建议要显示的信息;
  2. tag是唯一标记,是用户点击ResultSuggestion而触发ReslutionSuggestionChosen事件时,程序收到的信息,从而页面可以显示出相应的结果;
  3. image是搜索推荐要显示的图像;
  4. imageAlternateText是image的附加信息,不显示在搜索面板中;

实现效果:

AppendQuerySuggestion()方法和AppendResultSuggestion()方法主要区别:

  1. AppendQuerySuggestion主要告诉用户搜索信息的建议,AppendResultSuggestion主要告诉用户可能搜索出来的结果;
  2. AppendQuerySuggestion中只包含文本信息,AppendResultSuggestion中包含image、title、detailtitle等信息;
  3. AppendResultSuggestion可以让用户直接导航到某一条信息的详细页面;

本地搜索建议

设置SearchPaneLocalContentSuggestionSettings,并取消OnSuggestionsRequested事件监听,可以提供本地文件的搜索建议。其中LocalContentSuggestionSettings类包含了搜索范围,路径和文件格式。代码可如下:

LocalContentSuggestionSettings类方法和属性可参考MSDN:LocalContentSuggestionSettings class。

注意:要搜索到本地文件,需要在清单文件中开启对数据的读取权限。例如:

设置搜索历史:

长期使用我们应用之后会造成系统历史记录会变得非常冗长,可以通过以下代码关闭历史记录:

同时关于搜索历史还有一个属性:SearchHistoryContext

首先我们需要知道一个应用中可以包含多套搜索历史记录,通过SearchHistoryContext属性可以确实使用哪一套历史记录。

快速构建Windows 8风格应用13-SearchContract构建