mirror of
https://codeberg.org/Freeyourgadget/Gadgetbridge.git
synced 2025-01-25 16:15:55 +01:00
Heart Rate: initialize activity
This commit is contained in:
parent
67d46c453e
commit
503cd31d91
@ -127,7 +127,7 @@ public class GBApplication extends Application {
|
|||||||
private static SharedPreferences sharedPrefs;
|
private static SharedPreferences sharedPrefs;
|
||||||
private static final String PREFS_VERSION = "shared_preferences_version";
|
private static final String PREFS_VERSION = "shared_preferences_version";
|
||||||
//if preferences have to be migrated, increment the following and add the migration logic in migratePrefs below; see http://stackoverflow.com/questions/16397848/how-can-i-migrate-android-preferences-with-a-new-version
|
//if preferences have to be migrated, increment the following and add the migration logic in migratePrefs below; see http://stackoverflow.com/questions/16397848/how-can-i-migrate-android-preferences-with-a-new-version
|
||||||
private static final int CURRENT_PREFS_VERSION = 38;
|
private static final int CURRENT_PREFS_VERSION = 39;
|
||||||
|
|
||||||
private static final LimitedQueue<Integer, String> mIDSenderLookup = new LimitedQueue<>(16);
|
private static final LimitedQueue<Integer, String> mIDSenderLookup = new LimitedQueue<>(16);
|
||||||
private static GBPrefs prefs;
|
private static GBPrefs prefs;
|
||||||
@ -1761,6 +1761,38 @@ public class GBApplication extends Application {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (oldVersion < 39) {
|
||||||
|
// Add the new Heart Rate tab to all devices
|
||||||
|
try (DBHandler db = acquireDB()) {
|
||||||
|
final DaoSession daoSession = db.getDaoSession();
|
||||||
|
final List<Device> activeDevices = DBHelper.getActiveDevices(daoSession);
|
||||||
|
|
||||||
|
for (final Device dbDevice : activeDevices) {
|
||||||
|
final SharedPreferences deviceSharedPrefs = GBApplication.getDeviceSpecificSharedPrefs(dbDevice.getIdentifier());
|
||||||
|
|
||||||
|
final String chartsTabsValue = deviceSharedPrefs.getString("charts_tabs", null);
|
||||||
|
if (chartsTabsValue == null) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
String newPrefValue = chartsTabsValue;
|
||||||
|
if (!StringUtils.isBlank(chartsTabsValue)) {
|
||||||
|
if (!chartsTabsValue.contains("heartrate")) {
|
||||||
|
newPrefValue = newPrefValue + ",heartrate";
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
newPrefValue = "heartrate";
|
||||||
|
}
|
||||||
|
|
||||||
|
final SharedPreferences.Editor deviceSharedPrefsEdit = deviceSharedPrefs.edit();
|
||||||
|
deviceSharedPrefsEdit.putString("charts_tabs", newPrefValue);
|
||||||
|
deviceSharedPrefsEdit.apply();
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
Log.e(TAG, "Failed to migrate prefs to version 39", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
editor.putString(PREFS_VERSION, Integer.toString(CURRENT_PREFS_VERSION));
|
editor.putString(PREFS_VERSION, Integer.toString(CURRENT_PREFS_VERSION));
|
||||||
editor.apply();
|
editor.apply();
|
||||||
}
|
}
|
||||||
|
@ -124,6 +124,9 @@ public class ActivityChartsActivity extends AbstractChartsActivity {
|
|||||||
if (!coordinator.supportsHrvMeasurement()) {
|
if (!coordinator.supportsHrvMeasurement()) {
|
||||||
tabList.remove("hrvstatus");
|
tabList.remove("hrvstatus");
|
||||||
}
|
}
|
||||||
|
if (!coordinator.supportsHeartRateMeasurement(device)) {
|
||||||
|
tabList.remove("heartrate");
|
||||||
|
}
|
||||||
if (!coordinator.supportsBodyEnergy()) {
|
if (!coordinator.supportsBodyEnergy()) {
|
||||||
tabList.remove("bodyenergy");
|
tabList.remove("bodyenergy");
|
||||||
}
|
}
|
||||||
@ -155,6 +158,8 @@ public class ActivityChartsActivity extends AbstractChartsActivity {
|
|||||||
return new ActivityListingChartFragment();
|
return new ActivityListingChartFragment();
|
||||||
case "sleep":
|
case "sleep":
|
||||||
return SleepCollectionFragment.newInstance(enabledTabsList.size() == 1);
|
return SleepCollectionFragment.newInstance(enabledTabsList.size() == 1);
|
||||||
|
case "heartrate":
|
||||||
|
return new HeartRateDailyFragment();
|
||||||
case "hrvstatus":
|
case "hrvstatus":
|
||||||
return new HRVStatusFragment();
|
return new HRVStatusFragment();
|
||||||
case "bodyenergy":
|
case "bodyenergy":
|
||||||
@ -196,6 +201,8 @@ public class ActivityChartsActivity extends AbstractChartsActivity {
|
|||||||
return getString(R.string.charts_activity_list);
|
return getString(R.string.charts_activity_list);
|
||||||
case "sleep":
|
case "sleep":
|
||||||
return getString(R.string.sleepchart_your_sleep);
|
return getString(R.string.sleepchart_your_sleep);
|
||||||
|
case "heartrate":
|
||||||
|
return getString(R.string.menuitem_hr);
|
||||||
case "hrvstatus":
|
case "hrvstatus":
|
||||||
return getString(R.string.pref_header_hrv_status);
|
return getString(R.string.pref_header_hrv_status);
|
||||||
case "bodyenergy":
|
case "bodyenergy":
|
||||||
|
@ -0,0 +1,260 @@
|
|||||||
|
package nodomain.freeyourgadget.gadgetbridge.activities.charts;
|
||||||
|
|
||||||
|
import android.os.Build;
|
||||||
|
import android.os.Bundle;
|
||||||
|
import android.view.LayoutInflater;
|
||||||
|
import android.view.View;
|
||||||
|
import android.view.ViewGroup;
|
||||||
|
import android.widget.LinearLayout;
|
||||||
|
import android.widget.TextView;
|
||||||
|
|
||||||
|
import androidx.core.content.ContextCompat;
|
||||||
|
|
||||||
|
import com.github.mikephil.charting.charts.Chart;
|
||||||
|
import com.github.mikephil.charting.charts.LineChart;
|
||||||
|
import com.github.mikephil.charting.components.Legend;
|
||||||
|
import com.github.mikephil.charting.components.LegendEntry;
|
||||||
|
import com.github.mikephil.charting.components.XAxis;
|
||||||
|
import com.github.mikephil.charting.components.YAxis;
|
||||||
|
import com.github.mikephil.charting.data.Entry;
|
||||||
|
import com.github.mikephil.charting.data.LineData;
|
||||||
|
import com.github.mikephil.charting.data.LineDataSet;
|
||||||
|
|
||||||
|
import java.text.SimpleDateFormat;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Calendar;
|
||||||
|
import java.util.Date;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import nodomain.freeyourgadget.gadgetbridge.GBApplication;
|
||||||
|
import nodomain.freeyourgadget.gadgetbridge.R;
|
||||||
|
import nodomain.freeyourgadget.gadgetbridge.activities.HeartRateUtils;
|
||||||
|
import nodomain.freeyourgadget.gadgetbridge.database.DBHandler;
|
||||||
|
import nodomain.freeyourgadget.gadgetbridge.devices.DeviceCoordinator;
|
||||||
|
import nodomain.freeyourgadget.gadgetbridge.devices.SampleProvider;
|
||||||
|
import nodomain.freeyourgadget.gadgetbridge.entities.AbstractActivitySample;
|
||||||
|
import nodomain.freeyourgadget.gadgetbridge.impl.GBDevice;
|
||||||
|
import nodomain.freeyourgadget.gadgetbridge.model.ActivityKind;
|
||||||
|
import nodomain.freeyourgadget.gadgetbridge.model.ActivitySample;
|
||||||
|
import nodomain.freeyourgadget.gadgetbridge.util.Prefs;
|
||||||
|
|
||||||
|
public class HeartRateDailyFragment extends AbstractChartFragment<HeartRateDailyFragment.HeartRateData> {
|
||||||
|
|
||||||
|
protected int HEARTRATE_COLOR;
|
||||||
|
protected int CHART_TEXT_COLOR;
|
||||||
|
protected int BACKGROUND_COLOR;
|
||||||
|
protected int DESCRIPTION_COLOR;
|
||||||
|
protected int LEGEND_TEXT_COLOR;
|
||||||
|
|
||||||
|
private TextView mDateView;
|
||||||
|
private TextView hrResting;
|
||||||
|
private TextView hrAverage;
|
||||||
|
private TextView hrMinimum;
|
||||||
|
private TextView hrMaximum;
|
||||||
|
private LinearLayout heartRateRestingWrapper;
|
||||||
|
private LineChart hrLineChart;
|
||||||
|
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
|
||||||
|
View rootView = inflater.inflate(R.layout.fragment_heart_rate, container, false);
|
||||||
|
|
||||||
|
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
|
||||||
|
rootView.setOnScrollChangeListener((v, scrollX, scrollY, oldScrollX, oldScrollY) -> {
|
||||||
|
getChartsHost().enableSwipeRefresh(scrollY == 0);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
mDateView = rootView.findViewById(R.id.hr_date_view);
|
||||||
|
hrLineChart = rootView.findViewById(R.id.heart_rate_line_chart);
|
||||||
|
hrResting = rootView.findViewById(R.id.hr_resting);
|
||||||
|
hrAverage = rootView.findViewById(R.id.hr_average);
|
||||||
|
hrMinimum = rootView.findViewById(R.id.hr_minimum);
|
||||||
|
hrMaximum = rootView.findViewById(R.id.hr_maximum);
|
||||||
|
heartRateRestingWrapper = rootView.findViewById(R.id.hr_resting_wrapper);
|
||||||
|
|
||||||
|
setupChart();
|
||||||
|
refresh();
|
||||||
|
setupLegend(hrLineChart);
|
||||||
|
|
||||||
|
if (!supportHeartRateRestingMeasurement()) {
|
||||||
|
heartRateRestingWrapper.setVisibility(View.GONE);
|
||||||
|
}
|
||||||
|
|
||||||
|
return rootView;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean supportHeartRateRestingMeasurement() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected List<? extends AbstractActivitySample> getActivitySamples(DBHandler db, GBDevice device, int tsFrom, int tsTo) {
|
||||||
|
SampleProvider<? extends ActivitySample> provider = device.getDeviceCoordinator().getSampleProvider(device, db.getDaoSession());
|
||||||
|
return provider.getAllActivitySamples(tsFrom, tsTo);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getTitle() {
|
||||||
|
return getString(R.string.heart_rate);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void init() {
|
||||||
|
Prefs prefs = GBApplication.getPrefs();
|
||||||
|
CHART_TEXT_COLOR = GBApplication.getSecondaryTextColor(getContext());
|
||||||
|
DESCRIPTION_COLOR = LEGEND_TEXT_COLOR = GBApplication.getTextColor(getContext());
|
||||||
|
if (prefs.getBoolean("chart_heartrate_color", false)) {
|
||||||
|
HEARTRATE_COLOR = ContextCompat.getColor(getContext(), R.color.chart_heartrate_alternative);
|
||||||
|
}else{
|
||||||
|
HEARTRATE_COLOR = ContextCompat.getColor(getContext(), R.color.chart_heartrate);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected HeartRateDailyFragment.HeartRateData refreshInBackground(ChartsHost chartsHost, DBHandler db, GBDevice device) {
|
||||||
|
Calendar day = Calendar.getInstance();
|
||||||
|
day.setTime(chartsHost.getEndDate());
|
||||||
|
day.add(Calendar.DATE, 0);
|
||||||
|
day.set(Calendar.HOUR_OF_DAY, 0);
|
||||||
|
day.set(Calendar.MINUTE, 0);
|
||||||
|
day.set(Calendar.SECOND, 0);
|
||||||
|
day.add(Calendar.HOUR, 0);
|
||||||
|
int startTs = (int) (day.getTimeInMillis() / 1000);
|
||||||
|
int endTs = startTs + 24 * 60 * 60 - 1;
|
||||||
|
Date date = new Date((long) endTs * 1000);
|
||||||
|
String formattedDate = new SimpleDateFormat("E, MMM dd").format(date);
|
||||||
|
mDateView.setText(formattedDate);
|
||||||
|
List<? extends ActivitySample> samples = getActivitySamples(db, device, startTs, endTs);
|
||||||
|
return new HeartRateData(samples);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void renderCharts() {
|
||||||
|
hrLineChart.invalidate();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void setupChart() {
|
||||||
|
hrLineChart.setBackgroundColor(BACKGROUND_COLOR);
|
||||||
|
hrLineChart.getDescription().setTextColor(DESCRIPTION_COLOR);
|
||||||
|
hrLineChart.getDescription().setEnabled(false);
|
||||||
|
|
||||||
|
|
||||||
|
XAxis x = hrLineChart.getXAxis();
|
||||||
|
x.setDrawLabels(true);
|
||||||
|
x.setDrawGridLines(false);
|
||||||
|
x.setEnabled(true);
|
||||||
|
x.setTextColor(CHART_TEXT_COLOR);
|
||||||
|
x.setDrawLimitLinesBehindData(true);
|
||||||
|
x.setPosition(XAxis.XAxisPosition.BOTTOM);
|
||||||
|
x.setAxisMinimum(0f);
|
||||||
|
x.setAxisMaximum(86400f);
|
||||||
|
|
||||||
|
YAxis y = hrLineChart.getAxisLeft();
|
||||||
|
y.setDrawGridLines(false);
|
||||||
|
y.setDrawTopYLabelEntry(true);
|
||||||
|
y.setTextColor(CHART_TEXT_COLOR);
|
||||||
|
y.setEnabled(true);
|
||||||
|
y.setAxisMaximum(HeartRateUtils.getInstance().getMaxHeartRate());
|
||||||
|
y.setAxisMinimum(HeartRateUtils.getInstance().getMinHeartRate());
|
||||||
|
|
||||||
|
YAxis yAxisRight = hrLineChart.getAxisRight();
|
||||||
|
yAxisRight.setDrawGridLines(false);
|
||||||
|
yAxisRight.setDrawLabels(true);
|
||||||
|
yAxisRight.setDrawTopYLabelEntry(true);
|
||||||
|
yAxisRight.setTextColor(CHART_TEXT_COLOR);
|
||||||
|
yAxisRight.setAxisMaximum(HeartRateUtils.getInstance().getMaxHeartRate());
|
||||||
|
yAxisRight.setAxisMinimum(HeartRateUtils.getInstance().getMinHeartRate());
|
||||||
|
|
||||||
|
refresh();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void setupLegend(Chart<?> chart) {
|
||||||
|
List<LegendEntry> legendEntries = new ArrayList<>(1);
|
||||||
|
LegendEntry hrEntry = new LegendEntry();
|
||||||
|
hrEntry.label = getTitle();
|
||||||
|
hrEntry.formColor = HEARTRATE_COLOR;
|
||||||
|
legendEntries.add(hrEntry);
|
||||||
|
chart.getLegend().setCustom(legendEntries);
|
||||||
|
chart.getLegend().setTextColor(LEGEND_TEXT_COLOR);
|
||||||
|
chart.getLegend().setWordWrapEnabled(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void updateChartsnUIThread(HeartRateDailyFragment.HeartRateData data) {
|
||||||
|
HeartRateUtils heartRateUtilsInstance = HeartRateUtils.getInstance();
|
||||||
|
final TimestampTranslation tsTranslation = new TimestampTranslation();
|
||||||
|
final List<Entry> lineEntries = new ArrayList<>();
|
||||||
|
List<? extends ActivitySample> samples = data.samples;
|
||||||
|
int average = 0;
|
||||||
|
int resting = 0;
|
||||||
|
int minimum = 0;
|
||||||
|
int maximum = 0;
|
||||||
|
int sum = 0;
|
||||||
|
int n = 0;
|
||||||
|
int lastHrSampleIndex = -1;
|
||||||
|
for (int i =0; i < samples.size(); i++) {
|
||||||
|
ActivitySample sample = samples.get(i);
|
||||||
|
int ts = tsTranslation.shorten(sample.getTimestamp());
|
||||||
|
if (sample.getKind() != ActivityKind.NOT_WORN && heartRateUtilsInstance.isValidHeartRateValue(sample.getHeartRate())) {
|
||||||
|
if (lastHrSampleIndex > -1 && ts - lastHrSampleIndex > 1800 * HeartRateUtils.MAX_HR_MEASUREMENTS_GAP_MINUTES) {
|
||||||
|
lineEntries.add(new Entry(lastHrSampleIndex + 1, 0 ));
|
||||||
|
lineEntries.add(new Entry(ts - 1, 0));
|
||||||
|
}
|
||||||
|
lineEntries.add(new Entry(ts, sample.getHeartRate()));
|
||||||
|
lastHrSampleIndex = ts;
|
||||||
|
}
|
||||||
|
if (sample.getHeartRate() <= 0) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
n++;
|
||||||
|
sum += sample.getHeartRate();
|
||||||
|
if (sample.getHeartRate() > maximum) {
|
||||||
|
maximum = sample.getHeartRate();
|
||||||
|
}
|
||||||
|
if (minimum == 0 || sample.getHeartRate() < minimum) {
|
||||||
|
minimum = sample.getHeartRate();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
LineDataSet dataSet = new LineDataSet(lineEntries, "Heart Rate");
|
||||||
|
dataSet.setLineWidth(1.5f);
|
||||||
|
dataSet.setMode(LineDataSet.Mode.HORIZONTAL_BEZIER);
|
||||||
|
dataSet.setCubicIntensity(0.1f);
|
||||||
|
dataSet.setDrawCircles(false);
|
||||||
|
dataSet.setDrawValues(true);
|
||||||
|
dataSet.setAxisDependency(YAxis.AxisDependency.RIGHT);
|
||||||
|
dataSet.setColor(HEARTRATE_COLOR);
|
||||||
|
dataSet.setValueTextColor(CHART_TEXT_COLOR);
|
||||||
|
|
||||||
|
if (n > 0 && sum > 0) {
|
||||||
|
average = sum / n;
|
||||||
|
}
|
||||||
|
|
||||||
|
hrAverage.setText(average > 0 ? getString(R.string.bpm_value_unit, average) : "-");
|
||||||
|
hrMinimum.setText(minimum > 0 ? getString(R.string.bpm_value_unit, minimum) : "-");
|
||||||
|
hrMaximum.setText(maximum > 0 ? getString(R.string.bpm_value_unit, maximum) : "-");
|
||||||
|
hrResting.setText(resting > 0 ? getString(R.string.bpm_value_unit, resting) : "-");
|
||||||
|
|
||||||
|
|
||||||
|
if (minimum > 0) {
|
||||||
|
hrLineChart.getAxisLeft().setAxisMinimum(Math.max(minimum - 30, 0));
|
||||||
|
hrLineChart.getAxisRight().setAxisMinimum(Math.max(minimum - 30, 0));
|
||||||
|
}
|
||||||
|
if (maximum > 0) {
|
||||||
|
hrLineChart.getAxisLeft().setAxisMaximum(maximum + 30);
|
||||||
|
hrLineChart.getAxisRight().setAxisMaximum(maximum + 30);
|
||||||
|
}
|
||||||
|
|
||||||
|
hrLineChart.getXAxis().setValueFormatter(new SampleXLabelFormatter(tsTranslation));
|
||||||
|
hrLineChart.setData(new LineData(dataSet));
|
||||||
|
}
|
||||||
|
|
||||||
|
protected static class HeartRateData extends ChartsData {
|
||||||
|
public List<? extends ActivitySample> samples;
|
||||||
|
|
||||||
|
protected HeartRateData(List<? extends ActivitySample> samples) {
|
||||||
|
this.samples = samples;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
189
app/src/main/res/layout/fragment_heart_rate.xml
Normal file
189
app/src/main/res/layout/fragment_heart_rate.xml
Normal file
@ -0,0 +1,189 @@
|
|||||||
|
<ScrollView xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
xmlns:app="http://schemas.android.com/apk/res-auto"
|
||||||
|
xmlns:tools="http://schemas.android.com/tools"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent">
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:orientation="vertical">
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/hr_date_view"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginTop="15dp"
|
||||||
|
android:layout_marginBottom="20dp"
|
||||||
|
android:gravity="center"
|
||||||
|
android:textSize="20sp" />
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="300sp">
|
||||||
|
|
||||||
|
<com.github.mikephil.charting.charts.LineChart
|
||||||
|
android:id="@+id/heart_rate_line_chart"
|
||||||
|
android:layout_width="fill_parent"
|
||||||
|
android:layout_height="fill_parent"
|
||||||
|
android:layout_weight="2" />
|
||||||
|
</LinearLayout>
|
||||||
|
|
||||||
|
<TableLayout
|
||||||
|
android:layout_width="fill_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginTop="5dp"
|
||||||
|
android:layout_marginBottom="30dp"
|
||||||
|
android:layout_weight="3"
|
||||||
|
android:shrinkColumns="*"
|
||||||
|
android:stretchColumns="*">
|
||||||
|
|
||||||
|
<TableRow
|
||||||
|
android:layout_width="fill_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:weightSum="2">
|
||||||
|
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="0dp"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_weight="1"
|
||||||
|
android:orientation="vertical"
|
||||||
|
android:paddingLeft="20dip"
|
||||||
|
android:paddingTop="20dip"
|
||||||
|
android:paddingRight="20dip">
|
||||||
|
|
||||||
|
<View
|
||||||
|
android:layout_width="fill_parent"
|
||||||
|
android:layout_height="5px"
|
||||||
|
android:background="@color/value_line_color" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/hr_minimum"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_gravity="left"
|
||||||
|
android:layout_marginTop="20dip"
|
||||||
|
android:text="0"
|
||||||
|
android:textSize="20sp" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_gravity="left"
|
||||||
|
android:text="@string/hr_minimum"
|
||||||
|
android:textSize="12sp" />
|
||||||
|
</LinearLayout>
|
||||||
|
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="0dp"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_weight="1"
|
||||||
|
android:orientation="vertical"
|
||||||
|
android:paddingLeft="20dip"
|
||||||
|
android:paddingTop="20dip"
|
||||||
|
android:paddingRight="20dip">
|
||||||
|
|
||||||
|
<View
|
||||||
|
android:layout_width="fill_parent"
|
||||||
|
android:layout_height="5px"
|
||||||
|
android:background="@color/value_line_color" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/hr_maximum"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_gravity="left"
|
||||||
|
android:layout_marginTop="20dip"
|
||||||
|
android:text="0"
|
||||||
|
android:textSize="20sp" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_gravity="left"
|
||||||
|
android:text="@string/hr_maximum"
|
||||||
|
android:textSize="12sp" />
|
||||||
|
</LinearLayout>
|
||||||
|
</TableRow>
|
||||||
|
|
||||||
|
<TableRow
|
||||||
|
android:layout_width="fill_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:weightSum="2">
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="0dp"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_weight="1"
|
||||||
|
android:orientation="vertical"
|
||||||
|
android:paddingLeft="20dip"
|
||||||
|
android:paddingTop="20dip"
|
||||||
|
android:paddingRight="20dip">
|
||||||
|
|
||||||
|
<View
|
||||||
|
android:layout_width="fill_parent"
|
||||||
|
android:layout_height="5px"
|
||||||
|
android:background="@color/value_line_color" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/hr_average"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_gravity="left"
|
||||||
|
android:layout_marginTop="20dip"
|
||||||
|
android:text="0"
|
||||||
|
android:textSize="20sp" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_gravity="left"
|
||||||
|
android:text="@string/hr_average"
|
||||||
|
android:textSize="12sp" />
|
||||||
|
</LinearLayout>
|
||||||
|
<LinearLayout
|
||||||
|
android:id="@+id/hr_resting_wrapper"
|
||||||
|
android:layout_width="0dp"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_weight="1"
|
||||||
|
android:orientation="vertical"
|
||||||
|
android:paddingLeft="20dip"
|
||||||
|
android:paddingTop="20dip"
|
||||||
|
android:paddingRight="20dip">
|
||||||
|
|
||||||
|
<View
|
||||||
|
android:layout_width="fill_parent"
|
||||||
|
android:layout_height="5px"
|
||||||
|
android:background="@color/value_line_color" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/hr_resting"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_gravity="left"
|
||||||
|
android:layout_marginTop="20dip"
|
||||||
|
android:text="0"
|
||||||
|
android:textSize="20sp" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_gravity="left"
|
||||||
|
android:text="@string/hr_resting"
|
||||||
|
android:textSize="12sp" />
|
||||||
|
</LinearLayout>
|
||||||
|
</TableRow>
|
||||||
|
</TableLayout>
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/steps_chart_title"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_gravity="left"
|
||||||
|
android:paddingLeft="20dip"
|
||||||
|
android:text=""
|
||||||
|
android:textSize="20sp" />
|
||||||
|
</LinearLayout>
|
||||||
|
|
||||||
|
</ScrollView>
|
@ -923,6 +923,10 @@
|
|||||||
<string name="distance">Distance</string>
|
<string name="distance">Distance</string>
|
||||||
<string name="clock">Clock</string>
|
<string name="clock">Clock</string>
|
||||||
<string name="heart_rate">Heart rate</string>
|
<string name="heart_rate">Heart rate</string>
|
||||||
|
<string name="hr_resting">Resting</string>
|
||||||
|
<string name="hr_maximum">Maximum</string>
|
||||||
|
<string name="hr_minimum">Minimum</string>
|
||||||
|
<string name="hr_average">Average</string>
|
||||||
<string name="blood_pressure">Blood pressure</string>
|
<string name="blood_pressure">Blood pressure</string>
|
||||||
<string name="getting_heart_rate">Measuring</string>
|
<string name="getting_heart_rate">Measuring</string>
|
||||||
<string name="heart_rate_result">Measurement results</string>
|
<string name="heart_rate_result">Measurement results</string>
|
||||||
@ -1619,6 +1623,7 @@
|
|||||||
<string name="hrv_status_unit">%1$d ms</string>
|
<string name="hrv_status_unit">%1$d ms</string>
|
||||||
<string name="hrv_status_baseline">%1$d-%2$d ms</string>
|
<string name="hrv_status_baseline">%1$d-%2$d ms</string>
|
||||||
<string name="hrv_status_baseline_label">Baseline</string>
|
<string name="hrv_status_baseline_label">Baseline</string>
|
||||||
|
<string name="bpm_value_unit">%1$d bpm</string>
|
||||||
<string name="steps_distance_unit">%1$,.2f km</string>
|
<string name="steps_distance_unit">%1$,.2f km</string>
|
||||||
<string name="body_energy_gained">Gained</string>
|
<string name="body_energy_gained">Gained</string>
|
||||||
<string name="body_energy_lost">Lost</string>
|
<string name="body_energy_lost">Lost</string>
|
||||||
|
Loading…
Reference in New Issue
Block a user