UIScrollView 不会自动调整大小
Posted
技术标签:
【中文标题】UIScrollView 不会自动调整大小【英文标题】:UIScrollView will not resize with autosizing 【发布时间】:2013-03-14 05:27:35 【问题描述】:我读过的关于在 ios 5+ 上支持 UIScrollView 的所有内容都表明我应该能够使用 Xcode 的 Size Inspector 中的自动调整大小功能来自动调整我的视图大小。
使用 Storyboard,我有一个 TabBarViewController,其中一个标签有一个 UIScrollView 和一个页面控件。
在幕后,我以编程方式设置了 UIView 中页面的处理(我不知道是否有必要发布代码,但为了清楚起见,我还是会这样做)。
从 iPhone 3.5 英寸切换到 iPhone 4 英寸时,自动调整大小不起作用。 我想让 UIScrollView 和 Page 控件在使用 3.5 英寸屏幕时可见。
我应该注意 iPad 版本(请参阅下面的代码)在我的子视图中无法正确捕捉。 (这可能是一个完全不同的问题)。
4 英寸屏幕
3.5 英寸屏幕
以防万一,这是我的 .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
【问题讨论】:
【参考方案1】:这样使用
或
这样你的问题就解决了
或在您的 .m 文件中编写单行代码
scrollview.frame = CGRectMake(x, y, 320, self.view.bounds.size.height);
【讨论】:
我对 Page 控件和 UIScrollView 都这样做了,但这不起作用。我错过了什么吗? 对滚动视图和页面控制执行此操作 同样的结果。我像您的两个示例一样设置滚动视图,并且我只为页面控件的底部自动调整大小(我只是希望它保持在标签栏的顶部。没有运气。:( 如果您在 .m 文件中编写了调整大小的代码,那么只需对其进行注释并重试 你可以设置高度为 scrollview.frame = CGRectMake(x, y, 320, self.view.bounds.size.height);试试你的【参考方案2】:只需检查您添加滚动视图的视图是否启用了 AutoResizeSubviews。如果不是,它不会根据屏幕大小调整滚动视图。
其次,根据 3.5 英寸屏幕调整滚动视图,AutoResizing 将调整为 4 英寸屏幕。不要反其道而行之。
对于页面控制,这样做。它始终位于您的视图底部。
【讨论】:
这对我不起作用。我必须使用 CGRectMake 以编程方式设置滚动视图和页面控件,并找到顶层视图的高度来移动它们。 "只需检查您添加滚动视图的视图是否启用了 AutoResizeSubviews"。这是我的问题。【参考方案3】:在 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 );
【讨论】:
以上是关于UIScrollView 不会自动调整大小的主要内容,如果未能解决你的问题,请参考以下文章
在 UIScrollView 中自动调整 UITextView 的大小
当superView frameWidth 发生变化时,UIView 不会自动调整大小
将 UIImageView 动态添加到 UIScrollview 中,但它不能自动调整大小
在 UIScrollView 中自动调整 UITextView 的大小