แอปสามารถบันทึกข้อมูลน้ำตาลกลูโคสในเลือดได้โดยเขียนลงในประเภทข้อมูล com.google.blood_glucose
ในประเภทข้อมูลนี้ จุดข้อมูลแต่ละจุดจะแทนค่าน้ำตาลกลูโคสในเลือดเพียงครั้งเดียว จุดข้อมูลมีช่องสำหรับความเข้มข้นของน้ำตาลกลูโคสในเลือด ความสัมพันธ์ชั่วคราวกับมื้ออาหารและการนอนหลับ ตลอดจนแหล่งที่มาของตัวอย่างที่มีการวัด คุณไม่จำเป็นต้องระบุข้อมูลในช่องทั้งหมด ยกเว้นความเข้มข้นของน้ำตาลกลูโคสในเลือด
- ความเข้มข้นของน้ำตาลกลูโคสในเลือดจะวัดเป็น มิลลิโมล/ลิตร (1 มิลลิโมล/ลิตร เท่ากับ 18 มก./เดซิลิตร)
- หากระบุ ความสัมพันธ์ชั่วคราวกับอาหารต้องมีค่าใดค่าหนึ่งที่ระบุไว้ใน
FIELD_TEMPORAL_RELATION_TO_MEAL
- ประเภทอาหารต้องมีค่าใดค่าหนึ่งที่ระบุไว้ใน
FIELD_MEAL_TYPE
หากไม่ทราบประเภทอาหาร ให้ใช้MEAL_TYPE_UNKNOWN
- หากระบุไว้ ความสัมพันธ์ชั่วคราวของการนอนหลับต้องมีค่าใดค่าหนึ่งที่ระบุไว้ใน
FIELD_TEMPORAL_RELATION_TO_SLEEP
- หากระบุไว้ แหล่งที่มาของตัวอย่างน้ำตาลในเลือดต้องมีค่าใดค่าหนึ่งที่ระบุไว้ใน
FIELD_BLOOD_GLUCOSE_SPECIMEN_SOURCE
สร้างแหล่งข้อมูล
Android
หากต้องการเขียนจุดข้อมูลกลูโคสในเลือด ให้สร้าง DataSource
ใหม่ของ TYPE_BLOOD_GLUCOSE
ดังที่แสดงในตัวอย่างต่อไปนี้
val bloodGlucoseSource = DataSource.Builder()
.setDataType(TYPE_BLOOD_GLUCOSE)
// ...
.build()
REST
หากต้องการเขียนจุดข้อมูลน้ำตาลในเลือด ให้สร้างแหล่งข้อมูลใหม่
เมธอด HTTP
POST
URL คำขอ
https://www.googleapis.com/fitness/v1/users/me/dataSources
เนื้อความของคำขอ
{
"dataStreamName": "BloodGlucose",
"type": "raw",
"application": {
"detailsUrl": "http://example.com",
"name": "My Example App",
"version": "1"
},
"dataType": {
"name": "com.google.blood_glucose"
}
}
คำตอบ
หากสร้างแหล่งข้อมูลสำเร็จ การตอบกลับจะเป็นรหัสสถานะ 200 OK
เนื้อหาการตอบกลับจะแสดงรูปแบบ JSON ของแหล่งข้อมูล รวมถึงพร็อพเพอร์ตี้ datasource.dataStreamId
ที่คุณใช้เป็นรหัสแหล่งข้อมูลสำหรับคำขอในครั้งต่อๆ ไปได้
คำสั่ง CURL
$ curl --header "Authorization: Bearer ya29.yourtokenvalue --request POST \ --header "Content-Type: application/json;encoding=utf-8" --data @blood-glucose-ds.json \ https://www.googleapis.com/fitness/v1/users/me/dataSources
การเพิ่มข้อมูล
Android
หากต้องการเพิ่มข้อมูลไปยังแหล่งที่มาที่สร้างขึ้นด้านบน ให้สร้างจุดข้อมูลสำหรับแหล่งข้อมูลนี้ ซึ่งแทรกได้โดยใช้ History API
val bloodGlucose = DataPoint.builder(bloodGlucoseSource)
.setTimestamp(timestamp, TimeUnit.MILLISECONDS)
.setField(FIELD_BLOOD_GLUCOSE_LEVEL, 5.0f) // 90 mg/dL
.setField(FIELD_TEMPORAL_RELATION_TO_MEAL, FIELD_TEMPORAL_RELATION_TO_MEAL_BEFORE_MEAL)
.setField(FIELD_MEAL_TYPE, MEAL_TYPE_BREAKFAST)
.setField(FIELD_TEMPORAL_RELATION_TO_SLEEP, TEMPORAL_RELATION_TO_SLEEP_ON_WAKING)
.setField(FIELD_BLOOD_GLUCOSE_SPECIMEN_SOURCE, BLOOD_GLUCOSE_SPECIMEN_SOURCE_CAPILLARY_BLOOD)
.build()
REST
ตัวอย่างนี้แสดงการเพิ่มข้อมูลน้ำตาลกลูโคสในเลือดโดยใช้แหล่งข้อมูลที่สร้างขึ้นด้านบน
เมธอด HTTP
PATCH
URL คำขอ
https://www.googleapis.com/fitness/v1/users/me/dataSources/datasource.dataStreamId/datasets/1574159699023000000-1574159699023000000
เนื้อความของคำขอ
เพื่อความชัดเจน เนื้อหา JSON ที่แสดงด้านล่างจะมีคำอธิบายประกอบพร้อมกับความคิดเห็นเพื่อแสดงการใช้ค่าคงที่ฟิลด์สุขภาพ แม้ว่า Fit API จะทิ้งความคิดเห็นไว้ แต่ขอแนะนำเป็นอย่างยิ่งให้คุณนำความคิดเห็นเหล่านี้ออกจากโค้ด เนื่องจาก JSON ไม่ได้รองรับความคิดเห็นอย่างเป็นทางการ
{ "minStartTimeNs": 1574159699023000000, "maxEndTimeNs": 1574159699023000000, "dataSourceId": "datasource.dataStreamId", "point": [ { "startTimeNanos": 1574159699023000000, "endTimeNanos": 1574159699023000000, "dataTypeName": "com.google.blood_glucose", "value": [ { // Blood glucose level, 90 mg/dL "fpVal": 5.0 }, { // FIELD_TEMPORAL_RELATION_TO_MEAL_BEFORE_MEAL "intVal": 3 }, { // MEAL_TYPE_BREAKFAST "intVal": 1 }, { // TEMPORAL_RELATION_TO_SLEEP_ON_WAKING "intVal": 3 }, { // BLOOD_GLUCOSE_SPECIMEN_SOURCE_CAPILLARY_BLOOD "intVal": 2 } ] } ] }
คำตอบ
หากเพิ่มข้อมูลน้ำตาลกลูโคสในเลือดเรียบร้อยแล้ว คำตอบจะเป็นรหัสสถานะ 200 OK
เนื้อหาการตอบสนองมีการแสดงข้อมูลน้ำตาลกลูโคสในเลือดในรูปแบบ JSON
คำสั่ง CURL
$ curl --header "Authorization: Bearer ya29.yourtokenvalue --request PATCH \ --header "Content-Type: application/json;encoding=utf-8" --data @blood-glucose-data.json \ https://www.googleapis.com/fitness/v1/users/me/dataSources/datasource.dataStreamId/datasets/1574159699023000000-1574159699023000000