iOS 3DTouch

1. 3D Touch的主要應(yīng)用

官方文檔給出的應(yīng)用介紹主要有兩塊:

1.A user can now press your Home screen icon to immediately access functionality provided by your app.

2.Within your app, a user can now press views to see previews of additional content and gain accelerated access to features.

第一部分的應(yīng)用是我們可以通過3D手勢,在主屏幕上的應(yīng)用Icon處,直接進入應(yīng)用的響應(yīng)功能模塊。這個功能就例如我們上面的日歷示例,會在Icon旁邊出現(xiàn)一個菜單,點擊菜單我們可以進入相應(yīng)的功能單元。

我個人理解,這個功能,push消息功能加上iOS8推出的擴展today功能,這三個機制使iOS應(yīng)用變得無比靈活方便,用戶可以不需付出尋找的時間成本來快速使用自己需要的功能。

第二部分是對app的一個優(yōu)化,用戶可以通過3D Touch手勢在view上來預(yù)覽一些預(yù)加載信息,這樣的設(shè)計可以使app更加簡潔大方,交互性也更強。

2. 3D Touch的三大模塊

在我們的app中使用3D Touch功能,主要分為以下三個模塊:

1、Home Screen Quick Actions

通過主屏幕的應(yīng)用Icon,我們可以用3D Touch呼出一個菜單,進行快速定位應(yīng)用功能模塊相關(guān)功能的開發(fā)。如上面的日歷。

2、peek and pop

這個功能是一套全新的用戶交互機制,在使用3D Touch時,ViewController中會有如下三個交互階段:

(1)提示用戶這里有3D Touch的交互,會使交互控件周圍模糊


(2)繼續(xù)深按,會出現(xiàn)預(yù)覽視圖


(3)通過視圖上的交互控件進行進一步交互


這個模塊的設(shè)計可以在網(wǎng)址連接上進行網(wǎng)頁的預(yù)覽交互。

3.Force Properties

iOS9為我們提供了一個新的交互參數(shù):力度。我們可以檢測某一交互的力度值,來做相應(yīng)的交互處理。例如,我們可以通過力度來控制快進的快慢,音量增加的快慢等。

靜態(tài)3Dtouch 在info.plist中配置


必填項(下面兩個鍵值是必須設(shè)置的):

UIApplicationShortcutItemType 這個鍵值設(shè)置一個快捷通道類型的字符串

UIApplicationShortcutItemTitle 這個鍵值設(shè)置標簽的標題

選填項(下面這些鍵值不是必須設(shè)置的):

UIApplicationShortcutItemSubtitle 設(shè)置標簽的副標題

UIApplicationShortcutItemIconType 設(shè)置標簽Icon類型

UIApplicationShortcutItemIconFile? 設(shè)置標簽的Icon文件

② 動態(tài)在 appdelegate 中實現(xiàn)

動態(tài)標簽是我們在程序中,通過代碼添加的,與之相關(guān)的類,主要有三個:

UIApplicationShortcutItem 創(chuàng)建3DTouch標簽的類

UIMutableApplicationShortcutItem 創(chuàng)建可變的3DTouch標簽的類

UIApplicationShortcutIcon 創(chuàng)建標簽中圖片Icon的類

因為這些類是iOS9中新增加的類,所以其api的復(fù)雜程度并不大,下面我們來對其中方法與屬性進行簡要講解:

@interface UIApplicationShortcutItem : NSObject

//下面是兩個初始化方法 通過設(shè)置type,title等屬性來創(chuàng)建一個標簽,這里的icon是UIApplicationShortcutIcon對象,我們后面再說

- (instancetype)initWithType:(NSString *)type localizedTitle:(NSString *)localizedTitle localizedSubtitle:(nullable NSString *)localizedSubtitle icon:(nullable UIApplicationShortcutIcon *)icon userInfo:(nullable NSDictionary *)userInfo NS_DESIGNATED_INITIALIZER;

- (instancetype)initWithType:(NSString *)type localizedTitle:(NSString *)localizedTitle;

//下面這是一些只讀的屬性,獲取相應(yīng)的屬性值

@property (nonatomic, copy, readonly) NSString *type;

@property (nonatomic, copy, readonly) NSString *localizedTitle;

@property (nullable, nonatomic, copy, readonly) NSString *localizedSubtitle;

@property (nullable, nonatomic, copy, readonly) UIApplicationShortcutIcon *icon;

@property (nullable, nonatomic, copy, readonly) NSDictionary> *userInfo;

//這個類繼承于 UIApplicationShortcutItem,創(chuàng)建的標簽可變

@interface UIMutableApplicationShortcutItem : UIApplicationShortcutItem

@property (nonatomic, copy) NSString *type;

@property (nonatomic, copy) NSString *localizedTitle;

@property (nullable, nonatomic, copy) NSString *localizedSubtitle;

@property (nullable, nonatomic, copy) UIApplicationShortcutIcon *icon;

@property (nullable, nonatomic, copy) NSDictionary> *userInfo;

@end

//這個類創(chuàng)建標簽中的icon

@interface UIApplicationShortcutIcon : NSObject

//創(chuàng)建系統(tǒng)風(fēng)格的icon

+ (instancetype)iconWithType:(UIApplicationShortcutIconType)type;

//創(chuàng)建自定義的圖片icon

+ (instancetype)iconWithTemplateImageName:(NSString *)templateImageName;

@end

創(chuàng)建好標簽后,將其添加如application的hortcutItems數(shù)組中即可,示例如下:

- (void)viewDidLoad {

[super viewDidLoad];

// Do any additional setup after loading the view, typically from a nib.

//創(chuàng)建

UIApplicationShortcutItem * item = [[UIApplicationShortcutItem alloc]initWithType:@"two"localizedTitle:@"第二個標簽"localizedSubtitle:@"看我哦"icon:[UIApplicationShortcutIcon iconWithType:UIApplicationShortcutIconTypePlay] userInfo:nil];

//添加

[UIApplication sharedApplication].shortcutItems = @[item];

}

也可以在appdelegate 中寫

UIApplicationShortcutIcon *icon1 = [UIApplicationShortcutIcon iconWithTemplateImageName:@"iCon1"];

UIApplicationShortcutIcon *icon2 = [UIApplicationShortcutIcon iconWithTemplateImageName:@"iCon2"];

UIApplicationShortcutIcon *icon3 = [UIApplicationShortcutIcon iconWithTemplateImageName:@"iCon3"];

// create several (dynamic) shortcut items

UIMutableApplicationShortcutItem

*item1 = [[UIMutableApplicationShortcutItem

alloc]initWithType:@"com.test.dynamic" localizedTitle:@"Dynamic

Shortcut" localizedSubtitle:@"available after first launch" icon:icon1

userInfo:nil];

UIMutableApplicationShortcutItem

*item2 = [[UIMutableApplicationShortcutItem

alloc]initWithType:@"com.test.deep1" localizedTitle:@"Deep Link 1"

localizedSubtitle:@"Launch Nav Controller" icon:icon2 userInfo:nil];

UIMutableApplicationShortcutItem

*item3 = [[UIMutableApplicationShortcutItem

alloc]initWithType:@"com.test.deep2" localizedTitle:@"Deep Link 2"

localizedSubtitle:@"Launch 2nd Level" icon:icon3 userInfo:nil];

// add all items to an array

NSArray *items = @[item1, item2, item3];

// add this array to the potentially existing static UIApplicationShortcutItems

NSArray *existingItems = [UIApplication sharedApplication].shortcutItems;

NSArray *updatedItems = [existingItems arrayByAddingObjectsFromArray:items];

[UIApplication sharedApplication].shortcutItems = updatedItems;

- (void)application:(UIApplication *)application

performActionForShortcutItem:(UIApplicationShortcutItem *)shortcutItem

completionHandler:(void (^)(BOOL))completionHandler

在控制器中pop peek

首先控制器該繼承UIViewControllerPreviewingDelegate應(yīng)該判斷該控制器當前是否實現(xiàn)了3dtouch手勢 如果實現(xiàn)的話最好禁用長按手勢 (如果你的添加了該手勢的話)

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

[self registerForPreviewingWithDelegate:(id)self sourceView:self.view];

NSLog(@"3D Touch is available! Hurra!");

// no need for our alternative anymore

self.longPress.enabled = NO;

} else {

NSLog(@"3D Touch is not available on this device. Sniff!");

// handle a 3D Touch alternative (long gesture recognizer)

self.longPress.enabled = YES;

}

點擊進入預(yù)覽模式: 實現(xiàn)該協(xié)議方法

- (UIViewController *)previewingContext:(id)previewingContext viewControllerForLocation:(CGPoint)location

繼續(xù)按壓進入:實現(xiàn)該協(xié)議

- (void)previewingContext:(id)previewingContext commitViewController:(UIViewController *)viewControllerToCommit

預(yù)覽模式上拉實現(xiàn) :

我們預(yù)覽模式下上拉 出現(xiàn)一個視圖? 該視圖類 apple提供了 UIPreviewAction 該類來實現(xiàn),調(diào)用

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

NSLog(@"Action 1 triggered");

}];

回調(diào)中實現(xiàn)你要操作的行為

這個方法在 - (NSArray> *)previewActionItems? 中返回action 的數(shù)組

有趣的是 如果我們對action 繼續(xù)包裝一個數(shù)組 還是可以的

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容