iOS应用外搜索之 Core Spotlight 适配

前言

前段时间为APP做了应用外搜索的适配,也就是iOS Core spotlight服务的支持,可以让用户在iPhone系统中的下拉或者左滑搜索中搜索到APP中的内容,点击搜索结果可以直接跳转到APP中的相应结果页。

现在iPhone的存储配置从7开始已经以32G作为基础配置了,也就意味着iPhone用户能安装的APP数量肯定会上升,安装APP的数量多了,难以一下子找到想要使用的APP时,那么使用搜索功能的用户也一定会随之增多,spotlight不仅支持搜索APP,适配以后更支持搜索应用内内容,用户使用更便捷。

至于为什么要做spotlight搜索适配呢,那当然不言而喻了,这使APP增加了一个用户的入口,提升了APP的曝光度。

IMG_3367.PNG

基本知识

按照苹果一贯的风格——高度封装,面向开发者,它一般都会提供比较简洁的API,这次也不例外。

想要实现在APP外的系统搜索中搜索到应用内的内容,你只需要告诉系统,你哪些内容是可被搜索的,每条内容搜索的关键字是什么,显示的标题和内容是什么,以及为内容提供唯一标示就可以了。

以上单条内容都用一个CSSearchableItem对象来存放。

关键属性 关键子属性 描述
CSSearchableItem uniqueIdentifier 该条内容的唯一标识,类似于数据库字段中的id,在用户在应用外搜索到结果以后跳转到应用时,我们可以通过它来决定后续动作(如:在IM类应用搜索到某个联系人,跳转到对应的聊天会话;在购物类应用,跳转到某商品详情页)
domainIdentifier 该条内容的域标识,相当于类型ID(比如,如果应用内不仅可以搜索联系人,还可以搜索商品,可以用此属性来区分)
attributeSet title 显示的标题
contentDescription 显示的内容
thumbnailData 显示的缩略图(比如:联系人头像、商品缩略图等)
contactKeywords 搜索的关键字(比如:联系人住址、备注等其他信息)

以上是一条需要添加到搜索内容所需要的信息,你需要把所有需要支持搜索的信息转换为CSSearchableItem对象,来交给系统。

spotlight搜索实现步骤(代码)

1. 包装CSSearchableItem对象,交给spotlight搜索系统

class SpotlightManager: NSObject {
    @available(iOS 9.0, *)
    class dynamic func configSearch(myAppContentsArray: [MRContacts]?) -> Void {
        let searchableItems = self.searchableItems(myAppContentsArray)
        CSSearchableIndex.defaultSearchableIndex().indexSearchableItems(searchableItems) { (error: NSError?) in
            if let error = error {
                print("configSearch failed -> \(error)")
            }
        }

    }

    @available(iOS 9.0, *)
    class private dynamic func searchableItems(myAppContentsArray: [MRContacts]?) -> [CSSearchableItem] {
        var searchableItems = [CSSearchableItem]()
        guard let myAppContentsArray = myAppContentsArray else { return searchableItems }
        for contact in myAppContentsArray {
            let searchableItemSet = CSSearchableItemAttributeSet.init(itemContentType: "contact")
            searchableItemSet.title = contact.name
            searchableItemSet.contentDescription = contact.address
            let searchKeys = self.searchKeys(contact)
            if searchKeys.count > 0 {
                searchableItemSet.contactKeywords = self.searchKeys(contact)
                let searchableItem = CSSearchableItem.init(uniqueIdentifier: contact.id, domainIdentifier: "com.xingshulin.contact", attributeSet: searchableItemSet)
                searchableItems.append(searchableItem)
            }
        }
        return searchableItems
    }

    @available(iOS 9.0, *)
    class private dynamic func searchKeys(contact: MRContacts) -> [String] {
        var searchKeys = [String]()
        if let name = contact.name {
            searchKeys.append(name)
        }
        if let address = contact.address {
            searchKeys.append(address)
        }
        return searchKeys
    }
}

2. 处理搜索结果回调

func application(application: UIApplication, continueUserActivity userActivity: NSUserActivity, restorationHandler: ([AnyObject]?) -> Void) -> Bool {
    if let uniqueIdentifier = userActivity.userInfo?[CSSearchableItemActivityIdentifier] as? String {
        // 跳转到相应页面
    }    
    return true       
}

3.维护(追加或删除)需要支持搜索的内容

// 删除所有
CSSearchableIndex.defaultSearchableIndex().deleteAllSearchableItemsWithCompletionHandler { (error) in
    if let _ = error {
        return
    }
}

// 根据uniqueIdentifier删除
public func deleteSearchableItemsWithIdentifiers(identifiers: [String], completionHandler: ((NSError?) -> Void)?)

// 根据domainIdentifier删除
public func deleteSearchableItemsWithDomainIdentifiers(domainIdentifiers: [String], completionHandler: ((NSError?) -> Void)?)

// 追加(同1)
public func indexSearchableItems(items: [CSSearchableItem], completionHandler: ((NSError?) -> Void)?)
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 172,996评论 25 708
  • 1.尺寸适配1.原因 iOS7中所有导航栏都为半透明,导航栏(height=44)和状态栏(height=20)不...
    LZM轮回阅读 6,137评论 1 4
  • 文/朴杂 阴爵学院是座落在地狱上层的一间学院,这所学院里学员什么都有,鬼、怪、妖、神、人……而这里所教授的课程也是...
    朴杂阅读 556评论 14 10
  • 学习是一件很痛苦的事,也是一件很快乐的事。 最近在自学linux,参考的书籍是刘遄老师的< >,然后就写了一点点学...
    Rancune阅读 171评论 0 0
  • 今天还是很冷,记得多穿一点,不要向寒冷的冬天妥协,你比自己想象的,要强大得多了。 七点,天还没亮,菜市路口的菜农早...
    穆念晴阅读 321评论 0 2