با اهداف تناسب اندام کار کنید

اهداف اهدافی در برنامه Google Fit هستند که کاربران می توانند برای خود تعیین کنند. آنها به کاربران انگیزه می دهند تا هر روز فعال بمانند. از داخل نمایه خود، کاربران می توانند تعداد گام ها و نقاط قلبی را که می خواهند برای هر روز هدف بگیرند، تنظیم کنند. پلتفرم Fit اهداف آنها را ثبت می کند و فعالیت های روزانه آنها را در برابر آنها ردیابی می کند.

برنامه شما می تواند اهداف کاربر را بخواند تا اهداف شخصی آنها را پیگیری کند. این می تواند به ایجاد یک تجربه جذاب تر کمک کند. برای شروع، از مشتری GoalsClient برای خواندن مراحل و اهداف Heart Points کاربر استفاده کنید. سپس از سرویس گیرنده HistoryClient برای بررسی میزان نزدیک بودن آنها به این اهداف استفاده کنید.

از این داده‌ها برای کمک به کاربران برای جابه‌جایی یکپارچه بین Google Fit و برنامه‌تان استفاده کنید و اطلاعات ثابتی را از هر دو برنامه درباره پیشرفت آنها به سمت اهداف تناسب اندام خود دریافت کنید.

با به‌روزرسانی‌ها و بینش‌های مرتبط با پیشرفت‌شان، کاربران را برای رسیدن به اهداف روزانه‌شان ترغیب کنید.

یک هدف را بخوانید

مثال زیر نشان می دهد که چگونه یک مشتری تناسب اندام جدید ایجاد کنید و هدف امتیازات قلبی کاربر را دریافت کنید، یا اگر هدف تعیین شده ای نداشته باشد، آنها null .

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"
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 برای بررسی پیشرفت آنها استفاده کنید. مثال زیر نشان می دهد که چگونه می توان تعداد امتیازات قلب کاربر را بررسی کرد.

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")
   
}
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");
           
}
       
});

پیشرفت را به صورت درصد محاسبه کنید

اگر کل نمونه پیشرفت چک را بر هدف در مثال هدف خوانده شده تقسیم کنید، می توانید پیشرفت به سمت هدف را به صورت درصد محاسبه کنید.

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)
}
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;
}