怎么给App的某个功能添加桌面快捷方式?

iOS中给App添加快捷方式的几种方案:

  1. 3DTouch,长按App唤起3DTouch菜单,这个同时也可以当做小组件添加到首屏左边的快捷方式页面中。
  2. 通过Siri唤醒对应的App。
  3. 直接在桌面添加对应的快捷方式,点击快捷方式直接跳到某个App的某个功能。

方案1,3DTouch的入口不太容易发现,方案2,是跟Siri做的语音交互,下面重点说下方案三。

方案三是利用了Safari的PWA功能,将编码好的网页内容和图标保存到桌面。点击桌面快捷方式打开网页执行JS,跳转到App对应的功能。

下面是实现步骤

1. 配置App跳转的URL

在Xcode的Target->Info->URL Types的URL Schemes添加addshortcuts,作为跳转url的协议头。

BOB给app中需要添加快捷方式的功能页设置好跳转url:addshortcuts://profile。并在AppDelegate中添加如下代码

func?application(_?app:?UIApplication,?open?url:?URL,?options:?[UIApplication.OpenURLOptionsKey?:?Any]?=?[:])?->?Bool?{

let?storyboard?=?UIStoryboard.init(name:?“Main”,?bundle:?Bundle.main)
let?featureVc?=?storyboard.instantiateViewController(withIdentifier:?“FeatureViewController”)

if?let?navController?=?window?.rootViewController?as??UINavigationController,?let?topController?=?navController.topViewController{
if?topController.isKind(of:?FeatureViewController.self)?{
return?true
}
if?url.absoluteString?==?“addshortcuts://profile”?{
navController.pushViewController(featureVc,?animated:?false)
}
}
return?true
}到这里BOB可以在浏览器中输入addshortcuts://profile,如果可以跳转到App对应的功能页面表示一切正常。

2. 设置添加快捷方式到桌面的引导H5页面和跳转到App的H5页面

1. 引导添加桌面快捷方式的H5页面

2. 跳转到App的H5页面

这个页面是个空白页,当BOB点击快捷方式的时候,通过这个空白页跳转到App。

<a?id=”redirect”?href=”addshortcuts: profile”=””></a>

打开空白页,执行下面这段JS,模拟点击上面的a标签

var?element?=?document.getElementById(‘redirect’);
var?event?=?document.createEvent(‘MouseEvents’);
event.initEvent(‘click’,?true,?true,?document.defaultView,?1,?0,?0,?0,?0,?false,?false,?false,?false,?0,?null);
document.body.style.backgroundColor?=?‘#FFFFFF’;
setTimeout(function()?{?element.dispatchEvent(event);?},?25);

其实引导页和跳转页可以放到一起,通过window.navigator.standalone检测Safari打开的Web应用程序是否全屏显示。如果是全屏显示表示是从桌面快捷方式进入的,那么就显示空白页,自动执行上面那段JS。如果不是全屏显示表示是从app跳转过去的引导页。

3. 搭建可以打开编码后H5页面的本地server

1. h5编码

Safari可以直接打开一串包含页面内容编码的URL,这个URL包含了这个页面需要的所有信息。

data:text/html;base64,PGEgaHJlZj0iaHR0cHM6Ly9naXRodWIuY29tL0RhcmllbENoZW4vaU9TVGlwcyI+aU9TVGlwczwvYT4=

在Safari中输入上面那串URL,会显示一个iOSTips的标签。跟正常的标签一样,这是因为上面的URL是BOB经过base64编码后处理的。同样BOB可以把h5页面转化成这种URL编码格式。

2. 搭建本地server

iOS中不能用UIApplication.shared.open(url)的方式打开包含Base64编码的URL,如果BOB用SFSafariViewController,它也是不能够识别这个格式的URL。这个问题好像是出在苹果那边。

那支付宝是怎么做的呢?它是直接把这个页面部署到了服务端,BOB可以参考这种方法,用Swifter搭建一个本地的server。

guard?let?deeplink?=?URL(string:?“addshortcuts://profile”)?else?{
return
}
guard?let?shortcutUrl?=?URL(string:?“http://localhost:8244/s”)?else?{
return
}
guard?let?iconData?=?UIImage(named:?“feature_icon”)?.jpegData(compressionQuality:?0.5)?else?{
return
}
let?html?=?htmlFor(title:?“功能快捷方式”,?urlToRedirect:?deeplink.absoluteString,?icon:?iconData.base64EncodedString())
guard?let?base64?=?html.data(using:?.utf8)?.base64EncodedString()?else?{
return
}
server[“/s”]?=?{?request?in
return?.movedPermanently(“data:text/html;base64,\(base64)”)
}
try??server.start(8244)