Use textViews. Remove groups from data.

This commit is contained in:
vanous 2020-08-10 10:56:54 +02:00
parent 555eb34575
commit 4a4362eec4
3 changed files with 153 additions and 141 deletions

View File

@ -18,10 +18,14 @@
package nodomain.freeyourgadget.gadgetbridge.activities; package nodomain.freeyourgadget.gadgetbridge.activities;
import android.content.Intent; import android.content.Intent;
import android.graphics.Typeface;
import android.os.Bundle; import android.os.Bundle;
import android.view.Gravity;
import android.view.View; import android.view.View;
import android.widget.Button; import android.widget.Button;
import android.widget.ImageView; import android.widget.ImageView;
import android.widget.TableLayout;
import android.widget.TableRow;
import android.widget.TextView; import android.widget.TextView;
import android.widget.Toast; import android.widget.Toast;
@ -37,14 +41,9 @@ import java.util.Date;
import java.util.Iterator; import java.util.Iterator;
import java.util.concurrent.TimeUnit; import java.util.concurrent.TimeUnit;
import nodomain.freeyourgadget.gadgetbridge.GBApplication;
import nodomain.freeyourgadget.gadgetbridge.R; import nodomain.freeyourgadget.gadgetbridge.R;
import nodomain.freeyourgadget.gadgetbridge.activities.charts.ActivityAnalysis;
import nodomain.freeyourgadget.gadgetbridge.database.DBHandler;
import nodomain.freeyourgadget.gadgetbridge.impl.GBDevice; import nodomain.freeyourgadget.gadgetbridge.impl.GBDevice;
import nodomain.freeyourgadget.gadgetbridge.model.ActivityAmounts;
import nodomain.freeyourgadget.gadgetbridge.model.ActivityKind; import nodomain.freeyourgadget.gadgetbridge.model.ActivityKind;
import nodomain.freeyourgadget.gadgetbridge.model.DailyTotals;
import nodomain.freeyourgadget.gadgetbridge.util.AndroidUtils; import nodomain.freeyourgadget.gadgetbridge.util.AndroidUtils;
import nodomain.freeyourgadget.gadgetbridge.util.DateTimeUtils; import nodomain.freeyourgadget.gadgetbridge.util.DateTimeUtils;
import nodomain.freeyourgadget.gadgetbridge.util.GB; import nodomain.freeyourgadget.gadgetbridge.util.GB;
@ -52,6 +51,7 @@ import nodomain.freeyourgadget.gadgetbridge.util.GB;
public class ActivitySummaryDetail extends AbstractGBActivity { public class ActivitySummaryDetail extends AbstractGBActivity {
private static final Logger LOG = LoggerFactory.getLogger(ActivitySummaryDetail.class); private static final Logger LOG = LoggerFactory.getLogger(ActivitySummaryDetail.class);
private GBDevice mGBDevice; private GBDevice mGBDevice;
private JSONObject groupData = setGroups();
@Override @Override
protected void onCreate(Bundle savedInstanceState) { protected void onCreate(Bundle savedInstanceState) {
@ -82,11 +82,7 @@ public class ActivitySummaryDetail extends AbstractGBActivity {
Date endtime = (Date) intent.getSerializableExtra("EndTime"); Date endtime = (Date) intent.getSerializableExtra("EndTime");
String starttimeS = DateTimeUtils.formatDateTime(starttime); String starttimeS = DateTimeUtils.formatDateTime(starttime);
String endtimeS = DateTimeUtils.formatDateTime(endtime); String endtimeS = DateTimeUtils.formatDateTime(endtime);
long startTs = starttime.getTime() / 1000;
long endTs = endtime.getTime() / 1000;
String durationhms = DateTimeUtils.formatDurationHoursMinutes((endtime.getTime() - starttime.getTime()), TimeUnit.MILLISECONDS); String durationhms = DateTimeUtils.formatDurationHoursMinutes((endtime.getTime() - starttime.getTime()), TimeUnit.MILLISECONDS);
//int steps = getSteps((int) startTs, (int) endTs);
//unused now, as we use the more extensive summaryData
ImageView activity_icon = (ImageView) findViewById(R.id.item_image); ImageView activity_icon = (ImageView) findViewById(R.id.item_image);
activity_icon.setImageResource(ActivityKind.getIconId(intent.getIntExtra("ActivityKind",0))); activity_icon.setImageResource(ActivityKind.getIconId(intent.getIntExtra("ActivityKind",0)));
@ -112,12 +108,11 @@ public class ActivitySummaryDetail extends AbstractGBActivity {
if (summaryData == null) return; if (summaryData == null) return;
JSONObject listOfSummaries = makeSummaryList(summaryData); JSONObject listOfSummaries = makeSummaryList(summaryData);
TextView details = (TextView) findViewById(R.id.details); makeSummaryContent(listOfSummaries);
details.setText(makeSummaryContent(listOfSummaries));
} }
private String makeSummaryContent (JSONObject data){ private void makeSummaryContent (JSONObject data){
//convert dictionary to pretty print string, use localized names //build view, use localized names
StringBuilder content = new StringBuilder(); StringBuilder content = new StringBuilder();
Iterator<String> keys = data.keys(); Iterator<String> keys = data.keys();
DecimalFormat df = new DecimalFormat("#.##"); DecimalFormat df = new DecimalFormat("#.##");
@ -127,7 +122,15 @@ public class ActivitySummaryDetail extends AbstractGBActivity {
try { try {
LOG.error("SportsActivity:" + key + ": " + data.get(key) + "\n"); LOG.error("SportsActivity:" + key + ": " + data.get(key) + "\n");
JSONArray innerList = (JSONArray) data.get(key); JSONArray innerList = (JSONArray) data.get(key);
content.append(String.format("\n%s\n", getStringResourceByName(key).toUpperCase()));
TableLayout fieldLayout = findViewById(R.id.summaryDetails);
TableRow label_row = new TableRow(ActivitySummaryDetail.this);
TextView label_field = new TextView(ActivitySummaryDetail.this);
label_field.setTextSize(16);
label_field.setTypeface(null, Typeface.BOLD);
label_field.setText(String.format("%s", getStringResourceByName(key)));
label_row.addView(label_field);
fieldLayout.addView(label_row);
for (int i = 0; i < innerList.length(); i++) { for (int i = 0; i < innerList.length(); i++) {
JSONObject innerData = innerList.getJSONObject(i); JSONObject innerData = innerList.getJSONObject(i);
@ -151,16 +154,57 @@ public class ActivitySummaryDetail extends AbstractGBActivity {
break; break;
} }
content.append(String.format("%s: %s %s\n", getStringResourceByName(name), df.format(value), getStringResourceByName(unit))); TableRow field_row = new TableRow(ActivitySummaryDetail.this);
TextView name_field = new TextView(ActivitySummaryDetail.this);
TextView value_field = new TextView(ActivitySummaryDetail.this);
name_field.setGravity(Gravity.START);
value_field.setGravity(Gravity.END);
value_field.setText(String.format("%s %s", df.format(value), getStringResourceByName(unit)));
name_field.setText(getStringResourceByName(name));
field_row.addView(name_field);
field_row.addView(value_field);
fieldLayout.addView(field_row);
} }
} catch (JSONException e) { } catch (JSONException e) {
LOG.error("SportsActivity", e); LOG.error("SportsActivity", e);
} }
} }
return content.toString();
} }
private JSONObject setGroups(){
String groupDefinitions = "{'Strokes':['averageStrokeDistance','averageStrokesPerSecond','strokes'], " +
"'Swimming':['swolfIndex','swimStyle'], " +
"'Elevation':['ascentMeters','descentMeters','maxAltitude','minAltitude','ascentSeconds','descentSeconds','flatSeconds'], " +
"'Speed':['maxSpeed','minPace','maxPace','averageKMPaceSeconds'], " +
"'Activity':['distanceMeters','steps','activeSeconds','caloriesBurnt','totalStride'," +
"'averageHR','averageStride'], " +
"'Laps':['averageLapPace','laps']}";
JSONObject data = null;
try {
data = new JSONObject(groupDefinitions);
} catch (JSONException e) {
LOG.error("SportsActivity", e);
}
return data;
}
private String getGroup(String searchItem) {
Iterator<String> keys = groupData.keys();
while (keys.hasNext()) {
String key = keys.next();
try {
JSONArray itemList = (JSONArray) groupData.get(key);
for (int i = 0; i < itemList.length(); i++) {
if (itemList.getString(i).contains(searchItem)) {
return key;
}
}
} catch (JSONException e) {
LOG.error("SportsActivity", e);
}
}
return "Activity";
}
private JSONObject makeSummaryList(JSONObject summaryData){ private JSONObject makeSummaryList(JSONObject summaryData){
//make dictionary with data for each group //make dictionary with data for each group
@ -176,7 +220,7 @@ public class ActivitySummaryDetail extends AbstractGBActivity {
JSONObject innerData = (JSONObject) summaryData.get(key); JSONObject innerData = (JSONObject) summaryData.get(key);
Object value = innerData.get("value"); Object value = innerData.get("value");
String unit = innerData.getString("unit"); String unit = innerData.getString("unit");
String group = innerData.getString("group"); String group = getGroup(key);
if (!list.has(group)) { if (!list.has(group)) {
list.put(group,new JSONArray()); list.put(group,new JSONArray());
@ -207,16 +251,4 @@ public class ActivitySummaryDetail extends AbstractGBActivity {
} }
} }
private int getSteps(int tsStart, int tsEnd) {
try (DBHandler handler = GBApplication.acquireDB()) {
DailyTotals dt = new DailyTotals();
ActivityAnalysis analysis = new ActivityAnalysis();
ActivityAmounts amountsSteps;
amountsSteps = analysis.calculateActivityAmounts(dt.getSamples(handler, mGBDevice, tsStart, tsEnd));
return (int) dt.getTotalsStepsForActivityAmounts(amountsSteps);
} catch (Exception e) {
GB.toast("Error loading activity steps.", Toast.LENGTH_SHORT, GB.ERROR, e);
}
return 0;
}
} }

View File

@ -283,13 +283,13 @@ public class FetchSportsSummaryOperation extends AbstractFetchOperation {
buffer.getInt(); // unknown buffer.getInt(); // unknown
buffer.getShort(); // unknown buffer.getShort(); // unknown
addSummaryData("averageStrokeDistance", averageStrokeDistance, "meter", "Strokes"); addSummaryData("averageStrokeDistance", averageStrokeDistance, "meters");
addSummaryData("averageStrokesPerSecond", averageStrokesPerSecond, "strokes_second", "Strokes"); addSummaryData("averageStrokesPerSecond", averageStrokesPerSecond, "strokes_second");
addSummaryData("averageLapPace", averageLapPace, "second", "Laps"); addSummaryData("averageLapPace", averageLapPace, "second");
addSummaryData("strokes", strokes, "strokes", "Strokes"); addSummaryData("strokes", strokes, "strokes");
addSummaryData("swolfIndex", swolfIndex, "swolf_index", "Swimming"); addSummaryData("swolfIndex", swolfIndex, "swolf_index");
addSummaryData("swimStyle", swimStyle, "swim_style", "Swimming"); addSummaryData("swimStyle", swimStyle, "swim_style");
addSummaryData("laps", laps, "laps", "Laps"); addSummaryData("laps", laps, "laps");
} else { } else {
// 28 bytes // 28 bytes
@ -301,9 +301,9 @@ public class FetchSportsSummaryOperation extends AbstractFetchOperation {
buffer.getInt(); // unknown; buffer.getInt(); // unknown;
int flatSeconds = buffer.getInt() / 1000; // ms? int flatSeconds = buffer.getInt() / 1000; // ms?
addSummaryData("ascentSeconds", ascentSeconds, "seconds", "Elevation"); addSummaryData("ascentSeconds", ascentSeconds, "seconds");
addSummaryData("descentSeconds", descentSeconds, "seconds", "Elevation"); addSummaryData("descentSeconds", descentSeconds, "seconds");
addSummaryData("flatSeconds", flatSeconds, "seconds", "Elevation"); addSummaryData("flatSeconds", flatSeconds, "seconds");
} }
averageHR = buffer.getShort(); averageHR = buffer.getShort();
@ -336,37 +336,36 @@ public class FetchSportsSummaryOperation extends AbstractFetchOperation {
// summary.setAveragePace(BLETypeConversions.toUnsigned(averagePace); // summary.setAveragePace(BLETypeConversions.toUnsigned(averagePace);
// summary.setAverageStride(BLETypeConversions.toUnsigned(averageStride); // summary.setAverageStride(BLETypeConversions.toUnsigned(averageStride);
addSummaryData("distanceMeters", distanceMeters, "meters", "Activity"); addSummaryData("distanceMeters", distanceMeters, "meters");
addSummaryData("ascentMeters", ascentMeters, "meters", "Elevation"); addSummaryData("ascentMeters", ascentMeters, "meters");
addSummaryData("descentMeters", descentMeters, "meters", "Elevation"); addSummaryData("descentMeters", descentMeters, "meters");
if (maxAltitude != -100000) { if (maxAltitude != -100000) {
addSummaryData("maxAltitude", maxAltitude, "meters", "Elevation"); addSummaryData("maxAltitude", maxAltitude, "meters");
} }
if (minAltitude != 100000) { if (minAltitude != 100000) {
addSummaryData("minAltitude", minAltitude, "meters", "Elevation"); addSummaryData("minAltitude", minAltitude, "meters");
} }
addSummaryData("steps", steps, "steps_unit", "Activity"); addSummaryData("steps", steps, "steps_unit");
addSummaryData("activeSeconds", activeSeconds, "seconds", "Activity"); addSummaryData("activeSeconds", activeSeconds, "seconds");
addSummaryData("caloriesBurnt", caloriesBurnt, "calories_unit", "Activity"); addSummaryData("caloriesBurnt", caloriesBurnt, "calories_unit");
addSummaryData("maxSpeed", maxSpeed, "meters_second", "Speed"); addSummaryData("maxSpeed", maxSpeed, "meters_second");
addSummaryData("minPace", minPace, "seconds_m", "Speed"); addSummaryData("minPace", minPace, "seconds_m");
addSummaryData("maxPace", maxPace, "seconds_m", "Speed"); addSummaryData("maxPace", maxPace, "seconds_m");
addSummaryData("totalStride", totalStride, "meters", "Activity"); addSummaryData("totalStride", totalStride, "meters");
addSummaryData("averageHR", averageHR, "bpm", "Activity"); addSummaryData("averageHR", averageHR, "bpm");
addSummaryData("averageKMPaceSeconds", averageKMPaceSeconds, "seconds_km", "Speed"); addSummaryData("averageKMPaceSeconds", averageKMPaceSeconds, "seconds_km");
addSummaryData("averageStride", averageStride, "cm", "Activity"); addSummaryData("averageStride", averageStride, "cm");
summary.setSummaryData(summaryData.toString()); summary.setSummaryData(summaryData.toString());
return summary; return summary;
} }
private void addSummaryData(String key, float value, String unit, String group) { private void addSummaryData(String key, float value, String unit) {
if (value> 0) { if (value> 0) {
try { try {
JSONObject innerData= new JSONObject(); JSONObject innerData= new JSONObject();
innerData.put("value", value); innerData.put("value", value);
innerData.put("unit", unit); innerData.put("unit", unit);
innerData.put("group", group);
summaryData.put(key, innerData); summaryData.put(key, innerData);
} catch (JSONException ignore) { } catch (JSONException ignore) {
} }

View File

@ -28,95 +28,76 @@
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:fontFamily="sans-serif-black" android:fontFamily="sans-serif-black"
android:maxLines="1" android:maxLines="1"
android:scrollHorizontally="false" /> android:scrollHorizontally="false"
android:textSize="18sp" />
<LinearLayout <TableLayout
android:id="@+id/start"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_weight="1"
android:orientation="horizontal">
<TextView
android:id="@+id/starttime_label"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1"
android:gravity="start"
android:text="@string/activity_detail_start_label" />
<TextView
android:id="@+id/starttime"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1"
android:gravity="end" />
</LinearLayout>
<LinearLayout
android:id="@+id/end"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal">
<TextView
android:id="@+id/endtime_label"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1"
android:gravity="start"
android:text="@string/activity_detail_end_label" />
<TextView
android:id="@+id/endtime"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1"
android:gravity="end" />
</LinearLayout>
<LinearLayout
android:id="@+id/dur"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_weight="1"
android:orientation="horizontal">
<TextView
android:id="@+id/duration_label"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1"
android:gravity="start"
android:text="@string/activity_detail_duration_label" />
<TextView
android:id="@+id/duration"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1"
android:gravity="end" />
</LinearLayout>
<LinearLayout
android:id="@+id/summaryDetails" android:id="@+id/summaryDetails"
android:layout_width="match_parent" android:layout_width="match_parent"
android:layout_height="match_parent" android:layout_height="match_parent" >
android:layout_weight="1"
android:orientation="horizontal">
<TextView <TableRow
android:id="@+id/details" android:layout_width="match_parent"
android:layout_width="wrap_content" android:layout_height="match_parent">
android:layout_height="wrap_content"
android:layout_weight="1"
android:gravity="start" />
</LinearLayout> <TextView
android:id="@+id/starttime_label"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1"
android:gravity="start"
android:text="@string/activity_detail_start_label" />
<TextView
android:id="@+id/starttime"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1"
android:gravity="end" />
</TableRow>
<TableRow
android:layout_width="match_parent"
android:layout_height="match_parent">
<TextView
android:id="@+id/endtime_label"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1"
android:gravity="start"
android:text="@string/activity_detail_end_label" />
<TextView
android:id="@+id/endtime"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1"
android:gravity="end" />
</TableRow>
<TableRow
android:layout_width="match_parent"
android:layout_height="match_parent" >
<TextView
android:id="@+id/duration_label"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1"
android:gravity="start"
android:text="@string/activity_detail_duration_label" />
<TextView
android:id="@+id/duration"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1"
android:gravity="end" />
</TableRow>
</TableLayout>
<Button <Button