Получить историю Google Fit так же, как это делает приложение Google Fit (автоматическая запись действий Google Fit)

Я стараюсь отображать ту же историю действий, что и приложение Google Fit. Я отлично справляюсь с сеансами, но я просто не могу правильно понять автоматически записанные действия. Как эти две верхние прогулки в примере.

введите здесь описание изображения

Я думаю, все зависит от того, как устроен DataReadRequest. Самое близкое, что я получил, это:

DataReadRequest.Builder()
                            .aggregate(DataType.TYPE_ACTIVITY_SEGMENT, DataType.AGGREGATE_ACTIVITY_SUMMARY)
                            .bucketByActivitySegment(5, TimeUnit.MINUTES)
                            .setTimeRange(dateFrom.millis, dateTo.millis, TimeUnit.MILLISECONDS)
                            .build()

Намеренно исключены прогулки короче 5. Результаты похожи, но результат немного отличается. Примерно на 20% меньше продолжительность и ккал. Иногда это действительно сходит с ума, разрезая деятельность на мелкие кусочки. У меня есть 2 прогулки в Google Fit и в итоге 4 прогулки в моем приложении, которые не складываются с 2 из Google Fit. Я попытался декомпилировать приложение Google Fit, чтобы настроить запрос на заимствование, но приложение хорошо запутано. :)

Кто-нибудь добился этого?


person Jacek Kwiecień    schedule 12.10.2020    source источник
comment
Боюсь, это просто не поддерживается в настоящее время. Однако, чтобы помочь нам понять: почему вы хотите воспроизвести представление журнала?   -  person Graeme Morgan    schedule 16.11.2020
comment
@GraemeMorgan Я разрабатываю приложение для отслеживания калорий, которое записывает потребление и расход калорий пользователями, чтобы помочь им похудеть. В основном речь идет о регистрации еды, но также и о деятельности. В дополнение к нашей ручной регистрации активности мы ввели автоматический вход в систему с помощью Google Fit и Apple Health. Наши пользователи в основном ходят пешком, и многие из них используют автоматическую запись Google Fit, поэтому мы не хотели терять этот день, просто используя Sessions API.   -  person Jacek Kwiecień    schedule 27.11.2020


Ответы (1)


У меня сейчас нет данных в сервисе Google Fit, чтобы получить то, что вам нужно.

Но я делаю это, чтобы получить удары в минуту для каждого упражнения.

 /**
 * Returns a List of exercise with time period and their heart rate via callback
 */
public void getHeartRatePerExercise(Date date , ExerciseHeartRateListener exerciseHeartRateListener) {

    Calendar calendar = Calendar.getInstance();

    calendar.setTime(date);
    calendar.set(Calendar.MILLISECOND, 1);
    calendar.set(Calendar.SECOND, 1);
    calendar.set(Calendar.MINUTE, 0);
    calendar.set(Calendar.HOUR_OF_DAY, 0);

    long startTime = calendar.getTimeInMillis();

    calendar.set(Calendar.MILLISECOND, 0);
    calendar.set(Calendar.SECOND, 59);
    calendar.set(Calendar.MINUTE, 59);
    calendar.set(Calendar.HOUR_OF_DAY, 23);

    long endTime =  calendar.getTimeInMillis();


    DataReadRequest readRequest =
            new DataReadRequest.Builder()
                    .aggregate(DataType.TYPE_HEART_RATE_BPM, DataType.AGGREGATE_HEART_RATE_SUMMARY)
                    .bucketByActivityType(1, TimeUnit.MINUTES)
                    .setTimeRange(startTime, endTime, TimeUnit.MILLISECONDS)
                    .build();


    Task<DataReadResponse> readResponse = getHistoryClient(activity, googleSignIn).readData(readRequest);

    readResponse.addOnSuccessListener(response -> {
        List<Bucket> buckets = response.getBuckets();
        List<Workout> workouts = new ArrayList<>();

        for (Bucket bucket : buckets) {

            String activityName = bucket.getActivity();
            Timestamp start = new Timestamp(bucket.getStartTime(TimeUnit.MILLISECONDS));
            Timestamp end = new Timestamp(bucket.getEndTime(TimeUnit.MILLISECONDS));

            if (!(activityName.equals("still") || activityName.equals("unknown"))) {
                List<DataSet> dataSets = bucket.getDataSets();

                for (DataSet dataSet : dataSets) {
                    for (DataPoint dataPoint : dataSet.getDataPoints()) {
                        float min = dataPoint.getValue(Field.FIELD_MIN).asFloat();
                        float max = dataPoint.getValue(Field.FIELD_MAX).asFloat();
                        float avg = dataPoint.getValue(Field.FIELD_AVERAGE).asFloat();
                        HeartRate hr = new HeartRate(min, max, avg);
                        Workout workout = new Workout(activityName, start, end, hr);

                        workouts.add(workout);

                    }
                }
            }
        }
        exerciseHeartRateListener.getHR(workouts);
    }).addOnFailureListener(response -> {
        exerciseHeartRateListener.getHR(new ArrayList<>());
    });

}

Частота сердцебиения

public class HeartRate {

    private float min;
    private float max;
    private float avg;

    public HeartRate(float min, float max, float avg) {
        this.min = min;
        this.max = max;
        this.avg = avg;
    }

    public float getMin() {
        return min;
    }


    public float getMax() {
        return max;
    }


    public float getAvg() {
        return avg;
    }

}

Тренировка

public class Workout {

    private String name;
    private Timestamp start;
    private Timestamp end;
    private HeartRate heartRate;

    public Workout(String name, Timestamp start, Timestamp end, HeartRate heartRate) {
        this.name = name;
        this.start = start;
        this.end = end;
        this.heartRate = heartRate;
    }

    public String getName() {
        return name;
    }

    public Timestamp getStart() {
        return start;
    }

    public Timestamp getEnd() {
        return end;
    }

    public HeartRate getHeartRate() {
        return heartRate;
    }

}

Интерфейс:

 public interface ExerciseHeartRateListener {
    void getHR(List<Workout> workouts);
}
person Alexios    schedule 23.10.2020