1
0
mirror of https://codeberg.org/Freeyourgadget/Gadgetbridge synced 2025-01-28 02:27:32 +01:00

HuaweiWorkoutGbParser: Use ActivitySummaryData

This commit is contained in:
José Rebelo 2024-08-30 23:19:49 +01:00 committed by José Rebelo
parent 02286d2c2c
commit 967ae31b7a

View File

@ -18,7 +18,6 @@ package nodomain.freeyourgadget.gadgetbridge.service.devices.huawei;
import android.widget.Toast; import android.widget.Toast;
import org.json.JSONObject;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
@ -43,6 +42,7 @@ import nodomain.freeyourgadget.gadgetbridge.entities.HuaweiWorkoutPaceSampleDao;
import nodomain.freeyourgadget.gadgetbridge.entities.HuaweiWorkoutSummarySample; import nodomain.freeyourgadget.gadgetbridge.entities.HuaweiWorkoutSummarySample;
import nodomain.freeyourgadget.gadgetbridge.entities.HuaweiWorkoutSummarySampleDao; import nodomain.freeyourgadget.gadgetbridge.entities.HuaweiWorkoutSummarySampleDao;
import nodomain.freeyourgadget.gadgetbridge.model.ActivityKind; import nodomain.freeyourgadget.gadgetbridge.model.ActivityKind;
import nodomain.freeyourgadget.gadgetbridge.model.ActivitySummaryData;
import nodomain.freeyourgadget.gadgetbridge.model.ActivitySummaryEntries; import nodomain.freeyourgadget.gadgetbridge.model.ActivitySummaryEntries;
import nodomain.freeyourgadget.gadgetbridge.util.GB; import nodomain.freeyourgadget.gadgetbridge.util.GB;
import nodomain.freeyourgadget.gadgetbridge.util.StringUtils; import nodomain.freeyourgadget.gadgetbridge.util.StringUtils;
@ -54,7 +54,7 @@ import nodomain.freeyourgadget.gadgetbridge.util.StringUtils;
*/ */
public class HuaweiWorkoutGbParser { public class HuaweiWorkoutGbParser {
private static final Logger LOG = LoggerFactory.getLogger(HuaweiWorkoutGbParser.class); private static final Logger LOG = LoggerFactory.getLogger(HuaweiWorkoutGbParser.class);
// TODO: Might be nicer to propagate the exceptions, so they can be handled upstream // TODO: Might be nicer to propagate the exceptions, so they can be handled upstream
public enum HuaweiActivityType { public enum HuaweiActivityType {
@ -302,71 +302,34 @@ public class HuaweiWorkoutGbParser {
ActivityKind type = huaweiTypeToGbType(summary.getType()); ActivityKind type = huaweiTypeToGbType(summary.getType());
JSONObject jsonObject = new JSONObject(); ActivitySummaryData summaryData = new ActivitySummaryData();
JSONObject calories = new JSONObject(); summaryData.add(ActivitySummaryEntries.CALORIES_BURNT, summary.getCalories(), ActivitySummaryEntries.UNIT_KCAL);
calories.put("value", summary.getCalories()); summaryData.add(ActivitySummaryEntries.DISTANCE_METERS, summary.getDistance(), ActivitySummaryEntries.UNIT_METERS);
calories.put("unit", ActivitySummaryEntries.UNIT_KCAL); summaryData.add(ActivitySummaryEntries.STEPS, summary.getStepCount(), ActivitySummaryEntries.UNIT_STEPS);
jsonObject.put(ActivitySummaryEntries.CALORIES_BURNT, calories); summaryData.add(ActivitySummaryEntries.ACTIVE_SECONDS, summary.getDuration(), ActivitySummaryEntries.UNIT_SECONDS);
summaryData.add(ActivitySummaryEntries.STATUS, summary.getStatus() & 0xFF, ActivitySummaryEntries.UNIT_NONE);
JSONObject distance = new JSONObject(); summaryData.add(ActivitySummaryEntries.TYPE, summary.getType() & 0xFF, ActivitySummaryEntries.UNIT_NONE);
distance.put("value", summary.getDistance());
distance.put("unit", ActivitySummaryEntries.UNIT_METERS);
jsonObject.put(ActivitySummaryEntries.DISTANCE_METERS, distance);
JSONObject steps = new JSONObject();
steps.put("value", summary.getStepCount());
steps.put("unit", ActivitySummaryEntries.UNIT_STEPS);
jsonObject.put(ActivitySummaryEntries.STEPS, steps);
JSONObject time = new JSONObject();
time.put("value", summary.getDuration());
time.put("unit", ActivitySummaryEntries.UNIT_SECONDS);
jsonObject.put(ActivitySummaryEntries.ACTIVE_SECONDS, time);
JSONObject status = new JSONObject();
status.put("value", summary.getStatus() & 0xFF);
status.put("unit", "");
jsonObject.put(ActivitySummaryEntries.STATUS, status);
JSONObject typeJson = new JSONObject();
typeJson.put("value", summary.getType() & 0xFF);
typeJson.put("unit", "");
jsonObject.put(ActivitySummaryEntries.TYPE, typeJson);
if (summary.getStrokes() != -1) { if (summary.getStrokes() != -1) {
JSONObject strokesJson = new JSONObject(); summaryData.add(ActivitySummaryEntries.STROKES, summary.getStrokes(), ActivitySummaryEntries.UNIT_STROKES);
strokesJson.put("value", summary.getStrokes());
strokesJson.put("unit", ActivitySummaryEntries.UNIT_STROKES);
jsonObject.put(ActivitySummaryEntries.STROKES, strokesJson);
} }
if (summary.getAvgStrokeRate() != -1) { if (summary.getAvgStrokeRate() != -1) {
JSONObject avgStrokeRateJson = new JSONObject(); // TODO: find out unit
avgStrokeRateJson.put("value", summary.getAvgStrokeRate()); summaryData.add(ActivitySummaryEntries.STROKE_RATE_AVG, summary.getAvgStrokeRate(), ActivitySummaryEntries.UNIT_NONE);
avgStrokeRateJson.put("unit", ""); // TODO: find out unit
jsonObject.put(ActivitySummaryEntries.STROKE_RATE_AVG, avgStrokeRateJson);
} }
if (summary.getPoolLength() != -1) { if (summary.getPoolLength() != -1) {
JSONObject poolLengthJson = new JSONObject(); summaryData.add(ActivitySummaryEntries.LANE_LENGTH, summary.getPoolLength(), ActivitySummaryEntries.UNIT_CM);
poolLengthJson.put("value", summary.getPoolLength());
poolLengthJson.put("unit", ActivitySummaryEntries.UNIT_CM);
jsonObject.put(ActivitySummaryEntries.LANE_LENGTH, poolLengthJson);
} }
if (summary.getLaps() != -1) { if (summary.getLaps() != -1) {
JSONObject lapsJson = new JSONObject(); summaryData.add(ActivitySummaryEntries.LAPS, summary.getLaps(), ActivitySummaryEntries.UNIT_LAPS);
lapsJson.put("value", summary.getLaps());
lapsJson.put("unit", ActivitySummaryEntries.UNIT_LAPS);
jsonObject.put(ActivitySummaryEntries.LAPS, lapsJson);
} }
if (summary.getAvgSwolf() != -1) { if (summary.getAvgSwolf() != -1) {
JSONObject avgSwolfJson = new JSONObject(); summaryData.add(ActivitySummaryEntries.SWOLF_AVG, summary.getAvgSwolf(), ActivitySummaryEntries.UNIT_NONE);
avgSwolfJson.put("value", summary.getAvgSwolf());
avgSwolfJson.put("unit", "");
jsonObject.put(ActivitySummaryEntries.SWOLF_AVG, avgSwolfJson);
} }
boolean unknownData = false; boolean unknownData = false;
@ -550,188 +513,83 @@ public class HuaweiWorkoutGbParser {
avgAltitude = avgAltitude / altitudeCount; avgAltitude = avgAltitude / altitudeCount;
if (speedCount > 0) { if (speedCount > 0) {
JSONObject speedJson = new JSONObject(); summaryData.add(ActivitySummaryEntries.SPEED_AVG, speed / 10f, ActivitySummaryEntries.UNIT_METERS_PER_SECOND);
speedJson.put("value", speed / 10);
speedJson.put("unit", ActivitySummaryEntries.UNIT_METERS_PER_SECOND);
jsonObject.put(ActivitySummaryEntries.SPEED_AVG, speedJson);
} }
if (stepRatePresent) { if (stepRatePresent) {
JSONObject stepRateSumJson = new JSONObject(); summaryData.add(ActivitySummaryEntries.STEP_RATE_SUM, stepRate, ActivitySummaryEntries.UNIT_SPM);
stepRateSumJson.put("value", stepRate);
stepRateSumJson.put("unit", ActivitySummaryEntries.UNIT_SPM);
jsonObject.put(ActivitySummaryEntries.STEP_RATE_SUM, stepRateSumJson);
JSONObject stepRateAvgJson = new JSONObject(); summaryData.add(ActivitySummaryEntries.STEP_RATE_AVG, avgStepRate, ActivitySummaryEntries.UNIT_SPM);
stepRateAvgJson.put("value", avgStepRate);
stepRateAvgJson.put("unit", ActivitySummaryEntries.UNIT_SPM);
jsonObject.put(ActivitySummaryEntries.STEP_RATE_AVG, stepRateAvgJson);
} }
if (cadenceCount > 0) { if (cadenceCount > 0) {
JSONObject cadenceJson = new JSONObject(); summaryData.add(ActivitySummaryEntries.CADENCE_AVG, cadence, ActivitySummaryEntries.UNIT_SPM);
cadenceJson.put("value", cadence);
cadenceJson.put("unit", ActivitySummaryEntries.UNIT_SPM);
jsonObject.put(ActivitySummaryEntries.CADENCE_AVG, cadenceJson);
} }
if (stepLengthCount > 0) { if (stepLengthCount > 0) {
JSONObject stepLengthJson = new JSONObject(); summaryData.add(ActivitySummaryEntries.STEP_LENGTH_AVG, stepLength, ActivitySummaryEntries.UNIT_CM);
stepLengthJson.put("value", stepLength);
stepLengthJson.put("unit", ActivitySummaryEntries.UNIT_CM);
jsonObject.put(ActivitySummaryEntries.STEP_LENGTH_AVG, stepLengthJson);
} }
if (groundContactTimeCount > 0) { if (groundContactTimeCount > 0) {
JSONObject groundContactTimeJson = new JSONObject(); summaryData.add(ActivitySummaryEntries.GROUND_CONTACT_TIME_AVG, groundContactTime, ActivitySummaryEntries.UNIT_MILLISECONDS);
groundContactTimeJson.put("value", groundContactTime);
groundContactTimeJson.put("unit", ActivitySummaryEntries.UNIT_MILLISECONDS);
jsonObject.put(ActivitySummaryEntries.GROUND_CONTACT_TIME_AVG, groundContactTimeJson);
} }
if (impactCount > 0) { if (impactCount > 0) {
JSONObject impactJson = new JSONObject(); summaryData.add(ActivitySummaryEntries.IMPACT_AVG, impact, "g");
impactJson.put("value", impact); summaryData.add(ActivitySummaryEntries.IMPACT_MAX, maxImpact, "g");
impactJson.put("unit", "g");
jsonObject.put(ActivitySummaryEntries.IMPACT_AVG, impactJson);
JSONObject maxImpactJson = new JSONObject();
maxImpactJson.put("value", maxImpact);
maxImpactJson.put("unit", "g");
jsonObject.put(ActivitySummaryEntries.IMPACT_MAX, maxImpactJson);
} }
if (swingAngleCount > 0) { if (swingAngleCount > 0) {
JSONObject swingAngleJson = new JSONObject(); summaryData.add(ActivitySummaryEntries.SWING_ANGLE_AVG, swingAngle, ActivitySummaryEntries.UNIT_DEGREES);
swingAngleJson.put("value", swingAngle);
swingAngleJson.put("unit", ActivitySummaryEntries.UNIT_DEGREES);
jsonObject.put(ActivitySummaryEntries.SWING_ANGLE_AVG, swingAngleJson);
} }
if (footLandingPresent) { if (footLandingPresent) {
JSONObject foreFootLandingJson = new JSONObject(); summaryData.add(ActivitySummaryEntries.FORE_FOOT_LANDINGS, foreFootLanding, ActivitySummaryEntries.UNIT_NONE);
foreFootLandingJson.put("value", foreFootLanding); summaryData.add(ActivitySummaryEntries.MID_FOOT_LANDINGS, midFootLanding, ActivitySummaryEntries.UNIT_NONE);
foreFootLandingJson.put("unit", ""); summaryData.add(ActivitySummaryEntries.BACK_FOOT_LANDINGS, backFootLanding, ActivitySummaryEntries.UNIT_NONE);
jsonObject.put(ActivitySummaryEntries.FORE_FOOT_LANDINGS, foreFootLandingJson);
JSONObject midFootLandingJson = new JSONObject();
midFootLandingJson.put("value", midFootLanding);
midFootLandingJson.put("unit", "");
jsonObject.put(ActivitySummaryEntries.MID_FOOT_LANDINGS, midFootLandingJson);
JSONObject backFootLandingJson = new JSONObject();
backFootLandingJson.put("value", backFootLanding);
backFootLandingJson.put("unit", "");
jsonObject.put(ActivitySummaryEntries.BACK_FOOT_LANDINGS, backFootLandingJson);
} }
if (eversionAngleCount > 0) { if (eversionAngleCount > 0) {
JSONObject eversionAngleJson = new JSONObject(); summaryData.add(ActivitySummaryEntries.EVERSION_ANGLE_AVG, eversionAngle, ActivitySummaryEntries.UNIT_DEGREES);
eversionAngleJson.put("value", eversionAngle); summaryData.add(ActivitySummaryEntries.EVERSION_ANGLE_MAX, maxEversionAngle, ActivitySummaryEntries.UNIT_DEGREES);
eversionAngleJson.put("unit", ActivitySummaryEntries.UNIT_DEGREES);
jsonObject.put(ActivitySummaryEntries.EVERSION_ANGLE_AVG, eversionAngleJson);
JSONObject maxEversionAngleJson = new JSONObject();
maxEversionAngleJson.put("value", maxEversionAngle);
maxEversionAngleJson.put("unit", ActivitySummaryEntries.UNIT_DEGREES);
jsonObject.put(ActivitySummaryEntries.EVERSION_ANGLE_MAX, maxEversionAngleJson);
} }
if (swolfCount > 0) { if (swolfCount > 0) {
JSONObject swolfJson = new JSONObject(); summaryData.add(ActivitySummaryEntries.SWOLF_AVG, swolf, ActivitySummaryEntries.UNIT_NONE);
swolfJson.put("value", swolf); summaryData.add(ActivitySummaryEntries.SWOLF_MAX, maxSwolf, ActivitySummaryEntries.UNIT_NONE);
swolfJson.put("unit", ""); summaryData.add(ActivitySummaryEntries.SWOLF_MIN, minSwolf, ActivitySummaryEntries.UNIT_NONE);
jsonObject.put(ActivitySummaryEntries.SWOLF_AVG, swolfJson);
JSONObject maxSwolfJson = new JSONObject();
maxSwolfJson.put("value", maxSwolf);
maxSwolfJson.put("unit", "");
jsonObject.put(ActivitySummaryEntries.SWOLF_MAX, maxSwolfJson);
JSONObject minSwolfJson = new JSONObject();
minSwolfJson.put("value", minSwolf);
minSwolfJson.put("unit", "");
jsonObject.put(ActivitySummaryEntries.SWOLF_MIN, minSwolfJson);
} }
if (strokeRateCount > 0) { if (strokeRateCount > 0) {
JSONObject strokeRateJson = new JSONObject(); // TODO: find out unit?
strokeRateJson.put("value", strokeRate); summaryData.add(ActivitySummaryEntries.STROKE_RATE_AVG, strokeRate, ActivitySummaryEntries.UNIT_NONE);
strokeRateJson.put("unit", ""); // TODO: find out unit?
jsonObject.put(ActivitySummaryEntries.STROKE_RATE_AVG, strokeRateJson);
JSONObject maxStrokeRateJson = new JSONObject(); // TODO: find out unit?
maxStrokeRateJson.put("value", maxStrokeRate); summaryData.add(ActivitySummaryEntries.STROKE_RATE_MAX, maxStrokeRate, ActivitySummaryEntries.UNIT_NONE);
maxStrokeRateJson.put("unit", ""); // TODO: find out unit?
jsonObject.put(ActivitySummaryEntries.STROKE_RATE_MAX, maxStrokeRateJson);
} }
if (heartRateCount > 0) { if (heartRateCount > 0) {
JSONObject heartRateJson = new JSONObject(); summaryData.add(ActivitySummaryEntries.HR_AVG, heartRate, ActivitySummaryEntries.UNIT_BPM);
heartRateJson.put("value", heartRate); summaryData.add(ActivitySummaryEntries.HR_MAX, maxHeartRate, ActivitySummaryEntries.UNIT_BPM);
heartRateJson.put("unit", ActivitySummaryEntries.UNIT_BPM); summaryData.add(ActivitySummaryEntries.HR_MIN, minHeartRate, ActivitySummaryEntries.UNIT_BPM);
jsonObject.put(ActivitySummaryEntries.HR_AVG, heartRateJson);
JSONObject maxHeartRateJson = new JSONObject();
maxHeartRateJson.put("value", maxHeartRate);
maxHeartRateJson.put("unit", ActivitySummaryEntries.UNIT_BPM);
jsonObject.put(ActivitySummaryEntries.HR_MAX, maxHeartRateJson);
JSONObject minHeartRateJson = new JSONObject();
minHeartRateJson.put("value", minHeartRate);
minHeartRateJson.put("unit", ActivitySummaryEntries.UNIT_BPM);
jsonObject.put(ActivitySummaryEntries.HR_MIN, minHeartRateJson);
} }
if (sumCalories > 0) { if (sumCalories > 0) {
JSONObject caloriesSumJson = new JSONObject(); summaryData.add(ActivitySummaryEntries.CALORIES_BURNT, sumCalories, ActivitySummaryEntries.UNIT_KCAL);
caloriesSumJson.put("value", sumCalories);
caloriesSumJson.put("unit", ActivitySummaryEntries.UNIT_KCAL);
jsonObject.put(ActivitySummaryEntries.CALORIES_BURNT, caloriesSumJson);
} }
if (cyclingPowerCount > 0) { if (cyclingPowerCount > 0) {
JSONObject cyclingPowerJson = new JSONObject(); summaryData.add(ActivitySummaryEntries.CYCLING_POWER_AVERAGE, cyclingPower, ActivitySummaryEntries.UNIT_NONE);
cyclingPowerJson.put("value", cyclingPower); summaryData.add(ActivitySummaryEntries.CYCLING_POWER_MIN, minCyclingPower, ActivitySummaryEntries.UNIT_NONE);
cyclingPowerJson.put("unit", ""); summaryData.add(ActivitySummaryEntries.CYCLING_POWER_MAX, maxCyclingPower, ActivitySummaryEntries.UNIT_NONE);
jsonObject.put(ActivitySummaryEntries.CYCLING_POWER_AVERAGE, cyclingPowerJson);
JSONObject minCyclingPowerJson = new JSONObject();
minCyclingPowerJson.put("value", minCyclingPower);
minCyclingPowerJson.put("unit", "");
jsonObject.put(ActivitySummaryEntries.CYCLING_POWER_MIN, minCyclingPowerJson);
JSONObject maxCyclingPowerJson = new JSONObject();
maxCyclingPowerJson.put("value", maxCyclingPower);
maxCyclingPowerJson.put("unit", "");
jsonObject.put(ActivitySummaryEntries.CYCLING_POWER_MAX, maxCyclingPowerJson);
} }
if (altitudeCount > 0) { if (altitudeCount > 0) {
JSONObject avgAltitudeJson = new JSONObject(); summaryData.add(ActivitySummaryEntries.ALTITUDE_AVG, avgAltitude / 10.0f, ActivitySummaryEntries.UNIT_METERS);
avgAltitudeJson.put("value", avgAltitude / 10.0); summaryData.add(ActivitySummaryEntries.ALTITUDE_MIN, minAltitude / 10.0f, ActivitySummaryEntries.UNIT_METERS);
avgAltitudeJson.put("unit", ActivitySummaryEntries.UNIT_METERS); summaryData.add(ActivitySummaryEntries.ALTITUDE_MAX, maxAltitude / 10.0f, ActivitySummaryEntries.UNIT_METERS);
jsonObject.put(ActivitySummaryEntries.ALTITUDE_AVG, avgAltitudeJson); summaryData.add(ActivitySummaryEntries.ELEVATION_GAIN, sumAltitudeUp / 10.0f, ActivitySummaryEntries.UNIT_METERS);
summaryData.add(ActivitySummaryEntries.ELEVATION_LOSS, sumAltitudeDown / 10.0f, ActivitySummaryEntries.UNIT_METERS);
JSONObject minAltitudeJson = new JSONObject();
minAltitudeJson.put("value", minAltitude / 10.0);
minAltitudeJson.put("unit", ActivitySummaryEntries.UNIT_METERS);
jsonObject.put(ActivitySummaryEntries.ALTITUDE_MIN, minAltitudeJson);
JSONObject maxAltitudeJson = new JSONObject();
maxAltitudeJson.put("value", maxAltitude / 10.0);
maxAltitudeJson.put("unit", ActivitySummaryEntries.UNIT_METERS);
jsonObject.put(ActivitySummaryEntries.ALTITUDE_MAX, maxAltitudeJson);
JSONObject sumUpAltitudeJson = new JSONObject();
sumUpAltitudeJson.put("value", sumAltitudeUp / 10.0);
sumUpAltitudeJson.put("unit", ActivitySummaryEntries.UNIT_METERS);
jsonObject.put(ActivitySummaryEntries.ELEVATION_GAIN, sumUpAltitudeJson);
JSONObject sumDownAltitudeJson = new JSONObject();
sumDownAltitudeJson.put("value", sumAltitudeDown / 10.0);
sumDownAltitudeJson.put("unit", ActivitySummaryEntries.UNIT_METERS);
jsonObject.put(ActivitySummaryEntries.ELEVATION_LOSS, sumDownAltitudeJson);
} }
} }
@ -755,51 +613,56 @@ public class HuaweiWorkoutGbParser {
typeCount.put(sample.getType(), count); typeCount.put(sample.getType(), count);
typePace.put(sample.getType(), pace); typePace.put(sample.getType(), pace);
JSONObject paceDistance = new JSONObject(); summaryData.add(
paceDistance.put("value", sample.getDistance()); ActivitySummaryEntries.GROUP_PACE,
paceDistance.put("unit", ActivitySummaryEntries.UNIT_KILOMETERS); GBApplication.getContext().getString(R.string.fmtPaceDistance, index),
paceDistance.put("group", ActivitySummaryEntries.GROUP_PACE); sample.getDistance(),
jsonObject.put(String.format(GBApplication.getLanguage(), GBApplication.getContext().getString(R.string.fmtPaceDistance), index), paceDistance); ActivitySummaryEntries.UNIT_KILOMETERS
);
JSONObject paceType = new JSONObject(); summaryData.add(
paceType.put("value", sample.getType()); ActivitySummaryEntries.GROUP_PACE,
paceType.put("unit", ""); // TODO: find out types GBApplication.getContext().getString(R.string.fmtPaceType, index),
paceType.put("group", ActivitySummaryEntries.GROUP_PACE); sample.getType(),
jsonObject.put(String.format(GBApplication.getLanguage(), GBApplication.getContext().getString(R.string.fmtPaceType), index), paceType); ActivitySummaryEntries.UNIT_NONE // TODO: find out types
);
JSONObject pacePace = new JSONObject(); summaryData.add(
pacePace.put("value", sample.getPace()); ActivitySummaryEntries.GROUP_PACE,
pacePace.put("unit", ActivitySummaryEntries.UNIT_SECONDS_PER_KM); GBApplication.getContext().getString(R.string.fmtPacePace, index),
pacePace.put("group", ActivitySummaryEntries.GROUP_PACE); sample.getPace(),
jsonObject.put(String.format(GBApplication.getLanguage(), GBApplication.getContext().getString(R.string.fmtPacePace), index), pacePace); ActivitySummaryEntries.UNIT_SECONDS_PER_KM
);
if (sample.getCorrection() != 0) { if (sample.getCorrection() != 0) {
JSONObject paceCorrection = new JSONObject(); summaryData.add(
paceCorrection.put("value", sample.getCorrection() / 10); ActivitySummaryEntries.GROUP_PACE,
paceCorrection.put("unit", ActivitySummaryEntries.UNIT_METERS); GBApplication.getContext().getString(R.string.fmtPaceCorrection, index),
paceCorrection.put("group", ActivitySummaryEntries.GROUP_PACE); sample.getCorrection() / 10f,
jsonObject.put(String.format(GBApplication.getLanguage(), GBApplication.getContext().getString(R.string.fmtPaceCorrection), index), paceCorrection); ActivitySummaryEntries.UNIT_METERS
);
} }
} }
for (Byte key : typeCount.keySet()) { for (Byte key : typeCount.keySet()) {
Integer count = typeCount.get(key); Integer count = typeCount.get(key);
Integer pace = typePace.get(key); Integer pace = typePace.get(key);
if (count == null || pace == null) if (count == null || pace == null || count == 0)
continue; continue;
JSONObject avgPace = new JSONObject(); summaryData.add(
avgPace.put("value", pace / count); ActivitySummaryEntries.GROUP_PACE,
avgPace.put("unit", ActivitySummaryEntries.UNIT_SECONDS_PER_KM); GBApplication.getContext().getString(R.string.fmtPaceTypeAverage, key),
avgPace.put("group", ActivitySummaryEntries.GROUP_PACE); pace / (float) count,
jsonObject.put(String.format(GBApplication.getContext().getString(R.string.fmtPaceTypeAverage), key), avgPace); ActivitySummaryEntries.UNIT_SECONDS_PER_KM
);
} }
} }
if (unknownData) { if (unknownData) {
JSONObject unknownDataJson = new JSONObject(); summaryData.add(
unknownDataJson.put("value", GBApplication.getContext().getString(R.string.yes).toUpperCase()); GBApplication.getContext().getString(R.string.unknownDataEncountered),
unknownDataJson.put("unit", "string"); GBApplication.getContext().getString(R.string.yes).toUpperCase()
jsonObject.put(GBApplication.getContext().getString(R.string.unknownDataEncountered), unknownDataJson); );
} }
BaseActivitySummary baseSummary; BaseActivitySummary baseSummary;
@ -817,7 +680,7 @@ public class HuaweiWorkoutGbParser {
null, null,
deviceId, deviceId,
userId, userId,
jsonObject.toString(), summaryData.toString(),
null null
); );
} else { } else {
@ -834,7 +697,7 @@ public class HuaweiWorkoutGbParser {
previous.getRawDetailsPath(), previous.getRawDetailsPath(),
deviceId, deviceId,
userId, userId,
jsonObject.toString(), summaryData.toString(),
null null
); );
} }