Представить ViewController как поповер
У меня есть основной ViewController, в котором у меня есть tableView с пользовательским tableViewCell, внутри него я добавил несколько объектов представления и кнопку. Я хочу представить другой ViewController, когда я нажал кнопку в ячейке, а также мне нужно отправить (данные tableCell, где произошло событие click) и Receive (выбранное значение из pickerView и текст другой метки) из вытолкнутого ViewController, а затем, наконец, Мне нужен способ (как кнопка закрытия), чтобы закрыть его.
Я могу отправить данные ячейки, в которой произошло событие щелчка, используя следующий код
@IBAction func cellBtnClicked(_ sender: Any) {
let foodItem:FoodItem?
let indexPath : IndexPath
if let button = sender as? UIButton {
let cell = button.superview?.superview as! UITableViewCell
indexPath = self.tableView.indexPath(for: cell)!
let hotel = hotels[indexPath.section]
foodItem = hotel.menu[indexPath.row]
Затем я загружаю эти данные ячейки в контроллер поповера и пытаюсь представить его как поповер
let popoverContent = self.storyboard?.instantiateViewController(withIdentifier:"ShowPopoverVC" ) as! MiniCartVC
popoverContent.foodItem = foodItem
popoverContent.modalPresentationStyle = UIModalPresentationStyle.popover
if let popover = popoverContent.popoverPresentationController {
let viewForSource = sender as! UIView
popover.sourceView = viewForSource
// the position of the popover where it's showed
popover.sourceRect = viewForSource.bounds
// the size you want to display
popoverContent.preferredContentSize = CGSize(width: 200, height: 135)
popover.delegate = self
}
self.present(popoverContent, animated: true, completion: nil)
}
Но это не поп-ап, а не переход, расширяющий весь View. Также мне нужен способ отправки данных из VC-поповера в MainVC после его закрытия.
Пожалуйста, дайте мне знать, если есть какой-либо способ реализовать это должным образом. Любой ресурс в качестве справочной цели тоже хорошо, спасибо.
1 ответ
Из вашего перечисленного кода:
popover.delegate = self
Вы установили UIPopoverPresentationControllerDelegate, чтобы быть самостоятельно. Просто реализуйте дополнительный метод и используйте эту реализацию
func adaptivePresentationStyle(для контроллера: UIPresentationController) -> UIModalPresentationStyle { return .none }