forked from bannzai/Gecco
-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathSpotlightViewController.swift
101 lines (80 loc) · 3.88 KB
/
SpotlightViewController.swift
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
//
// SpotlightViewController.swift
// Gecco
//
// Created by yukiasai on 2016/01/15.
// Copyright (c) 2016 yukiasai. All rights reserved.
//
import UIKit
public protocol SpotlightViewControllerDelegate: AnyObject {
func spotlightViewControllerWillPresent(_ viewController: SpotlightViewController, animated: Bool)
func spotlightViewControllerWillDismiss(_ viewController: SpotlightViewController, animated: Bool)
func spotlightViewControllerTapped(_ viewController: SpotlightViewController, tappedSpotlight: SpotlightType?)
}
public typealias SpotlightViewAndControllerDelegate = SpotlightViewControllerDelegate & SpotlightViewDelegate
open class SpotlightViewController: UIViewController {
open weak var delegate: SpotlightViewControllerDelegate?
private lazy var transitionController: SpotlightTransitionController = {
let controller = SpotlightTransitionController()
controller.delegate = self
return controller
}()
public let spotlightView = SpotlightView()
open var alpha: CGFloat = 0.5
override public init(nibName nibNameOrNil: String?, bundle nibBundleOrNil: Bundle?) {
super.init(nibName: nibNameOrNil, bundle: nibBundleOrNil)
commonInit()
}
required public init?(coder aDecoder: NSCoder) {
super.init(coder: aDecoder)
commonInit()
}
private func commonInit() {
modalPresentationStyle = .overCurrentContext
transitioningDelegate = self
}
open override func viewDidLoad() {
super.viewDidLoad()
setupSpotlightView(alpha)
setupTapGesture()
view.backgroundColor = UIColor.clear
}
private func setupSpotlightView(_ alpha: CGFloat) {
spotlightView.frame = view.bounds
spotlightView.backgroundColor = UIColor(red: 0, green: 0, blue: 0, alpha: alpha)
spotlightView.isUserInteractionEnabled = false
view.insertSubview(spotlightView, at: 0)
view.addConstraints([NSLayoutConstraint.Attribute.top, .bottom, .left, .right].map {
NSLayoutConstraint(item: view!, attribute: $0, relatedBy: .equal, toItem: spotlightView, attribute: $0, multiplier: 1, constant: 0)
})
}
private func setupTapGesture() {
let gesture = UITapGestureRecognizer(target: self, action: #selector(SpotlightViewController.viewTapped(_:)));
view.addGestureRecognizer(gesture)
}
}
extension SpotlightViewController {
@objc func viewTapped(_ gesture: UITapGestureRecognizer) {
let touchPoint = gesture.location(in: spotlightView)
let tappedSpotlight = spotlightView.spotlights.first(where: { $0.frame.contains(touchPoint) })
delegate?.spotlightViewControllerTapped(self, tappedSpotlight: tappedSpotlight)
}
}
extension SpotlightViewController: SpotlightTransitionControllerDelegate {
func spotlightTransitionWillPresent(_ controller: SpotlightTransitionController, transitionContext: UIViewControllerContextTransitioning) {
delegate?.spotlightViewControllerWillPresent(self, animated: transitionContext.isAnimated)
}
func spotlightTransitionWillDismiss(_ controller: SpotlightTransitionController, transitionContext: UIViewControllerContextTransitioning) {
delegate?.spotlightViewControllerWillDismiss(self, animated: transitionContext.isAnimated)
}
}
extension SpotlightViewController: UIViewControllerTransitioningDelegate {
public func animationController(forPresented presented: UIViewController, presenting: UIViewController, source: UIViewController) -> UIViewControllerAnimatedTransitioning? {
transitionController.isPresent = true
return transitionController
}
public func animationController(forDismissed dismissed: UIViewController) -> UIViewControllerAnimatedTransitioning? {
transitionController.isPresent = false
return transitionController
}
}