• 快速构建Windows 8风格应用12SearchContract概述及原理


    本篇博文主要介绍Search Contract概述、Search Contract面板结构剖析、Search Contract实现原理、Search Contract最佳实践。

     Search Contract概述

    使用过Windows 8操作系统的开发者都知道什么是Charms(超级按钮)。其中在Charms中包含了一个Search,微软称之为Search Contact,我们可以在应用中调用Search Contract相应的API来实现应用搜索功能。

    使用Search Contract可以从系统的任何位置进入到我们的应用进行搜索,意思就是不管我们在操作系统上面做任何事情都可以随时使用Search Contract对第三方应用进行应用内搜索。

    Search Contract可以在任意的场景中调出,当然也可以依赖与某一场景(例如:联系人页面只是搜索联系人,新闻页面只是搜索新闻)。我们只需要轻轻一划就可以启用。 

    Search Contract面板结构剖析

    Search Contract面板可简单剖析如下:

    1)  搜索的范围在于我们所选择的应用程序;

    2)  搜索建议由我们所选择的应用程序提供,一般都是自动根据搜索条件在所选应用内搜索出来的结果,注意:搜索建议最多显示5条;

    3)  列出已安装的实现了Search Contract的Windows 8风格应用;

    4)  Search Contract面板显示所选应用的搜索推荐,一般最好提供包含缩略图和标题,提供精确的匹配信息,用户点击某一条搜索推荐后直接跳转到相应的详细信息页面。

    Search Contract实现原理

    首先我们来整体看一下搜索设置和相应的事件

    1.我们想要在自己的应用中使用Search Contract,首先需要在应用程序的清单文件(Package.appxmanifest)中注册应用的搜索功能以及文件访问能力。

    2.搜索面板中提供搜索历史(系统自动提供)默认是开启状态,应用本地内容的搜索建议以及设置占位符文本。

    3.搜索面板中涉及到三个重要事件:搜索激活事件;查询提交事件;搜索建议请求事件。

    搜索激活事件

    1.用户选择一个搜索位置;

    2.搜索面板中激活相应的应用进行搜索;

    3.触发应用程序中搜索激活事件,判断是否包含查询文本,若未包含查询文本加载之前的应用状态,若包含查询文本进行搜索并显示搜索结果视图;

    查询提交事件

    1.用户输入查询内容点击搜索按钮,或者用户选择一个查询建议;

    2.搜索面板中激活相应的应用进行搜索;

    3.触发应用程序中搜索激活事件后,触发查询提交的事件,需要判断查询文本是否改变了,若查询文本未改变显示之前搜索结果视图,若查询文本发生改变重新进行查询显示搜索结果视图;

    搜索建议请求事件

    1.用户在搜索框中输入查询文本;

    2.搜索面板中自动显示匹配的搜索历史记录,同时向相应的应用发起请求建议;

    3.触发查询提交事件,是否进行异步的处理,若未进行异步处理将建议添加到搜索建议集合中,在搜索面板中显示来自应用的建议,若进行异步处理,首先请求延迟将建议添加到搜索建议集合中完成延迟处理,在搜索面板中显示来自应用的建议;

    Search Contract最佳实践

    1.不要在应用中添加搜索相关的控件;

    2.不要在App Bar中放置搜索相关的UI;

    3.始终提供搜索建议;

    4.搜索建议应包含用户当前的搜索文本;

    5.搜索建议应体现应用能够提供的结果;

    6.用户选择搜索建议后,应立即跳转到相应的搜索结果页面;

    7.如果想要给用户提供精准匹配,请提供搜索结果的建议;

  • 相关阅读:
    [转] packagelock.json
    前端框架和技术
    typescript
    微信小程序登陆流程
    Introduction to my galaxy engine 4: Test on local light model
    Introduction to my galaxy engine 3: Local light model
    Introduction to my galaxy engine 5: Differed Lighting
    Introduction to my galaxy engine 2: Depth of field
    自己整理的一些国外免费3D模型网站,以后还会陆续添加
    Introduction to my galaxy engine 6: Differed Lighting 2
  • 原文地址:https://www.cnblogs.com/wzk89/p/2703562.html
Copyright © 2020-2023  润新知