iOS 指压即达集成iOS9里的3D Touch的方法
发布时间 - 2026-01-11 00:15:46 点击率:次1.前言

随着6S的到来,3DTouch被各大热门APP迅速普及,博主亲自体验后,发现使用便捷性大幅提高,随后自己照着文档,写了个Demo出来,分享给大家,希望能对有需要的朋友提供有一些帮助。
2.如何使用3D Touch?
2.1.主界面重按APP图标,弹出Touch菜单
在AppleDelegate文件中的程序入口处配置:
didFinishLaunchingWithOptions
//给App图标添加3D Touch菜单 //拍照 //菜单图标 UIApplicationShortcutIcon *iconCamera = [UIApplicationShortcutIcon iconWithType:UIApplicationShortcutIconTypeAdd]; //菜单文字 UIMutableApplicationShortcutItem *itemCamera = [[UIMutableApplicationShortcutItem alloc] initWithType:@"1" localizedTitle:@"拍照"]; //绑定信息到指定菜单 itemCamera.icon = iconCamera; //相册 //菜单图标 UIApplicationShortcutIcon *iconPhotoLibrary = [UIApplicationShortcutIcon iconWithType:UIApplicationShortcutIconTypeSearch]; //菜单文字 UIMutableApplicationShortcutItem *itemPhotoLibrary = [[UIMutableApplicationShortcutItem alloc] initWithType:@"2" localizedTitle:@"相册"]; //绑定信息到指定菜单 itemPhotoLibrary.icon = iconPhotoLibrary; //绑定到App icon application.shortcutItems = @[itemCamera,itemPhotoLibrary];
弹出菜单,我们需要让用户点击后跳转指定页面
这里我们会用到AppDelegate里新增加的一个方法
- (void)application:(UIApplication *)application performActionForShortcutItem:(nonnull UIApplicationShortcutItem *)shortcutItem completionHandler:(nonnull void (^)(BOOL))completionHandler;
让后我们需要在这个方法里做跳转的操作
//照相type
if ([shortcutItem.type isEqualToString:@"1"]) {
UIImagePickerController *picker = [[UIImagePickerController alloc] init];//初始化
picker.allowsEditing = YES;//设置可编辑
picker.sourceType = UIImagePickerControllerSourceTypeCamera;
[self.window.rootViewController presentViewController:picker animated:YES completion:nil];//进入照相界面
}
//相册type
if ([shortcutItem.type isEqualToString:@"2"]) {
UIImagePickerController *picker = [[UIImagePickerController alloc] init];//初始化
picker.allowsEditing = YES;//设置可编辑
picker.sourceType = UIImagePickerControllerSourceTypePhotoLibrary;
[self.window.rootViewController presentViewController:picker animated:YES completion:nil];//进入图片库
点击后分别会进入相机和相册
2.2. 3DTouch轻按预览功能,预览时底部菜单的添加
首先我们要把轻按预览和长按手势区分开来,这里要在初始化时做一个基本的检测。
nterface ViewController () <UIViewControllerPreviewingDelegate>
{
UILongPressGestureRecognizer *_longPress;
}
@end
@implementation ViewController
- (void)viewDidLoad {
[super viewDidLoad];
UILongPressGestureRecognizer *longPressGr = [[UILongPressGestureRecognizer alloc] initWithTarget:self action:@selector(longPressToDo)];
_longPress = longPressGr;
}
//检测页面是否处于3DTouch
- (void)check3DTouch{
if (self.traitCollection.forceTouchCapability == UIForceTouchCapabilityAvailable) {
[self registerForPreviewingWithDelegate:self sourceView:self.view];
NSLog(@"3D Touch 开启");
//长按停止
_longPress.enabled = NO;
}else{
_longPress.enabled = YES;
}
}
- (void)viewWillAppear:(BOOL)animated{
[self check3DTouch];
}
然后我们需要实现 UIViewControllerPreviewingDelegate的协议
@interface ViewController () <UIViewControllerPreviewingDelegate>
//然后实现代理方法
- (UIViewController *)previewingContext:(id<UIViewControllerPreviewing>)previewingContext viewControllerForLocation:(CGPoint)location;
#pragma mark >> 3D touch 代理方法
//轻按进入浮动预览页面
- (UIViewController *)previewingContext:(id<UIViewControllerPreviewing>)previewingContext viewControllerForLocation:(CGPoint)location{
//注意这里我因为测试,没做具体的位置处理,如果需要定位到具体的图片Cell位置的话,可以用location通过tableView的convertPoint来取到指定Cell
ASPreviewViewController *vc = [[ASPreviewViewController alloc] init];
vc.view.frame = self.view.frame;
UIImageView *er = [[UIImageView alloc] initWithImage:[UIImage imageNamed:@"123.png"]];
vc.view = er;
return vc;
}
完成后可以实现基本的预览效果:
最后我们加上一个
预览时下滑底部菜单的添加
在我们刚刚创建的预览控制器ASPreviewViewController里实现 UIViewControllerPreviewingDelegate的协议
然后重写它的代理方法
- (NSArray<id<UIPreviewActionItem>> *)previewActionItems;
//预览页面 底部Action Items
- (NSArray<id<UIPreviewActionItem>> *)previewActionItems{
UIPreviewAction *p1 =[UIPreviewAction actionWithTitle:@"分享" style:UIPreviewActionStyleDefault handler:^(UIPreviewAction * _Nonnull action, UIViewController * _Nonnull previewViewController) {
NSLog(@"点击了分享");
}];
UIPreviewAction *p2 =[UIPreviewAction actionWithTitle:@"收藏" style:UIPreviewActionStyleDefault handler:^(UIPreviewAction * _Nonnull action, UIViewController * _Nonnull previewViewController) {
NSLog(@"点击了收藏");
}];
NSArray *actions = @[p1,p2];
return actions;
}
以上所述是小编给大家介绍的iOS 指压即达集成iOS9里的3D Touch的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
# ios
# 3d
# touch
# iOS中3DTouch预览导致TableView滑动卡顿问题解决的方法
# IOS在Table View添加3D Touch功能
# iOS10 widget实现3Dtouch 弹出菜单
# iOS开发Quick Actions创建桌面Icon快捷方式
# 绑定
# 给大家
# 弹出
# 跳转
# 小编
# 在这个
# 在此
# 可以用
# 要在
# 要把
# 各大
# 做一个
# 写了
# 重写
# 可以实现
# 能对
# 时下
# 所述
# 如何使用
# 给我留言
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
再谈Python中的字符串与字符编码(推荐)
Laravel如何处理和验证JSON类型的数据库字段
Laravel Octane如何提升性能_使用Laravel Octane加速你的应用
Win11搜索栏无法输入_解决Win11开始菜单搜索没反应问题【技巧】
Laravel如何使用Seeder填充数据_Laravel模型工厂Factory批量生成测试数据【方法】
Laravel如何优化应用性能?(缓存和优化命令)
如何在阿里云通过域名搭建网站?
成都网站制作公司哪家好,四川省职工服务网是做什么用?
Laravel怎么实现一对多关联查询_Laravel Eloquent模型关系定义与预加载【实战】
Laravel用户认证怎么做_Laravel Breeze脚手架快速实现登录注册功能
如何快速搭建高效简练网站?
Laravel如何使用Livewire构建动态组件?(入门代码)
武汉网站设计制作公司,武汉有哪些比较大的同城网站或论坛,就是里面都是武汉人的?
如何快速登录WAP自助建站平台?
关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)
Laravel如何实现邮箱地址验证功能_Laravel邮件验证流程与配置
javascript中的数组方法有哪些_如何利用数组方法简化数据处理
Laravel怎么写单元测试_PHPUnit在Laravel项目中的基础测试入门
Laravel怎么配置不同环境的数据库_Laravel本地测试与生产环境动态切换【方法】
Python制作简易注册登录系统
php 三元运算符实例详细介绍
如何快速选择适合个人网站的云服务器配置?
在线教育网站制作平台,山西立德教育官网?
iOS UIView常见属性方法小结
如何获取上海专业网站定制建站电话?
Win11怎么关闭透明效果_Windows11辅助功能视觉效果设置
Linux虚拟化技术教程_KVMQEMU虚拟机安装与调优
JavaScript常见的五种数组去重的方式
Laravel如何自定义错误页面(404, 500)?(代码示例)
JavaScript如何实现路由_前端路由原理是什么
打开php文件提示内存不足_怎么调整php内存限制【解决方案】
详解Oracle修改字段类型方法总结
如何快速启动建站代理加盟业务?
Laravel如何发送系统通知?(Notification渠道示例)
如何在万网开始建站?分步指南解析
如何确保西部建站助手FTP传输的安全性?
如何制作一个表白网站视频,关于勇敢表白的小标题?
韩国代理服务器如何选?解析IP设置技巧与跨境访问优化指南
太平洋网站制作公司,网络用语太平洋是什么意思?
UC浏览器如何切换小说阅读源_UC浏览器阅读源切换【方法】
动图在线制作网站有哪些,滑动动图图集怎么做?
5种Android数据存储方式汇总
Laravel如何配置任务调度?(Cron Job示例)
Laravel如何配置和使用缓存?(Redis代码示例)
Laravel Eloquent性能优化技巧_Laravel N+1查询问题解决
如何用腾讯建站主机快速创建免费网站?
Laravel如何配置Horizon来管理队列?(安装和使用)
Laravel怎么多语言本地化设置_Laravel语言包翻译与Locale动态切换【手册】
如何用免费手机建站系统零基础打造专业网站?
Laravel集合Collection怎么用_Laravel集合常用函数详解

