6s以上机子增加的新功能3DTouch,官方给了两种实现方式,一是在plist文件中添加,二是纯代码实现,这里我做的是用代码实现,也是非常的简单的,至于plist里面的就不贴出来了.废话不多说,直接上代码.
自己在实现该功能的时候也是看了网上一些前辈写的东西,有很多都是在AppDelegate里面实现全部的操作。为了方便管理和性能,本人将其单独写了出来.
首先自己创建了一个继承NSObject的文件,在WoKaTouch3D.h(名字随意)里面定义了一个不可变的数组和一个shortcutItem.
WoKaTouch3D.m
对数组(shortcutItemArray)进行初始化
type :唯一标识,不能为空
localizedTitle:显示title
localizedSubtitle:子title(可以为nil)
icon:显示图标的名字
userInfo:可以为空;
以上都是用于界面显示的,
接下来实现之前定义的ShortCutItems的set方法
由于项目需要判断多个地方的viewControllers,所以这里将其写在了一个公共的方法里面
自己看,很好理解
+ (UIViewController *)findTopViewControllers
{
id topVC = [self topMostViewController];
UIViewController *topViewCotrl = nil;
if ([topVC isKindOfClass:[UINavigationController class]])//导航控制器
{
topViewCotrl = [[(UINavigationController *)topVC viewControllers] lastObject];
}
else if ([topVC isKindOfClass:[UITabBarController class]])// TabBar VC
{
topViewCotrl = [(UITabBarController *)topVC selectedViewController];
if ([topViewCotrl isKindOfClass:[UINavigationController class]])
{
topViewCotrl = [[(UINavigationController *)topViewCotrl viewControllers] lastObject];
}
}
else
{
topViewCotrl = (UIViewController *) topVC;
}
return topViewCotrl;
}
+ (UIViewController *)topMostViewController
{
UIViewController *TopVC = [UIApplication sharedApplication].keyWindow.rootViewController;
while (TopVC.presentedViewController)
{
TopVC = TopVC.presentedViewController;
}
return TopVC;
}
这里才是做页面跳转的真正的方法,我相信注释已经非常明白了
最后还有一些辅助方式的实现
- (void)changeShortCut:(shortcutItem)type withSubTitle:(NSString *)subTitle
{
NSMutableArray *tempArray = [NSMutableArray arrayWithArray:[UIApplication sharedApplication].shortcutItems];
UIMutableApplicationShortcutItem *item = [self getShortCutWithType:1-type];
item.localizedSubtitle = subTitle;
[tempArray replaceObjectAtIndex:1-type withObject:item];
[UIApplication sharedApplication].shortcutItems = tempArray;
}
- (UIMutableApplicationShortcutItem *)getShortCutWithType:(shortcutItem)type
{
return [self.shortcutItemArray objectAtIndex:type];
}
- (NSInteger)indexOfSpecificViewController:(Class)class
{
NSArray *viewControllers = appDelegate.tabBarController.viewControllers;
NSInteger index = -1;
for (UIViewController *temp in viewControllers)
{
if ([temp isKindOfClass:class])
{
index = [viewControllers indexOfObject:temp];
break;
}
}
return index;
}
- (BOOL)viewControllIsModal:(UIViewController *)viewController
{
if([viewController presentingViewController])
return YES;
if([[viewController presentingViewController] presentedViewController] == viewController)
return YES;
if([[[viewController navigationController] presentingViewController] presentedViewController] == [viewController navigationController])
return YES;
if([[[viewController tabBarController] presentingViewController] isKindOfClass:[UITabBarController class]])
return YES;
return NO;
}
到了这里,一个单独的方法已经基本上写完了,接下来就是要调用的问题
我们在APPDelegate.m里面实现调用
因为3D Touch是在9.0以后才能使用的,所以首先我们要在didFinishLaunchingWithOptions进行版本信息的判断,只有版本信息大于9.0以后的,我们才能使用
/*3D touch*/
if (OSVersion >= 9.0)
{
application.shortcutItems = [[self touch3D] shortcutItemArray];
}
当然在此之前,我们应该初始化这个单独的方法
做完这些之后,我运行,没有报错,也能跳转,只是随便哪个shortCut都只能跳转到第一个界面,一直达不到自己想要的效果,后面经过一些列的检查,原来是有一个地方没有实现
这里一定要实现,否则就会成为上面那种情况.
文章到这里也就完结了,具体的效果我就不贴图了,希望可以帮助到需要的小伙伴们