mirror of
https://codeberg.org/Freeyourgadget/Gadgetbridge.git
synced 2025-01-26 00:21:45 +01:00
Use textViews. Remove groups from data.
This commit is contained in:
parent
555eb34575
commit
4a4362eec4
@ -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;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -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) {
|
||||||
}
|
}
|
||||||
|
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user