mirror of
https://codeberg.org/Freeyourgadget/Gadgetbridge.git
synced 2025-01-10 17:11:56 +01:00
Huawei: Show pace summery before table. More summary.
This commit is contained in:
parent
af64ff3a79
commit
15f550d5a8
@ -673,8 +673,11 @@ public class HuaweiWorkoutGbParser implements ActivitySummaryParser {
|
||||
|
||||
byte unitType = (byte) (measurementSystem.equals("metric") ? 0 : 1);
|
||||
try (CloseableListIterator<HuaweiWorkoutPaceSample> it = qbPace.build().listIterator()) {
|
||||
HashMap<Byte, Integer> typeCount = new HashMap<>();
|
||||
HashMap<Byte, Integer> typePace = new HashMap<>();
|
||||
|
||||
int paceCount = 0;
|
||||
int paceSum = 0;
|
||||
int paceFastest = Integer.MAX_VALUE;
|
||||
int paceSlowest = 0;
|
||||
|
||||
int currentIndex = 1;
|
||||
while (it.hasNext()) {
|
||||
@ -685,16 +688,16 @@ public class HuaweiWorkoutGbParser implements ActivitySummaryParser {
|
||||
continue;
|
||||
|
||||
int pace = sample.getPace();
|
||||
int count = 1;
|
||||
|
||||
Integer previousCount = typeCount.get(sample.getType());
|
||||
Integer previousPace = typePace.get(sample.getType());
|
||||
if (previousCount != null)
|
||||
count += previousCount;
|
||||
if (previousPace != null)
|
||||
pace += previousPace;
|
||||
typeCount.put(sample.getType(), count);
|
||||
typePace.put(sample.getType(), pace);
|
||||
paceCount++;
|
||||
paceSum += pace;
|
||||
|
||||
if (pace < paceFastest)
|
||||
paceFastest = pace;
|
||||
|
||||
if (pace > paceSlowest)
|
||||
paceSlowest = pace;
|
||||
|
||||
double distance = sample.getDistance();
|
||||
|
||||
if (sample.getCorrection() != null) {
|
||||
@ -717,24 +720,38 @@ public class HuaweiWorkoutGbParser implements ActivitySummaryParser {
|
||||
);
|
||||
}
|
||||
|
||||
if (paceCount != 0 && paceSum != 0) {
|
||||
summaryData.add(
|
||||
ActivitySummaryEntries.GROUP_PACE,
|
||||
GBApplication.getContext().getString(R.string.fmtPaceAverage),
|
||||
paceSum / (float) paceCount,
|
||||
ActivitySummaryEntries.UNIT_SECONDS_PER_KM
|
||||
);
|
||||
}
|
||||
|
||||
if (paceFastest != Integer.MAX_VALUE) {
|
||||
summaryData.add(
|
||||
ActivitySummaryEntries.GROUP_PACE,
|
||||
GBApplication.getContext().getString(R.string.maxPace),
|
||||
paceFastest,
|
||||
ActivitySummaryEntries.UNIT_SECONDS_PER_KM
|
||||
);
|
||||
}
|
||||
|
||||
if (paceSlowest != 0) {
|
||||
summaryData.add(
|
||||
ActivitySummaryEntries.GROUP_PACE,
|
||||
GBApplication.getContext().getString(R.string.minPace),
|
||||
paceSlowest,
|
||||
ActivitySummaryEntries.UNIT_SECONDS_PER_KM
|
||||
);
|
||||
}
|
||||
|
||||
if (pacesTable.size() > 1) {
|
||||
for (final Map.Entry<String, ActivitySummaryTableRowEntry> e : pacesTable.entrySet()) {
|
||||
summaryData.add(e.getKey(), e.getValue());
|
||||
}
|
||||
}
|
||||
|
||||
for (Byte key : typeCount.keySet()) {
|
||||
Integer count = typeCount.get(key);
|
||||
Integer pace = typePace.get(key);
|
||||
if (count == null || pace == null || count == 0)
|
||||
continue;
|
||||
summaryData.add(
|
||||
ActivitySummaryEntries.GROUP_PACE,
|
||||
GBApplication.getContext().getString(R.string.fmtPaceTypeAverage, key),
|
||||
pace / (float) count,
|
||||
ActivitySummaryEntries.UNIT_SECONDS_PER_KM
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
if (unknownData) {
|
||||
|
@ -2238,6 +2238,7 @@
|
||||
<string name="fmtPaceCorrection">Pace %d correction</string>
|
||||
<string name="paceCorrection">Correction</string>
|
||||
<string name="fmtPaceTypeAverage">Pace Type %d average</string>
|
||||
<string name="fmtPaceAverage">Pace average</string>
|
||||
<string name="unknownDataEncountered">Unknown data encountered</string>
|
||||
<string name="cyclingPowerAverage">Average cycling power</string>
|
||||
<string name="cyclingPowerMin">Min cycling power</string>
|
||||
|
Loading…
Reference in New Issue
Block a user