Я добавил подпредставление на UIWindow
как toast view
, теперь я автоматически удаляю его (просмотр тоста) через 2 секунды.Но мне нужно добавить swipe/tap gesture recogniser
, чтобы удалить его, когда пользователь смахивает / касается его.Я много пробовал, но безрезультатно.
Есть ли способ реализовать это, пожалуйста, дайте мне знать, если есть решение.Спасибо.
class func showToast(withDuration duration: TimeInterval, afterDelay delay: TimeInterval, withMessage message: String, toastType type: UINotificationFeedbackGenerator.FeedbackType, hideToastAfterCompletion: Bool) {
let notificationFeedback = UINotificationFeedbackGenerator()
let window = UIApplication.shared.keyWindow
let toastView = UIView()
toastView.tag = 999
toastView.accessibilityHint = "toastView"
toastView.backgroundColor = UIColor.clear
toastView.frame = CGRect(x: 0, y: 0, width: screenWidth, height: 80)
toastView.isUserInteractionEnabled = true
let toastLabelWidth = screenWidth*0.75
let xPosition = (screenWidth - toastLabelWidth)/2
let size = message.height(withConstrainedWidth: toastLabelWidth, font: UIFont.LatoRegular(16))
var topPadding: CGFloat = 0.0
if #available(iOS 11.0, *) {
topPadding = window?.safeAreaInsets.top ?? 0.0
}
topPadding = (topPadding == 0.0 ? 20.0 : topPadding)
let toastLabel = UILabel(frame: CGRect(x: xPosition, y: topPadding, width: toastLabelWidth, height: size))
toastLabel.text = message
toastLabel.numberOfLines = 0
toastLabel.textAlignment = .center
toastLabel.textColor = type.TextColor
toastLabel.font = UIFont.LatoRegular(16)
toastLabel.backgroundColor = UIColor.clear
toastView.addSubview(toastLabel)
toastView.frame.size.height = toastLabel.frame.origin.y + size + 32
removeExistedToast()
self.drawWave(forToastView: toastView, fillColor: type.ToastColor)
toastView.transform = CGAffineTransform(translationX: 0, y: -toastView.frame.height)
window?.addSubview(toastView)
notificationFeedback.notificationOccurred(type)
Toast.animateLayer(toastView: toastView)
let swipeGestureRecognizer = UITapGestureRecognizer(target: self, action: #selector(toastViewSwiped))
toastView.addGestureRecognizer(swipeGestureRecognizer)
animate(toast: toastView, withDelay: delay, duration: 0.5, transform: CGAffineTransform.identity, {
if $0 && hideToastAfterCompletion {
animate(toast: toastView, withDelay: delay + duration, duration: 0.25, transform: CGAffineTransform(translationX: 0, y: -toastView.frame.height), { _ in
toastView.removeFromSuperview()
})
}
})
}
@objc private func toastViewSwiped(_ gesture: UIGestureRecognizer) {
Toast.removeExistedToast()
}
class func removeExistedToast(){
let window = UIApplication.shared.keyWindow
window?.subviews.filter({ $0.tag == 999 && $0.accessibilityHint == "toastView" }).forEach({ (existedToast) in
UIView.animate(withDuration: 0.25, animations: {
existedToast.alpha = 0
}, completion: { (_) in
existedToast.removeFromSuperview()
})
})
}
здесь id мой код позволяет проверить, есть ли ошибка при назначении цели для распознавателя жестов или добавлении цели невозможно.