คุณสามารถเพิ่มข้อมูลการดื่มน้ำลงใน Google Fit ได้โดยสร้างแหล่งข้อมูลและใช้ประเภทข้อมูล com.google.hydration
จุดข้อมูลแต่ละจุดแสดงปริมาณน้ำดื่ม (เป็นลิตร) ที่ผู้ใช้ดื่มในเครื่องดื่ม 1 แก้ว ใช้แบบลอยเพื่อ
ระบุระดับเสียง
หมายเหตุ: การประทับเวลาจะระบุเวลาที่ดื่มเครื่องดื่ม เนื่องจาก com.google.hydration
เป็นประเภทข้อมูลแบบทันที เวลาเริ่มต้นและเวลาสิ้นสุดจึงควรเหมือนกัน
การสร้างแหล่งข้อมูล
Android
ใช้ DataSource.Builder
เพื่อสร้างแหล่งข้อมูลใหม่ เช่น hydrationSource
val hydrationSource = DataSource.Builder()
.setDataType(DataType.TYPE_HYDRATION)
.setStreamName("hydrationSource")
// ...
.build()
REST
เรียกใช้ REST API เพื่อสร้างแหล่งข้อมูลใหม่ เช่น HydrationSource
เมธอด HTTP
POST
URL คำขอ
https://www.googleapis.com/fitness/v1/users/me/dataSources
เนื้อความของคำขอ
{
"dataStreamName": "HydrationSource",
"type": "raw",
"application": {
"detailsUrl": "http://example.com",
"name": "My Example App",
"version": "1"
},
"dataType": {
"name": "com.google.hydration",
"field": [
{
"name": "volume",
"format": "floatPoint",
"optional": false
}
]
}
}
การตอบกลับ
หากสร้างแหล่งข้อมูลสำเร็จ การตอบกลับจะเป็นสถานะ 200 OK
โค้ด เนื้อหาการตอบกลับประกอบด้วยการนําเสนอ JSON ของแหล่งข้อมูล รวมถึงพร็อพเพอร์ตี้ datasource.dataStreamId
ที่คุณใช้เป็นรหัสแหล่งข้อมูลสําหรับคําขอต่อๆ ไปได้
คำสั่ง CURL
$ curl --header "Authorization: Bearer ya29.yourtokenvalue" --request POST \
--header "Content-Type: application/json;encoding=utf-8" --data @hydration-ds.json \
https://www.googleapis.com/fitness/v1/users/me/dataSources
การเพิ่มข้อมูลการดื่มน้ำ
Android
ตัวอย่างนี้แสดงวิธีสร้างจุดข้อมูลใหม่และเพิ่มข้อมูลการดื่มน้ำ 0.3 ลิตรโดยใช้แหล่งข้อมูล
val hydration = DataPoint.builder(hydrationSource)
.setTimestamp(timestamp, TimeUnit.MILLISECONDS)
.setField(FIELD_VOLUME, 0.3f)
.build()
REST
ตัวอย่างนี้แสดงวิธีเพิ่มข้อมูลปริมาณน้ำที่ดื่มโดยใช้ข้อมูลของคุณ แหล่งที่มา
เมธอด HTTP
PATCH
URL คำขอ
https://www.googleapis.com/fitness/v1/users/me/dataSources/raw:com.google.hydration:407408718192:HydrationSource/datasets/1275753581000000000-1275753581000000000
เนื้อความของคำขอ
{
"minStartTimeNs": 1275753581000000000,
"maxEndTimeNs": 1275753581000000000,
"dataSourceId": "raw:com.google.hydration:407408718192:HydrationSource",
"point": [
{
"startTimeNanos": 1275753581000000000,
"endTimeNanos": 1275753581000000000,
"dataTypeName": "com.google.hydration",
"value": [
{
"fpVal": 0.3
}
]
}
]
}
การตอบกลับ
หากสร้างจุดข้อมูลสำเร็จ คุณจะได้รับ HTTP ของ 200 OK
รหัสสถานะการตอบสนอง เนื้อหาการตอบกลับมีการแสดงไฟล์ JSON ของ
ชุดข้อมูล
คำสั่ง CURL
$ curl --header "Authorization: Bearer ya29.yourtokenvalue" --request PATCH \
--header "Content-Type: application/json;encoding=utf-8" --data @hydration-data.json \
https://www.googleapis.com/fitness/v1/users/me/dataSources/raw:com.google.hydration:407408718192:HydrationSource/datasets/1275753581000000000-1275753581000000000