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

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

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

受付中

折れ線グラフのスクロールとズーム

rikaham0321
tkg

総合スコア2

1回答

0評価

0クリップ

155閲覧

投稿2022/06/16 19:15

下記のコードについて質問です。
現在、体重を入力して保存すると折れ線グラフが描かれるコードを書いています。
数回の入力ならいいのですが、多数回入力するとグラフの数字や〇が多くなり大変見づらくなってしまいます。
なので、①一定の間隔を開けて横スクロールにする
または、②ズームした状態でアプリを閉じて再度開いてもそこから始まる
この①か②を実現したいと思っています。
理想はどちらも可能にすることですが、私の知識や発想力では出来ませんでした。
アイデアや知識などお貸しいただければと思います。
よろしくお願いします。

swift

import SwiftUI import Charts struct WeightPage2: View{ @State var weight = "" @State var weightarray:[String] var body: some View{ TextField("今日の体重",text:$weight).textFieldStyle(RoundedBorderTextFieldStyle()).frame(width:120).overlay(RoundedRectangle(cornerRadius:1).stroke(Color.black, lineWidth:1)) Button(action:{weightarray.append(weight);UserDefaults.standard.set(weightarray, forKey: "weightkey")}){ Text("保存する") } LineChart(weightarray:$weightarray).frame(width:360 ,height: 400) } init() { let w = UserDefaults.standard.array(forKey: "weightkey") as? [String] ?? [] _weightarray = State(initialValue: w) } } struct LineChart : UIViewRepresentable { typealias UIViewType = LineChartView @Binding var weightarray:[String] func makeUIView(context: Context) -> LineChartView { let lineChartView = LineChartView() lineChartView.data = setData() return lineChartView } func updateUIView(_ uiView: LineChartView, context: Context) { uiView.data = setData() } func setData() -> LineChartData{ let dataPoint = getDataPoints() let set = LineChartDataSet(entries: dataPoint, label: "My data") let data = LineChartData(dataSet: set) return data } func getDataPoints() -> [ChartDataEntry] { var dataPoints: [ChartDataEntry] = [] for count in 0..<weightarray.count{ dataPoints.append(ChartDataEntry(x:Double(count),y: Double(weightarray[count]) ?? 0)) } return dataPoints } } struct WeightPage2_Previews: PreviewProvider { static var previews: some View { WeightPage2() } }

良い質問の評価を上げる

以下のような質問は評価を上げましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

  • プログラミングに関係のない質問
  • やってほしいことだけを記載した丸投げの質問
  • 問題・課題が含まれていない質問
  • 意図的に内容が抹消された質問
  • 過去に投稿した質問と同じ内容の質問
  • 広告と受け取られるような投稿

評価を下げると、トップページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

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

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

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

同じタグがついた質問を見る