2016-08-04 71 views
0

Es gibt 6 Tasten auf dem Bildschirm. Ich möchte 6 Tasten nacheinander auf dem Bildschirm platzieren, mit dem gleichen Abstand wie im Bild auf dem ganzen Bildschirm gezeigt, d. H. 4S, 5S, 6 und 6 Plus durch Kodierung.Stellen Sie die Taste mit Auto-Layout durch Programmierung

enter image description here

Die constrain, die wir und addConstraintToControls() in viewWillAppear Aufruf hinzugefügt:

func addConstraintToControls() 
{ 
    self.twitterButton.translatesAutoresizingMaskIntoConstraints = false; 
    self.facebookButton.translatesAutoresizingMaskIntoConstraints = false; 
    self.googleButton.translatesAutoresizingMaskIntoConstraints = false; 

    //Horizontal constraints: 
    scrollView.addConstraint(NSLayoutConstraint(item: twitterButton, attribute: .Leading, relatedBy: .Equal, toItem: scrollView, attribute: .Leading, multiplier: 1, constant:5)) 
    scrollView.addConstraint(NSLayoutConstraint(item: facebookButton, attribute: .Leading, relatedBy: .Equal, toItem: twitterButton, attribute: .Trailing, multiplier: 1, constant:5)) 
    scrollView.addConstraint(NSLayoutConstraint(item: googleButton, attribute: .Leading, relatedBy: .Equal, toItem: facebookButton, attribute: .Trailing, multiplier: 1, constant:5)) 

    scrollView.addConstraint(NSLayoutConstraint(item: googleButton, attribute: .Trailing, relatedBy: .Equal, toItem: scrollView, attribute: .Trailing, multiplier: 1, constant:-5)) 
    scrollView.addConstraint(NSLayoutConstraint(item: googleButton, attribute: .Width, relatedBy: .Equal, toItem: facebookButton, attribute: .Width, multiplier: 1, constant:0)) 
    scrollView.addConstraint(NSLayoutConstraint(item: googleButton, attribute: .Width, relatedBy: .Equal, toItem: twitterButton, attribute: .Width, multiplier: 1, constant:0)) 

    //Ratio constraints: 
    twitterButton.addConstraint(NSLayoutConstraint(item: twitterButton, attribute: .Width, relatedBy: .Equal, toItem: twitterButton, attribute: .Height, multiplier: 1, constant:0)) 
    googleButton.addConstraint(NSLayoutConstraint(item: googleButton, attribute: .Width, relatedBy: .Equal, toItem: googleButton, attribute: .Height, multiplier: 1, constant:0)) 
    facebookButton.addConstraint(NSLayoutConstraint(item: facebookButton, attribute: .Width, relatedBy: .Equal, toItem: facebookButton, attribute: .Height, multiplier: 1, constant:0)) 

    //Top constraints: 
    scrollView.addConstraint(NSLayoutConstraint(item: twitterButton, attribute: .Top, relatedBy: .Equal, toItem: scrollView, attribute: .Top, multiplier: 1, constant:5)) 
    scrollView.addConstraint(NSLayoutConstraint(item: facebookButton, attribute: .Top, relatedBy: .Equal, toItem: scrollView, attribute: .Top, multiplier: 1, constant:5)) 
    scrollView.addConstraint(NSLayoutConstraint(item: googleButton, attribute: .Top, relatedBy: .Equal, toItem: scrollView, attribute: .Top, multiplier: 1, constant:5)) 
} 

Aber wir sind nicht in der Lage den Tasten 2 und 3 mit dem eine nach der anderen Taste zu erreichen. Ich möchte dies erreichen, indem ich + Swift und Autolayout und Constraint benutze.

Ich erhalte die Warnung unten in der Konsole:

Unable to simultaneously satisfy constraints. 
    Probably at least one of the constraints in the following list is one you don't want. 
    Try this: 
     (1) look at each constraint and try to figure out which you don't expect; 
     (2) find the code that added the unwanted constraint or constraints and fix it. 
(
    "<NSLayoutConstraint:0x7fe321ce1880 H:|-(5)-[MyApp.HKBadgeButton:0x7fe321dedae0] (Names: '|':UIScrollView:0x7fe322070200)>", 
    "<NSIBPrototypingLayoutConstraint:0x7fe321dab140 'IB auto generated at build time for view with fixed frame' H:|-(145)-[MyApp.HKBadgeButton:0x7fe321dedae0](LTR) (Names: '|':UIScrollView:0x7fe322070200)>" 
) 

Will attempt to recover by breaking constraint 
<NSLayoutConstraint:0x7fe321ce1880 H:|-(5)-[MyApp.HKBadgeButton:0x7fe321dedae0] (Names: '|':UIScrollView:0x7fe322070200)> 

Make a symbolic breakpoint at UIViewAlertForUnsatisfiableConstraints to catch this in the debugger. 
The methods in the UIConstraintBasedLayoutDebugging category on UIView listed in <UIKit/UIView.h> may also be helpful. 

Bitte beraten.

+0

Wo und wie schaffen Sie Ihre Tasten? Was ist der Zweck der scrollView? Wie sollen Ihre Knöpfe aussehen, sagen wir 4S, verringern Sie die Größe oder scrollen Sie sie, um alle zu sehen? – Andrej

+0

1. Schaltflächen erstellt von IBOutlet und verbunden mit Code, 2. ScrollView ist meine UIScrollView, und auf 4s scrollview sollte Scroll sein. – aaK

Antwort

-1

Sie verwenden .Leading Attribut überall! Verwenden Sie manchmal .Trailing. Sie können die implizite Punktnotation verwenden, um Ihren Code kürzer und lesbarer zu machen. Normalerweise verwalten Sie Ansichten und Einschränkungen zusammen in xib oder zusammen im Code, selten getrennt. Weil es schwer zu erraten ist, wie Sie Ihre Scrollview und content konstruieren, können Sie mir zeigen, wie alles in Code getan werden kann, können Sie die einfache Nutzung Teile davon:

let scrollView = UIScrollView() 
let contentView = UIView() 

var twitterButton: UIButton! 
var facebookButton: UIButton! 
var googleButton: UIButton! 
var checkButton: UIButton! 
var mailButton: UIButton! 
var redditButton: UIButton! 

Zuerst müssen Sie die Einrichtung content richtig. Lassen Sie mich es als 'Tabellenansicht' Stil einrichten, nur vertikale Scroll. Alle folgenden Code sollte in viewDidLoad geschrieben werden:

initializeAllButtons() // initialize all buttons first 

view.addSubview(scrollView) 
scrollView.translatesAutoresizingMaskIntoConstraints = false 
view.addConstraint(NSLayoutConstraint(item: scrollView, attribute: .Leading, relatedBy: .Equal, toItem: view, attribute: .Leading, multiplier: 1, constant: 0)) 
view.addConstraint(NSLayoutConstraint(item: scrollView, attribute: .Top, relatedBy: .Equal, toItem: view, attribute: .Top, multiplier: 1, constant: 0)) 
view.addConstraint(NSLayoutConstraint(item: scrollView, attribute: .Trailing, relatedBy: .Equal, toItem: view, attribute: .Trailing, multiplier: 1, constant: 0)) 
view.addConstraint(NSLayoutConstraint(item: scrollView, attribute: .Bottom, relatedBy: .Equal, toItem: view, attribute: .Bottom, multiplier: 1, constant: 0)) 

scrollView.addSubview(contentView) 
contentView.translatesAutoresizingMaskIntoConstraints = false 
scrollView.addConstraint(NSLayoutConstraint(item: scrollView, attribute: .Leading, relatedBy: .Equal, toItem: contentView, attribute: .Leading, multiplier: 1, constant: 0)) 
scrollView.addConstraint(NSLayoutConstraint(item: scrollView, attribute: .Top, relatedBy: .Equal, toItem: contentView, attribute: .Top, multiplier: 1, constant: 0)) 
scrollView.addConstraint(NSLayoutConstraint(item: scrollView, attribute: .Trailing, relatedBy: .Equal, toItem: contentView, attribute: .Trailing, multiplier: 1, constant: 0)) 
scrollView.addConstraint(NSLayoutConstraint(item: scrollView, attribute: .Bottom, relatedBy: .Equal, toItem: contentView, attribute: .Bottom, multiplier: 1, constant: 0)) 

// next line prevent scrollView from horizontal scroll 
view.addConstraint(NSLayoutConstraint(item: view, attribute: .Width, relatedBy: .Equal, toItem: contentView, attribute: .Width, multiplier: 1, constant: 0)) 

Jetzt müssen Sie Ihre Schaltflächen hinzufügen zu content und fügen Einschränkungen (initialisiert!):

contentView.addSubview(twitterButton) 
contentView.addSubview(facebookButton) 
contentView.addSubview(googleButton) 
contentView.addSubview(checkButton) 
contentView.addSubview(mailButton) 
contentView.addSubview(redditButton) 
twitterButton.translatesAutoresizingMaskIntoConstraints = false 
facebookButton.translatesAutoresizingMaskIntoConstraints = false 
googleButton.translatesAutoresizingMaskIntoConstraints = false 
checkButton.translatesAutoresizingMaskIntoConstraints = false 
mailButton.translatesAutoresizingMaskIntoConstraints = false 
redditButton.translatesAutoresizingMaskIntoConstraints = false 

Horizontale Beschränkungen (von Ihrem veröffentlicht):

contentView.addConstraint(NSLayoutConstraint(item: twitterButton, attribute: .Leading, relatedBy: .Equal, toItem: contentView, attribute: .Leading, multiplier: 1, constant:5)) 
contentView.addConstraint(NSLayoutConstraint(item: facebookButton, attribute: .Leading, relatedBy: .Equal, toItem: twitterButton, attribute: .Trailing, multiplier: 1, constant:5)) 
contentView.addConstraint(NSLayoutConstraint(item: googleButton, attribute: .Leading, relatedBy: .Equal, toItem: facebookButton, attribute: .Trailing, multiplier: 1, constant:5)) 
contentView.addConstraint(NSLayoutConstraint(item: checkButton, attribute: .Leading, relatedBy: .Equal, toItem: googleButton, attribute: .Trailing, multiplier: 1, constant:5)) 
contentView.addConstraint(NSLayoutConstraint(item: mailButton, attribute: .Leading, relatedBy: .Equal, toItem: checkButton, attribute: .Trailing, multiplier: 1, constant:5)) 
contentView.addConstraint(NSLayoutConstraint(item: redditButton, attribute: .Leading, relatedBy: .Equal, toItem: mailButton, attribute: .Trailing, multiplier: 1, constant:5)) 
contentView.addConstraint(NSLayoutConstraint(item: contentView, attribute: .Trailing, relatedBy: .Equal, toItem: redditButton, attribute: .Trailing, multiplier: 1, constant:5)) 

Horizontal Bilder gleich Größenbeschränkungen:

contentView.addConstraint(NSLayoutConstraint(item: googleButton, attribute: .Width, relatedBy: .Equal, toItem: facebookButton, attribute: .Width, multiplier: 1, constant:0)) 
contentView.addConstraint(NSLayoutConstraint(item: googleButton, attribute: .Width, relatedBy: .Equal, toItem: twitterButton, attribute: .Width, multiplier: 1, constant:0)) 
contentView.addConstraint(NSLayoutConstraint(item: googleButton, attribute: .Width, relatedBy: .Equal, toItem: checkButton, attribute: .Width, multiplier: 1, constant:0)) 
contentView.addConstraint(NSLayoutConstraint(item: googleButton, attribute: .Width, relatedBy: .Equal, toItem: mailButton, attribute: .Width, multiplier: 1, constant:0)) 
contentView.addConstraint(NSLayoutConstraint(item: googleButton, attribute: .Width, relatedBy: .Equal, toItem: redditButton, attribute: .Width, multiplier: 1, constant:0)) 

Verhältnis Einschränkungen:

twitterButton.addConstraint(NSLayoutConstraint(item: twitterButton, attribute: .Width, relatedBy: .Equal, toItem: twitterButton, attribute: .Height, multiplier: 1, constant:0)) 
googleButton.addConstraint(NSLayoutConstraint(item: googleButton, attribute: .Width, relatedBy: .Equal, toItem: googleButton, attribute: .Height, multiplier: 1, constant:0)) 
facebookButton.addConstraint(NSLayoutConstraint(item: facebookButton, attribute: .Width, relatedBy: .Equal, toItem: facebookButton, attribute: .Height, multiplier: 1, constant:0)) 
checkButton.addConstraint(NSLayoutConstraint(item: checkButton, attribute: .Width, relatedBy: .Equal, toItem: checkButton, attribute: .Height, multiplier: 1, constant:0)) 
mailButton.addConstraint(NSLayoutConstraint(item: mailButton, attribute: .Width, relatedBy: .Equal, toItem: mailButton, attribute: .Height, multiplier: 1, constant:0)) 
redditButton.addConstraint(NSLayoutConstraint(item: redditButton, attribute: .Width, relatedBy: .Equal, toItem: redditButton, attribute: .Height, multiplier: 1, constant:0)) 

Top Einschränkungen:

contentView.addConstraint(NSLayoutConstraint(item: twitterButton, attribute: .Top, relatedBy: .Equal, toItem: contentView, attribute: .Top, multiplier: 1, constant:5)) 
contentView.addConstraint(NSLayoutConstraint(item: facebookButton, attribute: .Top, relatedBy: .Equal, toItem: contentView, attribute: .Top, multiplier: 1, constant:5)) 
contentView.addConstraint(NSLayoutConstraint(item: googleButton, attribute: .Top, relatedBy: .Equal, toItem: contentView, attribute: .Top, multiplier: 1, constant:5)) 
contentView.addConstraint(NSLayoutConstraint(item: checkButton, attribute: .Top, relatedBy: .Equal, toItem: contentView, attribute: .Top, multiplier: 1, constant:5)) 
contentView.addConstraint(NSLayoutConstraint(item: mailButton, attribute: .Top, relatedBy: .Equal, toItem: contentView, attribute: .Top, multiplier: 1, constant:5)) 
contentView.addConstraint(NSLayoutConstraint(item: redditButton, attribute: .Top, relatedBy: .Equal, toItem: contentView, attribute: .Top, multiplier: 1, constant:5)) 

Bottom Einschränkungen:

contentView.addConstraint(NSLayoutConstraint(item: twitterButton, attribute: .Bottom, relatedBy: .Equal, toItem: contentView, attribute: . Bottom, multiplier: 1, constant:-5)) 
contentView.addConstraint(NSLayoutConstraint(item: facebookButton, attribute: .Bottom, relatedBy: .Equal, toItem: contentView, attribute: .Bottom, multiplier: 1, constant:-5)) 
contentView.addConstraint(NSLayoutConstraint(item: googleButton, attribute: .Bottom, relatedBy: .Equal, toItem: contentView, attribute: .Bottom, multiplier: 1, constant:-5)) 
contentView.addConstraint(NSLayoutConstraint(item: checkButton, attribute: .Bottom, relatedBy: .Equal, toItem: contentView, attribute: .Bottom, multiplier: 1, constant:-5)) 
contentView.addConstraint(NSLayoutConstraint(item: mailButton, attribute: .Bottom, relatedBy: .Equal, toItem: contentView, attribute: .Bottom, multiplier: 1, constant:-5)) 
contentView.addConstraint(NSLayoutConstraint(item: redditButton, attribute: .Bottom, relatedBy: .Equal, toItem: contentView, attribute: .Bottom, multiplier: 1, constant:-5)) 
+0

Versucht, aber nicht erfolgreich :( – aaK

+0

@aaK überprüfen verbesserte Antwort –

1

Ich denke visuelles Format mit automatischem Layout wird Ihren Code massiv reduzieren. Wenn Sie alle Schaltflächen in einer Containeransicht platzieren, können Sie die Breite des Containers so festlegen, dass die gewünschte Größe angezeigt wird. Dann fügen Sie diesen Container Ihrer scrollView hinzu.

let views = ["view1":view1, 
      "view2":view2, 
      "view3":view3, 
      "view4":view4, 
      "view5":view5, 
      "view6":view6] 
let metrics = ["spacing":5] 

containerView.addConstraints(NSLayoutConstraint.constraintsWithVisualFormat("|[view1]-spacing-[view2(==view1)]-spacing-[view3(==view1)]-spacing-[view4(==view1)]-spacing-[view5(==view1)]-spacing-[view6(==view1)]|", options: [.AlignAllTop, .AlignAllBottom], metrics: metrics, views: views)) 
containerView.addConstraints(NSLayoutConstraint.constraintsWithVisualFormat("V:|[view1]|", options: [], metrics: metrics, views: views)) 
1

Wenn Sie in Code Einschränkungen zu verwenden, würde ich empfehlen, einen Rahmen für die Verwendung. Die Art und Weise, wie Beschränkungen hinzugefügt werden, ist sehr unordentlich.

Ein guter Rahmen für programmatische Einschränkungen ist PureLayout. https://github.com/PureLayout/PureLayout

Hoffentlich könnte dies Ihnen helfen, die Fehler zu sortieren.

0

/**** Swift 3.0 - Automatische Anordnung ****/

let label1 = UILabel() 
    label1.translatesAutoresizingMaskIntoConstraints = false 
    label1.backgroundColor = UIColor.red 
    label1.text = "THESE" 

    let label2 = UILabel() 
    label2.translatesAutoresizingMaskIntoConstraints = false 
    label2.backgroundColor = UIColor.cyan 
    label2.text = "ARE" 

    let label3 = UILabel() 
    label3.translatesAutoresizingMaskIntoConstraints = false 
    label3.backgroundColor = UIColor.yellow 
    label3.text = "SOME" 

    view.addSubview(label1) 
    view.addSubview(label2) 
    view.addSubview(label3) 

    let viewsDictionary = ["label1": label1, "label2": label2, "label3": label3] 
    let height: Int = 30 
    let Y:Int = 100 
    let X:Int = 10 
    let space:Int = 10 

    for label in viewsDictionary.keys { 
     view.addConstraints(NSLayoutConstraint.constraints(withVisualFormat: "V:|-\(Y)-[\(label)(\(height))]|", options: [], metrics: nil, views: viewsDictionary)) 
    } 
    view.addConstraints(NSLayoutConstraint.constraints(withVisualFormat:"H:|-\(X)-[label1]-\(space)-[label2(==label1)]-\(space)-[label3(==label1)]-\(space)-|", options: [], metrics: nil, views: viewsDictionary))