UIScrollView将不会随着自动调整大小而重新调整大小。

3

在iOS 5+上支持UIScrollView的所有内容都应该能够使用Xcode Size Inspector中的自动调整大小功能来调整视图。

使用Storyboards,我有一个TabBarViewController,其中一个选项卡有一个UIScrollView和一个Page Control。

在幕后,我已经以编程方式设置了UIView中页面的处理(我不知道是否需要发布代码,但为了清晰起见,我会这样做)。

当从iPhone 3.5英寸切换到iPhone 4英寸时,自动调整大小根本无效。我希望在使用3.5英寸屏幕时既能看到UIScrollView又能看到Page控件。

值得注意的是,iPad版本(请参阅下面的代码)在我的子视图中不能正确地对齐。(可能是个完全不同的问题)。

4英寸屏幕 4 Inch Screen

3.5英寸屏幕 3.5 Inch Screen

以防万一,这是我的.m文件:

#import "TutorialViewController.h"

@interface TutorialViewController ()
@property (nonatomic, strong) NSArray *pageImages;
@property (nonatomic, strong) NSMutableArray *pageViews;

- (void)loadVisiblePages;
- (void)loadPage:(NSInteger)page;
- (void)purgePage:(NSInteger)page;

#ifdef UI_USER_INTERFACE_IDIOM
#define IS_IPAD() (UI_USER_INTERFACE_IDIOM() == UIUserInterfaceIdiomPad)
#else
#define IS_IPAD() (false)
#endif


@end

@implementation TutorialViewController

@synthesize scrollView = _scrollView;
@synthesize pageControl = _pageControl;

@synthesize pageImages = _pageImages;
@synthesize pageViews = _pageViews;



- (void)loadPage:(NSInteger)page {
    if (page < 0 || page >= self.pageImages.count) {
        // If it's outside the range of what you have to display, then do nothing
        return;
    }

    // 1
    UIView *pageView = [self.pageViews objectAtIndex:page];
    if ((NSNull*)pageView == [NSNull null]) {
        // 2
        CGRect frame = self.scrollView.bounds;
        frame.origin.x = frame.size.width * page;
        frame.origin.y = 0.0f;

        // 3
        UIImageView *newPageView = [[UIImageView alloc] initWithImage:[self.pageImages objectAtIndex:page]];
        newPageView.contentMode = UIViewContentModeScaleAspectFill;
        newPageView.frame = frame;
        [self.scrollView addSubview:newPageView];
        // 4
        [self.pageViews replaceObjectAtIndex:page withObject:newPageView];
    }
}

- (void)purgePage:(NSInteger)page {
    if (page < 0 || page >= self.pageImages.count) {
        // If it's outside the range of what you have to display, then do nothing
        return;
    }

    // Remove a page from the scroll view and reset the container array
    UIView *pageView = [self.pageViews objectAtIndex:page];
    if ((NSNull*)pageView != [NSNull null]) {
        [pageView removeFromSuperview];
        [self.pageViews replaceObjectAtIndex:page withObject:[NSNull null]];
    }
}

- (void)loadVisiblePages {
    // First, determine which page is currently visible
    CGFloat pageWidth = self.scrollView.frame.size.width;
    NSInteger page = (NSInteger)floor((self.scrollView.contentOffset.x * 2.0f + pageWidth) / (pageWidth * 2.0f));

    // Update the page control
    self.pageControl.currentPage = page;

    // Work out which pages you want to load
    NSInteger firstPage = page - 1;
    NSInteger lastPage = page + 1;


    // Purge anything before the first page
    for (NSInteger i=0; i<firstPage; i++) {
        [self purgePage:i];
    }

    // Load pages in our range
    for (NSInteger i=firstPage; i<=lastPage; i++) {
        [self loadPage:i];
    }

    // Purge anything after the last page
    for (NSInteger i=lastPage+1; i<self.pageImages.count; i++) {
        [self purgePage:i];
    }

}

- (void)scrollViewDidScroll:(UIScrollView *)scrollView {
    // Load the pages that are now on screen
    [self loadVisiblePages];
    // NSLog(@"Scroll View Did Scroll");
}


- (void)viewDidLoad {
    [super viewDidLoad];

    // Step 1
    if (IS_IPAD())
    {
        self.pageImages = [NSArray arrayWithObjects:
                           [UIImage imageNamed:@"1536x2048 tutorial_1.png"],
                           [UIImage imageNamed:@"1536x2048 tutorial_2.png"],
                           [UIImage imageNamed:@"1536x2048 tutorial_3.png"],
                           [UIImage imageNamed:@"1536x2048 tutorial_4.png"],
                           nil];
    }
    else
    {
        self.pageImages = [NSArray arrayWithObjects:
                           [UIImage imageNamed:@"640x960 tutorial_1.png"],
                           [UIImage imageNamed:@"640x960 tutorial_2.png"],
                           [UIImage imageNamed:@"640x960 tutorial_3.png"],
                           [UIImage imageNamed:@"640x960 tutorial_4.png"],
                           nil];
    }


    NSInteger pageCount = self.pageImages.count;

    // Step 2
    self.pageControl.currentPage = 0;
    self.pageControl.numberOfPages = pageCount;

    // Step 3
    self.pageViews = [[NSMutableArray alloc] init];
    for (NSInteger i = 0; i < pageCount; ++i) {
        [self.pageViews addObject:[NSNull null]];
    }
}

- (void)viewWillAppear:(BOOL)animated {
    [super viewWillAppear:animated];

    // Step 4
    // 3.5in height = 388
    // 4in height = 476
    CGSize pagesScrollViewSize = self.scrollView.frame.size;
    self.scrollView.contentSize = CGSizeMake(pagesScrollViewSize.width * self.pageImages.count, pagesScrollViewSize.height);

    // Step 5
    [self loadVisiblePages];
}

@end
3个回答

5

这里输入图片描述

使用方法如下:

或者

这里输入图片描述

使用上述方法可以解决你的问题。

或在您的.m文件中编写单行代码。

 scrollview.frame = CGRectMake(x, y, 320, self.view.bounds.size.height);

我对Page Control和UIScrollView都做了这个,并且这并没有起作用。我是否遗漏了什么? - Macness
请对滚动视图和页面控制器执行与您已经完成的相同操作。 - Pratik
同样的结果。我像你们两个的示例一样设置了滚动视图,并且仅对页面控件进行了底部自动调整大小(我只想让它保持在选项卡栏的顶部)。但是没有成功。:( - Macness
如果您在 .m 文件中编写了调整大小的代码,请将其注释掉并重试。 - Pratik
1
你可以将高度设置为 scrollview.frame = CGRectMake(x, y, 320, self.view.bounds.size.height)。 - Pratik
显示剩余3条评论

4
只需检查您已添加滚动视图的视图是否启用了AutoResizeSubviews。如果没有启用,则不会根据屏幕大小调整滚动视图。
其次,根据3.5英寸屏幕调整滚动视图,而AutoResizing将根据4英寸屏幕进行调整。不要反过来做。
对于页面控件,请按照以下方式操作。它将始终位于视图底部。

这对我无效。我必须使用CGRectMake和查找顶级视图的高度来编程设置滚动视图和页面控件。 - Macness
1
只需检查您添加滚动视图的视图是否启用了AutoResizeSubviews。这就是我的问题所在。 - Xavi Gil

1
在Supporting Files文件夹中选择yourappname.pch,将此行添加到文件底部的最后一个#endif之前,以检查设备... #define IS_IPHONE5 (([[UIScreen mainScreen] bounds].size.height-568)?NO:YES) 然后在ViewWillAppear()中编写以下内容。
    if (IS_IPHONE5)
    {
        scrollView.contentSize = CGSizeMake(width,height );
    }

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接