เป้าหมายคือเป้าหมายใน Google Fit แอป ที่ผู้ใช้กำหนดได้เอง ซึ่งช่วยกระตุ้นให้ผู้ใช้มีความเคลื่อนไหวอยู่เสมอ วัน จากภายในโปรไฟล์ ผู้ใช้สามารถปรับจำนวนขั้นตอน คะแนนคาร์ดิโอที่ต้องการตั้งเป้าหมาย ในแต่ละวัน แพลตฟอร์ม Fit จะบันทึกเป้าหมายและติดตามการเคลื่อนไหวในแต่ละวัน กับกิจกรรมเหล่านี้
สร้างประสบการณ์ของผู้ใช้ที่ดียิ่งขึ้นด้วยเป้าหมาย
แอปของคุณอ่านเป้าหมายของผู้ใช้เพื่อติดตามเป้าหมายส่วนตัวได้ ช่วงเวลานี้
ช่วยสร้างประสบการณ์
ที่น่าดึงดูดมากขึ้นได้ ในการเริ่มต้น ให้ใช้
GoalsClient
อ่านเป้าหมายจำนวนก้าวและคะแนนคาร์ดิโอของผู้ใช้ จากนั้นใช้
HistoryClient
เพื่อตรวจสอบว่าพวกเขาเข้าใกล้เป้าหมายเหล่านั้นมากน้อยแค่ไหน
ใช้ข้อมูลนี้เพื่อช่วยให้ผู้ใช้สลับระหว่าง Google Fit กับแอปของคุณ ได้อย่างราบรื่น และได้รับข้อมูลที่สอดคล้องกันเกี่ยวกับความคืบหน้าจากทั้ง 2 แอป ไปให้ถึงเป้าหมาย การออกกำลังกาย
กระตุ้นให้ผู้ใช้บรรลุเป้าหมายประจำวันโดยการให้ข้อมูลอัปเดตและข้อมูลเชิงลึก ที่เกี่ยวข้องกับความคืบหน้า
อ่านเป้าหมาย
ตัวอย่างต่อไปนี้จะแสดงวิธีสร้างลูกค้าฟิตเนสใหม่และรับ
เป้าหมายคะแนนคาร์ดิโอของผู้ใช้ หรือ null
หากผู้ใช้ไม่ได้ตั้งเป้าหมายไว้
Kotlin
private val fitnessOptions: FitnessOptions by lazy { FitnessOptions.builder() .addDataType(DataType.TYPE_HEART_POINTS, FitnessOptions.ACCESS_READ) .build() } private val goalsReadRequest: GoalsReadRequest by lazy { GoalsReadRequest.Builder() .addDataType(DataType.TYPE_HEART_POINTS) .build() } private fun getGoogleAccount(): GoogleSignInAccount = GoogleSignIn.getAccountForExtension(requireContext(), fitnessOptions) private fun readGoals() { Fitness.getGoalsClient(requireContext(), getGoogleAccount()) .readCurrentGoals(goalsReadRequest) .addOnSuccessListener { goals -> // There should be at most one heart points goal currently. goals.firstOrNull()?.apply { // What is the value of the goal val goalValue = metricObjective.value Log.i(TAG, "Goal value: $goalValue") // How is the goal measured? Log.i(TAG, "Objective: $objective") // How often does the goal repeat? Log.i(TAG, "Recurrence: $recurrenceDetails") } } } private val Goal.objective: String get() = when (objectiveType) { OBJECTIVE_TYPE_DURATION -> "Duration (s): ${durationObjective.getDuration(TimeUnit.SECONDS)}" OBJECTIVE_TYPE_FREQUENCY -> "Frequency : ${frequencyObjective.frequency}" OBJECTIVE_TYPE_METRIC -> "Metric : ${metricObjective.dataTypeName} - ${metricObjective.value}" else -> "Unknown objective" } private val Goal.recurrenceDetails: String get() = recurrence?.let { val period = when (it.unit) { Recurrence.UNIT_DAY -> "days" Recurrence.UNIT_WEEK -> "weeks" Recurrence.UNIT_MONTH -> "months" else -> "Unknown" } "Every ${recurrence!!.count} $period" } ?: "Does not repeat"
Java
private final FitnessOptions fitnessOptions = FitnessOptions.builder() .addDataType(DataType.TYPE_HEART_POINTS, FitnessOptions.ACCESS_READ) .build(); private final GoalsReadRequest goalsReadRequest = new GoalsReadRequest.Builder() .addDataType(DataType.TYPE_HEART_POINTS) .build(); private GoogleSignInAccount getGoogleAccount() { GoogleSignIn.getAccountForExtension(getApplicationContext(), fitnessOptions); } private void readGoals() { Fitness.getGoalsClient(getApplicationContext(), getGoogleAccount()) .readCurrentGoals(goalsReadRequest) .addOnSuccessListener(goals -> { // There should be at most one heart points goal currently. Optional<Goal> optionalGoal = goals.stream().findFirst(); if (optionalGoal.isPresent()) { // What is the value of the goal double goalValue = optionalGoal.get().getMetricObjective().getValue(); Log.i(TAG, "Goal value: $goalValue"); // How is the goal measured? Log.i(TAG, "Objective: ${getObjective(optionalGoal.get())}"); // How often does the goal repeat? Log.i(TAG, "Recurrence: ${getRecurrenceDetails(optionalGoal.get())}"); } }); } private String getObjective(Goal goal) { switch (goal.getObjectiveType()) { case OBJECTIVE_TYPE_DURATION: return "Duration (s): ${goal.getDurationObjective().getDuration(TimeUnit.SECONDS)}"; case OBJECTIVE_TYPE_FREQUENCY: return "Frequency : ${goal.getFrequencyObjective().getFrequency()}"; case OBJECTIVE_TYPE_METRIC: return "Metric : ${goal.getMetricObjective().getDataTypeName()} - ${goal.getMetricObjective().getValue()}"; default: return "Unknown objective"; } } private String getRecurrenceDetails(Goal goal) { Goal.Recurrence recurrence = goal.getRecurrence(); if (recurrence == null) { return "Does not repeat"; } StringBuilder recurrenceMessage = new StringBuilder("Every ${recurrence.getCount()}"); switch (recurrence.getUnit()) { case UNIT_DAY: recurrenceMessage.append("days"); break; case UNIT_WEEK: recurrenceMessage.append("weeks"); break; case UNIT_MONTH: recurrenceMessage.append("months"); break; default: recurrenceMessage.delete(0, recurrenceMessage.length()); recurrenceMessage.append("Unknown"); break; } return recurrenceMessage.toString(); }
ตรวจสอบความคืบหน้า
หลังจากมีเป้าหมายคะแนนคาร์ดิโอของผู้ใช้แล้ว คุณสามารถใช้
HistoryClient
เพื่อดูความคืบหน้า ดังต่อไปนี้
เช่น แสดงวิธีตรวจสอบจำนวนคะแนนคาร์ดิโอของผู้ใช้
Kotlin
val current = Calendar.getInstance() val request = DataReadRequest.Builder() .read(DataType.TYPE_HEART_POINTS) .setTimeRange( goal.getStartTime(current, TimeUnit.NANOSECONDS), goal.getEndTime(current, TimeUnit.NANOSECONDS), TimeUnit.NANOSECONDS ) .build() Fitness.getHistoryClient(requireContext(), getGoogleAccount()) .readData(request) .addOnSuccessListener { response -> val heartPointsSet = response.dataSets.first() val totalHeartPoints = heartPointsSet.dataPoints.sumBy { it.getValue(Field.FIELD_INTENSITY).asFloat().toInt() } Log.i(TAG, "Total heart points: $totalHeartPoints") }
Java
Calendar current = Calendar.getInstance(); DataReadRequest request = new DataReadRequest.Builder() .read(DataType.TYPE_HEART_POINTS) .setTimeRange( goal.getStartTime(current, TimeUnit.NANOSECONDS), goal.getEndTime(current, TimeUnit.NANOSECONDS), TimeUnit.NANOSECONDS ) .build(); Fitness.getHistoryClient(getApplicationContext(), getGoogleAccount()) .readData(request) .addOnSuccessListener(response -> { Optional<DataSet> heartPointsSet = response.getDataSets().stream().findFirst(); if (heartPointsSet.isPresent()) { int totalHeartPoints = 0; for (DataPoint dp : heartPointsSet.get().getDataPoints()) { totalHeartPoints += (int) dp.getValue(Field.FIELD_INTENSITY).asFloat(); } Log.i(TAG, "Total heart points: $totalHeartPoints"); } });
คำนวณความคืบหน้าเป็นเปอร์เซ็นต์
หากคุณหารยอดรวมจากตัวอย่างการตรวจสอบความคืบหน้า ตามเป้าหมายในตัวอย่าง อ่านเป้าหมาย คุณจะสามารถคำนวณ ความคืบหน้าสู่เป้าหมายเป็นเปอร์เซ็นต์
Kotlin
private fun calculateProgressPercentage(goal: Goal, response: DataReadResponse): Double { val goalValue = goal.metricObjective.value val currentTotal = response.dataSets.first().dataPoints.sumBy { it.getValue(Field.FIELD_INTENSITY).asFloat().toInt() } return (currentTotal.div(goalValue)).times(100.0) }
Java
private double calculateProgressPercentage(Goal goal, DataReadResponse response) { double goalValue = goal.getMetricObjective().getValue(); Optional<DataSet> firstDataSet = response.getDataSets().stream().findFirst(); if (!(firstDataSet.isPresent())) { return NaN; } double currentTotal = 0; for (DataPoint dp : firstDataSet.get().getDataPoints()) { currentTotal += (int)dp.getValue(Field.FIELD_INTENSITY).asFloat(); } return (currentTotal / goalValue) * 100.0; }