iOS APP开发添加3D Touch

本文就iOS开发中如何集成3DTouch做下简单的讲解。

开发环境及调试设备: Xcode7或以上,iOS9或以上,iPhone6s或以上3DTouch功能主要分为两大块:

1、主屏幕Icon上的快捷标签(Home Screen Quick Actions); 

2、Peek(预览)和Pop(跳至预览的详细界面)

一、Home Screen Quick Actions的实现

主屏幕icon上的快捷标签的实现方式有两种,一种是在工程文件info.plist里静态设置,另一种是代码的动态实现。本人比较喜欢第二种设置,动态实现。

1、静态设置

静态设置方式如下图所示:

下面是各个标签类型的说明,plist文件里还没提供UIApplicationShortcutItems选项,没办法,只能手动敲了,或者直接复制粘贴过去。

UIApplicationShortcutItems:数组中的元素就是我们的那些快捷选项标签。

UIApplicationShortcutItemTitle:标签标题(必填)

UIApplicationShortcutItemType:标签的唯一标识 (必填)

UIApplicationShortcutItemIconType:使用系统图标的类型,如搜索、定位、home等(可选)

UIApplicationShortcutItemIcon File:使用项目中的图片作为标签图标 (可选)

UIApplicationShortcutItemSubtitle:标签副标题 (可选)

UIApplicationShortcutItemUserInfo:字典信息,如传值使用 (可选)

2、动态实现

一、在app启动方法里 

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions

实现

//设置3D Touch

if([[[UIDevice currentDevice] systemVersion] floatValue] >= 9.0){

          [self setup3DTouch:application];

}

注意:需要判断是ios 9.0之后才有的,防止没有3D Touch闪退问题

二、创建自定义的UIApplicationShortcutItem,这里我创建了4个

   type 该item 唯一标识符     

    localizedTitle :标题   

   localizedSubtitle:副标题    

   icon:icon图标 可以使用系统类型 也可以使用自定义的图片   

   userInfo:用户信息字典 自定义参数,完成具体功能需求   

系统自带的icon图对应如下,不想用的话也可以让你们UI自己设计一下

三、实现相应的点击跳转处理方法


很多人按上面集成后,发现没有系统分享,难道哪里不对吗?当然对了,哥哥怎么能骗你们,欺骗你们幼小的心灵呢?看下图:

是不是费劲脑汁找这个呢,这个要等到app上线之后系统会为你自动加上的,不要瞎找设置的方法了。

注意:系统分享 app上线之后才显示的,别费尽脑汁找方法了!

二、Peek和Pop的实现

效果实现

1、注册(在哪个页面上使用该功能就注册在哪个页面上) 这里以UI tableVIew为例:

- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath 

在这个代理面写上 

if ([self respondsToSelector:@selector(traitCollection)]) {

        if ([self.traitCollection respondsToSelector:@selector(forceTouchCapability)]) {

            if (self.traitCollection.forceTouchCapability == UIForceTouchCapabilityAvailable) {

                [self registerForPreviewingWithDelegate:(id)self sourceView:cell];

            }

        }

    }

2、遵守UIViewControllerPreviewingDelegate协议

3、实现UIViewControllerPreviewingDelegate方法

peek方法

- (nullable UIViewController *)previewingContext:(id)previewingContext viewControllerForLocation:(CGPoint)location NS_AVAILABLE_IOS(9_0) {

    NSIndexPath *indexPath = [self.tableView indexPathForCell:(UITableViewCell* )[previewingContext sourceView]];

    HomeListModel *model = self.viewModel.dataArray[indexPath.row];

    OrderDetailViewController *orderDetailVC = [[OrderDetailViewController alloc] initWithParams:@{@"orderId":@(model.order_id)}];

    previewingContext.sourceRect = orderDetailVC.view.frame;

    return orderDetailVC;

}

pop方法

- (void)previewingContext:(id)previewingContext commitViewController:(UIViewController *)viewControllerToCommit NS_AVAILABLE_IOS(9_0) {

    [self showViewController:viewControllerToCommit sender:self];

}

4、当弹出预览时,上滑预览视图,出现预览视图中快捷选项(注意:该项是可选的,如果没有上滑按钮操作可以不实现该方法)

- (NSArray> *)previewActionItems {

    UIPreviewAction *action1 = [UIPreviewAction actionWithTitle:@"分享" style:UIPreviewActionStyleDefault handler:^(UIPreviewAction * _Nonnull action, UIViewController * _Nonnull previewViewController) {

        //点击事件处理

    }];

    UIPreviewAction *action2 = [UIPreviewAction actionWithTitle:@"跳过" style:UIPreviewActionStyleDefault handler:^(UIPreviewAction * _Nonnull action, UIViewController * _Nonnull previewViewController) {

        //点击事件处理

    }];

    NSArray *actions = @[action1,action2];

    return actions;

}

3DTouch就先介绍这些,以上有说的不对的地方,还望高手指正,相互学习,共同进步。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,911评论 5 460
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 82,014评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 142,129评论 0 320
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,283评论 1 264
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,159评论 4 357
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,161评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,565评论 3 382
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,251评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,531评论 1 292
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,619评论 2 310
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,383评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,255评论 3 313
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,624评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,916评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,199评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,553评论 2 342
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,756评论 2 335

推荐阅读更多精彩内容

  • 极光推送: 1.JPush当前版本是1.8.2,其SDK的开发除了正常的功能完善和扩展外也紧随苹果官方的步伐,SD...
    Isspace阅读 6,690评论 10 16
  • 前言 关于这篇文章 由于iPhone 6S发布不到一年的时间,很多新特性、新技术还未普遍,不管是3D Touch的...
    Tangentw阅读 4,444评论 8 18
  • 1.模拟器touch 效果git下载连接:https://github.com/DeskConnect/SBSho...
    f48ac133a97f阅读 1,132评论 0 1
  • API介绍 UITouch类里API的变化 iOS9中添加的属性 altitudeAngle 当笔平行于平面时,该...
    雄壮的玻璃心阅读 2,462评论 0 5
  • 许多集成的步骤个推官网都有了,这里只写关于推送的远程推送和本地通知的步骤和代码。APP在后台时:走苹果的APNS通...
    AllureJM阅读 2,675评论 1 9