前提・実現したいこと
現在XcodeでSwiftを用いて、iPhoneアプリを開発しています。
棒グラフをChartsで作成し、scrollViewを用いてスクロールさせたいと考えています。
https://bombrary.github.io/blog/posts/iphone-barchart-ioscharts/
を参考にして、scrollViewの設定を行なっていたところ、思っている挙動とは異なる動きをしました。
どのようにしたら解決するのか教えて頂きたいです。よろしくお願いします。
該当のソースコード
Swift
1import UIKit 2import Charts 3 4struct BarChartModel { 5 let value: Int 6 let name: String 7} 8 9class ViewController: UIViewController ,ChartViewDelegate, UIScrollViewDelegate{ 10 11 @IBOutlet weak var scrollView: UIScrollView! 12 //sample data 13 var barItems = [ 14 (7, "太郎"), (1, "次郎"), (2, "三郎"), (6, "四郎"), (3, "五郎"), 15 (9, "六郎"), (2, "七郎"), (3, "八郎"), (1, "九郎"), (5, "十郎"), 16 (1, "十一郎"), (1, "十二郎"), (6, "十三郎") 17 ] 18 lazy var maxVal: Int = barItems.map({ $0.0 }).max()! 19 override func viewDidLoad() { 20 super.viewDidLoad() 21 scrollView.frame = CGRect( 22 x: 0, 23 y: 0, 24 width: scrollView.superview!.frame.width, 25 height: scrollView.superview!.frame.height 26 ) 27 let contentsView = createContentsView( 28 of: barItems.map({ BarChartModel(value: $0.0, name: $0.1 ) }), 29 barsCountPerPage: 5 30 ) 31 scrollView.addSubview(contentsView) 32 scrollView.contentSize = contentsView.frame.size 33 scrollView.isPagingEnabled = true 34 } 35 private func createBarChartView(of items: [BarChartModel]) -> BarChartView { 36 37 let barChartView = BarChartView() 38 barChartView.data = createBarChartData(of: barItems.map({BarChartModel(value: $0.0, name: $0.1)})) 39 //アニメーション 40 barChartView.animate(yAxisDuration: 1) 41 42 //x軸設定 43 barChartView.xAxis.labelCount = barItems.count 44 barChartView.xAxis.labelPosition = .bottom 45 barChartView.xAxis.valueFormatter = IndexAxisValueFormatter(values: items.map({$0.name})) 46 47 // グリッドやy軸を非表示 48 barChartView.xAxis.drawGridLinesEnabled = false 49 barChartView.leftAxis.enabled = false //後にtrueに変更 50 barChartView.rightAxis.enabled = false 51 52 // 凡例を非表示にする 53 barChartView.legend.enabled = false 54 55 // ズームできないようにする 56 barChartView.pinchZoomEnabled = false 57 barChartView.doubleTapToZoomEnabled = false 58 return barChartView 59 } 60 61 private func createBarChartData(of items: [BarChartModel]) -> BarChartData { 62 let entries: [BarChartDataEntry] = items.enumerated().map { 63 let (i, item) = $0 64 return BarChartDataEntry(x: Double(i), y: Double(item.value)) 65 } 66 let barChartDataSet = BarChartDataSet(entries: entries, label: "Label") 67 let barChartData = BarChartData(dataSet: barChartDataSet) 68 //上の数字の設定 69 barChartDataSet.valueFormatter = ValueFormatter(of: items) 70 return barChartData 71 } 72 //x軸設定 73 class XAxisFormatter: IAxisValueFormatter { 74 let items: [BarChartModel] 75 init(of items: [BarChartModel]) { 76 self.items = items 77 } 78 func stringForValue(_ value: Double, axis: AxisBase?) -> String { 79 let index = Int(value) 80 return self.items[index].name 81 } 82 } 83 //上に表示される数字の設定 84 class ValueFormatter: IValueFormatter { 85 let items: [BarChartModel] 86 init(of items: [BarChartModel]) { 87 self.items = items 88 } 89 func stringForValue(_ value: Double, entry: ChartDataEntry, dataSetIndex: Int, viewPortHandler: ViewPortHandler?) -> String { 90 return "(Int(value))" 91 } 92 } 93 //scrollView 94 private func createContentsView(of items: [BarChartModel], barsCountPerPage: Int) -> UIView { 95 let itemsPerPage = stride(from: 0, to: items.count, by: barsCountPerPage).map { 96 Array(items[$0 ..< min($0 + barsCountPerPage, items.count)]) 97 } 98 let contentsView = UIView(frame: CGRect( 99 x: 0, 100 y: 0, 101 width: scrollView.frame.width * CGFloat(itemsPerPage.count), 102 height: scrollView.frame.height 103 )) 104 for (i, items) in itemsPerPage.enumerated() { 105 let barChartView = createBarChartView(of: items) 106 107 let percent = CGFloat(items.count) / CGFloat(itemsPerPage[0].count) 108 barChartView.frame = CGRect( 109 x: scrollView.frame.width * CGFloat(i), 110 y: 0, 111 width: scrollView.frame.width * percent, 112 height: scrollView.frame.height 113 ) 114 contentsView.addSubview(barChartView) 115 } 116 return contentsView 117 } 118}
あなたの回答
tips
プレビュー