質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
スクロール

スクロールとは、ディスプレイスクリーン上において連続的にコンテンツが滑っていくことを指します。

Xcode

Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

iPhone

iPhoneとは、アップル社が開発・販売しているスマートフォンです。 同社のデジタルオーディオプレーヤーiPodの機能、電話機能、インターネットやメールなどのWeb通信機能の3つをドッキングした機器です。

Q&A

0回答

1139閲覧

scrollViewを用いて、グラフをスクロールさせる

sakon071

総合スコア0

スクロール

スクロールとは、ディスプレイスクリーン上において連続的にコンテンツが滑っていくことを指します。

Xcode

Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

iPhone

iPhoneとは、アップル社が開発・販売しているスマートフォンです。 同社のデジタルオーディオプレーヤーiPodの機能、電話機能、インターネットやメールなどのWeb通信機能の3つをドッキングした機器です。

0グッド

0クリップ

投稿2021/12/15 12:48

前提・実現したいこと

現在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}

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問