当前位置:首页 > 通信资讯 > 正文

前言

  感觉 Spotlight 这个功能还是蛮有用的,能提升用户活跃,增加应用内容曝光几率。

正文

  一、实现(iOS 9.0)

    1.1  添加索引

?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 var searchableItems = [CSSearchableItem]() for app in apps { let searchableItemAttributeSet = CSSearchableItemAttributeSet(itemContentType: kUTTypeText as String) searchableItemAttributeSet.title = app.label searchableItemAttributeSet.contentDescription = "Watch \(app.label) LIVE on Shou" let searchableItem = CSSearchableItem(uniqueIdentifier: app.id, domainIdentifier: "youappbundlerid.apps", attributeSet: searchableItemAttributeSet) searchableItems.append(searchableItem) } CSSearchableIndex.defaultSearchableIndex().indexSearchableItems(searchableItems, completionHandler: { (error: NSError?) in if error == nil { print("initSpotlight...completed") } else { print("\(error)") } })

一定要注意把上面代码加到子线程里面执行,略慢。可以在 AppDelegate 里面从服务器请求完数据再加索引的。

    1.2  接收点击事件

?
1 2 3 4 5 6 7 8 9 10 11 @available(iOS 8.0, *) func application(application: UIApplication, continueUserActivity userActivity: NSUserActivity, restorationHandler: ([AnyObject]?) -> Void) -> Bool { if #available(iOS 9.0, *) { if userActivity.activityType == CSSearchableItemActionType { if let uniqueIdentifier = userActivity.userInfo?[CSSearchableItemActivityIdentifier] as? String, let label = userActivity.title { // 页面跳转 } } } return true }

二、额外经验

    2.1  CSSearchableItemAttributeSet

    可以不设置 thumbnailData ,这样默认就是当前应用的 LOGO;另外注意 thumbnailURL 并不是用来指定网络图片地址的 - - #,所以你要加缩略图的话需要先把网上的下载到本地再设置

    2.2  CSSearchableItem

    默认失效是一个月,另外发现无法携带更多数据(比如通过 CSSearchableItemAttributeSet 的 setValue ,在 userActivity 那边都接收不到)

    2.3  没有找到索引条数的限制

    http://stackoverflow.com/questions/35284223/is-there-a-limit-for-number-of-items-cssearchableitem-in-core-spotlight-cssear

    我发现添加索引还是挺慢的,另外那个批量索引没弄懂,感觉应该是又有删除又有新增的话适合批量处理。

    2.4  没用找到重新索引的方法

    重复调用也没用问题,只要 uniqueIdentifier 匹配会覆盖老的数据

    2.5  没有找到提升排名的方法

    好像系统会有一套算法来自动提升排名。

总结:以上就是 IOS 开发 Core Spotlight 实例应用,以及经验分享,希望能帮助开发IOS的同学。

如果您对该产品感兴趣,请填写办理(客服微信:xiaoxiongyidong)

为您推荐:

发表评论

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。