##はじめに
Peek、Popを実装した時のメモです。
data:image/s3,"s3://crabby-images/16f04/16f04d294e909bfeb16195a575727cf0ead4977b" alt=""
##PeekとPop
###Peekとは?
弱く押し込んだ時のイベントです。
data:image/s3,"s3://crabby-images/8c051/8c051fb429147a8f739804e47f795e7c09d7f04e" alt=""
###Popとは?
Peekからさらに強く押し込んだ時のイベントです。
data:image/s3,"s3://crabby-images/115f6/115f6052a90c3164b374f64346d996e910a478e8" alt=""
実装方法
1、registerForPreviewing
PeekとPopするviewをregisterForPreviewing
で有効にします。
registerForPreviewing(with: self, sourceView: tableView)
2、UIViewControllerPreviewingDelegate
Peekした時にpreviewingContext(_ previewingContext: UIViewControllerPreviewing, viewControllerForLocation location: CGPoint)
が呼ばれます。
Peekで表示するViewControllerをここで返します。
Popした時にpreviewingContext(_ previewingContext: UIViewControllerPreviewing, commit viewControllerToCommit: UIViewController)
が呼ばれます。
Peekしていた時のViewControllerがviewControllerToCommit
になります。
extension ViewController: UIViewControllerPreviewingDelegate {
// Peek
func previewingContext(_ previewingContext: UIViewControllerPreviewing, viewControllerForLocation location: CGPoint) -> UIViewController? {
guard let indexPath = tableView.indexPathForRow(at: location) else {
return nil
}
return SecondViewController(indexPath: indexPath)
}
// Pop
func previewingContext(_ previewingContext: UIViewControllerPreviewing, commit viewControllerToCommit: UIViewController) {
self.navigationController?.pushViewController(viewControllerToCommit, animated: true)
}
}
##Peek quick actions
###Peek quick actionsとは?
Peekして上にスワイプすると出てくるショートカットメニューです。
data:image/s3,"s3://crabby-images/fa8ba/fa8baec12afb0559423f74913fa8cbc6dead4ca8" alt=""
実装方法
遷移後のViewControllerのpreviewActionItems
をoverrideして実装します。
override var previewActionItems: [UIPreviewActionItem] {
let edit = UIPreviewAction(title: "編集", style: .default) { _, _ in
print("編集をタップ")
}
let delete = UIPreviewAction(title: "削除", style: .destructive) { _, _ in
print("削除をタップ")
}
return [edit, delete]
}
##GitHub
https://github.com/hideyukitone/PeekPopSample
##参考
https://qiita.com/takashings/items/ead3e9d935c2108d55a7