IOS在Table View添加3D Touch功能

本文通过实例教给大家如何在Table View添加3D Touch功能以及详细写法,跟着测试下吧。

Peek & Pop 在 iPhone 中是很实用的一个硬件相关特色功能,既可以提高操作效率,又有清晰的视觉表达。

Peek & Pop 是两个过程的组合,Peek 代表轻按屏幕激活预览窗口(会不会联想到在电脑中鼠标滑过链接时给出的提示,但这里视觉上更丰富了),Pop 代表继续重(zhòng)按屏幕打开刚才的预览窗口,如果只是轻按一下屏幕,预览窗口随着手指拿起就消失了。

实现这个功能最简单的方法就是通过 Storyboard 创建 Segue(手动触发模式的 Segue 除外),并在 Segue 上勾选 Peek & Pop。但是如果想定制展现过程,就要通过编码的方式显示了。

通过编码实现这个功能的要点之一是提供一个用于预览的视图对象,而提供这个对象有 3 种不同的方法(一般教程中都未提到):

通过完整的程序编码创建并初始化一个视图控制器。
通过 XIB 设计视图、自定义视图控制器类文件,并通过 init(nibName:bundle:) 方法初始化视图。
通过 Storyboard 设计好视图,再通过 Storyboard 的 instantiateViewController 方法初始化这个视图。
网上的其他教程基本都是描述的方法 1(包含开头提到最简单的方法),方法 2、3 几乎没有提及。而方法 2、3 也是最容易出错的地方。

创建视图的过程就不多说了,用哪个方法都可以,重点是初始化它。假设我们创建的视图控制器类名称是: PreviewingViewController。

方法 1 直接用自定义的初始化方法就可以了(初始化方法甚至可以不写),最典型就是: PreviewingViewController()。
方法 2、3 如果还用 PreviewingViewController() ,接下来就等着报错和不停找问题了,笔者当时就在这里耗了很多时间。因为方法 2、3 都是通过 UI 文件创建的视图,它们的初始化方法只能使用特定的、也是标准的。具体说就是:
使用 XIB 方式创建的视图,要使用 init(nibName:bundle:) 方法初始化。
通过 Storyboard 创建的视图,要使用 instantiateViewController 方法初始化。
以上初始化方法掌握了,接下来就简单了,完成 Peek & Pop 一共三步。假设源视图是 MainViewController,要预览的是 PreviewingViewController:

让 MainViewController 遵守 UIViewControllerPreviewingDelegate 协议,并在其 viewDidLoad() 方法中注册 Peek & Pop:
if traitCollection.forceTouchCapability == .available {
registerForPreviewing(with: self, sourceView: tableView) // sourceView 使用需要触发的 view 即可
}
添加代理方法提供预览的视图: previewingContext(_:viewControllerForLocation:):

// Peek 操作
func previewingContext(_ previewingContext: UIViewControllerPreviewing,
            viewControllerForLocation location: CGPoint) -> UIViewController?
{
  // 获取被按压的 Cell
  guard
  let indexPath = tableView.indexPathForRow(at: location),
  let cell = tableView.cellForRow(at: indexPath)
  else {
    return nil
  }
  // 按压时聚焦 Cell
  // 按压时要聚焦的区域都可以定制,提供你需要的就行。
  previewingContext.sourceRect = cell.frame

  // 根据上文讨论的,提供相应的初始化方法,这里以 storyboard 为例。
  let previewVC = self.storyboard?.instantiateViewController(
    withIdentifier: "xxx") as! PreviewingViewController
  // 把预览需要的信息传递过去
  previewVC.xxx = self.xxx
  return previewVC
}  

添加代理方法打开预览视图: previewingContext(_:commit:):

// Pop 操作
func previewingContext(_ previewingContext: UIViewControllerPreviewing,
              commit viewControllerToCommit: UIViewController)
{
  // 这里使用的条件判断,让你在某些情况下不触发 Pop 操作。
  if xxx {
    show(viewControllerToCommit, sender: self)
    // 根据打开视图的方式选择 show 或 present
    // present(viewControllerToCommit, animated: true)
  }
}
(0)

相关推荐

  • IOS在Table View添加3D Touch功能

    本文通过实例教给大家如何在Table View添加3D Touch功能以及详细写法,跟着测试下吧. Peek & Pop 在 iPhone 中是很实用的一个硬件相关特色功能,既可以提高操作效率,又有清晰的视觉表达. Peek & Pop 是两个过程的组合,Peek 代表轻按屏幕激活预览窗口(会不会联想到在电脑中鼠标滑过链接时给出的提示,但这里视觉上更丰富了),Pop 代表继续重(zhòng)按屏幕打开刚才的预览窗口,如果只是轻按一下屏幕,预览窗口随着手指拿起就消失了. 实现这个功能最简单的

  • iOS 指压即达集成iOS9里的3D Touch的方法

    1.前言 随着6S的到来,3DTouch被各大热门APP迅速普及,博主亲自体验后,发现使用便捷性大幅提高,随后自己照着文档,写了个Demo出来,分享给大家,希望能对有需要的朋友提供有一些帮助. 2.如何使用3D Touch? 2.1.主界面重按APP图标,弹出Touch菜单 在AppleDelegate文件中的程序入口处配置: didFinishLaunchingWithOptions //给App图标添加3D Touch菜单 //拍照 //菜单图标 UIApplicationShortcutI

  • iOS开发之如何给View添加指定位置的边框线详解

    前言 本文主要给大家介绍了关于iOS如何给View添加指定位置边框线的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧. 略微封装了一下,给View添加指定位置的边框线,其中位移枚举的使用询问了哥们儿,总算搞定: 示例代码 封装一:直接封装成了一个方法 /// 边框类型(位移枚举) typedef NS_ENUM(NSInteger, UIBorderSideType) { UIBorderSideTypeAll = 0, UIBorderSideTypeTop = 1

  • Android实现类似3D Touch菜单功能

    前言 在开发中,我们经常遇到需要菜单功能的实现,我们经常会参考其他人的优秀设计.比如3D Touch菜单,作为iphone6和iphone6s上引人注目的新功能.现在,我们希望尽力来模仿这种菜单设计,尽力,因为系统的差异,会导致很多东西实现起来有难度. 思路 想要尽力模仿这种菜单,经过分析,我觉得主要实现以下几个点: 1)菜单的出现方式,在ios上,方式是用户用手指用力按下,然而在Android上,受限于硬件,我们无法捕捉用力按压这种动作,所以,我改用另一种比较次的方式,长按弹出,捕捉手指长按动

  • JS/jQuery实现超简单的Table表格添加,删除行功能示例

    本文实例讲述了JS/jQuery实现超简单的Table表格添加,删除行功能.分享给大家供大家参考,具体如下: 最近需要表格添加删除行,添加行简单,删除行就有点儿懵逼了,于是网上找实例,功夫不负有心人,终于让我找到了,下面的是代码,大家觉得可以,记得点赞哦!!!谢谢! 需要的拿去,转载请在明显的位置标注出出处!!! <html> <head> <title>table添加/删除行</title> </head> <body> <t

  • iOS键盘如何添加隐藏键盘功能

    本文实例为大家分享了iOS添加隐藏键盘功能的具体方法,供大家参考,具体内容如下 键盘添加个隐藏键盘功能 使用方法:导入XMCustomKeyBoard.h [XMCustomKeyBoard CancelableKeyboard:控件对象 ]; 控件对象可以是UITextFiled,UITextView,UISearchBar 等一系列调用键盘输入的类的实例 1.自定义个UIBarButtonItem,添加属性editableView,editableView存储需要添加隐藏键盘功能的那个控件

  • iOS开发微信收款到账语音提醒功能思路详解

    一.背景 为了解决小商户老板们在频繁交易中不方便核对.确认到账的痛点,产品MM提出了新版本需要支持收款到账语音提醒功能.这篇文章总结了开发过程中遇到的坑和一些小技巧. 二.技术方案 后台唤醒App 收款到账语音提醒需要收款方在收到款后,播放一段TTS合成语音播报金额,微信在前台时可以通过模板消息将需要播报的金额带下来,再请求TTS数据并播放,但是app在挂起或者被kill掉的情况下要如何请求语音数据并播放呢? iOS提供了两种方式唤醒处于挂起或已经被kill掉的app.分别是Silent Not

  • swift在IOS应用图标上添加提醒个数的方法

    在应用图标右上角添加消息数提醒,可以很方便的告知用户该应用中有无新消息需要处理.下面用xcode 7.3.1来简要说明一下如何用swift语言进行此功能的实现. 1.修改 AppDelegate.swift // // AppDelegate.swift // RainbowDemo // // Created by Jackwang on 16/8/17. // Copyright © 2016年 Jackwang . All rights reserved. // import UIKit

  • BootStrap实现邮件列表的分页和模态框添加邮件的功能

    废话不多说具体代码如下所示: package com.rc.controller; import java.io.IOException; import java.io.PrintWriter; import java.util.ArrayList; import java.util.List; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.ht

  • iOS高仿微信文章悬浮球功能

    前言 微信在最新版本6.6.7,新加了一个文章悬浮球功能.当你正在阅读文章的时候,突然有好友发来了紧急消息,你需要立即回复.又或者你刚好路过小吃店,需要临时打开微信支付,等等临时中断阅读的情况.以前只有退出文章详情页面,处理完事情之后,再挨着挨着找到原来的文章.对于我们这种重度微信使用者来说,每次遭遇这种情况,真的很蛋疼.所以,当这个功能推出的事情,立马更新了最新版本,这个功能感觉就像遇到了知心人一样,用起来十分顺手.可以通过下面的动图感受一下 其实悬浮球的概念早就有了.比如360助手的流量监控

随机推荐