mirror of
https://codeberg.org/Freeyourgadget/Gadgetbridge
synced 2025-02-18 05:17:08 +01:00
Xiaomi: Fix SpO2
This commit is contained in:
parent
11ccf86056
commit
e53c67e8bf
@ -41,6 +41,7 @@ public abstract class AbstractSampleToTimeSampleProvider<T extends TimeSample, S
|
|||||||
mSession = session;
|
mSession = session;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Nullable
|
||||||
protected abstract T convertSample(final S sample);
|
protected abstract T convertSample(final S sample);
|
||||||
|
|
||||||
public GBDevice getDevice() {
|
public GBDevice getDevice() {
|
||||||
@ -57,7 +58,10 @@ public abstract class AbstractSampleToTimeSampleProvider<T extends TimeSample, S
|
|||||||
final List<S> upstreamSamples = mSampleProvider.getAllActivitySamples((int) (timestampFrom / 1000L), (int) (timestampTo / 1000L));
|
final List<S> upstreamSamples = mSampleProvider.getAllActivitySamples((int) (timestampFrom / 1000L), (int) (timestampTo / 1000L));
|
||||||
final List<T> ret = new ArrayList<>();
|
final List<T> ret = new ArrayList<>();
|
||||||
for (final S sample : upstreamSamples) {
|
for (final S sample : upstreamSamples) {
|
||||||
ret.add(convertSample(sample));
|
final T converted = convertSample(sample);
|
||||||
|
if (converted != null) {
|
||||||
|
ret.add(converted);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
@ -76,8 +76,7 @@ public abstract class XiaomiCoordinator extends AbstractBLEDeviceCoordinator {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public TimeSampleProvider<? extends Spo2Sample> getSpo2SampleProvider(final GBDevice device, final DaoSession session) {
|
public TimeSampleProvider<? extends Spo2Sample> getSpo2SampleProvider(final GBDevice device, final DaoSession session) {
|
||||||
// TODO XiaomiSpo2SampleProvider
|
return new XiaomiSpo2SampleProvider(device, session);
|
||||||
return super.getSpo2SampleProvider(device, session);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -156,24 +155,6 @@ public abstract class XiaomiCoordinator extends AbstractBLEDeviceCoordinator {
|
|||||||
return AppManagerActivity.class;
|
return AppManagerActivity.class;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public File getAppCacheDir() throws IOException {
|
|
||||||
// TODO we don't need this
|
|
||||||
return new File(FileUtils.getExternalFilesDir(), "xiaomi-app-cache");
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String getAppCacheSortFilename() {
|
|
||||||
// TODO we don't need this
|
|
||||||
return "xiaomi-app-cache-order.txt";
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String getAppFileExtension() {
|
|
||||||
// TODO we don't need this
|
|
||||||
return ".bin";
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean supportsAppListFetching() {
|
public boolean supportsAppListFetching() {
|
||||||
return true;
|
return true;
|
||||||
@ -217,8 +198,7 @@ public abstract class XiaomiCoordinator extends AbstractBLEDeviceCoordinator {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean supportsSpo2() {
|
public boolean supportsSpo2() {
|
||||||
// TODO it does, but not yet implemented, so let's not crash
|
return true;
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -0,0 +1,66 @@
|
|||||||
|
/* Copyright (C) 2023 José Rebelo
|
||||||
|
|
||||||
|
This file is part of Gadgetbridge.
|
||||||
|
|
||||||
|
Gadgetbridge is free software: you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU Affero General Public License as published
|
||||||
|
by the Free Software Foundation, either version 3 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
Gadgetbridge is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Affero General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Affero General Public License
|
||||||
|
along with this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
|
package nodomain.freeyourgadget.gadgetbridge.devices.xiaomi;
|
||||||
|
|
||||||
|
import nodomain.freeyourgadget.gadgetbridge.devices.AbstractSampleToTimeSampleProvider;
|
||||||
|
import nodomain.freeyourgadget.gadgetbridge.entities.DaoSession;
|
||||||
|
import nodomain.freeyourgadget.gadgetbridge.entities.XiaomiActivitySample;
|
||||||
|
import nodomain.freeyourgadget.gadgetbridge.impl.GBDevice;
|
||||||
|
import nodomain.freeyourgadget.gadgetbridge.model.Spo2Sample;
|
||||||
|
|
||||||
|
public class XiaomiSpo2SampleProvider extends AbstractSampleToTimeSampleProvider<Spo2Sample, XiaomiActivitySample> {
|
||||||
|
public XiaomiSpo2SampleProvider(final GBDevice device, final DaoSession session) {
|
||||||
|
super(new XiaomiSampleProvider(device, session), device, session);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected Spo2Sample convertSample(final XiaomiActivitySample sample) {
|
||||||
|
if (sample.getSpo2() == 0) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
return new XiaomiSpo2Sample(
|
||||||
|
sample.getTimestamp() * 1000L,
|
||||||
|
sample.getSpo2()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected static class XiaomiSpo2Sample implements Spo2Sample {
|
||||||
|
private final long timestamp;
|
||||||
|
private final int spo2;
|
||||||
|
|
||||||
|
public XiaomiSpo2Sample(final long timestamp, final int spo2) {
|
||||||
|
this.timestamp = timestamp;
|
||||||
|
this.spo2 = spo2;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public long getTimestamp() {
|
||||||
|
return timestamp;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Type getType() {
|
||||||
|
return Type.UNKNOWN;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getSpo2() {
|
||||||
|
return spo2;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -20,6 +20,7 @@ public interface Spo2Sample extends TimeSample {
|
|||||||
enum Type {
|
enum Type {
|
||||||
MANUAL(0),
|
MANUAL(0),
|
||||||
AUTOMATIC(1),
|
AUTOMATIC(1),
|
||||||
|
UNKNOWN(2),
|
||||||
;
|
;
|
||||||
|
|
||||||
private final int num;
|
private final int num;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user