我有两个UIView
,比如containerView
和testView
。假设testView
的宽度大于containerView
的宽度。在这种情况下,当我将testView
作为子视图添加到containerView
时,出现了我的问题。 testView
的帧超出了containerView
的范围。这是我的代码 -
- (void)viewDidLoad
{
[super viewDidLoad];
// Do any additional setup after loading the view, typically from a nib.
UIView *containerView = [[UIView alloc] initWithFrame:CGRectMake(60, 154, 200, 200)];
containerView.backgroundColor = [UIColor grayColor];
containerView.clipsToBounds = NO;
UIView *testView = [[UIView alloc] initWithFrame:CGRectMake(0, 0, 260, 100)];
testView.backgroundColor = [UIColor yellowColor];
testView.layer.borderWidth = 3;
testView.layer.borderColor = [[UIColor blackColor] CGColor];
testView.center = CGPointMake(containerView.frame.size.width / 2, containerView.frame.size.height / 2);
UILabel *label = [[UILabel alloc] initWithFrame:CGRectMake(15, 25, 230, 50)];
label.text = @"This is a Label to test the size";
[testView addSubview:label];
[containerView addSubview:testView];
[self.view addSubview:containerView];
}
此代码的输出是 -
当containerView.clipsToBounds = YES;
时,输出为 -
但我真正需要的是 - (已编辑图片)
当我添加宽度/高度大于其超级视图testView
的{{1}}时,应调整containerView
(包括儿童)的框架,使其完全适合在其超级视图中。
我欢迎您的想法..!
答案 0 :(得分:4)
这样做的现代方法是创建视图,向视图添加约束以建立与包含视图的关系,然后将该视图添加为子视图。
这样你就不会搞乱框架,并且会为你处理旋转大小。
已编辑添加
以下是一些示例代码,用于执行类似于您要求的内容
- (void)viewDidLoad {
[super viewDidLoad];
// Create the containing view
UIView *greyView = [[UIView alloc] initWithFrame:CGRectZero];
greyView.backgroundColor = [UIColor grayColor];
greyView.translatesAutoresizingMaskIntoConstraints = NO;
[self.view addSubview:greyView];
// Create the label to go into the containing view
UILabel *label = [[UILabel alloc] initWithFrame:CGRectZero];
label.translatesAutoresizingMaskIntoConstraints = NO;
label.text = @"Example Text";
label.backgroundColor = [UIColor yellowColor];
[greyView addSubview:label];
NSDictionary *bindings = NSDictionaryOfVariableBindings(greyView, label);
// Set the constraints for the greyView relative to it's superview - to cover completely
[self.view addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"H:|[greyView]|" options:NSLayoutFormatDirectionLeadingToTrailing metrics:nil views:bindings]];
[self.view addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"V:|[greyView]|" options:NSLayoutFormatDirectionLeadingToTrailing metrics:nil views:bindings]];
// Set the constraints for the label to be pinned equally with padding
[greyView addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"H:|-(30)-[label]-(30)-|" options:NSLayoutFormatDirectionLeadingToTrailing metrics:nil views:bindings]];
[greyView addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"V:|-(30)-[label]-(30)-|" options:NSLayoutFormatDirectionLeadingToTrailing metrics:nil views:bindings]];
}
如果你想看到它的实际效果并自己调整约束,我已经上传了你可以使用的simple example project。
答案 1 :(得分:0)
为什么你将testView(黄色)的宽度设置得比它的容器大?然后抱怨它更大?你应该做的
UIView *containerView = [[UIView alloc] initWithFrame:CGRectMake(60, 154, 200, 200)];
[...]
UIView *testView = [[UIView alloc] initWithFrame:CGRectMake(0, 0, 180, 100)]; // 180 not 260
[...]
UILabel *label = [[UILabel alloc] initWithFrame:CGRectMake(15, 25, 150, 50)]; // 150 not 230
或使用建议的自动布局。