iOS-自定义Intent及ShortCut,能通过快捷指令唤醒APP并跳转到指定页面

1.Xcode->New->File->搜索Intent

2.在新建的intent文件中中New intent

3.完善资料,内容可自定义

4.创建Extension,file -> new -> target , 选择 Intents Extension 即可

创建完成后,在intents文件中勾选以下target,否则在扩展里,无法访问到前面创建的Intent类

编译程序,Xcode 会自动生成对应的类,我这里的话会生成 LaunchAppIntent 类,下面需要使用

5.完善IntentHandler

引入上述生成的文件,并写入代理,如果之前未勾选target是无法引入的

在代理中写入,以及点击确认按钮后执行的事件

复制代码
- (void)handleLaunchApp:(LaunchAppIntent *)intent completion:(void (^)(LaunchAppIntentResponse * _Nonnull))completion {
    completion([[LaunchAppIntentResponse alloc] initWithCode:LaunchAppIntentResponseCodeContinueInApp userActivity:nil]);
}

- (void)confirmLaunchApp:(LaunchAppIntent *)intent completion:(void (^)(LaunchAppIntentResponse * _Nonnull))completion {
    NSUserActivity *userActivity = [[NSUserActivity alloc] initWithActivityType:NSStringFromClass([LaunchAppIntent class])];
    LaunchAppIntentResponse *response = [[LaunchAppIntentResponse alloc] initWithCode:LaunchAppIntentResponseCodeSuccess userActivity:userActivity];
    completion(response);
}

6.在手机快捷指令中可以进行测试,新增快捷指令,搜索Xcode中设置好的,点击完成

点击创建好的指令,即能实现唤起APP,也可通过Siri唤醒,名字按照上述自行定义

7.实现APP自动跳转到制动页面

在AppDelegate中引入你要跳转的界面和intent,唤醒APP会通过一下方法进行执行,设置好快捷指令后将会自动跳转到你设置好的控制器

复制代码
- (BOOL)application:(UIApplication *)application continueUserActivity:(NSUserActivity *)userActivity restorationHandler:(void (^)(NSArray<id<UIUserActivityRestoring>> * _Nullable))restorationHandler {
    if([userActivity.interaction.intent isKindOfClass:[LaunchAppIntent class]]){
        ViewController *vc = [ViewController new];
        UINavigationController *nav = [[UINavigationController alloc] initWithRootViewController:vc];
        self.window.rootViewController = nav;
        ViewController2 *secondVC = [[ViewController2 alloc] init];
        [vc.navigationController pushViewController:secondVC animated:YES];
        return YES;
    }
    return NO;
}

8.如果想进行多种操作,可以在此处设置Parameters,在Parameters内新增变量

demo在这里

相关推荐
一枚前端小能手1 分钟前
「周更第3期」实用JS库推荐:Lodash
前端·javascript
艾小码1 分钟前
Vue组件到底怎么定义?全局注册和局部注册,我踩过的坑你别再踩了!
前端·javascript·vue.js
Cyan_RA98 分钟前
计算机网络面试题 — TCP连接如何确保可靠性?
前端·后端·面试
谢尔登8 分钟前
【CSS】层叠上下文和z-index
前端·css
鹏多多9 分钟前
前端复制功能的高效解决方案:copy-to-clipboard详解
前端·javascript
AryaNimbus11 分钟前
你不知道的 Cursor系列(三):再也不用死记硬背 Linux 命令,终端 Cmd+K 来帮你!
前端·ai编程·cursor
uhakadotcom13 分钟前
Rollup 从0到1:TypeScript打包完全指南
前端·javascript·面试
Mintopia18 分钟前
实时语音转写 + AIGC:Web 端智能交互的技术链路
前端·javascript·aigc
2503_9284115620 分钟前
9.15 ES6-变量-常量-块级作用域-解构赋值-箭头函数
前端·javascript·es6
Pedantic22 分钟前
SwiftUI ShareLink – 显示分享表单的使用
前端