在iOS8中调整旋转工具栏的大小

时间:2014-10-28 12:57:13

标签: ios iphone swift ios8

当我旋转iphone / ipod时,我正试图让应用程序底部的工具栏调整大小。导航控制器会自动调整iOS8中导航栏的大小。如果活动开始时它已经处于横向状态,它确实获得了正确的高度。

与纵向旋转到横向后相同的尺寸 Now

较小,因为活动是在风景中开始的 Want

工具栏已添加到故事板中。

@IBOutlet var toolbar: UIToolbar!

我尝试更改willRotateToInterfaceOrientation(toInterfaceOrientation: UIInterfaceOrientation, duration: NSTimeInterval)

中工具栏的矩形

像这样:

override func willRotateToInterfaceOrientation(toInterfaceOrientation: UIInterfaceOrientation, duration: NSTimeInterval) {
    var customToolbarFrame: CGRect!
    if toInterfaceOrientation == UIInterfaceOrientation.Portrait {
        customToolbarFrame = CGRectMake(0,self.view.bounds.size.height - 44, self.toolbar.frame.size.width, 44)
    }
    else {
        customToolbarFrame = CGRectMake(0,self.view.bounds.size.height - 32, self.toolbar.frame.size.width, 32)
    }
    UIView.animateWithDuration(duration, animations: {
        self.toolbar.frame = customToolbarFrame
    })
}

我也试过没有动画,但没有运气。

然而,如果我在didRotateFromInterfaceOrientation(fromInterfaceOrientation: UIInterfaceOrientation)中做同样的事情,它确实有效但没有动画它看起来很糟糕,因为有一些延迟。

解决方案

来自gabbler

  1. 我为所有iphone选择了w Any h Compact(我不希望它在ipads上更小)
  2. 选择了我的工具栏
  3. 在约束上将高度设置为32px,将更新框架设置为新约束项目

3 个答案:

答案 0 :(得分:4)

如果使用自动布局,可以在纵向和横向设置不同的高度约束,例如在wCompact | hCompact模式下为工具栏添加32高度约束,您将能够在横向模式下看到32高度工具栏,这是一个Toolbar test example

答案 1 :(得分:1)

我做了很多研究,并没有找到任何解释如何在IOS8中更改/修复导航控制器工具栏高度的文档,但我使用Autolayout构建了一个解决方法。

首先所有尝试过相同的方法,但使用" ViewWillTransitionToSize "函数,因为不推荐使用接口循环的方法。

iOS 8 Rotation Methods Deprecation - Backwards Compatibility

-(void) viewWillTransitionToSize:(CGSize)size withTransitionCoordinator:(id<UIViewControllerTransitionCoordinator>)coordinator {

    [super viewWillTransitionToSize: size withTransitionCoordinator: coordinator];

    [coordinator animateAlongsideTransition:^(id<UIViewControllerTransitionCoordinatorContext> context) {

        UIDeviceOrientation deviceOrientation   = [[UIDevice currentDevice] orientation];

        if (UIDeviceOrientationIsLandscape(deviceOrientation)) {
            NSLog(@"Will change to Landscape");

        }
        else {
            NSLog(@"Will change to Portrait");
        }


    }
    completion:^(id<UIViewControllerTransitionCoordinatorContext> context) {
        NSLog(@"finish Transition");
    }];


}

第二次我试图构建一个从UIToolbar继承的自定义类,并在initWithFrame方法上实现对rect的更改。

如果您要使用自动布局来实施解决方法来解决此问题,请按照以下步骤操作:

1-将工具栏拖动到视图控制器并固定前导,底部和高度:

enter image description here

2-控制从工具栏拖动到容器View and Pin&#34; Equal Widths&#34;

enter image description here

3-完成它:

Portrait

enter image description here

答案 2 :(得分:0)

我不确定是否可以创建一个利用适应性的故事板工具栏(因为工具栏的顶部约束没有容器)。

您可以设置高度约束并在代码中进行调整,但导航控制器的工具栏已经为您调整了高度(基于方向)。

如果您不介意在代码中设置工具栏项目(使用视图控制器的toolbarItems属性),您将免费获得自适应大小调整。

self.toolbarItems = @[...];

以下是我设置工具栏的示例:

/**
 Setup a segmented control of bible versions, and add it to the toolbar
 */
- (void)setupBibleVersionToolbarItems
{
    self.versionSegmentedControl = [[UISegmentedControl alloc] initWithItems:@[@"ESV",
                                                                               @"KJV",
                                                                               @"NASB",
                                                                               @"NIV",
                                                                               @"NKJV",
                                                                               @"NLT"]];
    self.versionSegmentedControl.opaque = NO;
    [self.versionSegmentedControl addTarget:self
                                     action:@selector(versionChanged:)
                           forControlEvents:UIControlEventValueChanged];

    UIBarButtonItem *bibleVersionItem = [[UIBarButtonItem alloc]
                                         initWithCustomView:(UIView *)self.versionSegmentedControl];
    bibleVersionItem.width = 300.0f;
    UIBarButtonItem *flexibleSpace = [[UIBarButtonItem alloc]
                                      initWithBarButtonSystemItem:UIBarButtonSystemItemFlexibleSpace
                                      target:nil
                                      action:nil];

    self.toolbarItems = @[flexibleSpace, bibleVersionItem, flexibleSpace];
}

您可以根据需要通过设置其toolbarHidden属性来显示或隐藏导航控制器的工具栏。

- (void)viewWillAppear:(BOOL)animated
{
    [super viewWillAppear:animated];
    self.navigationController.toolbarHidden = NO;
}

- (void)viewWillDisappear:(BOOL)animated
{
    [super viewWillDisappear:animated];
    self.navigationController.toolbarHidden = YES;
}