Выдвиньте контроллер просмотра снизу с помощью Swift

Я хотел бы подтолкнуть контроллер вида с помощью Swift и анимировать его так, чтобы он появлялся снизу и двигался вверх. У меня есть следующий код, чтобы подтолкнуть мой контроллер представления:

let helloTableViewController = self.storyboard!.instantiateViewControllerWithIdentifier("helloTableViewController") as! HelloTableViewController
self.navigationController!.pushViewController(helloTableViewController, animated: true)

Я нашел следующее из другого вопроса, но не могу заставить его работать в Swift:

CATransition *animation = [CATransition animation]; 
[animation setDuration:2]; 
[animation setType:kCATransitionPush]; 
[animation setSubtype:kCATransitionFromTop]; 
[animation setTimingFunction:[CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseInEaseOut]]; 
SecondView *sObj=[[SecondView alloc] initWithNibName:@"SecondView" bundle:nil];
[self.navigationController pushViewController:sObj animated:YES];
[[sObj.view layer] addAnimation:animation forKey:@"SwitchToView1"];

Ответ 1

Вот код для нажатия

  let transition:CATransition = CATransition()
    transition.duration = 0.5
    transition.timingFunction = CAMediaTimingFunction(name: kCAMediaTimingFunctionEaseInEaseOut)
    transition.type = kCATransitionPush
    transition.subtype = kCATransitionFromBottom
    self.navigationController!.view.layer.add(transition, forKey: kCATransition)
    self.navigationController?.pushViewController(dstVC, animated: false)

и тип перехода, который вы можете использовать,

 kCATransitionFromLeft
 kCATransitionFromBottom
 kCATransitionFromRight
 kCATransitionFromTop

Ответ 2

Swift3:

для push:

    // push view controller but animate modally
    let storyBoard: UIStoryboard = UIStoryboard(name: "myStoryBoard", bundle: nil)
    let vc = storyBoard.instantiateViewController(withIdentifier: "myViewControllerIdentifier") as! MyViewController

    let navigationController = self.navigationController


    vc.navigationItem.rightBarButtonItem = UIBarButtonItem(title: "Close", style: .plain, target: vc, action: #selector(vc.closeView))
    vc.navigationItem.leftBarButtonItem = UIBarButtonItem(title: "", style: .plain, target: vc, action: nil)

    let transition = CATransition()
    transition.duration = 0.5
    transition.timingFunction = CAMediaTimingFunction(name: kCAMediaTimingFunctionEaseInEaseOut)
    transition.type = kCATransitionMoveIn
    transition.subtype = kCATransitionFromTop
    navigationController?.view.layer.add(transition, forKey: nil)
    navigationController?.pushViewController(vc, animated: false)

и в vc для поп:

func closeView() {
    let transition = CATransition()
    transition.duration = 0.5
    transition.timingFunction = CAMediaTimingFunction(name: kCAMediaTimingFunctionEaseInEaseOut)
    transition.type = kCATransitionReveal
    transition.subtype = kCATransitionFromBottom
    navigationController?.view.layer.add(transition, forKey: nil)
    _ = navigationController?.popViewController(animated: false)
}

Ответ 3

Swift 4. 2+ решение, основанное на ответе Nex Mishra:

let transition = CATransition()
transition.duration = 0.5
transition.timingFunction = CAMediaTimingFunction(name: .easeInEaseOut)
transition.type = .push
transition.subtype = .fromBottom
navigationController?.view.layer.add(transition, forKey: kCATransition) 
navigationController?.pushViewController([destination VC], animated: false)

Ответ 4

У меня была похожая ситуация, когда мне нужно было показать элемент навигации с некоторыми UIBarButtonItems на контроллере представления, но при модальном представлении он не отображался. Он показывался только при нажатии на навигационный контроллер, но мне действительно нужна была анимация снизу вверх>. Я попробовал примеры CATransition сверху, но это вывело еще одну ошибку, когда во время анимации был черный фон/полупрозрачный фон. В конце концов я нашел довольно простое решение:

let someVC = storyboard?.instantiateViewController(withIdentifier: "SomeVC") as! SomeVC
let navController = UINavigationController(rootViewController: someVC)
navigationController?.present(navController, animated: true, completion: nil)

А чтобы закрыть контроллер представления и вообще избавиться от контроллера навигации, просто позвоните:

self.dismiss(animated: true, completion: nil)

Это отключит контроллер представления и освободит наш NavigationController из памяти.

В конце концов, это простое решение, но я потратил некоторое время на его разработку. Может быть, я сэкономлю чужое время :)