iOS9新特性の3D-touch-下篇

再看一下如何在應(yīng)用內(nèi)集成3Dtouch.
3D-touch操作分為輕按peek跟重按pop,根據(jù)apple官方設(shè)計規(guī)范,一般來說peek呼出預(yù)覽視圖,我在storyboard里面創(chuàng)建一個PreviewController用于描述呼出的預(yù)覽視圖,同時創(chuàng)建了一個DetailViewController用于顯示最終顯示的視圖,同時我們應(yīng)該注意,pop之后的視圖應(yīng)該與用戶正常點擊進去之后沒有任何區(qū)別.
此時我們應(yīng)用層級為

tableView---(peek)---->previewController---(pop)--->DetailviewController

無論何時,我們在使用3D-touch的時候應(yīng)當(dāng)先檢查3D-touch的可用性

- (void)check3Dtouch
{
    //檢測3Dtouch是否可用,若可用注冊預(yù)覽視圖代理
    if (self.traitCollection.forceTouchCapability == UIForceTouchCapabilityAvailable) {
        [self registerForPreviewingWithDelegate:self sourceView:self.view];
    }
}

我們在viewWillAppear里面和用戶進行3D-touch相關(guān)設(shè)置的時候都要檢查可用性

- (void)viewWillAppear:(BOOL)animated
{
    [super viewWillAppear:animated];
    
    [self check3Dtouch];
}

///用戶可能進入設(shè)置開啟/關(guān)閉3Dtouch的時候,在這里需要再次檢測3Dtouch可用性
- (void)traitCollectionDidChange:(UITraitCollection *)previousTraitCollection
{
    [self check3Dtouch];
}

別忘了設(shè)置UIViewControllerPreviewingDelegate預(yù)覽視圖代理.

接下來只需要在對應(yīng)的代理方法里面返回相應(yīng)的控制器即可


- (UIViewController *)previewingContext:(id<UIViewControllerPreviewing>)previewingContext viewControllerForLocation:(CGPoint)location{
    
    if ([self.presentedViewController isKindOfClass:[PreviewViewController class]]) {return nil;}
    
    UIStoryboard *sb = [UIStoryboard storyboardWithName:@"Main" bundle:nil];
    PreviewViewController *previewController = [sb instantiateViewControllerWithIdentifier:@"preview"];
    
    location = CGPointMake(10, 100);
    return previewController;
}

- (void)previewingContext:(id<UIViewControllerPreviewing>)previewingContext commitViewController:(UIViewController *)viewControllerToCommit{
    
    UIStoryboard *sb = [UIStoryboard storyboardWithName:@"Main" bundle:nil];
    DetailViewController *detailView = [sb instantiateViewControllerWithIdentifier:@"detailView"];
    
    [self showViewController:detailView sender:self];
    
}

此時peekpop手勢都已經(jīng)集成完畢,這時候還想實現(xiàn)類似在preview下面添加alert的操作,如系統(tǒng)message里面的快捷回復(fù)

8.png

其實只需要在previewController里面實現(xiàn)- (NSArray<id<UIPreviewActionItem>> *)previewActionItems方法即可.
PS:在xcode6.3時OC添加了制定數(shù)組元組類型的功能,有利于寫出更加嚴謹?shù)拇a,好評~

- (NSArray<id<UIPreviewActionItem>> *)previewActionItems
{
    UIPreviewAction *action1 = [UIPreviewAction actionWithTitle:@"action1" style:UIPreviewActionStyleDefault handler:^(UIPreviewAction * _Nonnull action, UIViewController * _Nonnull previewViewController) {
        NSLog(@"action1 click");
    }];
    UIPreviewAction *action2 = [UIPreviewAction actionWithTitle:@"action2" style:UIPreviewActionStyleDestructive handler:^(UIPreviewAction * _Nonnull action, UIViewController * _Nonnull previewViewController) {
        NSLog(@"action2 click");
    }];
    UIPreviewAction *action3 = [UIPreviewAction actionWithTitle:@"action3" style:UIPreviewActionStyleSelected handler:^(UIPreviewAction * _Nonnull action, UIViewController * _Nonnull previewViewController) {
        NSLog(@"action3 click");
    }];
    
    
    UIPreviewActionGroup *group1 = [UIPreviewActionGroup actionGroupWithTitle:@"group1" style:UIPreviewActionStyleDefault actions:@[action1,action2]];
    UIPreviewActionGroup *group2 = [UIPreviewActionGroup actionGroupWithTitle:@"group2" style:UIPreviewActionStyleDestructive actions:@[action1,action3]];
    UIPreviewActionGroup *group3 = [UIPreviewActionGroup actionGroupWithTitle:@"group3" style:UIPreviewActionStyleSelected actions:@[action2,action3]];
    
//    NSArray *items = @[action1,action2,action3];
//    NSArray *items = @[group1,group2,group3];
    NSArray *items = @[action1,group1,action2,group2,action3,group3];
    return items;
}

有興趣的話可以自己動手體會一下UIPreviewActionGroupUIPreviewAction的區(qū)別.

你可以在github下載到此源碼

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末郊艘,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,682評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件萍桌,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機沐兵,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,277評論 3 395
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來便监,“玉大人扎谎,你說我怎么就攤上這事碳想。” “怎么了毁靶?”我有些...
    開封第一講書人閱讀 165,083評論 0 355
  • 文/不壞的土叔 我叫張陵胧奔,是天一觀的道長。 經(jīng)常有香客問我预吆,道長龙填,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,763評論 1 295
  • 正文 為了忘掉前任拐叉,我火速辦了婚禮岩遗,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘凤瘦。我一直安慰自己宿礁,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,785評論 6 392
  • 文/花漫 我一把揭開白布蔬芥。 她就那樣靜靜地躺著梆靖,像睡著了一般。 火紅的嫁衣襯著肌膚如雪笔诵。 梳的紋絲不亂的頭發(fā)上返吻,一...
    開封第一講書人閱讀 51,624評論 1 305
  • 那天,我揣著相機與錄音嗤放,去河邊找鬼思喊。 笑死,一個胖子當(dāng)著我的面吹牛次酌,可吹牛的內(nèi)容都是我干的恨课。 我是一名探鬼主播,決...
    沈念sama閱讀 40,358評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼岳服,長吁一口氣:“原來是場噩夢啊……” “哼剂公!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起吊宋,我...
    開封第一講書人閱讀 39,261評論 0 276
  • 序言:老撾萬榮一對情侶失蹤纲辽,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后璃搜,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體拖吼,經(jīng)...
    沈念sama閱讀 45,722評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,900評論 3 336
  • 正文 我和宋清朗相戀三年这吻,在試婚紗的時候發(fā)現(xiàn)自己被綠了吊档。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,030評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡唾糯,死狀恐怖怠硼,靈堂內(nèi)的尸體忽然破棺而出鬼贱,到底是詐尸還是另有隱情,我是刑警寧澤香璃,帶...
    沈念sama閱讀 35,737評論 5 346
  • 正文 年R本政府宣布这难,位于F島的核電站,受9級特大地震影響葡秒,放射性物質(zhì)發(fā)生泄漏姻乓。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,360評論 3 330
  • 文/蒙蒙 一眯牧、第九天 我趴在偏房一處隱蔽的房頂上張望糖权。 院中可真熱鬧,春花似錦炸站、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,941評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至腿堤,卻和暖如春阀坏,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背笆檀。 一陣腳步聲響...
    開封第一講書人閱讀 33,057評論 1 270
  • 我被黑心中介騙來泰國打工忌堂, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人酗洒。 一個月前我還...
    沈念sama閱讀 48,237評論 3 371
  • 正文 我出身青樓士修,卻偏偏與公主長得像,于是被迫代替她去往敵國和親樱衷。 傳聞我的和親對象是個殘疾皇子棋嘲,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,976評論 2 355

推薦閱讀更多精彩內(nèi)容

  • 前言 關(guān)于這篇文章 由于iPhone 6S發(fā)布不到一年的時間,很多新特性矩桂、新技術(shù)還未普遍沸移,不管是3D Touch的...
    Tangentw閱讀 4,497評論 8 18
  • 前言 關(guān)于3D touch蘋果官方文檔是這么開始介紹的: 大意如下:iOS9開始,所有新的手機都增加了一個三維的用...
    VV木公子閱讀 2,229評論 3 39
  • 發(fā)現(xiàn) 關(guān)注 消息 iOS 第三方庫侄榴、插件雹锣、知名博客總結(jié) 作者大灰狼的小綿羊哥哥關(guān)注 2017.06.26 09:4...
    肇東周閱讀 12,105評論 4 62
  • 如果我辭職了會怎樣蕊爵,這是我一直都不敢面對的問題,也是我的恐懼所在涣达。 我正在做著的是一份親人朋友稱羨的工...
    青_竹閱讀 210評論 0 1
  • 有一天在辆,爺爺把油畫拿到了家里证薇,·我們吃完飯后,就在家里畫油畫匆篓。 我畫的是小豬佩奇和喬治浑度,我從小豬的臉開始畫,我把佩...
    嘉張怡2閱讀 201評論 0 0