2017-10-05 18 views
1

UIScrollViewの仕組みを理解しようとしていて、別のbackgroundColorプロパティでいくつかのサブビューを追加しました。 ios9 autolayoutを使ってサブビューをレイアウトしましたが、ビューが画面外にあっても、UIScrollViewはまだスクロールしません。 UIScrollViewsで自動レイアウトを使用する場合UIScrollViewをプログラムでレイアウトし、そのサブビューに自動レイアウトを追加しましたがスクロールしません。

import UIKit 

class ViewController: UIViewController { 

    let scrollView: UIScrollView = { 
     let sv = UIScrollView() 
     sv.translatesAutoresizingMaskIntoConstraints = false 
     sv.backgroundColor = .gray 
     return sv 
    }() 

    override func viewDidLoad() { 
     super.viewDidLoad() 

     view.addSubview(scrollView) 

     scrollView.leftAnchor.constraint(equalTo: view.leftAnchor).isActive = true 
     scrollView.rightAnchor.constraint(equalTo: view.rightAnchor).isActive = true 
     scrollView.topAnchor.constraint(equalTo: view.topAnchor).isActive = true 
     scrollView.bottomAnchor.constraint(equalTo: view.bottomAnchor).isActive = true 

     let view1 = UIView() 
     view1.backgroundColor = .red 

     let view2 = UIView() 
     view2.backgroundColor = .blue 

     let view3 = UIView() 
     view3.backgroundColor = .green 

     let view4 = UIView() 
     view4.backgroundColor = .purple 

     let views = [view1, view2, view3, view4] 

     for view in views { 
      scrollView.addSubview(view) 
      view.translatesAutoresizingMaskIntoConstraints = false 
     } 

     view1.topAnchor.constraint(equalTo: scrollView.topAnchor).isActive = true 
     view1.leftAnchor.constraint(equalTo: scrollView.leftAnchor).isActive = true 
     view1.heightAnchor.constraint(equalToConstant: 140).isActive = true 
     view1.widthAnchor.constraint(equalToConstant: 140).isActive = true 

     view2.topAnchor.constraint(equalTo: view1.bottomAnchor, constant: 100).isActive = true 
     view2.leftAnchor.constraint(equalTo: view1.rightAnchor).isActive = true 
     view2.heightAnchor.constraint(equalToConstant: 140).isActive = true 
     view2.widthAnchor.constraint(equalToConstant: 140).isActive = true 

     view3.topAnchor.constraint(equalTo: view2.bottomAnchor, constant: 50).isActive = true 
     view3.leftAnchor.constraint(equalTo: view1.rightAnchor).isActive = true 
     view3.heightAnchor.constraint(equalToConstant: 140).isActive = true 
     view3.widthAnchor.constraint(equalToConstant: 140).isActive = true 

     view4.topAnchor.constraint(equalTo: view3.bottomAnchor, constant: 20).isActive = true 
     view4.leftAnchor.constraint(equalTo: view1.rightAnchor).isActive = true 
     view4.heightAnchor.constraint(equalToConstant: 140).isActive = true 
     view4.widthAnchor.constraint(equalToConstant: 140).isActive = true 
    } 

} 

答えて

0

あなたはscrollviewはそのcontentSizeを計算することができますscrollviewの上部と下部にサブビューの両方を固定する必要があります。

この行を追加すると、それが修正されています。

view4.bottomAnchor.constraint(equalTo: scrollView.bottomAnchor, constant: 0).isActive = true 
関連する問題