IOS Autolayout(VFL) 处理子视图居中

attribute:NSLayoutAttributeCenterY 垂直居中
 
VFL的子视图居中,网上搜了很多都没找到有用代码,自己研究出来了。代码如下
UIActivityIndicatorView* prgrssView 
  = [[UIActivityIndicatorView alloc] initWithActivityIndicatorStyle:UIActivityIndicatorViewStyleWhiteLarge]; prgrssView.translatesAutoresizingMaskIntoConstraints = NO; [self.view addSubview:prgrssView];
[prgrssView release]; NSDictionary
* views = NSDictionaryOfVariableBindings(prgrssView); [self.view addConstraints:[NSLayoutConstraint
  constraintsWithVisualFormat:
@"|-[prgrssView]-|"
  options:NSLayoutFormatAlignAllCenterX metrics:nil views:views]];

 

 
上面的代码可以让prgrssView 水平居中。垂直代码如下
 
[self.view addConstraints:[NSLayoutConstraint 
  constraintsWithVisualFormat:@"V:|-[prgrssView]-|"
    options:NSLayoutFormatAlignAllCenterY metrics:nil views:views]];
 
以上代码测试下来只对UIActivityIndicatorView有效,如果一个view有宽度和高度则上面的居中代码会报错。可以通过另一种方式来处理,具体代码如下
 
//beging
UIImageView* imagevew = [UIImageView autolayoutView];
[imagevew setContentMode:UIViewContentModeScaleToFill];
[imagevew setImage:_tabCellImage];
[imagevew setTag:AEC_TAG_IMAGE_VIEW];
[self.view addSubview:imagevew];
[imagevew release];
 
NSDictionary* views = NSDictionaryOfVariableBindings(imagevew);
//设置高度
[self.view.contentView addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:
                      @"V:[imagevew(60)]" options:0 metrics:nil views:views]];
//设置宽度
[self.view.contentView addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:
                          @"[imagevew(60)]" options:0 metrics:nil views:views]];
//垂直居中
[self.view addConstraint:[NSLayoutConstraint constraintWithItem:imagevew 
                               relatedBy:NSLayoutRelationEqual toItem:self.view
                               attribute:NSLayoutAttributeCenterY multiplier:1 constant:0]];
//水平居中
[self.view addConstraint:[NSLayoutConstraint constraintWithItem:imagevew
                                 attribute:NSLayoutAttributeCenterX                    
                               relatedBy:NSLayoutRelationEqual toItem:self.view
           attribute:NSLayoutAttributeCenterX multiplier:1 constant:0]];
//end
 
这样就设置了一个imageview其大小为60*60 在整个视图中居中。
 
UIView *superView=_button.superview; 

//添加约束,使按钮在屏幕水平方向的中央
NSLayoutConstraint *centerXContraint = [NSLayoutConstraint constraintWithItem:_button attribute:NSLayoutAttributeCenterX
                  relatedBy:NSLayoutRelationEqual toItem:superView
                      attribute:NSLayoutAttributeCenterX multiplier:1.0f constant:0.0];

//添加约束,使按钮在屏幕垂直方向的中央
NSLayoutConstraint *centerYContraint=[NSLayoutConstraint constraintWithItem:_button attribute:NSLayoutAttributeCenterY
                  relatedBy:NSLayoutRelationEqual toItem:superView
                      attribute:NSLayoutAttributeCenterY multiplier:1.0f constant:0.0];

//给button的父节点添加约束
[superView addConstraints:@[centerXContraint,centerYContraint]];

 

posted on 2015-07-27 23:25  pTrack  阅读(769)  评论(0)    收藏  举报