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

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

新規登録して質問してみよう
ただいま回答率
85.48%
iOS

iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

Xcode

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

Swift

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

Q&A

解決済

2回答

7026閲覧

[Swift] [iOS-Charts] X軸に関する設定の確認

ks-cap

総合スコア22

iOS

iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

Xcode

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

Swift

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

0グッド

1クリップ

投稿2017/06/20 14:27

編集2017/06/21 00:13

###前提・実現したいこと
Qiitaの記事ios-charts チャート表示ライブラリ Xcode8 + Swift3を参考に、iOS-Chartsを使って棒グラフを作成してみようと思ったのですが、とある箇所の引数が理解できずに困っています。

public func stringForValue(_ value: Double, axis: AxisBase?) -> String {
// 0 -> Jan, 1 -> Feb...
return months[Int(value)]
}

この関数に疑問を持ち、
stringForValue(_ value: Double, axis: AxisBase?)
の第一引数である
「_ value: Double」はどこから値が呼ばれているか知りたいです。

教えていただければ幸いです。よろしくお願いいたします。

###試したこと
print(value)置き、value値を確かめたところ、
0.0、1.0、2.0、3.0、4.0、...となりました。
X軸やY軸の個数(unitsSoldやmonthsの配列の増減 例)共に4つ格納)を変化すると実行結果が
0.0、0.7、1.4、2.1、2.8、3.5
となったりします。

###補足情報(言語/FW/ツール等のバージョンなど)
swift 3.0 / Xcode 8.3.3 / Charts 3.0.2 を使用しています。

###ソースコード

// ChartViewController.swift import UIKit import Charts class ChartViewController: UIViewController { // ここに棒グラフを描きます @IBOutlet weak var myChartView: BarChartView! override func viewDidLoad() { super.viewDidLoad() // y軸のプロットデータ let unitsSold = [20.0, 4.0, 6.0, 3.0, 12.0, 16.0, 4.0, 18.0, 2.0, 4.0, 5.0, 4.0] setChart(y: unitsSold) } func setChart(y: [Double]) { // プロットデータ(y軸)を保持する配列 var dataEntries = [BarChartDataEntry]() for (i, val) in y.enumerated() { let dataEntry = BarChartDataEntry(x: Double(i), y: val) // X軸データは、0,1,2,... dataEntries.append(dataEntry) } // グラフをUIViewにセット let chartDataSet = BarChartDataSet(values: dataEntries, label: "Units Sold") myChartView.data = BarChartData(dataSet: chartDataSet) // X軸のラベルを設定 let xaxis = XAxis() xaxis.valueFormatter = BarChartFormatter() myChartView.xAxis.valueFormatter = xaxis.valueFormatter // x軸のラベルをボトムに表示 myChartView.xAxis.labelPosition = .bottom // グラフの色 chartDataSet.colors = [UIColor(red: 230/255, green: 126/255, blue: 34/255, alpha: 1)] // グラフの背景色 myChartView.backgroundColor = UIColor(red: 189/255, green: 195/255, blue: 199/255, alpha: 1) // グラフの棒をニョキッとアニメーションさせる myChartView.animate(xAxisDuration: 2.0, yAxisDuration: 2.0) // 横に赤いボーダーラインを描く let ll = ChartLimitLine(limit: 10.0, label: "Target") myChartView.rightAxis.addLimitLine(ll) // グラフのタイトル myChartView.chartDescription?.text = "Cool Graph!" } } public class BarChartFormatter: NSObject, IAxisValueFormatter{ // x軸のラベル var months: [String]! = ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"] // デリゲート。TableViewのcellForRowAtで、indexで渡されたセルをレンダリングするのに似てる。 public func stringForValue(_ value: Double, axis: AxisBase?) -> String { // 0 -> Jan, 1 -> Feb... return months[Int(value)] } }

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

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

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

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

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

fuzzball

2017/06/20 23:46 編集

「どこから値をもらっているか」というのは「どこから呼ばれているか」という意味でいいでしょうか?あと、コードは ``` で囲って下さい。
ks-cap

2017/06/21 00:15

指摘された点につきまして変更致しました。はい、引数である「_ value: Double」がどこから呼ばれているかです。
guest

回答2

0

ベストアンサー

おそらく、x軸の値はライブラリ側で自動で計算されているのだと思います。(自分の場合は0.0, 2.0, 4.0... となりました。)

以下、このライブラリの説明をします。
https://github.com/danielgindi/Charts

計算方法

x軸のラベルの数はデフォルトで 6 個になっています。
Source/Charts/Components/AxisBase.swift

lang

1 /// the number of label entries the axis should have 2 /// 3 /// **default**: 6 4 fileprivate var _labelCount = Int(6)

その _labelCount ですが、ViewController内などで、

lang

1 myChartView.xAxis.labelCount = Int(12)

などと設定した場合、 AxisBase.swift内のsetLabelCountという関数が実行されます。
その中身ですが、

lang

1 open func setLabelCount(_ count: Int, force: Bool) 2 { 3 self.labelCount = count 4 forceLabelsEnabled = force 5 }

このようになっており、 labelCountに値を保持させています。
さて、labelCountですが、

/// the number of label entries the axis should have /// max = 25, /// min = 2, /// default = 6, /// be aware that this number is not fixed and can only be approximated open var labelCount: Int { get { return _labelCount } set { _labelCount = newValue if _labelCount > 25 { _labelCount = 25 } if _labelCount < 2 { _labelCount = 2 } forceLabelsEnabled = false } }

このようになっており、実質_labelCountの値を返しています。
この値は書いてある通り、最小値2、最大値25を保持するようですね。

それらを元に、元のx軸の最小値と最大値からlabelCountで割っていった値が来るみたいですね。

投稿2017/06/21 01:00

編集2017/06/21 01:06
tantakan

総合スコア34

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

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

ks-cap

2017/06/22 08:12

回答ありがとうございます。 事細かく教えてくださりありがとうございます。 "myChartView.xAxis.labelCount = Int(...)" を利用することで理想に近いX軸ラベルにすることが出来ました。
guest

0

** stringForValue()**にブレークポイントを設定して、バックトレースを確認して下さい。
止まった後で、コンソール(Debug Area)でbtと打ち込むか、Debug navigatorでバックトレースを確認できます。

投稿2017/06/21 00:24

fuzzball

総合スコア16731

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

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

ks-cap

2017/07/19 10:14

回答ありがとうございます。 btと打ち込むことで確認できるとは知りませんでした。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問