Merge top buttons into a single parent view
(also fix tapping just outside a HUDButton)
This commit is contained in:
parent
582d1cf295
commit
ed580541f0
|
@ -63,4 +63,12 @@ class HUDButton: UIView {
|
||||||
super.traitCollectionDidChange(previousTraitCollection)
|
super.traitCollectionDidChange(previousTraitCollection)
|
||||||
button.titleLabel?.font = UIFontMetrics(forTextStyle: .body).scaledFont(for: .systemFont(ofSize: 15, weight: .bold))
|
button.titleLabel?.font = UIFontMetrics(forTextStyle: .body).scaledFont(for: .systemFont(ofSize: 15, weight: .bold))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
override func point(inside point: CGPoint, with event: UIEvent?) -> Bool {
|
||||||
|
button.point(inside: button.convert(point, from: self), with: event)
|
||||||
|
}
|
||||||
|
|
||||||
|
override func hitTest(_ point: CGPoint, with event: UIEvent?) -> UIView? {
|
||||||
|
button
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -25,6 +25,31 @@ final class MediaPreviewViewController: UIViewController, NeedsDependency {
|
||||||
let visualEffectView = UIVisualEffectView(effect: UIBlurEffect(style: .systemMaterial))
|
let visualEffectView = UIVisualEffectView(effect: UIBlurEffect(style: .systemMaterial))
|
||||||
let pagingViewController = MediaPreviewPagingViewController()
|
let pagingViewController = MediaPreviewPagingViewController()
|
||||||
|
|
||||||
|
let topToolbar: UIStackView = {
|
||||||
|
class TouchTransparentStackView: UIStackView {
|
||||||
|
// allow button hit boxes to grow outside of this view’s bounds
|
||||||
|
override func point(inside point: CGPoint, with event: UIEvent?) -> Bool {
|
||||||
|
subviews.contains { $0.point(inside: $0.convert(point, from: self), with: event) }
|
||||||
|
}
|
||||||
|
|
||||||
|
// allow taps on blank areas to pass through
|
||||||
|
override func hitTest(_ point: CGPoint, with event: UIEvent?) -> UIView? {
|
||||||
|
let view = super.hitTest(point, with: event)
|
||||||
|
if view == self {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
return view
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
let stackView = TouchTransparentStackView()
|
||||||
|
stackView.axis = .horizontal
|
||||||
|
stackView.distribution = .equalSpacing
|
||||||
|
stackView.alignment = .fill
|
||||||
|
stackView.translatesAutoresizingMaskIntoConstraints = false
|
||||||
|
return stackView
|
||||||
|
}()
|
||||||
|
|
||||||
let closeButton = HUDButton { button in
|
let closeButton = HUDButton { button in
|
||||||
button.setImage(UIImage(systemName: "xmark", withConfiguration: UIImage.SymbolConfiguration(pointSize: 16, weight: .bold))!, for: .normal)
|
button.setImage(UIImage(systemName: "xmark", withConfiguration: UIImage.SymbolConfiguration(pointSize: 16, weight: .bold))!, for: .normal)
|
||||||
}
|
}
|
||||||
|
@ -56,18 +81,19 @@ extension MediaPreviewViewController {
|
||||||
visualEffectView.pinTo(to: pagingViewController.view)
|
visualEffectView.pinTo(to: pagingViewController.view)
|
||||||
pagingViewController.didMove(toParent: self)
|
pagingViewController.didMove(toParent: self)
|
||||||
|
|
||||||
view.addSubview(closeButton)
|
view.addSubview(topToolbar)
|
||||||
|
NSLayoutConstraint.activate([
|
||||||
|
topToolbar.topAnchor.constraint(equalTo: view.layoutMarginsGuide.topAnchor, constant: 12),
|
||||||
|
topToolbar.leadingAnchor.constraint(equalTo: view.layoutMarginsGuide.leadingAnchor),
|
||||||
|
topToolbar.trailingAnchor.constraint(equalTo: view.layoutMarginsGuide.trailingAnchor),
|
||||||
|
])
|
||||||
|
|
||||||
|
topToolbar.addArrangedSubview(closeButton)
|
||||||
NSLayoutConstraint.activate([
|
NSLayoutConstraint.activate([
|
||||||
closeButton.topAnchor.constraint(equalTo: view.layoutMarginsGuide.topAnchor, constant: 12),
|
|
||||||
closeButton.leadingAnchor.constraint(equalTo: view.layoutMarginsGuide.leadingAnchor),
|
|
||||||
closeButton.widthAnchor.constraint(equalToConstant: HUDButton.height).priority(.defaultHigh),
|
closeButton.widthAnchor.constraint(equalToConstant: HUDButton.height).priority(.defaultHigh),
|
||||||
])
|
])
|
||||||
|
|
||||||
view.addSubview(altButton)
|
topToolbar.addArrangedSubview(altButton)
|
||||||
NSLayoutConstraint.activate([
|
|
||||||
altButton.topAnchor.constraint(equalTo: view.layoutMarginsGuide.topAnchor, constant: 12),
|
|
||||||
altButton.trailingAnchor.constraint(equalTo: view.layoutMarginsGuide.trailingAnchor),
|
|
||||||
])
|
|
||||||
|
|
||||||
viewModel.mediaPreviewImageViewControllerDelegate = self
|
viewModel.mediaPreviewImageViewControllerDelegate = self
|
||||||
|
|
||||||
|
@ -121,7 +147,7 @@ extension MediaPreviewViewController {
|
||||||
.sink { [weak self] showingChrome in
|
.sink { [weak self] showingChrome in
|
||||||
UIView.animate(withDuration: 0.3) {
|
UIView.animate(withDuration: 0.3) {
|
||||||
self?.setNeedsStatusBarAppearanceUpdate()
|
self?.setNeedsStatusBarAppearanceUpdate()
|
||||||
self?.closeButton.alpha = showingChrome ? 1 : 0
|
self?.topToolbar.alpha = showingChrome ? 1 : 0
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
.store(in: &disposeBag)
|
.store(in: &disposeBag)
|
||||||
|
|
|
@ -81,7 +81,7 @@ extension MediaHostToMediaPreviewViewControllerAnimatedTransitioning {
|
||||||
transitionItem.transitionView = transitionImageView
|
transitionItem.transitionView = transitionImageView
|
||||||
transitionContext.containerView.addSubview(transitionImageView)
|
transitionContext.containerView.addSubview(transitionImageView)
|
||||||
|
|
||||||
toVC.closeButton.alpha = 0
|
toVC.topToolbar.alpha = 0
|
||||||
|
|
||||||
if UIAccessibility.isReduceTransparencyEnabled {
|
if UIAccessibility.isReduceTransparencyEnabled {
|
||||||
toVC.visualEffectView.alpha = 0
|
toVC.visualEffectView.alpha = 0
|
||||||
|
@ -101,7 +101,7 @@ extension MediaHostToMediaPreviewViewControllerAnimatedTransitioning {
|
||||||
toVC.pagingViewController.view.alpha = 1
|
toVC.pagingViewController.view.alpha = 1
|
||||||
transitionImageView.removeFromSuperview()
|
transitionImageView.removeFromSuperview()
|
||||||
UIView.animate(withDuration: 0.33, delay: 0, options: [.curveEaseInOut]) {
|
UIView.animate(withDuration: 0.33, delay: 0, options: [.curveEaseInOut]) {
|
||||||
toVC.closeButton.alpha = 1
|
toVC.topToolbar.alpha = 1
|
||||||
}
|
}
|
||||||
transitionContext.completeTransition(position == .end)
|
transitionContext.completeTransition(position == .end)
|
||||||
}
|
}
|
||||||
|
@ -138,13 +138,13 @@ extension MediaHostToMediaPreviewViewControllerAnimatedTransitioning {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// update close button
|
// update top toolbar
|
||||||
UIView.animate(withDuration: 0.33, delay: 0, options: [.curveEaseInOut]) {
|
UIView.animate(withDuration: 0.33, delay: 0, options: [.curveEaseInOut]) {
|
||||||
fromVC.closeButton.alpha = 0
|
fromVC.topToolbar.alpha = 0
|
||||||
}
|
}
|
||||||
animator.addCompletion { position in
|
animator.addCompletion { position in
|
||||||
UIView.animate(withDuration: 0.33, delay: 0, options: [.curveEaseInOut]) {
|
UIView.animate(withDuration: 0.33, delay: 0, options: [.curveEaseInOut]) {
|
||||||
fromVC.closeButton.alpha = position == .end ? 0 : 1
|
fromVC.topToolbar.alpha = position == .end ? 0 : 1
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -202,7 +202,7 @@ extension MediaHostToMediaPreviewViewControllerAnimatedTransitioning {
|
||||||
mediaPreviewTransitionContext.snapshot.contentMode = .scaleAspectFill
|
mediaPreviewTransitionContext.snapshot.contentMode = .scaleAspectFill
|
||||||
mediaPreviewTransitionContext.snapshot.clipsToBounds = true
|
mediaPreviewTransitionContext.snapshot.clipsToBounds = true
|
||||||
transitionMaskView.addSubview(mediaPreviewTransitionContext.snapshot)
|
transitionMaskView.addSubview(mediaPreviewTransitionContext.snapshot)
|
||||||
fromVC.view.bringSubviewToFront(fromVC.closeButton)
|
fromVC.view.bringSubviewToFront(fromVC.topToolbar)
|
||||||
|
|
||||||
transitionItem.transitionView = mediaPreviewTransitionContext.transitionView
|
transitionItem.transitionView = mediaPreviewTransitionContext.transitionView
|
||||||
transitionItem.snapshotTransitioning = mediaPreviewTransitionContext.snapshot
|
transitionItem.snapshotTransitioning = mediaPreviewTransitionContext.snapshot
|
||||||
|
|
Loading…
Reference in New Issue