#8 summary/lap fit fix

This commit is contained in:
Gyuri Horák 2023-11-12 18:50:49 +01:00
parent 9258c4eda0
commit 47e74c8dfe
Signed by: dyuri
GPG Key ID: 4993F07B3EAE8D38
4 changed files with 49 additions and 79 deletions

View File

@ -8,27 +8,17 @@
dataLabel="@Strings.chartGrade"
unitLabel="@Strings.uGrade"
fillColor="#00FFFF" />
<fitField id="5"
<fitField id="3"
displayInActivitySummary="true"
sortOrder="5"
precision="2"
dataLabel="@Strings.fitMinGrade"
unitLabel="@Strings.uGrade" />
<fitField id="6"
displayInActivitySummary="true"
sortOrder="6"
precision="2"
dataLabel="@Strings.fitMaxGrade"
unitLabel="@Strings.uGrade" />
<fitField id="7"
displayInActivitySummary="true"
sortOrder="7"
displayInActivityLaps="false"
displayInChart="false"
sortOrder="3"
precision="2"
dataLabel="@Strings.fitAGrade"
unitLabel="@Strings.uGrade" />
<fitField id="8"
<fitField id="4"
displayInActivityLaps="true"
sortOrder="8"
sortOrder="4"
precision="2"
dataLabel="@Strings.fitAGrade"
unitLabel="@Strings.uGrade" />
@ -41,18 +31,6 @@
dataLabel="@Strings.chartGAP"
unitLabel="@Strings.uGAP"
fillColor="#AAFF44" />
<fitField id="3"
displayInActivitySummary="true"
sortOrder="3"
precision="2"
dataLabel="@Strings.fitAGAP"
unitLabel="@Strings.uGAP" />
<fitField id="4"
displayInActivityLaps="true"
sortOrder="4"
precision="2"
dataLabel="@Strings.fitAGAP"
unitLabel="@Strings.uGAP" />
<!-- vertical speed -->
<fitField id="2"
displayInChart="true"
@ -62,27 +40,15 @@
dataLabel="@Strings.chartVSpeed"
unitLabel="@Strings.uVSpeed"
fillColor="#FF8888" />
<fitField id="9"
<fitField id="5"
displayInActivitySummary="true"
sortOrder="9"
precision="2"
dataLabel="@Strings.fitMinVSpeed"
unitLabel="@Strings.uVSpeed" />
<fitField id="10"
displayInActivitySummary="true"
sortOrder="10"
precision="2"
dataLabel="@Strings.fitMaxVSpeed"
unitLabel="@Strings.uVSpeed" />
<fitField id="11"
displayInActivitySummary="true"
sortOrder="11"
sortOrder="5"
precision="2"
dataLabel="@Strings.fitAVSpeed"
unitLabel="@Strings.uVSpeed" />
<fitField id="12"
<fitField id="6"
displayInActivityLaps="true"
sortOrder="12"
sortOrder="6"
precision="2"
dataLabel="@Strings.fitAVSpeed"
unitLabel="@Strings.uVSpeed" />

View File

@ -1,11 +1,11 @@
<properties>
<property id="appVersion" type="string">2.0.0</property>
<property id="appVersion" type="string">2.0.1</property>
<property id="themeColor" type="string">0</property>
<property id="themeColor2" type="string">0088FF</property>
<property id="themeColor3" type="string">00AA55</property>
<property id="hrDisplay" type="number">0</property>
<property id="speedNotPace" type="boolean">false</property>
<property id="showNextPoint" type="boolean">true</property>
<property id="saveToFit" type="boolean">false</property>
<property id="saveToFit" type="boolean">true</property>
<property id="tlFieldData" type="number">1</property>
</properties>

View File

@ -59,9 +59,11 @@ class Track extends WatchUi.Drawable {
var astart = 150;
var aend = 390;
var offtrack = _offCourse > 50.0f;
dc.setPenWidth((dc.getWidth() * 0.01).toNumber());
dc.setPenWidth((dc.getWidth() * 0.01).toNumber() + 1);
dc.setColor(offtrack ? 0x880000 : 0x555555, Graphics.COLOR_TRANSPARENT);
dc.drawArc(w / 2, h / 2, w / 2 - 2, Graphics.ARC_COUNTER_CLOCKWISE, astart, aend);
// the center is between two points, so draw twice
dc.drawArc(w / 2 - 1, h / 2, w / 2 - 1, Graphics.ARC_COUNTER_CLOCKWISE, astart, aend);
dc.drawArc(w / 2, h / 2, w / 2 - 1, Graphics.ARC_COUNTER_CLOCKWISE, astart, aend);
if (trackPercentage <= 0.0f) {
return;
@ -88,7 +90,8 @@ class Track extends WatchUi.Drawable {
} else if (acurrent > aend) {
acurrent = aend;
}
dc.drawArc(w / 2, h / 2, w / 2 - 2, Graphics.ARC_COUNTER_CLOCKWISE, astart, acurrent);
dc.drawArc(w / 2 - 1, h / 2, w / 2 - 1, Graphics.ARC_COUNTER_CLOCKWISE, astart, acurrent);
dc.drawArc(w / 2, h / 2, w / 2 - 1, Graphics.ARC_COUNTER_CLOCKWISE, astart, acurrent);
// next point
if (_toNextPoint > 0.0f) {
@ -101,8 +104,15 @@ class Track extends WatchUi.Drawable {
anext = aend;
}
dc.setPenWidth((dc.getWidth() * 0.01).toNumber());
dc.setColor(offtrack ? 0xAA0000 : 0xAAAAAA, Graphics.COLOR_TRANSPARENT);
dc.drawArc(w / 2, h / 2, w / 2 - 2, Graphics.ARC_COUNTER_CLOCKWISE, acurrent, anext);
if (offtrack) {
dc.setColor(0xAA0000, Graphics.COLOR_TRANSPARENT);
} else if (_toNextPoint > 500) {
dc.setColor(0xAAAAAA, Graphics.COLOR_TRANSPARENT);
} else {
dc.setColor(0xAAFF44, Graphics.COLOR_TRANSPARENT);
}
dc.drawArc(w / 2, h / 2, w / 2 - 1, Graphics.ARC_COUNTER_CLOCKWISE, acurrent, anext);
dc.drawArc(w / 2 - 1, h / 2, w / 2 - 1, Graphics.ARC_COUNTER_CLOCKWISE, acurrent, anext);
// next point name
if (_showNextPoint && _font != null && h > 350) {
@ -112,7 +122,7 @@ class Track extends WatchUi.Drawable {
} else if (_nextPointName.length() > 20) {
pointText += " | " + _nextPointName.substring(0, 17) + "...";
}
if (_toNextPoint > 1000) {
if (_toNextPoint > 500) {
dc.setColor(0x88FFFF, Graphics.COLOR_TRANSPARENT);
} else {
dc.setColor(0xAAFF44, Graphics.COLOR_TRANSPARENT);

View File

@ -16,18 +16,12 @@ const TLF_GAP = 2;
const TLF_VSPEED = 3;
const FIT_GRADE_ID = 0;
const FIT_GRADE_SUM_MIN_ID = 5;
const FIT_GRADE_SUM_MAX_ID = 6;
const FIT_GRADE_SUM_AVG_ID = 7;
const FIT_GRADE_LAP_AVG_ID = 8;
const FIT_GRADE_SUM_AVG_ID = 3;
const FIT_GRADE_LAP_AVG_ID = 4;
const FIT_GAP_ID = 1;
const FIT_GAP_SUM_AVG_ID = 3;
const FIT_GAP_LAP_AVG_ID = 4;
const FIT_VSPEED_ID = 2;
const FIT_VSPEED_SUM_MIN_ID = 9;
const FIT_VSPEED_SUM_MAX_ID = 10;
const FIT_VSPEED_SUM_AVG_ID = 11;
const FIT_VSPEED_LAP_AVG_ID = 12;
const FIT_VSPEED_SUM_AVG_ID = 5;
const FIT_VSPEED_LAP_AVG_ID = 6;
function displayHr(hr as Number, type as Number, zones as Array<Number>) as String {
if (hr == 0) {
@ -191,7 +185,7 @@ class RepaFieldView extends WatchUi.DataField {
fitVSpeedSumAvg = null;
fitVSpeedLapAvg = null;
if (Application.Properties.getValue("saveToFit")) {
fitGrade = DataField.createField(
fitGrade = createField(
"grade",
FIT_GRADE_ID,
FitContributor.DATA_TYPE_FLOAT,
@ -200,25 +194,25 @@ class RepaFieldView extends WatchUi.DataField {
:units=>"%",
}
);
fitGradeSumAvg = DataField.createField(
fitGradeSumAvg = createField(
"avg_grade",
FIT_GRADE_SUM_AVG_ID,
FitContributor.DATA_TYPE_FLOAT,
{
:mesgType=>FitContributor.MESG_TYPE_RECORD,
:mesgType=>FitContributor.MESG_TYPE_SESSION,
:units=>"%",
}
);
fitGradeLapAvg = DataField.createField(
"avg_grade",
fitGradeLapAvg = createField(
"lap_avg_grade",
FIT_GRADE_LAP_AVG_ID,
FitContributor.DATA_TYPE_FLOAT,
{
:mesgType=>FitContributor.MESG_TYPE_RECORD,
:mesgType=>FitContributor.MESG_TYPE_LAP,
:units=>"%",
}
);
fitGAP = DataField.createField(
fitGAP = createField(
"gap",
FIT_GAP_ID,
FitContributor.DATA_TYPE_FLOAT,
@ -227,7 +221,7 @@ class RepaFieldView extends WatchUi.DataField {
:units=>isPaceMetric ? "min/km" : "min/mi",
}
);
fitVSpeed = DataField.createField(
fitVSpeed = createField(
"vspeed",
FIT_VSPEED_ID,
FitContributor.DATA_TYPE_FLOAT,
@ -236,21 +230,21 @@ class RepaFieldView extends WatchUi.DataField {
:units=>isElevationMetric ? "m/min" : "ft/min",
}
);
fitVSpeedSumAvg = DataField.createField(
fitVSpeedSumAvg = createField(
"avg_vspeed",
FIT_VSPEED_SUM_AVG_ID,
FitContributor.DATA_TYPE_FLOAT,
{
:mesgType=>FitContributor.MESG_TYPE_RECORD,
:mesgType=>FitContributor.MESG_TYPE_SESSION,
:units=>isElevationMetric ? "m/min" : "ft/min",
}
);
fitVSpeedLapAvg = DataField.createField(
"avg_vspeed",
fitVSpeedLapAvg = createField(
"lap_avg_vspeed",
FIT_VSPEED_LAP_AVG_ID,
FitContributor.DATA_TYPE_FLOAT,
{
:mesgType=>FitContributor.MESG_TYPE_RECORD,
:mesgType=>FitContributor.MESG_TYPE_LAP,
:units=>isElevationMetric ? "m/min" : "ft/min",
}
);
@ -537,18 +531,18 @@ class RepaFieldView extends WatchUi.DataField {
if (fitGrade != null) {
fitGrade.setData(cgrade ? cgrade : 0);
var gradeSumAvg = grade.totalAvg();
fitGradeSumAvg.setData(gradeSumAvg ? gradeSumAvg : 0);
fitGradeSumAvg.setData(gradeSumAvg ? gradeSumAvg * 100 : 0);
var gradeLapAvg = grade.lapAvg();
fitGradeLapAvg.setData(gradeLapAvg ? gradeLapAvg : 0);
fitGradeLapAvg.setData(gradeLapAvg ? gradeLapAvg * 100 : 0);
}
if (fitGAP != null) {
fitGAP.setData(cgap ? cgap : 0);
}
if (fitVSpeed != null) {
fitVSpeed.setData(cvspeed ? cvspeed : 0);
var vsSumAvg = grade.totalAvg();
var vsSumAvg = vspeed.totalAvg();
fitVSpeedSumAvg.setData(vsSumAvg ? vsSumAvg : 0);
var vsLapAvg = grade.lapAvg();
var vsLapAvg = vspeed.lapAvg();
fitVSpeedLapAvg.setData(vsLapAvg ? vsLapAvg : 0);
}
}