Sto aggiungendo un UIView a UIScrollView
e vincolandolo in modo che riempia lo spazio orizzontale, ad eccezione di alcuni margini. Il mio vincolo visivo si presenta così:UIView non obbedisce ai vincoli di autolayout in UIScrollView
@"|-16-[theLineView]-16-|"
ho fatto la vista di un pixel ad alta in modo che apparirà come una linea, e la pose tra due etichette di testo:
@"V:[someOtherStuff]-[aTextLabel]-[theLineView]-[anotherLabel]"
Tuttavia, sto trovando che la larghezza della linea si espande solo fino alla larghezza dell'etichetta più lunga sopra/sotto di essa.
Perché dovrebbe essere?
P.S Ho letto questo http://developer.apple.com/library/ios/#technotes/tn2154/_index.html
Codice
Ecco la totalità del codice di vista del regolatore da un progetto di test che presenta questo problema sulla sim iPad.
- (void)viewDidLoad
{ [super viewDidLoad];
self.scrollView = [[UIScrollView alloc] init];
self.scrollView.translatesAutoresizingMaskIntoConstraints = NO;
self.scrollView.backgroundColor = [UIColor greenColor];
[self.view addSubview:self.scrollView];
[self.view addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"|[scrollView]|"
options:0
metrics:0
views:@{@"scrollView":self.scrollView}]];
[self.view addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"V:|[scrollView]|"
options:0
metrics:0
views:@{@"scrollView":self.scrollView}]];
self.line1 = [[UIView alloc] init];
self.line2 = [[UIView alloc] init];
self.label1 = [[UILabel alloc] init];
self.label2 = [[UILabel alloc] init];
self.label3 = [[UILabel alloc] init];
for (UILabel *label in @[self.label1, self.label2, self.label3])
{
label.text = @"I am a label and I am long enough that I can be multiline on an iphone but single on ipad";
}
for (UIView *view in @[self.line1, self.line2, self.label1, self.label2, self.label3])
{
view.translatesAutoresizingMaskIntoConstraints = NO;
view.backgroundColor = [UIColor redColor];
[self.scrollView addSubview:view];
}
//horizontal layout - all views/labels should fill the horizontal space expect for margin
for (UIView *view in @[self.line1, self.line2, self.label1, self.label2, self.label3])
{
NSArray *constraints = [NSLayoutConstraint constraintsWithVisualFormat:@"|-16-[view]-16-|"
options:0
metrics:0
views:@{@"view":view}];
[self.scrollView addConstraints:constraints];
}
//vertical layout - stack em up
[self.scrollView addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"V:|-[lab1]-[line1(==1)]-[lab2]-[line2(==1)]-[lab3]-|"
options:0
metrics:0
views:@{@"lab1":self.label1, @"line1":self.line1, @"lab2":self.label2, @"line2":self.line2, @"lab3":self.label3}]];
}
Il tuo 1px 'UIView' ha altri vincoli su di esso? – Yazid
[guarda] la stessa vista di [theLineView]? Avete qualche impostazione delle opzioni di allineamento nel parametro opzioni? – rdelmar
Nessun altro vincolo o nulla nel parametro opzioni. Vedrò se riesco a riprodurre in un progetto di test. Sì, quelle visualizzazioni sono le stesse, corretto lo snippet. –