3Dtouch

3DTouch简介

3D Touch的触控技术,被苹果称为新一代多点触控技术。其实,就是此前在Apple Watch上采用的Force Touch,
屏幕可感应不同的感压力度触控。

3D Touch ,苹果iPhone 6s的新功能,看起来类似 PC 上的右键。有Peek Pop 两种新手势。

实现效果

效果图.png

其它不多讲,直接上效果

效果一:

当点击AppIcon时弹出以下效果(起个专业点的名称:AppIcon深按弹窗)

效果.png

该效果实现分为两步:
第一步:设置标题
静态设置:通过plist文件方式
动态设置:通过代码方式.
第二步:监听标题点击

第一步:设置标题
静态设置:通过plist文件配置,配置信息如果

B6F8D76A-2923-435B-BC03-EAB356DB2DEA.png

动态设置:通过代码方式.
实现步骤:
在AppDelegate当中书写

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

      //设置图标长按时,弹出的样式.
      //iconWithType:图标的类型
      UIApplicationShortcutIcon *icon0 =
      [UIApplicationShortcutIcon iconWithType:UIApplicationShortcutIconTypeSearch];
      //创建第一个标题
      UIApplicationShortcutItem *item0 = [[UIApplicationShortcutItem alloc] initWithType:@"tpye0"
                                                                          localizedTitle:@"标题"
                                                                       localizedSubtitle:@"我是子标题"
                                                                                    icon:icon0
                                                                                userInfo:@{@"info": @"我是要传入的信息"}];
      //创建第二个标题
      UIApplicationShortcutItem *item1 = [[UIApplicationShortcutItem alloc] initWithType:@"tpye0"
                                                                          localizedTitle:@"标题2"
                                                                       localizedSubtitle:@"我是子标题"
                                                                                    icon:icon0
                                                                                userInfo:@{@"info": @"我是要传入的信息"}];
      //设置shortcutItems
      application.shortcutItems = @[item0,item1];


      return YES;
  }

第二步:监听标题点击(在Appdelegate中监听)

//当点击AppIcon弹窗口,点击标题时调用
//shortcutItem点击的是哪一个Item
- (void)application:(UIApplication *)application performActionForShortcutItem:(nonnull UIApplicationShortcutItem *)shortcutItem completionHandler:(nonnull void (^)(BOOL))completionHandler
{
   //通过判断标题的类型,执行相应的操作
    if ([shortcutItem.type isEqualToString:@"tpye0"]) {
        NSLog(@"%@",shortcutItem.userInfo[@"info"]);
    } else {
        NSLog(@"asdf");
    }
}

效果二:Peek和Pop


效果如下:
点击一行Cell重按弹出以下效果

.png

点击peek出来的窗口继续重按弹出以下效果

.png

使用步骤:
1:给Cell注册3DTouch
2:遵守协议<UIViewControllerPreviewingDelegate>
3:实现协议方法

第1步:给Cell注册3DTouch

1.1 判断是否支持3DTouch
 1.2 注册Cell支持3DTouch,并设置代理
       实现代码如下:

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

XqHeroCell *cell =  [tableView dequeueReusableCellWithIdentifier:@"CellID"];
//判断是否支持3DTouch
if (self.traitCollection.forceTouchCapability == UIForceTouchCapabilityAvailable) {
    //注册Cell支持3DTouch,并设置代理
    [self registerForPreviewingWithDelegate:self sourceView:cell];
}
//取出当前行模型
XqHeroItem *item = self.dataArray[indexPath.row];
cell.heroItem = item;
return cell; 
 }

第2步:遵守协议<UIViewControllerPreviewingDelegate>

        @interface XqViewController ()<UITableViewDataSource,UITableViewDelegate,UIViewControllerPreviewingDelegate>
@property (weak, nonatomic) IBOutlet UITableView *tableView;
@property(nonatomic, strong) NSArray *dataArray;
     @end

第3步:实现协议方法

//当中度按压时调用该方法
//previewingContext:可以从该参数中获取之前注册的View.
- (nullable UIViewController *)previewingContext:(id     <UIViewControllerPreviewing>)previewingContext     viewControllerForLocation:(CGPoint)location{
    //获取sourceView
    XqHeroCell *cell = (XqHeroCell *)[previewingContext sourceView];
    //设置弹出预览的位置(peek是从哪个位置弹出)
    [previewingContext setSourceRect:cell.bounds];
    //设置弹框的View.
    XqDetailViewController *detailVC = [[XqDetailViewController alloc] init];
    //设置弹出peek的高度(设置宽度是没有效果的)
    detailVC.preferredContentSize = CGSizeMake(0, 500);
    //取出Cell的模型传递给详情控制器.
    detailVC.heroItem = cell.heroItem;
    //设置标题
    detailVC.title = @“高俊";
    //在这里想弹一个带有导航条的控制器,控制器里面包装一个导航条.直接返回导航控制器.那么就会peek出一个导航控制器.

    return [[XqNavigationController alloc]     initWithRootViewController:detailVC];
}

弹出效果如果下:

  //弹框出现后,继续重按时调用
  //viewControllerToCommit:就是上面传入的XqDetailViewController的控制器.
  //commitViewController默认是UIViewController,因为peek时返回的控制器是一个导航控制器.那么在这里面自己手动改成的导航控制器.
  - (void)previewingContext:(id <UIViewControllerPreviewing>)previewingContext commitViewController:(UINavigationController *)viewControllerToCommit{

      //获取导航控制器的根控制器.因为当前已经是一个导航控制器了,不能再继续push一个导航控制器,所以要先获取peek的导航控制器里面的根控制器.
      //然后再拿当前的控制器把获取的控制器push进去.
      XqDetailViewController *detailVC = viewControllerToCommit.childViewControllers.lastObject;
      [self.navigationController pushViewController:detailVC animated:YES];

      //使用show和push是一样的效果
      //[self showViewController:viewControllerToCommit sender:self];
  }

执行效果如下:


相当于点击cell跳转到下一个控制器.点击Cell跳转到下一个控制器代码如果:

-(void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath{    
   //创建控制器
    XqDetailViewController *detailVC =     [[XqDetailViewController alloc] init];   
 //获取当前选中的行模型   
   XqHeroItem *item = self.dataArray[indexPath.row];    
  //给详情控制器模型赋值  
  detailVC.heroItem = item; 
   //跳转到详情控制器    [self.navigationController pushViewController:detailVC animated:YES];

}

效果三:弹窗Peek出现后,向上滑动,会出现类似ActionSheet的控件.
效果如下:

实现该效果必须得要是在peek出来的那个控制器当中实现以下方法,
(我们这里peek出来的是一个导航控制器,所以必须得要在导航控制器中实现该方法)

   //设置控制器在弹窗时候,下面输出的数组
-(NSArray<id<UIPreviewActionItem>> *)previewActionItems{
    //弹出的第一个按钮
    UIPreviewAction *action0 = [UIPreviewAction actionWithTitle:@"action0" style:UIPreviewActionStyleDefault handler:^(UIPreviewAction * _Nonnull action, UIViewController * _Nonnull previewViewController) {
        NSLog(@"%s, line = %d, action0 = %@, previewViewController = %@", __FUNCTION__, __LINE__, action, previewViewController);

    }];

    UIPreviewAction *action1 = [UIPreviewAction actionWithTitle:@"action1" style:UIPreviewActionStyleDestructive handler:^(UIPreviewAction * _Nonnull action, UIViewController * _Nonnull previewViewController) {
        NSLog(@"%s, line = %d, action1 = %@, previewViewController = %@", __FUNCTION__, __LINE__, action, previewViewController);
    }];

    UIPreviewAction *action2 = [UIPreviewAction actionWithTitle:@"action2" style:UIPreviewActionStyleSelected handler:^(UIPreviewAction * _Nonnull action, UIViewController * _Nonnull previewViewController) {
        NSLog(@"%s, line = %d, action2 = %@, previewViewController = %@", __FUNCTION__, __LINE__, action, previewViewController);
    }];
    UIPreviewAction *action3 = [UIPreviewAction actionWithTitle:@"action3" style:UIPreviewActionStyleSelected handler:^(UIPreviewAction * _Nonnull action, UIViewController * _Nonnull previewViewController) {
        NSLog(@"%s, line = %d, action2 = %@, previewViewController = %@", __FUNCTION__, __LINE__, action, previewViewController);
    }];

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

推荐阅读更多精彩内容

  • 一.3DTouch的主要作用: 0.demo地址在最下面 1.Home Screen Quick Actions ...
    哆啦_阅读 2,239评论 6 5
  • Swift开发之3DTouch实用演练 2015年,苹果发布了iOS9以及iphone6s/iphone6s Pl...
    TitanCoder阅读 2,423评论 0 8
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 11,974评论 4 60
  • 简介:3D Touch的触控技术,被苹果称为新一代多点触控技术。其实,就是此前在Apple Watch上采用的Fo...
    d2757084c82f阅读 2,561评论 0 3
  • 今天来到公司,想着等会要出去了,内心居然没有渴望,而是一份纠结,不知去了结果怎样,不知去了别人会怎么看,写出来自己...
    Hi_张阅读 111评论 0 0