OStack程序员社区-中国程序员成长平台

标题: iOS 导航项横向模式下额外填充顶部的问题 [打印本页]

作者: 菜鸟教程小白    时间: 2022-12-11 16:36
标题: iOS 导航项横向模式下额外填充顶部的问题

当我的应用在横向时,顶部有额外的填充。 这是我以编程方式创建导航栏时的代码。 在横向模式下删除填充顶部有什么建议吗?

    let navigationBar = UINavigationBar(frame: CGRectMake(0, 0, self.view.frame.size.width, 44)

    navigationBar.backgroundColor = UIColor.redColor()
    navigationBar.delegate = self;

    let navigationItem = UINavigationItem()
    navigationItem.title = "Title"

    let btnLeft = UIButton(frame: CGRectMake(0, 0, 44, 44))
    btnLeft.setImage(UIImage(named: “myImage.png"), forState: .Normal)

    let leftButton =  UIBarButtonItem()
    leftButton.customView = btnLeft

    navigationItem.leftBarButtonItem = leftButton

    navigationBar.items = [navigationItem]

    self.view.addSubview(navigationBar)

模拟器快照(横向)

enter image description here

模拟器截图(纵向)

enter image description here



Best Answer-推荐答案


您应该使用此设置轻松解决(例如在您的 viewDidLoad 中):

self.edgesForExtendedLayout = UIRectEdge.None

替代方案:你也可以把它放在你的 UINavigationController 委托(delegate)方法中(如果你在你的类中设置了你的导航委托(delegate) UINavigationControllerDelegate )叫做 willShowViewController :

func navigationController(navigationController: UINavigationController, willShowViewController viewController: UIViewController, animated: Bool) {
    viewController.edgesForExtendedLayout = UIRectEdge.None
}

如果你使用 UITableView 你也可以这样做:

 self.automaticallyAdjustsScrollViewInsets = false

你也可以直接编辑到属性检查器:

enter image description here

如果这些方法中的任何一个都不起作用,默认情况下,您的 UINavigationBar 根据您的方向具有不同的高度。例如,导航栏是纵向 44 点,横向 32 点。 解决方法可以是:

// Create an IBOutlet of your navigationBar height constraint
@IBOutlet weak var navBarHeight: NSLayoutConstraint

override func viewWillLayoutSubviews() {
        super.viewWillLayoutSubviews()
        if self.view.bounds.size.height > self.view.bounds.size.width {
            self.navBarHeight.constant = 44
        } else {
            self.navBarHeight.constant = 32
        }
}

关于iOS 导航项横向模式下额外填充顶部的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37487080/






欢迎光临 OStack程序员社区-中国程序员成长平台 (http://ostack.cn/) Powered by Discuz! X3.4