Swift3にて、スクロールビューのコンテンツサイズの高さを可変させる方法が分からないので質問させて頂きます。
スクロールビューにのせているラベル表示の数や座標が変化するので、それに合わせてスクロールビューのコンテンツサイズを動的に変化させたいのですが、色々やってもエラーがでるので解決方法を教えて頂きたいです。
<やってみたこと>
scrollView.contentSize の height を
変数 scrollViewHeight に view.frame.heightのサイズ(h=667) としてセットしてありますが、
ラベル表示が終わった頃のscrollViewHeightは、
print("scrollViewHeight: (scrollViewHeight)") // 860
画面に収まらないサイズになっているので、
スクロールビューの scrollView.contentSize の height を更新させたいです。
宜しくお願い致します。
■ サンプルコード Swift3 xcode8
Swift3
1import UIKit 2 3class FirstViewController: UIViewController { 4 5 // csvArrayから取り出した問題を格納する配列 6 var dayArray:[String?] = [] 7 8 // スクロールビューのコンテンツサイズのheight 9 var scrollViewHeight: CGFloat = 667 10 11 override func viewDidLoad() { 12 super.viewDidLoad() 13 14 // スクロールビューを生成 15 let scrollView = UIScrollView() 16 scrollView.backgroundColor = UIColor.clear 17 scrollView.frame.size = CGSize(width: view.frame.width, height: view.frame.height) 18 scrollView.center = self.view.center 19 scrollView.contentSize = CGSize(width: view.frame.width, height: scrollViewHeight) 20 scrollView.bounces = false 21 scrollView.indicatorStyle = .default 22 scrollView.scrollIndicatorInsets = UIEdgeInsets(top: 10, left: 5, bottom: 10, right: 5) 23 scrollView.delegate = self 24 print("スクロールview.frame.width: (view.frame.width)") // 375 25 print("スクロールview.frame.height: (view.frame.height)") // 667 26 print("スクロールコンテンツscrollViewHeight: (scrollViewHeight)") // 667 27 self.view.addSubview(scrollView) 28 29 // CSVファイルを読み込む 30 let csvArray = loadCSV("test") 31 32 //csvArrayから取り出した問題を格納する配列 33 var dayArray:[String] = [] 34 35 //csvArrayの行を取得 36 dayArray = csvArray[2].components(separatedBy: ";") 37 38 //ラベル作成 39 // Dayビュー 40 let dayLabelBase = UIView() 41 dayLabelBase.frame = CGRect(x: 20, y: 10, width: 100, height: 40) 42 dayLabelBase.backgroundColor = rgbaCeruleanBlue 43 scrollView.addSubview(dayLabelBase) 44 ・ 45 ・ 46 (略) 47 ・ 48 ・ 49 50 51 // UILabelを配列に入れる 52 var labels = [UILabel]() 53 for index in 0..<31 { 54 let label = UILabel() 55 label.font = UIFont.systemFont(ofSize: 12) 56 label.backgroundColor = rgbaPaleGray 57 label.frame = CGRect(x: 40, y: 100 + (index * 30), width: 315, height: 30) 58 labels.append(label) 59 scrollView.addSubview(label) 60 } 61 62 // ラベルにテキストをセット 63 labels[0].text = dayArray[4] 64 ・ 65 (略) 66 ・ 67 labels[30].text = dayArray[124] 68 69 70 // テキストのないラベルは表示させない 71 for i in labels { 72 if i.text == "" { 73 i.isHidden = true 74 } else if i.text == nil { 75 i.isHidden = true 76 } 77 } 78 79 // 文字列が多い場合は改行させる 80 var maxY: CGFloat = 100 81 for c in labels { 82 c.frame.origin.y = maxY 83 guard let cc = c.text?.characters.count else { 84 return 85 } 86 if cc > 25 { 87 c.numberOfLines = 0 88 c.frame.size.height += 20 89 c.frame = CGRect(x: 40, y: maxY, width: 315, height: c.frame.size.height) 90 } 91 maxY = c.frame.maxY 92 } 93 } 94 95 // 配列labelsの表示されているラベルの高さの合計で最後のラベルのmaxYを取得 96 var labelsMaxY: CGFloat 97 var sum = 100 98 for i in labels { 99 if i.isHidden == false { 100 let height: Int = Int(i.frame.height) 101 sum += height 102 } 103 } 104 labelsMaxY = CGFloat(sum) 105 print("sum: (sum)") // 580 106 107 // aLabel生成 108 let aLabel = UILabel() 109 aLabel.frame = CGRect(x: 300, y: labelsMaxY + 200, width: 50, height: 30) 110 aLabel.backgroundColor = .green 111 scrollView.addSubview(aLabel) 112 113 // scrollViewHeightを再設定 114 scrollViewHeight = aLabel.frame.maxY + 50 115 print("scrollViewHeight: (scrollViewHeight)") // 860 116 117 } 118 (略) 119}

回答1件
あなたの回答
tips
プレビュー
下記のような回答は推奨されていません。
このような回答には修正を依頼しましょう。
また依頼した内容が修正された場合は、修正依頼を取り消すようにしましょう。
2018/01/29 03:36