Всплывающее окно не работает изнутри Alert в коде - PullRequest
0 голосов
/ 10 ноября 2019

Я создаю оповещение из-за проволочного удара в виде таблицы. При нажатии «Изменить» я пытаюсь создать экземпляр другого контроллера представления и показать его как всплывающее окно.

Проблема заключается в том, что всплывающее окно отображается либо на том же экране, либо, когда оно отображается, поскольку во всплывающем окне отсутствует панель навигации.

Я просмотрел разные потоки на stackoverflow, но не смог найтирешение.

На другом экране это прекрасно работает, когда я настроил контроллер представления для показа всплывающего окна из раскадровки, но я не могу понять, как заставить это работать изнутри Alert.

Я добавил основную часть кода, которая не работает. Рад добавить любые другие детали, которые вам нужно изучить.

То, что я пробовал до сих пор:

1) Настройка стиля представления для vc

vc.modalPresentationStyle =. popover

2) Попробуйте выполнить переход - это отобразит vc в том же окне

            let transition = CATransition()
            transition.duration = 0.5
            transition.timingFunction = CAMediaTimingFunction(name: CAMediaTimingFunctionName.easeInEaseOut)
            transition.type = CATransitionType.reveal
            transition.subtype = CATransitionSubtype.fromTop
            self.navigationController?.view.layer.add(transition, forKey: nil)
            self.navigationController?.pushViewController(vc, animated: false)

3) Результат такой же, как # 2

self.navigationController ?. присутствует (vc, animated: false)

4) Self.Present без контроллера навигации.

let modifyAction = UIContextualAction(style: .normal, title:  "Manage", handler: { (ac:UIContextualAction, view:UIView, success:(Bool) -> Void) in
            print("Update action ...")


            let alert = UIAlertController()

            alert.addAction(UIAlertAction(title: "Edit", style: .default , handler:{ (UIAlertAction)in
                    print("User click Edit button")

                let vc = self.storyboard?.instantiateViewController(withIdentifier: "ManageCategoryViewController") as! ManageCategoryViewController

                vc.selectedIdx = indexPath.row
                vc.categoryListArray = self.categoryListArray
                vc.type = "update"
                //vc.modalPresentationStyle = .popover

                /*
                let transition = CATransition()
                transition.duration = 0.5
                transition.timingFunction = CAMediaTimingFunction(name: CAMediaTimingFunctionName.easeInEaseOut)
                transition.type = CATransitionType.reveal
                transition.subtype = CATransitionSubtype.fromTop
                self.navigationController?.view.layer.add(transition, forKey: nil)
                self.navigationController?.pushViewController(vc, animated: false)
                */

                self.navigationController?.present(vc, animated: false)

            }))

alert.addAction(UIAlertAction(title: "Cancel", style: .cancel, handler:{ (UIAlertAction)in
                print("User click Cancel button")
            }))

            self.present(alert, animated: true, completion: {
                print("completion block")
            })

1 Ответ

0 голосов
/ 11 ноября 2019

При дальнейшем чтении и пробовании нескольких вариантов я смог решить эту проблему не из-за всплывающего окна, инициируемого изнутри оповещения.

https://developer.apple.com/documentation/uikit/windows_and_screens/displaying_transient_content_in_a_popover

Если вам нужна навигацияконтроллер, вы можете добавить контроллер навигации, как предложено в одном из ответов в посте ниже.

presentViewController и отображение панели навигации

Размещение кода, если это полезнокому-то.

let navController = UINavigationController(rootViewController: vc)
                vc.modalPresentationStyle = .popover
                self.navigationController?.present(navController, animated: true) {
                     // The popover is visible.
                }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...