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

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

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

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

Swift

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

AppleWatch

AppleWatchは、iPhoneと連動して動作する時計型のデバイスです。時間の確認だけでなく、通話や受信メールの確認などを行うことができます。

Q&A

1回答

4245閲覧

apple watchで取得した値をローカルに保存したい

退会済みユーザー

退会済みユーザー

総合スコア0

Xcode

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

Swift

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

AppleWatch

AppleWatchは、iPhoneと連動して動作する時計型のデバイスです。時間の確認だけでなく、通話や受信メールの確認などを行うことができます。

0グッド

0クリップ

投稿2018/10/22 06:12

Apple watchを使って心拍数を測定し, 測定した値をテキストファイルに書き込むアプリを作成しています。
測定はできており,ラベルやログに出力はできる状態にあるのですが,テキストファイルに書き出すことができません。
色々と参考にして「書き込みに成功」という文字はでるのですが, どこを探してもファイルを見つけることができません。
直接デスクトップなどに保存したいのですが…可能でしょうか。

swiftのバージョン:4.0
watchOSのバージョン:4.0

InterfaceController.swift

1import WatchKit 2import Foundation 3import HealthKit 4import WatchConnectivity 5 6 7class InterfaceController: WKInterfaceController { 8 9 @IBOutlet var label: WKInterfaceLabel! 10 @IBOutlet var messageLabel: WKInterfaceLabel! 11 @IBOutlet var button: WKInterfaceButton! 12 @IBOutlet var secondbutton: WKInterfaceButton! 13 14 // HealthKitで扱うデータを管理するクラス(データの読み書きにはユーザの許可が必要) 15 let healthStore = HKHealthStore() 16 // 取得したいデータの識別子、今回は心拍数 17 let heartRateType = HKQuantityType.quantityType(forIdentifier: HKQuantityTypeIdentifier.heartRate)! 18 // 取得したデータの単位、今回はBPM 19 let heartRateUnit = HKUnit(from: "count/min") 20 // HealthStoreへのクエリ 21 var heartRateQuery: HKQuery? 22 //iphoneと通信 23 var wcSession = WCSession.default 24 25 26 override func awake( withContext context: Any?) { 27 super.awake(withContext: context) 28 29 30 // check supported 31 if WCSession.isSupported() { 32 // get default session 33 wcSession = WCSession.default 34 35 // set delegate 36 wcSession.delegate = self as? WCSessionDelegate 37 38 // activate session 39 wcSession.activate() 40 41 } else { 42 print("Not support WCSession") 43 } 44 45 // iPhoneとAppleWatchの連携チェック 46 if WCSession.isSupported() { 47 wcSession.delegate = self as? WCSessionDelegate 48 wcSession.activate() 49 } 50 // Configure interface objects here. 51 } 52 53 override func willActivate() { 54 // This method is called when watch view controller is about to be visible to user 55 super.willActivate() 56 57 // HealthKitがデバイス上で利用できるか確認 58 guard HKHealthStore.isHealthDataAvailable() else { 59 self.label.setText("not available") 60 return 61 } 62 63 // アクセス許可をユーザに求める 64 let dataTypes = Set([self.heartRateType]) 65 self.healthStore.requestAuthorization(toShare: nil, read: dataTypes) { (success, error) -> Void in 66 guard success else { 67 self.label.setText("not allowed") 68 return 69 } 70 } 71 } 72 73 override func didDeactivate() { 74 // This method is called when watch view controller is no longer visible 75 super.didDeactivate() 76 } 77 78 @IBAction func buttonTapped() { 79 if self.heartRateQuery == nil { 80 // start 81 // クエリ生成 82 self.heartRateQuery = self.createStreamingQuery() 83 // クエリ実行 84 self.healthStore.execute(self.heartRateQuery!) 85 self.button.setTitle("Stop") 86 self.messageLabel.setText("Measuring...") 87 } 88 else { 89 // end 90 self.healthStore.stop(self.heartRateQuery!) 91 self.heartRateQuery = nil 92 self.button.setTitle("Start") 93 self.messageLabel.setText("") 94 } 95 } 96 97 // healthStoreへのクエリ生成 98 private func createStreamingQuery() -> HKQuery { 99 let predicate = HKQuery.predicateForSamples(withStart: NSDate() as Date, end: nil, options: []) 100 101 // HKAnchoredObjectQueryだと他のアプリケーションによる更新を検知 102 let query = HKAnchoredObjectQuery(type: heartRateType, predicate: predicate, anchor: nil, limit: Int(HKObjectQueryNoLimit)) { (query, samples, deletedObjects, anchor, error) -> Void in 103 self.addSamples(samples: samples) 104 } 105 query.updateHandler = { (query, samples, deletedObjects, anchor, error) -> Void in 106 self.addSamples(samples: samples) 107 } 108 109 return query 110 } 111 112 // 取得したデータを表示,保存 113 114 private func addSamples(samples: [HKSample]?){ 115 guard let samples = samples as? [HKQuantitySample] else { 116 return 117 } 118 guard let quantity = samples.last?.quantity else { 119 return 120 } 121 122 let hartrate = (quantity.doubleValue(for: heartRateUnit)) 123 label.setText("(hartrate)") 124 print(hartrate) 125 126 let file_name = "test_HR.txt" 127 let text = "(hartrate)" 128 129 130 let path = NSHomeDirectory() + "/Documents/(file_name)" 131 132 print("(path)") 133 134 do{ 135 try text.write(toFile: path, atomically: true, encoding: String.Encoding.utf8) 136 print("書き込み成功") 137 138 }catch{ 139 print("失敗") 140 //print(message) 141 } 142 } 143 144} 145 146

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

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

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

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

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

CHERRY

2018/10/22 07:04

デスクトップって 何のデスクトップですか?
退会済みユーザー

退会済みユーザー

2018/10/22 07:07

デスクトップは, 動作しているPCのデスクトップです。よろしくお願いします。
guest

回答1

0

コードをみる限り、ファイルに保存はできていますね。

どこを探してもファイルを見つけることができません。

「書き込み成功」 とのことですので、ご自分で保存した場所にありますよ。

直接デスクトップなどに保存したいのですが…可能でしょうか。

iOS や watchOS にはデスクトップという概念はないので不可能です。

投稿2019/03/24 10:51

errolizer

総合スコア443

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

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

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

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

ただいまの回答率
85.34%

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

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

質問する

関連した質問