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

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

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

Objective-Cはオブジェクト指向型のプログラミング言語のひとつです。C言語をベースにSmalltalkが取り入れられています。

iOS 9

iOS 9は、アップル社のモバイルOSであるiOSシリーズのバージョン。特徴として検索機能の強化、Siriの機能改良、iPad向けマルチタスクなどがあります。マルチウィンドウ機能をサポートし、iPad向けマルチタスクもサポートされています。

Swift

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

iOS 8

iOS 8(アイ・オーエス8)は、アップル社が2014年9月に発表したオペレーティングシステムです。iPhone 4sより対応しています。デザイン性の変更はなく、アプリや各種機能が強化されています。また、サードパーティ開発者のために、多くのAPIが開放されています。

Swift 2

Swift 2は、Apple社が独自に開発を行っている言語「Swift」のアップグレード版です。iOSやOS X、さらにLinuxにも対応可能です。また、throws-catchベースのエラーハンドリングが追加されています。

Q&A

解決済

2回答

2363閲覧

最新の値をグラフに追加していく方法

PYPP

総合スコア51

Objective-C

Objective-Cはオブジェクト指向型のプログラミング言語のひとつです。C言語をベースにSmalltalkが取り入れられています。

iOS 9

iOS 9は、アップル社のモバイルOSであるiOSシリーズのバージョン。特徴として検索機能の強化、Siriの機能改良、iPad向けマルチタスクなどがあります。マルチウィンドウ機能をサポートし、iPad向けマルチタスクもサポートされています。

Swift

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

iOS 8

iOS 8(アイ・オーエス8)は、アップル社が2014年9月に発表したオペレーティングシステムです。iPhone 4sより対応しています。デザイン性の変更はなく、アプリや各種機能が強化されています。また、サードパーティ開発者のために、多くのAPIが開放されています。

Swift 2

Swift 2は、Apple社が独自に開発を行っている言語「Swift」のアップグレード版です。iOSやOS X、さらにLinuxにも対応可能です。また、throws-catchベースのエラーハンドリングが追加されています。

0グッド

0クリップ

投稿2016/11/03 01:40

編集2016/11/03 16:31

###前提・実現したいこと
X-codeにてswiftを用いて、心電図の状態をリアルタイムで表示するものを作成したく思っております。

###発生している問題・エラーメッセージ
現状下記のようなグラフを表示させるとこまで辿り着くことができました(参照ライブラリ)。ただ、リアルタイムで最新の値をグラフに追加していくグラフをどのように実装すべきかがわかりません。
イメージ説明

###該当のソースコード

swift

1import UIKit 2import ScrollableGraphView 3 4class EcgDailyViewController: UIViewController { 5 6 @IBOutlet weak var ecgGraph: UIView! 7 8 var graphView = ScrollableGraphView() 9 var label = UILabel() 10 let numberOfDataItems = 29 11 lazy var data: [Double] = self.generateRandomData(self.numberOfDataItems, max: 50) 12 lazy var labels: [String] = self.generateSequentialLabels(self.numberOfDataItems, text: "Time") 13 14 15 override func viewDidLoad() { 16 super.viewDidLoad() 17 18 createDarkGraph() 19 graphView.set(data: data, withLabels: labels) 20 self.ecgGraph.clipsToBounds = true 21 self.ecgGraph.addSubview(graphView) 22 23 } 24 25 override func viewDidLayoutSubviews() { 26 super.viewDidLayoutSubviews() 27 28 let rect = CGRect(x:0, y:0, width:ecgGraph.frame.width, height:ecgGraph.frame.height) //Swift3.0 29 graphView.frame = rect 30 } 31 32 fileprivate func createDarkGraph() { 33 34 graphView.backgroundFillColor = UIColor.colorFromHex(hexString: "#333333") 35 36 graphView.lineWidth = 1 37 graphView.lineColor = UIColor.colorFromHex(hexString: "#777777") 38 graphView.lineStyle = ScrollableGraphViewLineStyle.smooth 39 40 graphView.shouldFill = true 41 graphView.fillType = ScrollableGraphViewFillType.gradient 42 graphView.fillColor = UIColor.colorFromHex(hexString: "#555555") 43 graphView.fillGradientType = ScrollableGraphViewGradientType.linear 44 graphView.fillGradientStartColor = UIColor.colorFromHex(hexString: "#555555") 45 graphView.fillGradientEndColor = UIColor.colorFromHex(hexString: "#444444") 46 47 graphView.dataPointSpacing = 80 48 graphView.dataPointSize = 2 49 graphView.dataPointFillColor = UIColor.white 50 51 graphView.referenceLineLabelFont = UIFont.boldSystemFont(ofSize: 8) 52 graphView.referenceLineColor = UIColor.white.withAlphaComponent(0.2) 53 graphView.referenceLineLabelColor = UIColor.white 54 graphView.numberOfIntermediateReferenceLines = 5 55 graphView.dataPointLabelColor = UIColor.white.withAlphaComponent(0.5) 56 57 graphView.shouldAnimateOnStartup = true 58 graphView.shouldAdaptRange = true 59 graphView.adaptAnimationType = ScrollableGraphViewAnimationType.elastic 60 graphView.animationDuration = 1.5 61 graphView.rangeMax = 50 62 graphView.shouldRangeAlwaysStartAtZero = true 63 64 return 65 } 66 67 private func generateRandomData(_ numberOfItems: Int, max: Double) -> [Double] { 68 var data = [Double]() 69 for _ in 0 ..< numberOfItems { 70 var randomNumber = Double(arc4random()).truncatingRemainder(dividingBy: max) 71 72 if(arc4random() % 100 < 10) { 73 randomNumber *= 3 74 } 75 76 data.append(randomNumber) 77 } 78 return data 79 } 80 81 private func generateSequentialLabels(_ numberOfItems: Int, text: String) -> [String] { 82 var labels = [String]() 83 for i in 0 ..< numberOfItems { 84 labels.append("\(text) \(i+1)") 85 } 86 return labels 87 } 88 89 override func didReceiveMemoryWarning() { 90 super.didReceiveMemoryWarning() 91 } 92 93 94}

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

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

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

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

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

guest

回答2

0

ベストアンサー

データを追加してセットし直してやればグラフにも追加できますが、スクロール位置が先頭に戻ったり、アニメーションしたりします。

swift

1//データ追加 2data.append(Double(arc4random_uniform(50))) 3labels.append("Time \(labels.count+1)") 4 5//アニメーションを一旦off 6graphView.shouldAnimateOnStartup = false //※追記 7 8//こうしておくとグラフ描画時に右端が表示される 9graphView.direction = .RightToLeft //※追記 10 11//データ再セット 12graphView.setData(data, withLabels: labels) 13 14//アニメーションをonに戻す 15graphView.shouldAnimateOnStartup = true //※追記

余計なことをせずにグラフをリフレッシュするような関数があるのではないかと思うので探してみて下さい。

【追記】
ということで、少し探してみたのですが見つからなかったので、それっぽくなるように追記しておきました。

投稿2016/11/03 23:56

編集2016/11/04 00:47
fuzzball

総合スコア16731

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

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

PYPP

2016/11/04 12:32

ご返信いただき誠にありがとうございます。他のコードをどこに記載すべきかはわかったと思うのですが、下記の2行は新しくメソッドを作成しそこで動作させる形でしょうか? ------------------------------------------------------------------------------ graphView.setData(data, withLabels: labels) graphView.shouldAnimateOnStartup = true ------------------------------------------------------------------------------ 他のコード文は下記の認識です。 ------------------------------------------------------------------------------ data.append(Double(arc4random_uniform(50))) //generateRandomDataメソッドを修正 labels.append("Time \(labels.count+1)") //generateSequentialLabelsメソッドを修正 graphView.shouldAnimateOnStartup = false //createDarkGraph()メソッドを修正 graphView.direction = .RightToLeft //createDarkGraph()メソッドに追記 ------------------------------------------------------------------------------
fuzzball

2016/11/04 14:05

回答に書いたコードは一連の動作です。「データ追加」から「アニメーションをonに戻す」まで、一気に実行して下さい。(既存のコードに対する修正ではありません)
PYPP

2016/11/04 16:37

ご返信いただきありがとうございます。新しいメソッドrecreateDarkGraph()を作成し、viewDidLoad() メソッドにrecreateDarkGraph()を記載するイメージでしょうか?
fuzzball

2016/11/05 07:10

後からデータを追加したいのではないのでしょうか?viewDidLoad()だと、起動時に追加することになりますが。データを追加したいタイミングでrecreateDarkGraph()を呼び出して下さい。
PYPP

2016/11/05 08:52

その通りです。それにて実行してみます。
guest

0

動的の意味が分からないので、推測で書きますが、何らかの方法で心電図の最新の値をグラフに追加していきたいということであれば、CoreGraphicsを使って2つの点(x0,x0),(x1,y1)の間を直線で描画するのを繰り返すのが一番簡単だと思います。
一定間隔で、新たなデータセットで毎回再描画すればよいです。

投稿2016/11/03 03:23

pebble8888

総合スコア390

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

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

PYPP

2016/11/03 13:01

ご回答いただきありがとうございます。推測された通り、最新の値をグラフに追加していきたいと考えています。現在使っているライブラリを用いずにCoreGraphicsでということでしょうか?
pebble8888

2016/11/04 01:37

そうですね。 まずはfuzzballさんの回答の方を試すのがよいと思います。 参照ライブラリは内部的にCoreGraphicsを使っているようですので、 更新頻度とデータ量が多くて、要求に合わなければ、そのライブラリを修正していくのがよいかもです。
PYPP

2016/11/04 12:33

ありがとうございます。承知しました。現在使用しているライブラリを修正しつつ、難しそうであれば他の方法を取る形にしてみようかと思います。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問