UIScrollView和约束问题

我创build一个UIScrollView:

// datasetSubView.m UIScrollView *scrollView = [UIScrollView new]; scrollView.translatesAutoresizingMaskIntoConstraints = FALSE; scrollView.userInteractionEnabled = TRUE; scrollView.scrollEnabled = TRUE; scrollView.backgroundColor = [UIColor whiteColor]; scrollView.alpha = 0; self.filterListView = scrollView; 

然后在我的UIViewController,我添加滚动视图,并给它一个大小:

 [self.view addSubview:self.datasetSubBar.filterListView]; [self.view addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"H:|[filterListView]|" options:0 metrics:nil views:@{@"filterListView": self.datasetSubBar.filterListView}]]; [self.view addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"V:|[filterListView][filtersSubBar]" options:0 metrics:nil views:@{@"filterListView": self.datasetSubBar.filterListView, @"filtersSubBar" : self.datasetSubBar.filtersSubBar}]]; [self.view layoutIfNeeded]; //gives the filterListView its frame 

然后我创build一个自定义UIView放置在滚动视图:

 [self.datasetSubBar createPanels]; [self.datasetSubBar.filterListView layoutIfNeeded]; // w/out this, the panel's size is 0 //datasetSubBar.m -(void)createPanels { DatasetFilterListPanelView *panel = [[DatasetFilterListPanelView alloc] init]; panel.translatesAutoresizingMaskIntoConstraints = FALSE; panel.headerLabel.text = [NSString stringWithFormat:@"Panel %d", 1]; panel.tag = 1; [self.filterListView addSubview:panel]; [self.filterListView addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"V:|-[panel]" options:0 metrics:nil views:NSDictionaryOfVariableBindings(panel)]]; [self.filterListView addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"H:[panel]-|" options:0 metrics:nil views:NSDictionaryOfVariableBindings(panel)]]; self.panels = @[panel]; } 

它应该放置在右上angular的子视图,但它不:

 NSLog(@"viewDidAppear | self.datasetSubBar.filterListView: %@", self.datasetSubBar.filterListView); NSLog(@"self.datasetSubBar.panels: %@", self.datasetSubBar.panels) 

 2013-02-22 16:28:22.912 [5196:14003] viewDidAppear | self.datasetSubBar.filterListView: <UIScrollView: 0x8489f90; frame = (0 0; 768 934); clipsToBounds = YES; alpha = 0.8; gestureRecognizers = <NSArray: 0x848a650>; animations = { opacity=<CABasicAnimation: 0x98138b0>; }; layer = <CALayer: 0x848a160>; contentOffset: {0, 0}> 2013-02-22 16:28:22.913 [5196:14003] self.datasetSubBar.panels: ( "<DatasetFilterListPanelView: 0x9853570; frame = (-385 20; 365 165); tag = 1; layer = <CALayer: 0x9853640>>" 

感觉就像在创build子视图的时候,filterListView的宽度是0,因为如果superView是768,子视图锚点应该是(383,20){superView的宽度(768) – 子视图的宽度(365) – 填充(20) }。

这令我感到沮丧,它应该工作。 UIScrollView的行为有不同的约束?

编辑:

是的,UIScrolView处理约束不同; 我改变了滚动视图到一个UIView和工作应该像。

做了更多的挖掘和想出我需要在滚动视图中使用contentView:

 -(UIScrollView *)createFilterListView { UIScrollView *scrollView = [UIScrollView new]; scrollView.translatesAutoresizingMaskIntoConstraints = FALSE; UIView *contentView = [UIView new]; scrollView.contentView = contentView; [scrollView addSubview:contentView]; return scrollView; } 

然后在实现滚动视图的位置,为其设置约束条件,然后将contentView和contentSize设置为您需要的大小:

 [self.view layoutIfNeeded]; self.scrollView.contentView.frame = CGRectMake(0, 0, self.scrollView.frame.size.width, self.scrollView.frame.size.width * 2); self.scrollView.contentSize = CGSizeMake(self.scrollView.frame.size.width, self.scrollView.frame.size.width * 2); // made it twice as big to test scrolling 

我向UIScrollView添加了一个类别来存储内容视图。 然后使用约束将项目添加到contentView。 当您的项目需要滚动时,您将需要调整contentView和contentSize的大小。

iOS 6发行说明也会介绍这一点。