Merge branch 'dev' of https://github.com/nightscout/AndroidAPS into dev
This commit is contained in:
commit
f309f8136f
39 changed files with 1575 additions and 443 deletions
|
@ -175,6 +175,10 @@ class WizardDialog : DaggerDialogFragment() {
|
||||||
}
|
}
|
||||||
dismiss()
|
dismiss()
|
||||||
}
|
}
|
||||||
|
binding.bgEnabledIcon.setOnClickListener { binding.bgCheckbox.isChecked = !binding.bgCheckbox.isChecked }
|
||||||
|
binding.trendEnabledIcon.setOnClickListener { binding.bgTrendCheckbox.isChecked = !binding.bgTrendCheckbox.isChecked }
|
||||||
|
binding.cobEnabledIcon.setOnClickListener { binding.cobCheckbox.isChecked = !binding.cobCheckbox.isChecked; processCobCheckBox(); }
|
||||||
|
binding.iobEnabledIcon.setOnClickListener { if (!binding.cobCheckbox.isChecked) binding.iobCheckbox.isChecked = !binding.iobCheckbox.isChecked }
|
||||||
// cancel button
|
// cancel button
|
||||||
binding.cancel.setOnClickListener {
|
binding.cancel.setOnClickListener {
|
||||||
aapsLogger.debug(LTag.APS, "Dialog canceled: ${this.javaClass.name}")
|
aapsLogger.debug(LTag.APS, "Dialog canceled: ${this.javaClass.name}")
|
||||||
|
|
|
@ -81,7 +81,7 @@ allprojects {
|
||||||
// Source: https://issuetracker.google.com/issues/174695268
|
// Source: https://issuetracker.google.com/issues/174695268
|
||||||
configurations.configureEach {
|
configurations.configureEach {
|
||||||
resolutionStrategy {
|
resolutionStrategy {
|
||||||
force 'org.xerial:sqlite-jdbc:3.34.0'
|
force 'org.xerial:sqlite-jdbc:3.36.0.3'
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -759,6 +759,7 @@ class MedtronicHistoryData @Inject constructor(
|
||||||
}
|
}
|
||||||
|
|
||||||
var previousItem: TempBasalProcessDTO? = null
|
var previousItem: TempBasalProcessDTO? = null
|
||||||
|
val removalList : MutableList<TempBasalProcessDTO> = arrayListOf()
|
||||||
|
|
||||||
// fix for Zero TBRs
|
// fix for Zero TBRs
|
||||||
for (tempBasalProcessDTO in processList) {
|
for (tempBasalProcessDTO in processList) {
|
||||||
|
@ -768,8 +769,18 @@ class MedtronicHistoryData @Inject constructor(
|
||||||
pheEnd.atechDateTime = DateTimeUtil.getATDWithAddedSeconds(tempBasalProcessDTO.itemOne.atechDateTime, -2)
|
pheEnd.atechDateTime = DateTimeUtil.getATDWithAddedSeconds(tempBasalProcessDTO.itemOne.atechDateTime, -2)
|
||||||
pheEnd.addDecodedData("Object", TempBasalPair(0.0, false, 0))
|
pheEnd.addDecodedData("Object", TempBasalPair(0.0, false, 0))
|
||||||
|
|
||||||
|
val initialDuration = previousItem.durationAsSeconds
|
||||||
|
|
||||||
previousItem.itemTwo = pheEnd
|
previousItem.itemTwo = pheEnd
|
||||||
|
|
||||||
|
if (previousItem.durationAsSeconds <=0) {
|
||||||
|
// if we have duration of 0 or less, then we have invalid entry which needs to be removed
|
||||||
|
removalList.add(previousItem)
|
||||||
|
} else if (previousItem.durationAsSeconds > initialDuration) {
|
||||||
|
// if duration with last item is longer than planned TBR duration we remove previous item and leave original duration
|
||||||
|
previousItem.itemTwo = null
|
||||||
|
}
|
||||||
|
|
||||||
previousItem = null
|
previousItem = null
|
||||||
}
|
}
|
||||||
if (tempBasalProcessDTO.itemOneTbr!!.isZeroTBR) {
|
if (tempBasalProcessDTO.itemOneTbr!!.isZeroTBR) {
|
||||||
|
@ -777,6 +788,13 @@ class MedtronicHistoryData @Inject constructor(
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// removing previously tagged item
|
||||||
|
if (removalList.isNotEmpty()) {
|
||||||
|
for (tempBasalProcessDTO in removalList) {
|
||||||
|
processList.remove(tempBasalProcessDTO)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return processList
|
return processList
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -12,7 +12,11 @@ class TempBasalProcessDTO constructor(var itemOne: PumpHistoryEntry,
|
||||||
set(value) {
|
set(value) {
|
||||||
field = value
|
field = value
|
||||||
if (objectType == ObjectType.TemporaryBasal) {
|
if (objectType == ObjectType.TemporaryBasal) {
|
||||||
itemTwoTbr = value!!.getDecodedDataEntry("Object") as TempBasalPair
|
if (value!=null) {
|
||||||
|
itemTwoTbr = value.getDecodedDataEntry("Object") as TempBasalPair
|
||||||
|
} else {
|
||||||
|
itemTwoTbr = null
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -86,4 +86,47 @@ class MedtronicHistoryDataUTest : TestBase() {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun createTBRProcessList_SpecialCase() {
|
||||||
|
|
||||||
|
var unitToTest = MedtronicHistoryData(packetInjector, aapsLogger, sp, rh, rxBus, activePlugin,
|
||||||
|
medtronicUtil, medtronicPumpHistoryDecoder,
|
||||||
|
medtronicPumpStatus,
|
||||||
|
pumpSync,
|
||||||
|
pumpSyncStorage)
|
||||||
|
|
||||||
|
|
||||||
|
val gson = Gson()
|
||||||
|
|
||||||
|
val fileText = ClassLoader.getSystemResource("tbr_data_special.json").readText()
|
||||||
|
|
||||||
|
val listType: Type = object : TypeToken<MutableList<PumpHistoryEntry?>?>() {}.getType()
|
||||||
|
val yourClassList: MutableList<PumpHistoryEntry> = gson.fromJson(fileText, listType)
|
||||||
|
|
||||||
|
for (pumpHistoryEntry in yourClassList) {
|
||||||
|
val stringObject = pumpHistoryEntry.decodedData["Object"] as LinkedTreeMap<String,Object>
|
||||||
|
|
||||||
|
val rate : Double = stringObject.get("insulinRate") as Double
|
||||||
|
val durationMinutes: Double = stringObject.get("durationMinutes") as Double
|
||||||
|
val durationMinutesInt : Int = durationMinutes.toInt()
|
||||||
|
|
||||||
|
var tmbPair = TempBasalPair(rate, false, durationMinutesInt)
|
||||||
|
|
||||||
|
pumpHistoryEntry.decodedData.remove("Object")
|
||||||
|
pumpHistoryEntry.addDecodedData("Object", tmbPair)
|
||||||
|
}
|
||||||
|
|
||||||
|
System.out.println("TBR Pre-Process List (Special): " + gson.toJson(yourClassList))
|
||||||
|
|
||||||
|
val createTBRProcessList = unitToTest.createTBRProcessList(yourClassList)
|
||||||
|
|
||||||
|
System.out.println("TBR Process List (Special): " + createTBRProcessList.size)
|
||||||
|
|
||||||
|
for (tempBasalProcessDTO in createTBRProcessList) {
|
||||||
|
System.out.println(tempBasalProcessDTO.toTreatmentString())
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
1090
medtronic/src/test/resources/tbr_data_special.json
Normal file
1090
medtronic/src/test/resources/tbr_data_special.json
Normal file
File diff suppressed because it is too large
Load diff
|
@ -135,7 +135,7 @@ public class RawDisplayData {
|
||||||
}
|
}
|
||||||
|
|
||||||
private void updateData(DataMap dataMap) {
|
private void updateData(DataMap dataMap) {
|
||||||
wearUtil.getWakeLock("readingPrefs", 50);
|
PowerManager.WakeLock wl = wearUtil.getWakeLock("readingPrefs", 50);
|
||||||
sgvLevel = dataMap.getLong("sgvLevel");
|
sgvLevel = dataMap.getLong("sgvLevel");
|
||||||
datetime = dataMap.getLong("timestamp");
|
datetime = dataMap.getLong("timestamp");
|
||||||
sSgv = dataMap.getString("sgvString");
|
sSgv = dataMap.getString("sgvString");
|
||||||
|
@ -143,6 +143,7 @@ public class RawDisplayData {
|
||||||
sDelta = dataMap.getString("delta");
|
sDelta = dataMap.getString("delta");
|
||||||
sAvgDelta = dataMap.getString("avgDelta");
|
sAvgDelta = dataMap.getString("avgDelta");
|
||||||
sUnits = dataMap.getString("glucoseUnits");
|
sUnits = dataMap.getString("glucoseUnits");
|
||||||
|
wearUtil.releaseWakeLock(wl);
|
||||||
}
|
}
|
||||||
|
|
||||||
public DataMap updateStatusFromMessage(Intent intent, PowerManager.WakeLock wakeLock) {
|
public DataMap updateStatusFromMessage(Intent intent, PowerManager.WakeLock wakeLock) {
|
||||||
|
@ -156,7 +157,7 @@ public class RawDisplayData {
|
||||||
}
|
}
|
||||||
|
|
||||||
private void updateStatus(DataMap dataMap) {
|
private void updateStatus(DataMap dataMap) {
|
||||||
wearUtil.getWakeLock("readingPrefs", 50);
|
PowerManager.WakeLock wl = wearUtil.getWakeLock("readingPrefs", 50);
|
||||||
sBasalRate = dataMap.getString("currentBasal");
|
sBasalRate = dataMap.getString("currentBasal");
|
||||||
sUploaderBattery = dataMap.getString("battery");
|
sUploaderBattery = dataMap.getString("battery");
|
||||||
sRigBattery = dataMap.getString("rigBattery");
|
sRigBattery = dataMap.getString("rigBattery");
|
||||||
|
@ -170,6 +171,7 @@ public class RawDisplayData {
|
||||||
externalStatusString = dataMap.getString("externalStatusString");
|
externalStatusString = dataMap.getString("externalStatusString");
|
||||||
batteryLevel = dataMap.getInt("batteryLevel");
|
batteryLevel = dataMap.getInt("batteryLevel");
|
||||||
openApsStatus = dataMap.getLong("openApsStatus");
|
openApsStatus = dataMap.getLong("openApsStatus");
|
||||||
|
wearUtil.releaseWakeLock(wl);
|
||||||
}
|
}
|
||||||
|
|
||||||
public DataMap updateBasalsFromMessage(Intent intent, PowerManager.WakeLock wakeLock) {
|
public DataMap updateBasalsFromMessage(Intent intent, PowerManager.WakeLock wakeLock) {
|
||||||
|
@ -183,8 +185,9 @@ public class RawDisplayData {
|
||||||
}
|
}
|
||||||
|
|
||||||
private void updateBasals(DataMap dataMap) {
|
private void updateBasals(DataMap dataMap) {
|
||||||
wearUtil.getWakeLock("readingPrefs", 500);
|
PowerManager.WakeLock wl = wearUtil.getWakeLock("readingPrefs", 500);
|
||||||
loadBasalsAndTemps(dataMap);
|
loadBasalsAndTemps(dataMap);
|
||||||
|
wearUtil.releaseWakeLock(wl);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void loadBasalsAndTemps(DataMap dataMap) {
|
private void loadBasalsAndTemps(DataMap dataMap) {
|
||||||
|
|
|
@ -3,19 +3,20 @@ package info.nightscout.androidaps.interaction.utils;
|
||||||
import android.os.Handler;
|
import android.os.Handler;
|
||||||
import android.os.Looper;
|
import android.os.Looper;
|
||||||
import android.os.Message;
|
import android.os.Message;
|
||||||
import android.support.wearable.input.RotaryEncoder;
|
|
||||||
import android.view.KeyEvent;
|
import android.view.KeyEvent;
|
||||||
import android.view.MotionEvent;
|
import android.view.MotionEvent;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.widget.ImageView;
|
import android.widget.ImageView;
|
||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
|
|
||||||
|
import androidx.core.view.InputDeviceCompat;
|
||||||
|
import androidx.core.view.MotionEventCompat;
|
||||||
|
|
||||||
import java.text.NumberFormat;
|
import java.text.NumberFormat;
|
||||||
import java.util.concurrent.Executors;
|
import java.util.concurrent.Executors;
|
||||||
import java.util.concurrent.ScheduledExecutorService;
|
import java.util.concurrent.ScheduledExecutorService;
|
||||||
import java.util.concurrent.TimeUnit;
|
import java.util.concurrent.TimeUnit;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Created by mike on 28.06.2016.
|
* Created by mike on 28.06.2016.
|
||||||
*/
|
*/
|
||||||
|
@ -35,6 +36,12 @@ public class PlusMinusEditText implements View.OnKeyListener,
|
||||||
boolean allowZero = false;
|
boolean allowZero = false;
|
||||||
boolean roundRobin;
|
boolean roundRobin;
|
||||||
|
|
||||||
|
private int mChangeCounter = 0;
|
||||||
|
private long mLastChange = 0;
|
||||||
|
private final static int THRESHOLD_COUNTER = 5;
|
||||||
|
private final static int THRESHOLD_COUNTER_LONG = 10;
|
||||||
|
private final static int THRESHOLD_TIME = 100;
|
||||||
|
|
||||||
private final Handler mHandler;
|
private final Handler mHandler;
|
||||||
private ScheduledExecutorService mUpdater;
|
private ScheduledExecutorService mUpdater;
|
||||||
|
|
||||||
|
@ -121,6 +128,7 @@ public class PlusMinusEditText implements View.OnKeyListener,
|
||||||
public void setStep(Double step) {
|
public void setStep(Double step) {
|
||||||
this.step = step;
|
this.step = step;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void inc(int multiplier) {
|
private void inc(int multiplier) {
|
||||||
value += step * multiplier;
|
value += step * multiplier;
|
||||||
if (value > maxValue) {
|
if (value > maxValue) {
|
||||||
|
@ -211,13 +219,21 @@ public class PlusMinusEditText implements View.OnKeyListener,
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean onGenericMotion(View v, MotionEvent ev) {
|
public boolean onGenericMotion(View v, MotionEvent ev) {
|
||||||
if (ev.getAction() == MotionEvent.ACTION_SCROLL && RotaryEncoder.isFromRotaryEncoder(ev)) {
|
if (ev.getAction() == MotionEvent.ACTION_SCROLL && ev.isFromSource(InputDeviceCompat.SOURCE_ROTARY_ENCODER)) {
|
||||||
float delta = -RotaryEncoder.getRotaryAxisValue(ev);
|
long now = System.currentTimeMillis();
|
||||||
|
if (now - mLastChange > THRESHOLD_TIME) mChangeCounter = 0;
|
||||||
|
|
||||||
|
int dynamicMultiplier = mChangeCounter < THRESHOLD_COUNTER ? 1 :
|
||||||
|
mChangeCounter < THRESHOLD_COUNTER_LONG ? 2 : 4;
|
||||||
|
|
||||||
|
float delta = -ev.getAxisValue(MotionEventCompat.AXIS_SCROLL);
|
||||||
if (delta > 0) {
|
if (delta > 0) {
|
||||||
inc(1);
|
inc(dynamicMultiplier);
|
||||||
} else {
|
} else {
|
||||||
dec(1);
|
dec(dynamicMultiplier);
|
||||||
}
|
}
|
||||||
|
mLastChange = System.currentTimeMillis();
|
||||||
|
mChangeCounter++;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
|
|
|
@ -5,11 +5,13 @@ import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.content.IntentFilter;
|
import android.content.IntentFilter;
|
||||||
import android.content.SharedPreferences;
|
import android.content.SharedPreferences;
|
||||||
|
import android.content.res.Resources;
|
||||||
import android.graphics.Canvas;
|
import android.graphics.Canvas;
|
||||||
import android.graphics.Color;
|
import android.graphics.Color;
|
||||||
import android.graphics.Paint;
|
import android.graphics.Paint;
|
||||||
import android.graphics.Point;
|
import android.graphics.Point;
|
||||||
import android.graphics.Rect;
|
import android.graphics.Rect;
|
||||||
|
import android.graphics.Typeface;
|
||||||
import android.os.BatteryManager;
|
import android.os.BatteryManager;
|
||||||
import android.os.PowerManager;
|
import android.os.PowerManager;
|
||||||
import android.os.Vibrator;
|
import android.os.Vibrator;
|
||||||
|
@ -37,6 +39,7 @@ import com.ustwo.clockwise.wearable.WatchFace;
|
||||||
|
|
||||||
import java.text.SimpleDateFormat;
|
import java.text.SimpleDateFormat;
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
|
import java.util.Locale;
|
||||||
|
|
||||||
import javax.inject.Inject;
|
import javax.inject.Inject;
|
||||||
|
|
||||||
|
@ -70,13 +73,11 @@ public abstract class BaseWatchFace extends WatchFace implements SharedPreferenc
|
||||||
|
|
||||||
public final Point displaySize = new Point();
|
public final Point displaySize = new Point();
|
||||||
public TextView mTime, mHour, mMinute, mTimePeriod, mSgv, mDirection, mTimestamp, mUploaderBattery, mRigBattery, mDelta, mAvgDelta, mStatus, mBasalRate, mIOB1, mIOB2, mCOB1, mCOB2, mBgi, mLoop, mDay, mDayName, mMonth, isAAPSv2, mHighLight, mLowLight;
|
public TextView mTime, mHour, mMinute, mTimePeriod, mSgv, mDirection, mTimestamp, mUploaderBattery, mRigBattery, mDelta, mAvgDelta, mStatus, mBasalRate, mIOB1, mIOB2, mCOB1, mCOB2, mBgi, mLoop, mDay, mDayName, mMonth, isAAPSv2, mHighLight, mLowLight;
|
||||||
public TextView mSimpleSvg, mSimpleDirection, mSimpleTime;
|
|
||||||
public ImageView mGlucoseDial, mDeltaGauge, mHourHand, mMinuteHand;
|
public ImageView mGlucoseDial, mDeltaGauge, mHourHand, mMinuteHand;
|
||||||
public View mSimpleUi;
|
|
||||||
public RelativeLayout mRelativeLayout;
|
public RelativeLayout mRelativeLayout;
|
||||||
public LinearLayout mLinearLayout, mLinearLayout2, mDate, mChartTap, mMainMenuTap;
|
public LinearLayout mLinearLayout, mLinearLayout2, mDate, mChartTap, mMainMenuTap;
|
||||||
public int ageLevel = 1;
|
public int ageLevel = 1;
|
||||||
public int loopLevel = 1;
|
public int loopLevel = -1;
|
||||||
public int highColor = Color.YELLOW;
|
public int highColor = Color.YELLOW;
|
||||||
public int lowColor = Color.RED;
|
public int lowColor = Color.RED;
|
||||||
public int midColor = Color.WHITE;
|
public int midColor = Color.WHITE;
|
||||||
|
@ -96,20 +97,32 @@ public abstract class BaseWatchFace extends WatchFace implements SharedPreferenc
|
||||||
// related endTime manual layout
|
// related endTime manual layout
|
||||||
public View layoutView;
|
public View layoutView;
|
||||||
public int specW, specH;
|
public int specW, specH;
|
||||||
public boolean forceSquareCanvas = false; //set to true by the Steampunk watch face.
|
public boolean forceSquareCanvas = false; // Set to true by the Steampunk watch face.
|
||||||
public String sMinute = "0";
|
public String sMinute = "0";
|
||||||
public String sHour = "0";
|
public String sHour = "0";
|
||||||
protected SharedPreferences sharedPrefs;
|
protected SharedPreferences sharedPrefs;
|
||||||
private LocalBroadcastManager localBroadcastManager;
|
private LocalBroadcastManager localBroadcastManager;
|
||||||
private MessageReceiver messageReceiver;
|
private MessageReceiver messageReceiver;
|
||||||
private BroadcastReceiver batteryReceiver;
|
private BroadcastReceiver batteryReceiver;
|
||||||
protected boolean isCharging = false;
|
private int colorDarkHigh, colorDarkMid, colorDarkLow;
|
||||||
|
private java.text.DateFormat timeFormat;
|
||||||
|
private SimpleDateFormat sdfDay, sdfMonth, sdfHour, sdfPeriod, sdfDayName, sdfMinute;
|
||||||
|
private Paint mBackgroundPaint, mTimePaint, mSvgPaint, mDirectionPaint;
|
||||||
|
private Date mDateTime;
|
||||||
|
private String mLastSvg = "", mLastDirection = "";
|
||||||
|
private float mYOffset = 0;
|
||||||
|
private Intent mBatteryStatus;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onCreate() {
|
public void onCreate() {
|
||||||
// Not derived from DaggerService, do injection here
|
// Not derived from DaggerService, do injection here
|
||||||
AndroidInjection.inject(this);
|
AndroidInjection.inject(this);
|
||||||
super.onCreate();
|
super.onCreate();
|
||||||
|
|
||||||
|
colorDarkHigh = ContextCompat.getColor(getApplicationContext(), R.color.dark_highColor);
|
||||||
|
colorDarkMid = ContextCompat.getColor(getApplicationContext(), R.color.dark_midColor);
|
||||||
|
colorDarkLow = ContextCompat.getColor(getApplicationContext(), R.color.dark_lowColor);
|
||||||
|
|
||||||
rawData = new RawDisplayData(wearUtil);
|
rawData = new RawDisplayData(wearUtil);
|
||||||
Display display = ((WindowManager) getSystemService(Context.WINDOW_SERVICE)).getDefaultDisplay();
|
Display display = ((WindowManager) getSystemService(Context.WINDOW_SERVICE)).getDefaultDisplay();
|
||||||
display.getSize(displaySize);
|
display.getSize(displaySize);
|
||||||
|
@ -127,10 +140,15 @@ public abstract class BaseWatchFace extends WatchFace implements SharedPreferenc
|
||||||
persistence.turnOff();
|
persistence.turnOff();
|
||||||
|
|
||||||
setupBatteryReceiver();
|
setupBatteryReceiver();
|
||||||
|
initFormats();
|
||||||
|
setupSimpleUi();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void setupBatteryReceiver() {
|
private void setupBatteryReceiver() {
|
||||||
if (sharedPrefs.getBoolean("simplify_ui_charging", false) && batteryReceiver == null) {
|
IntentFilter iFilter = new IntentFilter(Intent.ACTION_BATTERY_CHANGED);
|
||||||
|
mBatteryStatus = this.registerReceiver(null, iFilter);
|
||||||
|
String setting = sharedPrefs.getString("simplify_ui", "off");
|
||||||
|
if (setting.equals("charging") || setting.equals("ambient_charging") && batteryReceiver == null) {
|
||||||
IntentFilter intentBatteryFilter = new IntentFilter();
|
IntentFilter intentBatteryFilter = new IntentFilter();
|
||||||
intentBatteryFilter.addAction(BatteryManager.ACTION_CHARGING);
|
intentBatteryFilter.addAction(BatteryManager.ACTION_CHARGING);
|
||||||
intentBatteryFilter.addAction(BatteryManager.ACTION_DISCHARGING);
|
intentBatteryFilter.addAction(BatteryManager.ACTION_DISCHARGING);
|
||||||
|
@ -145,6 +163,48 @@ public abstract class BaseWatchFace extends WatchFace implements SharedPreferenc
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void initFormats() {
|
||||||
|
Locale locale = Locale.getDefault();
|
||||||
|
timeFormat = DateFormat.getTimeFormat(BaseWatchFace.this);
|
||||||
|
sdfMinute = new SimpleDateFormat("mm", locale);
|
||||||
|
sdfHour = DateFormat.is24HourFormat(this) ? new SimpleDateFormat("HH", locale) : new SimpleDateFormat("hh", locale);
|
||||||
|
sdfPeriod = new SimpleDateFormat("a", locale);
|
||||||
|
sdfDay = new SimpleDateFormat("dd", locale);
|
||||||
|
sdfDayName = new SimpleDateFormat("E", locale);
|
||||||
|
sdfMonth = new SimpleDateFormat("MMM", locale);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void setupSimpleUi() {
|
||||||
|
mDateTime = new Date();
|
||||||
|
|
||||||
|
int black = ContextCompat.getColor(getApplicationContext(), R.color.black);
|
||||||
|
mBackgroundPaint = new Paint();
|
||||||
|
mBackgroundPaint.setColor(black);
|
||||||
|
|
||||||
|
final Typeface NORMAL_TYPEFACE = Typeface.create(Typeface.SANS_SERIF, Typeface.NORMAL);
|
||||||
|
final Typeface BOLD_TYPEFACE = Typeface.create(Typeface.SANS_SERIF, Typeface.BOLD);
|
||||||
|
int white = ContextCompat.getColor(getApplicationContext(), R.color.white);
|
||||||
|
|
||||||
|
Resources resources = this.getResources();
|
||||||
|
float textSizeSvg = resources.getDimension(R.dimen.simple_ui_svg_text_size);
|
||||||
|
float textSizeDirection = resources.getDimension(R.dimen.simple_ui_direction_text_size);
|
||||||
|
float textSizeTime = resources.getDimension(R.dimen.simple_ui_time_text_size);
|
||||||
|
mYOffset = resources.getDimension(R.dimen.simple_ui_y_offset);
|
||||||
|
|
||||||
|
mSvgPaint = createTextPaint(NORMAL_TYPEFACE, white, textSizeSvg);
|
||||||
|
mDirectionPaint = createTextPaint(BOLD_TYPEFACE, white, textSizeDirection);
|
||||||
|
mTimePaint = createTextPaint(NORMAL_TYPEFACE, white, textSizeTime);
|
||||||
|
}
|
||||||
|
|
||||||
|
private Paint createTextPaint(Typeface typeface, int colour, float textSize) {
|
||||||
|
Paint paint = new Paint();
|
||||||
|
paint.setColor(colour);
|
||||||
|
paint.setTypeface(typeface);
|
||||||
|
paint.setAntiAlias(true);
|
||||||
|
paint.setTextSize(textSize);
|
||||||
|
return paint;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onLayout(WatchShape shape, Rect screenBounds, WindowInsets screenInsets) {
|
protected void onLayout(WatchShape shape, Rect screenBounds, WindowInsets screenInsets) {
|
||||||
super.onLayout(shape, screenBounds, screenInsets);
|
super.onLayout(shape, screenBounds, screenInsets);
|
||||||
|
@ -153,16 +213,14 @@ public abstract class BaseWatchFace extends WatchFace implements SharedPreferenc
|
||||||
}
|
}
|
||||||
|
|
||||||
public void performViewSetup() {
|
public void performViewSetup() {
|
||||||
final WatchViewStub stub = layoutView.findViewById(R.id.watch_view_stub);
|
final WatchViewStub layoutStub = layoutView.findViewById(R.id.watch_view_stub);
|
||||||
IntentFilter messageFilter = new IntentFilter(Intent.ACTION_SEND);
|
IntentFilter messageFilter = new IntentFilter(Intent.ACTION_SEND);
|
||||||
|
|
||||||
messageReceiver = new MessageReceiver();
|
messageReceiver = new MessageReceiver();
|
||||||
localBroadcastManager = LocalBroadcastManager.getInstance(this);
|
localBroadcastManager = LocalBroadcastManager.getInstance(this);
|
||||||
localBroadcastManager.registerReceiver(messageReceiver, messageFilter);
|
localBroadcastManager.registerReceiver(messageReceiver, messageFilter);
|
||||||
|
|
||||||
stub.setOnLayoutInflatedListener(new WatchViewStub.OnLayoutInflatedListener() {
|
layoutStub.setOnLayoutInflatedListener((WatchViewStub stub) -> {
|
||||||
@Override
|
|
||||||
public void onLayoutInflated(WatchViewStub stub) {
|
|
||||||
mTime = stub.findViewById(R.id.watch_time);
|
mTime = stub.findViewById(R.id.watch_time);
|
||||||
mHour = stub.findViewById(R.id.hour);
|
mHour = stub.findViewById(R.id.hour);
|
||||||
mMinute = stub.findViewById(R.id.minute);
|
mMinute = stub.findViewById(R.id.minute);
|
||||||
|
@ -199,25 +257,19 @@ public abstract class BaseWatchFace extends WatchFace implements SharedPreferenc
|
||||||
mChartTap = stub.findViewById(R.id.chart_zoom_tap);
|
mChartTap = stub.findViewById(R.id.chart_zoom_tap);
|
||||||
mMainMenuTap = stub.findViewById(R.id.main_menu_tap);
|
mMainMenuTap = stub.findViewById(R.id.main_menu_tap);
|
||||||
chart = stub.findViewById(R.id.chart);
|
chart = stub.findViewById(R.id.chart);
|
||||||
mSimpleUi = stub.findViewById(R.id.simple_ui);
|
|
||||||
mSimpleSvg = stub.findViewById(R.id.simple_sgv);
|
|
||||||
mSimpleDirection = stub.findViewById(R.id.simple_direction);
|
|
||||||
mSimpleTime = stub.findViewById(R.id.simple_watch_time);
|
|
||||||
layoutSet = true;
|
layoutSet = true;
|
||||||
|
setupCharts();
|
||||||
setDataFields();
|
setDataFields();
|
||||||
setColor();
|
missedReadingAlert();
|
||||||
}
|
});
|
||||||
}
|
|
||||||
);
|
|
||||||
wakeLock.acquire(50);
|
wakeLock.acquire(50);
|
||||||
}
|
}
|
||||||
|
|
||||||
public int ageLevel() {
|
public int ageLevel() {
|
||||||
if (timeSince() <= (1000 * 60 * 12)) {
|
if (timeSince() <= (1000 * 60 * 12)) {
|
||||||
return 1;
|
return 1;
|
||||||
} else {
|
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
public double timeSince() {
|
public double timeSince() {
|
||||||
|
@ -226,7 +278,7 @@ public abstract class BaseWatchFace extends WatchFace implements SharedPreferenc
|
||||||
|
|
||||||
public String readingAge(boolean shortString) {
|
public String readingAge(boolean shortString) {
|
||||||
if (rawData.datetime == 0) {
|
if (rawData.datetime == 0) {
|
||||||
return shortString ? "--'" : "-- Minute ago";
|
return shortString ? "--" : "-- Minute ago";
|
||||||
}
|
}
|
||||||
int minutesAgo = (int) Math.floor(timeSince() / (1000 * 60));
|
int minutesAgo = (int) Math.floor(timeSince() / (1000 * 60));
|
||||||
if (minutesAgo == 1) {
|
if (minutesAgo == 1) {
|
||||||
|
@ -250,45 +302,79 @@ public abstract class BaseWatchFace extends WatchFace implements SharedPreferenc
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onDraw(Canvas canvas) {
|
protected long getInteractiveModeUpdateRate() {
|
||||||
if (layoutSet) {
|
return 60 * 1000L; // Only call onTimeChanged every 60 seconds
|
||||||
setupCharts();
|
}
|
||||||
|
|
||||||
mRelativeLayout.measure(specW, specH);
|
@Override
|
||||||
if (forceSquareCanvas) {
|
protected void onDraw(Canvas canvas) {
|
||||||
mRelativeLayout.layout(0, 0, displaySize.x, displaySize.x); //force a square for Steampunk watch face.
|
if (isSimpleUi()) {
|
||||||
|
onDrawSimpleUi(canvas);
|
||||||
} else {
|
} else {
|
||||||
mRelativeLayout.layout(0, 0, displaySize.x, displaySize.y);
|
if (layoutSet) {
|
||||||
}
|
mRelativeLayout.measure(specW, specH);
|
||||||
|
int y = forceSquareCanvas ? displaySize.x : displaySize.y; // Square Steampunk
|
||||||
|
mRelativeLayout.layout(0, 0, displaySize.x, y);
|
||||||
mRelativeLayout.draw(canvas);
|
mRelativeLayout.draw(canvas);
|
||||||
Log.d("onDraw", "draw");
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void onDrawSimpleUi(Canvas canvas) {
|
||||||
|
canvas.drawRect(0, 0, displaySize.x, displaySize.y, mBackgroundPaint);
|
||||||
|
float xHalf = displaySize.x / 2f;
|
||||||
|
float yThird = displaySize.y / 3f;
|
||||||
|
|
||||||
|
boolean isOutdated = rawData.datetime > 0 && ageLevel() <= 0;
|
||||||
|
mSvgPaint.setStrikeThruText(isOutdated);
|
||||||
|
|
||||||
|
mSvgPaint.setColor(getBgColour(rawData.sgvLevel));
|
||||||
|
mDirectionPaint.setColor(getBgColour(rawData.sgvLevel));
|
||||||
|
|
||||||
|
String sSvg = rawData.sSgv;
|
||||||
|
float svgWidth = mSvgPaint.measureText(sSvg);
|
||||||
|
|
||||||
|
String sDirection = " " + rawData.sDirection + "\uFE0E";
|
||||||
|
float directionWidth = mDirectionPaint.measureText(sDirection);
|
||||||
|
|
||||||
|
float xSvg = xHalf - (svgWidth + directionWidth) / 2;
|
||||||
|
canvas.drawText(sSvg, xSvg, yThird + mYOffset, mSvgPaint);
|
||||||
|
float xDirection = xSvg + svgWidth;
|
||||||
|
canvas.drawText(sDirection, xDirection, yThird + mYOffset, mDirectionPaint);
|
||||||
|
|
||||||
|
String sTime = timeFormat.format(mDateTime);
|
||||||
|
float xTime = xHalf - mTimePaint.measureText(sTime) / 2f;
|
||||||
|
canvas.drawText(timeFormat.format(mDateTime), xTime, yThird * 2f + mYOffset, mTimePaint);
|
||||||
|
}
|
||||||
|
|
||||||
|
int getBgColour(long level) {
|
||||||
|
if (level == 1) {
|
||||||
|
return colorDarkHigh;
|
||||||
|
}
|
||||||
|
if (level == 0) {
|
||||||
|
return colorDarkMid;
|
||||||
|
}
|
||||||
|
return colorDarkLow;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onTimeChanged(WatchFaceTime oldTime, WatchFaceTime newTime) {
|
protected void onTimeChanged(WatchFaceTime oldTime, WatchFaceTime newTime) {
|
||||||
if (layoutSet && (newTime.hasHourChanged(oldTime) || newTime.hasMinuteChanged(oldTime))) {
|
if (layoutSet && (newTime.hasHourChanged(oldTime) || newTime.hasMinuteChanged(oldTime))) {
|
||||||
wakeLock.acquire(50);
|
long now = System.currentTimeMillis();
|
||||||
|
mDateTime.setTime(now);
|
||||||
|
|
||||||
setDataFields();
|
PowerManager.WakeLock wl = wearUtil.getWakeLock("readingPrefs", 50);
|
||||||
setColor();
|
|
||||||
missedReadingAlert();
|
missedReadingAlert();
|
||||||
checkVibrateHourly(oldTime, newTime);
|
checkVibrateHourly(oldTime, newTime);
|
||||||
|
if (!isSimpleUi()) {
|
||||||
mRelativeLayout.measure(specW, specH);
|
setDataFields();
|
||||||
if (forceSquareCanvas) {
|
|
||||||
mRelativeLayout.layout(0, 0, displaySize.x, displaySize.x); //force a square for Steampunk watch face.
|
|
||||||
} else {
|
|
||||||
mRelativeLayout.layout(0, 0, displaySize.x, displaySize.y);
|
|
||||||
}
|
}
|
||||||
invalidate();
|
wearUtil.releaseWakeLock(wl);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean isCharging() {
|
private boolean isCharging() {
|
||||||
IntentFilter iFilter = new IntentFilter(Intent.ACTION_BATTERY_CHANGED);
|
int status = mBatteryStatus.getIntExtra(BatteryManager.EXTRA_STATUS, -1);
|
||||||
Intent batteryStatus = this.registerReceiver(null, iFilter);
|
|
||||||
int status = batteryStatus.getIntExtra(BatteryManager.EXTRA_STATUS, -1);
|
|
||||||
return status == BatteryManager.BATTERY_STATUS_CHARGING ||
|
return status == BatteryManager.BATTERY_STATUS_CHARGING ||
|
||||||
status == BatteryManager.BATTERY_STATUS_FULL;
|
status == BatteryManager.BATTERY_STATUS_FULL;
|
||||||
}
|
}
|
||||||
|
@ -304,15 +390,13 @@ public abstract class BaseWatchFace extends WatchFace implements SharedPreferenc
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setDataFields() {
|
public void setDataFields() {
|
||||||
|
|
||||||
setDateAndTime();
|
setDateAndTime();
|
||||||
|
|
||||||
if (mSgv != null) {
|
if (mSgv != null) {
|
||||||
if (sharedPrefs.getBoolean("showBG", true)) {
|
if (sharedPrefs.getBoolean("showBG", true)) {
|
||||||
mSgv.setText(rawData.sSgv);
|
mSgv.setText(rawData.sSgv);
|
||||||
mSgv.setVisibility(View.VISIBLE);
|
mSgv.setVisibility(View.VISIBLE);
|
||||||
} else {
|
} else {
|
||||||
//leave the textview there but invisible, as a height holder for the empty space above the white line
|
// Leave the textview there but invisible, as a height holder for the empty space above the white line
|
||||||
mSgv.setVisibility(View.INVISIBLE);
|
mSgv.setVisibility(View.INVISIBLE);
|
||||||
mSgv.setText("");
|
mSgv.setText("");
|
||||||
}
|
}
|
||||||
|
@ -356,7 +440,7 @@ public abstract class BaseWatchFace extends WatchFace implements SharedPreferenc
|
||||||
mCOB1.setVisibility(View.GONE);
|
mCOB1.setVisibility(View.GONE);
|
||||||
mCOB2.setVisibility(View.GONE);
|
mCOB2.setVisibility(View.GONE);
|
||||||
}
|
}
|
||||||
//deal with cases where there is only the value shown for COB, and not the label
|
// Deal with cases where there is only the value shown for COB, and not the label
|
||||||
} else if (mCOB2 != null) {
|
} else if (mCOB2 != null) {
|
||||||
mCOB2.setText(rawData.sCOB2);
|
mCOB2.setText(rawData.sCOB2);
|
||||||
if (sharedPrefs.getBoolean("show_cob", true)) {
|
if (sharedPrefs.getBoolean("show_cob", true)) {
|
||||||
|
@ -381,7 +465,7 @@ public abstract class BaseWatchFace extends WatchFace implements SharedPreferenc
|
||||||
mIOB1.setVisibility(View.GONE);
|
mIOB1.setVisibility(View.GONE);
|
||||||
mIOB2.setVisibility(View.GONE);
|
mIOB2.setVisibility(View.GONE);
|
||||||
}
|
}
|
||||||
//deal with cases where there is only the value shown for IOB, and not the label
|
// Deal with cases where there is only the value shown for IOB, and not the label
|
||||||
} else if (mIOB2 != null) {
|
} else if (mIOB2 != null) {
|
||||||
if (sharedPrefs.getBoolean("show_iob", true)) {
|
if (sharedPrefs.getBoolean("show_iob", true)) {
|
||||||
mIOB2.setVisibility(View.VISIBLE);
|
mIOB2.setVisibility(View.VISIBLE);
|
||||||
|
@ -400,11 +484,8 @@ public abstract class BaseWatchFace extends WatchFace implements SharedPreferenc
|
||||||
if (isAAPSv2 != null) {
|
if (isAAPSv2 != null) {
|
||||||
mTimestamp.setText(readingAge(true));
|
mTimestamp.setText(readingAge(true));
|
||||||
} else {
|
} else {
|
||||||
if (sharedPrefs.getBoolean("showExternalStatus", true)) {
|
boolean shortString = sharedPrefs.getBoolean("showExternalStatus", true);
|
||||||
mTimestamp.setText(readingAge(true));
|
mTimestamp.setText(readingAge(shortString));
|
||||||
} else {
|
|
||||||
mTimestamp.setText(readingAge(false));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
mTimestamp.setVisibility(View.VISIBLE);
|
mTimestamp.setVisibility(View.VISIBLE);
|
||||||
} else {
|
} else {
|
||||||
|
@ -479,68 +560,34 @@ public abstract class BaseWatchFace extends WatchFace implements SharedPreferenc
|
||||||
mLoop.setBackgroundResource(R.drawable.loop_green_25);
|
mLoop.setBackgroundResource(R.drawable.loop_green_25);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
mLoop.setText("-'");
|
loopLevel = -1;
|
||||||
|
mLoop.setText("-");
|
||||||
|
mLoop.setBackgroundResource(R.drawable.loop_grey_25);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
mLoop.setVisibility(View.GONE);
|
mLoop.setVisibility(View.GONE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
setDataFieldsSimpleUi();
|
|
||||||
}
|
|
||||||
|
|
||||||
void setDataFieldsSimpleUi() {
|
setColor();
|
||||||
if (sharedPrefs.getBoolean("simplify_ui_charging", false) && isCharging()) {
|
|
||||||
mSimpleUi.setVisibility(View.VISIBLE);
|
|
||||||
|
|
||||||
mSimpleSvg.setText(rawData.sSgv);
|
|
||||||
if (ageLevel() <= 0) {
|
|
||||||
mSimpleSvg.setPaintFlags(mSimpleSvg.getPaintFlags() | Paint.STRIKE_THRU_TEXT_FLAG);
|
|
||||||
} else {
|
|
||||||
mSimpleSvg.setPaintFlags(mSimpleSvg.getPaintFlags() & ~Paint.STRIKE_THRU_TEXT_FLAG);
|
|
||||||
}
|
|
||||||
if (rawData.sgvLevel == 1) {
|
|
||||||
mSimpleSvg.setTextColor(ContextCompat.getColor(getApplicationContext(), R.color.dark_highColor));
|
|
||||||
mSimpleDirection.setTextColor(ContextCompat.getColor(getApplicationContext(), R.color.dark_highColor));
|
|
||||||
} else if (rawData.sgvLevel == 0) {
|
|
||||||
mSimpleSvg.setTextColor(ContextCompat.getColor(getApplicationContext(), R.color.dark_midColor));
|
|
||||||
mSimpleDirection.setTextColor(ContextCompat.getColor(getApplicationContext(), R.color.dark_midColor));
|
|
||||||
} else if (rawData.sgvLevel == -1) {
|
|
||||||
mSimpleSvg.setTextColor(ContextCompat.getColor(getApplicationContext(), R.color.dark_lowColor));
|
|
||||||
mSimpleDirection.setTextColor(ContextCompat.getColor(getApplicationContext(), R.color.dark_lowColor));
|
|
||||||
}
|
|
||||||
|
|
||||||
mSimpleDirection.setText(rawData.sDirection+"\uFE0E");
|
|
||||||
|
|
||||||
final java.text.DateFormat timeFormat = DateFormat.getTimeFormat(BaseWatchFace.this);
|
|
||||||
mSimpleTime.setText(timeFormat.format(System.currentTimeMillis()));
|
|
||||||
} else {
|
|
||||||
mSimpleUi.setVisibility(View.GONE);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void on24HourFormatChanged(boolean is24HourFormat) {
|
protected void on24HourFormatChanged(boolean is24HourFormat) {
|
||||||
setDateAndTime();
|
initFormats();
|
||||||
|
if (!isSimpleUi()) {
|
||||||
|
setDataFields();
|
||||||
|
}
|
||||||
|
invalidate();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setDateAndTime() {
|
public void setDateAndTime() {
|
||||||
|
|
||||||
final java.text.DateFormat timeFormat = DateFormat.getTimeFormat(BaseWatchFace.this);
|
|
||||||
if (mTime != null) {
|
if (mTime != null) {
|
||||||
mTime.setText(timeFormat.format(System.currentTimeMillis()));
|
mTime.setText(timeFormat.format(mDateTime));
|
||||||
}
|
}
|
||||||
|
|
||||||
Date now = new Date();
|
sMinute = sdfMinute.format(mDateTime);
|
||||||
SimpleDateFormat sdfHour;
|
sHour = sdfHour.format(mDateTime);
|
||||||
SimpleDateFormat sdfMinute = new SimpleDateFormat("mm");
|
|
||||||
if (DateFormat.is24HourFormat(this)) {
|
|
||||||
sdfHour = new SimpleDateFormat("HH");
|
|
||||||
} else {
|
|
||||||
sdfHour = new SimpleDateFormat("hh");
|
|
||||||
}
|
|
||||||
sHour = sdfHour.format(now);
|
|
||||||
sMinute = sdfMinute.format(now);
|
|
||||||
|
|
||||||
if (mHour != null && mMinute != null) {
|
if (mHour != null && mMinute != null) {
|
||||||
mHour.setText(sHour);
|
mHour.setText(sHour);
|
||||||
mMinute.setText(sMinute);
|
mMinute.setText(sMinute);
|
||||||
|
@ -549,8 +596,7 @@ public abstract class BaseWatchFace extends WatchFace implements SharedPreferenc
|
||||||
if (mTimePeriod != null) {
|
if (mTimePeriod != null) {
|
||||||
if (!DateFormat.is24HourFormat(this)) {
|
if (!DateFormat.is24HourFormat(this)) {
|
||||||
mTimePeriod.setVisibility(View.VISIBLE);
|
mTimePeriod.setVisibility(View.VISIBLE);
|
||||||
SimpleDateFormat sdfPeriod = new SimpleDateFormat("a");
|
mTimePeriod.setText(sdfPeriod.format(mDateTime).toUpperCase());
|
||||||
mTimePeriod.setText(sdfPeriod.format(now).toUpperCase());
|
|
||||||
} else {
|
} else {
|
||||||
mTimePeriod.setVisibility(View.GONE);
|
mTimePeriod.setVisibility(View.GONE);
|
||||||
}
|
}
|
||||||
|
@ -559,14 +605,11 @@ public abstract class BaseWatchFace extends WatchFace implements SharedPreferenc
|
||||||
if (mDate != null && mDay != null && mMonth != null) {
|
if (mDate != null && mDay != null && mMonth != null) {
|
||||||
if (sharedPrefs.getBoolean("show_date", false)) {
|
if (sharedPrefs.getBoolean("show_date", false)) {
|
||||||
if (mDayName != null) {
|
if (mDayName != null) {
|
||||||
SimpleDateFormat sdfDayName = new SimpleDateFormat("E");
|
mDayName.setText(sdfDayName.format(mDateTime));
|
||||||
mDayName.setText(sdfDayName.format(now));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
SimpleDateFormat sdfDay = new SimpleDateFormat("dd");
|
mDay.setText(sdfDay.format(mDateTime));
|
||||||
SimpleDateFormat sdfMonth = new SimpleDateFormat("MMM");
|
mMonth.setText(sdfMonth.format(mDateTime));
|
||||||
mDay.setText(sdfDay.format(now));
|
|
||||||
mMonth.setText(sdfMonth.format(now));
|
|
||||||
mDate.setVisibility(View.VISIBLE);
|
mDate.setVisibility(View.VISIBLE);
|
||||||
} else {
|
} else {
|
||||||
mDate.setVisibility(View.GONE);
|
mDate.setVisibility(View.GONE);
|
||||||
|
@ -588,7 +631,7 @@ public abstract class BaseWatchFace extends WatchFace implements SharedPreferenc
|
||||||
public void strikeThroughSgvIfNeeded() {
|
public void strikeThroughSgvIfNeeded() {
|
||||||
if (mSgv != null) {
|
if (mSgv != null) {
|
||||||
if (sharedPrefs.getBoolean("showBG", true)) {
|
if (sharedPrefs.getBoolean("showBG", true)) {
|
||||||
if (ageLevel() <= 0) {
|
if (ageLevel() <= 0 && rawData.datetime > 0) {
|
||||||
mSgv.setPaintFlags(mSgv.getPaintFlags() | Paint.STRIKE_THRU_TEXT_FLAG);
|
mSgv.setPaintFlags(mSgv.getPaintFlags() | Paint.STRIKE_THRU_TEXT_FLAG);
|
||||||
} else {
|
} else {
|
||||||
mSgv.setPaintFlags(mSgv.getPaintFlags() & ~Paint.STRIKE_THRU_TEXT_FLAG);
|
mSgv.setPaintFlags(mSgv.getPaintFlags() & ~Paint.STRIKE_THRU_TEXT_FLAG);
|
||||||
|
@ -598,30 +641,45 @@ public abstract class BaseWatchFace extends WatchFace implements SharedPreferenc
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void onWatchModeChanged(WatchMode watchMode) {
|
protected void onWatchModeChanged(WatchMode watchMode) {
|
||||||
|
|
||||||
if (lowResMode ^ isLowRes(watchMode)) { //if there was a change in lowResMode
|
|
||||||
lowResMode = isLowRes(watchMode);
|
lowResMode = isLowRes(watchMode);
|
||||||
setColor();
|
if (isSimpleUi()) {
|
||||||
} else if (!sharedPrefs.getBoolean("dark", true)) {
|
setSimpleUiAntiAlias();
|
||||||
//in bright mode: different colours if active:
|
} else {
|
||||||
setColor();
|
setDataFields();
|
||||||
}
|
}
|
||||||
|
invalidate();
|
||||||
|
}
|
||||||
|
|
||||||
|
void setSimpleUiAntiAlias() {
|
||||||
|
boolean antiAlias = getCurrentWatchMode() == WatchMode.AMBIENT;
|
||||||
|
mSvgPaint.setAntiAlias(antiAlias);
|
||||||
|
mDirectionPaint.setAntiAlias(antiAlias);
|
||||||
|
mTimePaint.setAntiAlias(antiAlias);
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean isLowRes(WatchMode watchMode) {
|
private boolean isLowRes(WatchMode watchMode) {
|
||||||
return (watchMode == WatchMode.LOW_BIT) || (watchMode == WatchMode.LOW_BIT_BURN_IN); // || (watchMode == WatchMode.LOW_BIT_BURN_IN);
|
return (watchMode == WatchMode.LOW_BIT) || (watchMode == WatchMode.LOW_BIT_BURN_IN); // || (watchMode == WatchMode.LOW_BIT_BURN_IN);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private boolean isSimpleUi() {
|
||||||
|
String simplify = sharedPrefs.getString("simplify_ui", "off");
|
||||||
|
if (simplify.equals("off")) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if ((simplify.equals("ambient") || simplify.equals("ambient_charging")) && getCurrentWatchMode() == WatchMode.AMBIENT) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return (simplify.equals("charging") || simplify.equals("ambient_charging")) && isCharging();
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onSharedPreferenceChanged(SharedPreferences sharedPreferences, String key) {
|
public void onSharedPreferenceChanged(SharedPreferences sharedPreferences, String key) {
|
||||||
setupBatteryReceiver();
|
setupBatteryReceiver();
|
||||||
if ("delta_granularity".equals(key)) {
|
if ("delta_granularity".equals(key)) {
|
||||||
ListenerService.requestData(this);
|
ListenerService.requestData(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (layoutSet) {
|
if (layoutSet) {
|
||||||
setDataFields();
|
setDataFields();
|
||||||
setColor();
|
|
||||||
}
|
}
|
||||||
invalidate();
|
invalidate();
|
||||||
}
|
}
|
||||||
|
@ -634,12 +692,15 @@ public abstract class BaseWatchFace extends WatchFace implements SharedPreferenc
|
||||||
|
|
||||||
public void missedReadingAlert() {
|
public void missedReadingAlert() {
|
||||||
int minutes_since = (int) Math.floor(timeSince() / (1000 * 60));
|
int minutes_since = (int) Math.floor(timeSince() / (1000 * 60));
|
||||||
if (minutes_since >= 16 && ((minutes_since - 16) % 5) == 0) {
|
if (rawData.datetime == 0 || minutes_since >= 16 && ((minutes_since - 16) % 5) == 0) {
|
||||||
ListenerService.requestData(this); // attempt endTime recover missing data
|
ListenerService.requestData(this); // Attempt endTime recover missing data
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setupCharts() {
|
public void setupCharts() {
|
||||||
|
if (isSimpleUi()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
if (rawData.bgDataList.size() > 0) { // Dont crash things just because we dont have values, people dont like crashy things
|
if (rawData.bgDataList.size() > 0) { // Dont crash things just because we dont have values, people dont like crashy things
|
||||||
int timeframe = Integer.parseInt(sharedPrefs.getString("chart_timeframe", "3"));
|
int timeframe = Integer.parseInt(sharedPrefs.getString("chart_timeframe", "3"));
|
||||||
if (lowResMode) {
|
if (lowResMode) {
|
||||||
|
@ -657,31 +718,36 @@ public abstract class BaseWatchFace extends WatchFace implements SharedPreferenc
|
||||||
public class MessageReceiver extends BroadcastReceiver {
|
public class MessageReceiver extends BroadcastReceiver {
|
||||||
@Override
|
@Override
|
||||||
public void onReceive(Context context, Intent intent) {
|
public void onReceive(Context context, Intent intent) {
|
||||||
|
PowerManager.WakeLock wl = wearUtil.getWakeLock("readingPrefs", 50);
|
||||||
|
|
||||||
if (layoutSet) {
|
|
||||||
final DataMap dataMap = rawData.updateDataFromMessage(intent, wakeLock);
|
final DataMap dataMap = rawData.updateDataFromMessage(intent, wakeLock);
|
||||||
if (chart != null && dataMap != null) {
|
if (chart != null && dataMap != null) {
|
||||||
rawData.addToWatchSet(dataMap);
|
rawData.addToWatchSet(dataMap);
|
||||||
setupCharts();
|
setupCharts();
|
||||||
}
|
}
|
||||||
rawData.updateStatusFromMessage(intent, wakeLock);
|
rawData.updateStatusFromMessage(intent, wakeLock);
|
||||||
}
|
|
||||||
|
|
||||||
setDataFields();
|
|
||||||
setColor();
|
|
||||||
|
|
||||||
if (layoutSet) {
|
|
||||||
rawData.updateBasalsFromMessage(intent, wakeLock);
|
rawData.updateBasalsFromMessage(intent, wakeLock);
|
||||||
}
|
|
||||||
|
|
||||||
mRelativeLayout.measure(specW, specH);
|
if (isSimpleUi()) {
|
||||||
if (forceSquareCanvas) {
|
if (needUpdate()) {
|
||||||
mRelativeLayout.layout(0, 0, displaySize.x, displaySize.x); //force a square for Steampunk watch face.
|
|
||||||
} else {
|
|
||||||
mRelativeLayout.layout(0, 0, displaySize.x, displaySize.y);
|
|
||||||
}
|
|
||||||
invalidate();
|
invalidate();
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
setupCharts();
|
||||||
|
setDataFields();
|
||||||
|
invalidate();
|
||||||
|
}
|
||||||
|
wearUtil.releaseWakeLock(wl);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean needUpdate() {
|
||||||
|
if (mLastSvg.equals(rawData.sSgv) && mLastDirection.equals(rawData.sDirection)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
mLastSvg = rawData.sSgv;
|
||||||
|
mLastDirection = rawData.sDirection;
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -60,7 +60,9 @@ public class Cockpit extends BaseWatchFace {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (loopLevel == 1) {
|
if (loopLevel == -1) {
|
||||||
|
mLoop.setBackgroundResource(R.drawable.loop_grey_25);
|
||||||
|
} else if (loopLevel == 1) {
|
||||||
mLoop.setBackgroundResource(R.drawable.loop_green_25);
|
mLoop.setBackgroundResource(R.drawable.loop_green_25);
|
||||||
} else {
|
} else {
|
||||||
mLoop.setBackgroundResource(R.drawable.loop_red_25);
|
mLoop.setBackgroundResource(R.drawable.loop_red_25);
|
||||||
|
|
|
@ -117,7 +117,9 @@ public class Home2 extends BaseWatchFace {
|
||||||
mBasalRate.setTextColor(dividerTxtColor);
|
mBasalRate.setTextColor(dividerTxtColor);
|
||||||
mBgi.setTextColor(dividerTxtColor);
|
mBgi.setTextColor(dividerTxtColor);
|
||||||
|
|
||||||
if (loopLevel == 1) {
|
if (loopLevel == -1) {
|
||||||
|
mLoop.setBackgroundResource(R.drawable.loop_grey_25);
|
||||||
|
} else if (loopLevel == 1) {
|
||||||
mLoop.setBackgroundResource(R.drawable.loop_green_25);
|
mLoop.setBackgroundResource(R.drawable.loop_green_25);
|
||||||
} else {
|
} else {
|
||||||
mLoop.setBackgroundResource(R.drawable.loop_red_25);
|
mLoop.setBackgroundResource(R.drawable.loop_red_25);
|
||||||
|
@ -226,7 +228,9 @@ public class Home2 extends BaseWatchFace {
|
||||||
mBasalRate.setTextColor(dividerTxtColor);
|
mBasalRate.setTextColor(dividerTxtColor);
|
||||||
mBgi.setTextColor(dividerTxtColor);
|
mBgi.setTextColor(dividerTxtColor);
|
||||||
|
|
||||||
if (loopLevel == 1) {
|
if (loopLevel == -1) {
|
||||||
|
mLoop.setBackgroundResource(R.drawable.loop_grey_25);
|
||||||
|
} else if (loopLevel == 1) {
|
||||||
mLoop.setBackgroundResource(R.drawable.loop_green_25);
|
mLoop.setBackgroundResource(R.drawable.loop_green_25);
|
||||||
} else {
|
} else {
|
||||||
mLoop.setBackgroundResource(R.drawable.loop_red_25);
|
mLoop.setBackgroundResource(R.drawable.loop_red_25);
|
||||||
|
|
|
@ -67,7 +67,7 @@ public class Steampunk extends BaseWatchFace {
|
||||||
protected void setColorDark() {
|
protected void setColorDark() {
|
||||||
|
|
||||||
if (mLinearLayout2 != null) {
|
if (mLinearLayout2 != null) {
|
||||||
if (ageLevel() <= 0) {
|
if (ageLevel() <= 0 && rawData.datetime != 0) {
|
||||||
mLinearLayout2.setBackgroundResource(R.drawable.redline);
|
mLinearLayout2.setBackgroundResource(R.drawable.redline);
|
||||||
mTimestamp.setTextColor(getResources().getColor(R.color.red_600));
|
mTimestamp.setTextColor(getResources().getColor(R.color.red_600));
|
||||||
} else {
|
} else {
|
||||||
|
@ -108,6 +108,7 @@ public class Steampunk extends BaseWatchFace {
|
||||||
|
|
||||||
if (rotationAngle > 330) rotationAngle = 330; //if the glucose value is higher than 330 then show "HIGH" on the dial. ("HIGH" is at 330 degrees on the dial)
|
if (rotationAngle > 330) rotationAngle = 330; //if the glucose value is higher than 330 then show "HIGH" on the dial. ("HIGH" is at 330 degrees on the dial)
|
||||||
if (rotationAngle != 0 && rotationAngle < 30) rotationAngle = 30; //if the glucose value is lower than 30 show "LOW" on the dial. ("LOW" is at 30 degrees on the dial)
|
if (rotationAngle != 0 && rotationAngle < 30) rotationAngle = 30; //if the glucose value is lower than 30 show "LOW" on the dial. ("LOW" is at 30 degrees on the dial)
|
||||||
|
if (lastEndDegrees == 0) lastEndDegrees = rotationAngle;
|
||||||
|
|
||||||
//rotate glucose dial
|
//rotate glucose dial
|
||||||
RotateAnimation rotate = new RotateAnimation(
|
RotateAnimation rotate = new RotateAnimation(
|
||||||
|
|
|
@ -559,11 +559,6 @@
|
||||||
</LinearLayout>
|
</LinearLayout>
|
||||||
</LinearLayout>
|
</LinearLayout>
|
||||||
|
|
||||||
<include
|
|
||||||
android:id="@+id/simple_ui"
|
|
||||||
layout="@layout/simple_ui"
|
|
||||||
android:visibility="gone" />
|
|
||||||
|
|
||||||
<!-- FLAGs -->
|
<!-- FLAGs -->
|
||||||
<TextView
|
<TextView
|
||||||
android:id="@+id/AAPSv2"
|
android:id="@+id/AAPSv2"
|
||||||
|
|
|
@ -154,9 +154,4 @@
|
||||||
|
|
||||||
</LinearLayout>
|
</LinearLayout>
|
||||||
|
|
||||||
<include
|
|
||||||
android:id="@+id/simple_ui"
|
|
||||||
layout="@layout/simple_ui"
|
|
||||||
android:visibility="gone" />
|
|
||||||
|
|
||||||
</RelativeLayout>
|
</RelativeLayout>
|
||||||
|
|
|
@ -370,9 +370,4 @@
|
||||||
|
|
||||||
</LinearLayout>
|
</LinearLayout>
|
||||||
|
|
||||||
<include
|
|
||||||
android:id="@+id/simple_ui"
|
|
||||||
layout="@layout/simple_ui"
|
|
||||||
android:visibility="gone" />
|
|
||||||
|
|
||||||
</RelativeLayout>
|
</RelativeLayout>
|
||||||
|
|
|
@ -136,9 +136,4 @@
|
||||||
|
|
||||||
</LinearLayout>
|
</LinearLayout>
|
||||||
|
|
||||||
<include
|
|
||||||
android:id="@+id/simple_ui"
|
|
||||||
layout="@layout/simple_ui"
|
|
||||||
android:visibility="gone" />
|
|
||||||
|
|
||||||
</RelativeLayout>
|
</RelativeLayout>
|
||||||
|
|
|
@ -488,9 +488,4 @@
|
||||||
|
|
||||||
</LinearLayout>
|
</LinearLayout>
|
||||||
|
|
||||||
<include
|
|
||||||
android:id="@+id/simple_ui"
|
|
||||||
layout="@layout/simple_ui"
|
|
||||||
android:visibility="gone" />
|
|
||||||
|
|
||||||
</RelativeLayout>
|
</RelativeLayout>
|
|
@ -378,9 +378,4 @@
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:visibility="gone"/>
|
android:visibility="gone"/>
|
||||||
|
|
||||||
<include
|
|
||||||
android:id="@+id/simple_ui"
|
|
||||||
layout="@layout/simple_ui"
|
|
||||||
android:visibility="gone" />
|
|
||||||
|
|
||||||
</RelativeLayout>
|
</RelativeLayout>
|
||||||
|
|
|
@ -560,11 +560,6 @@
|
||||||
</LinearLayout>
|
</LinearLayout>
|
||||||
</LinearLayout>
|
</LinearLayout>
|
||||||
|
|
||||||
<include
|
|
||||||
android:id="@+id/simple_ui"
|
|
||||||
layout="@layout/simple_ui"
|
|
||||||
android:visibility="gone" />
|
|
||||||
|
|
||||||
<!-- FLAGs -->
|
<!-- FLAGs -->
|
||||||
<TextView
|
<TextView
|
||||||
android:id="@+id/AAPSv2"
|
android:id="@+id/AAPSv2"
|
||||||
|
|
|
@ -152,9 +152,4 @@
|
||||||
|
|
||||||
</LinearLayout>
|
</LinearLayout>
|
||||||
|
|
||||||
<include
|
|
||||||
android:id="@+id/simple_ui"
|
|
||||||
layout="@layout/simple_ui"
|
|
||||||
android:visibility="gone" />
|
|
||||||
|
|
||||||
</RelativeLayout>
|
</RelativeLayout>
|
||||||
|
|
|
@ -383,9 +383,4 @@
|
||||||
|
|
||||||
</LinearLayout>
|
</LinearLayout>
|
||||||
|
|
||||||
<include
|
|
||||||
android:id="@+id/simple_ui"
|
|
||||||
layout="@layout/simple_ui"
|
|
||||||
android:visibility="gone" />
|
|
||||||
|
|
||||||
</RelativeLayout>
|
</RelativeLayout>
|
||||||
|
|
|
@ -135,9 +135,4 @@
|
||||||
|
|
||||||
</LinearLayout>
|
</LinearLayout>
|
||||||
|
|
||||||
<include
|
|
||||||
android:id="@+id/simple_ui"
|
|
||||||
layout="@layout/simple_ui"
|
|
||||||
android:visibility="gone" />
|
|
||||||
|
|
||||||
</RelativeLayout>
|
</RelativeLayout>
|
||||||
|
|
|
@ -488,9 +488,4 @@
|
||||||
|
|
||||||
</LinearLayout>
|
</LinearLayout>
|
||||||
|
|
||||||
<include
|
|
||||||
android:id="@+id/simple_ui"
|
|
||||||
layout="@layout/simple_ui"
|
|
||||||
android:visibility="gone" />
|
|
||||||
|
|
||||||
</RelativeLayout>
|
</RelativeLayout>
|
|
@ -378,9 +378,4 @@
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:visibility="gone"/>
|
android:visibility="gone"/>
|
||||||
|
|
||||||
<include
|
|
||||||
android:id="@+id/simple_ui"
|
|
||||||
layout="@layout/simple_ui"
|
|
||||||
android:visibility="gone" />
|
|
||||||
|
|
||||||
</RelativeLayout>
|
</RelativeLayout>
|
||||||
|
|
|
@ -1,81 +0,0 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
|
||||||
android:layout_width="fill_parent"
|
|
||||||
android:layout_height="fill_parent"
|
|
||||||
android:background="@color/black"
|
|
||||||
android:orientation="vertical"
|
|
||||||
android:weightSum="100">
|
|
||||||
|
|
||||||
<LinearLayout
|
|
||||||
android:layout_width="fill_parent"
|
|
||||||
android:layout_height="fill_parent"
|
|
||||||
android:layout_weight="50"
|
|
||||||
android:gravity="center_horizontal">
|
|
||||||
|
|
||||||
<LinearLayout
|
|
||||||
android:layout_width="wrap_content"
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:layout_gravity="center_horizontal|bottom"
|
|
||||||
android:layout_marginBottom="5dp"
|
|
||||||
android:gravity="center_horizontal"
|
|
||||||
android:orientation="horizontal"
|
|
||||||
android:textAlignment="center">
|
|
||||||
|
|
||||||
<TextView
|
|
||||||
android:id="@+id/simple_sgv"
|
|
||||||
android:layout_width="wrap_content"
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:layout_gravity="bottom"
|
|
||||||
android:layout_marginBottom="-2dp"
|
|
||||||
android:gravity="bottom|end"
|
|
||||||
android:text="---"
|
|
||||||
android:textColor="@color/white"
|
|
||||||
android:textSize="50sp" />
|
|
||||||
|
|
||||||
<LinearLayout
|
|
||||||
android:layout_width="fill_parent"
|
|
||||||
android:layout_height="fill_parent"
|
|
||||||
android:layout_gravity="center_horizontal"
|
|
||||||
android:baselineAligned="false"
|
|
||||||
android:gravity="center_horizontal"
|
|
||||||
android:orientation="vertical"
|
|
||||||
android:textAlignment="center"
|
|
||||||
android:weightSum="1">
|
|
||||||
|
|
||||||
<TextView
|
|
||||||
android:id="@+id/simple_direction"
|
|
||||||
android:layout_width="wrap_content"
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:layout_gravity="center_horizontal|bottom"
|
|
||||||
android:layout_marginTop="-2dp"
|
|
||||||
android:layout_marginBottom="-5dp"
|
|
||||||
android:gravity="center_horizontal|bottom"
|
|
||||||
android:text="--"
|
|
||||||
android:textColor="@color/white"
|
|
||||||
android:textSize="35sp"
|
|
||||||
android:textStyle="bold" />
|
|
||||||
|
|
||||||
</LinearLayout>
|
|
||||||
|
|
||||||
</LinearLayout>
|
|
||||||
|
|
||||||
</LinearLayout>
|
|
||||||
|
|
||||||
<LinearLayout
|
|
||||||
android:layout_width="fill_parent"
|
|
||||||
android:layout_height="fill_parent"
|
|
||||||
android:layout_weight="50"
|
|
||||||
android:gravity="center_horizontal">
|
|
||||||
|
|
||||||
<TextView
|
|
||||||
android:id="@+id/simple_watch_time"
|
|
||||||
android:layout_width="wrap_content"
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:layout_gravity="center_horizontal|top"
|
|
||||||
android:layout_marginTop="5dp"
|
|
||||||
android:text="12:00"
|
|
||||||
android:textColor="#FFFFFF"
|
|
||||||
android:textSize="35sp" />
|
|
||||||
</LinearLayout>
|
|
||||||
|
|
||||||
</LinearLayout>
|
|
|
@ -65,4 +65,18 @@
|
||||||
<item>none</item>
|
<item>none</item>
|
||||||
</string-array>
|
</string-array>
|
||||||
|
|
||||||
|
<string-array name="watchface_simplify_ui_name">
|
||||||
|
<item>@string/simple_ui_off</item>
|
||||||
|
<item>@string/simple_ui_charging</item>
|
||||||
|
<item>@string/simple_ui_always_on</item>
|
||||||
|
<item>@string/simple_ui_always_on_charging</item>
|
||||||
|
</string-array>
|
||||||
|
|
||||||
|
<string-array name="watchface_simplify_ui_values">
|
||||||
|
<item>off</item>
|
||||||
|
<item>charging</item>
|
||||||
|
<item>ambient</item>
|
||||||
|
<item>ambient_charging</item>
|
||||||
|
</string-array>
|
||||||
|
|
||||||
</resources>
|
</resources>
|
||||||
|
|
8
wear/src/main/res/values/dimens.xml
Normal file
8
wear/src/main/res/values/dimens.xml
Normal file
|
@ -0,0 +1,8 @@
|
||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
|
||||||
|
<resources>
|
||||||
|
<dimen name="simple_ui_svg_text_size">50sp</dimen>
|
||||||
|
<dimen name="simple_ui_direction_text_size">35sp</dimen>
|
||||||
|
<dimen name="simple_ui_time_text_size">35sp</dimen>
|
||||||
|
<dimen name="simple_ui_y_offset">5dp</dimen>
|
||||||
|
</resources>
|
|
@ -136,8 +136,8 @@
|
||||||
<string name="color_name_white">white</string>
|
<string name="color_name_white">white</string>
|
||||||
<string name="color_name_black">black</string>
|
<string name="color_name_black">black</string>
|
||||||
<string name="color_name_multicolor">multicolor</string>
|
<string name="color_name_multicolor">multicolor</string>
|
||||||
<string name="pref_simplify_ui_charging">Simplify Charging UI</string>
|
<string name="pref_simplify_ui">Simplify UI</string>
|
||||||
<string name="pref_simplify_ui_charging_sum">Only show time and BG when charging</string>
|
<string name="pref_simplify_ui_sum">Only show time and BG</string>
|
||||||
|
|
||||||
|
|
||||||
<string name="pref_vibrate_hourly">Vibrate hourly</string>
|
<string name="pref_vibrate_hourly">Vibrate hourly</string>
|
||||||
|
@ -157,5 +157,9 @@
|
||||||
<string name="bolus_progress_channel_description">Bolus progress and cancel</string>
|
<string name="bolus_progress_channel_description">Bolus progress and cancel</string>
|
||||||
<string name="bolus_progress_silent_channel_description">Bolus progress and cancel with less vibrations</string>
|
<string name="bolus_progress_silent_channel_description">Bolus progress and cancel with less vibrations</string>
|
||||||
|
|
||||||
|
<string name="simple_ui_off">Off</string>
|
||||||
|
<string name="simple_ui_charging">During Charging</string>
|
||||||
|
<string name="simple_ui_always_on">Always On Mode</string>
|
||||||
|
<string name="simple_ui_always_on_charging">Always On and Charging</string>
|
||||||
|
|
||||||
</resources>
|
</resources>
|
||||||
|
|
|
@ -5,16 +5,16 @@
|
||||||
<CheckBoxPreference
|
<CheckBoxPreference
|
||||||
android:defaultValue="true"
|
android:defaultValue="true"
|
||||||
android:key="show_iob"
|
android:key="show_iob"
|
||||||
android:title="@string/pref_show_iob"
|
|
||||||
android:summary="Show insulin on board."
|
android:summary="Show insulin on board."
|
||||||
|
android:title="@string/pref_show_iob"
|
||||||
app:wear_iconOff="@drawable/settings_off"
|
app:wear_iconOff="@drawable/settings_off"
|
||||||
app:wear_iconOn="@drawable/settings_on" />
|
app:wear_iconOn="@drawable/settings_on" />
|
||||||
|
|
||||||
<CheckBoxPreference
|
<CheckBoxPreference
|
||||||
android:defaultValue="true"
|
android:defaultValue="true"
|
||||||
android:key="show_cob"
|
android:key="show_cob"
|
||||||
android:title="@string/pref_show_cob"
|
|
||||||
android:summary="Show carb on board."
|
android:summary="Show carb on board."
|
||||||
|
android:title="@string/pref_show_cob"
|
||||||
app:wear_iconOff="@drawable/settings_off"
|
app:wear_iconOff="@drawable/settings_off"
|
||||||
app:wear_iconOn="@drawable/settings_on" />
|
app:wear_iconOn="@drawable/settings_on" />
|
||||||
|
|
||||||
|
@ -85,8 +85,6 @@
|
||||||
app:wear_iconOff="@drawable/settings_off"
|
app:wear_iconOff="@drawable/settings_off"
|
||||||
app:wear_iconOn="@drawable/settings_on" />
|
app:wear_iconOn="@drawable/settings_on" />
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<CheckBoxPreference
|
<CheckBoxPreference
|
||||||
android:defaultValue="false"
|
android:defaultValue="false"
|
||||||
android:key="highlight_basals"
|
android:key="highlight_basals"
|
||||||
|
@ -103,14 +101,12 @@
|
||||||
android:summary="Chart Timeframe"
|
android:summary="Chart Timeframe"
|
||||||
android:title="@string/pref_chart_timeframe" />
|
android:title="@string/pref_chart_timeframe" />
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<CheckBoxPreference
|
<CheckBoxPreference
|
||||||
android:defaultValue="true"
|
android:defaultValue="true"
|
||||||
android:key="units_mgdl"
|
android:key="units_mgdl"
|
||||||
android:title="@string/pref_units_for_actions"
|
|
||||||
android:summaryOn="mg/dl"
|
|
||||||
android:summaryOff="mmol/l"
|
android:summaryOff="mmol/l"
|
||||||
|
android:summaryOn="mg/dl"
|
||||||
|
android:title="@string/pref_units_for_actions"
|
||||||
app:wear_iconOff="@drawable/settings_off"
|
app:wear_iconOff="@drawable/settings_off"
|
||||||
app:wear_iconOn="@drawable/settings_on" />
|
app:wear_iconOn="@drawable/settings_on" />
|
||||||
|
|
||||||
|
@ -161,8 +157,6 @@
|
||||||
app:wear_iconOff="@drawable/settings_off"
|
app:wear_iconOff="@drawable/settings_off"
|
||||||
app:wear_iconOn="@drawable/settings_on" />
|
app:wear_iconOn="@drawable/settings_on" />
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<ListPreference
|
<ListPreference
|
||||||
android:defaultValue="default"
|
android:defaultValue="default"
|
||||||
android:entries="@array/complication_tap_action"
|
android:entries="@array/complication_tap_action"
|
||||||
|
|
|
@ -12,9 +12,10 @@
|
||||||
app:wear_iconOn="@drawable/settings_on" />
|
app:wear_iconOn="@drawable/settings_on" />
|
||||||
|
|
||||||
<CheckBoxPreference
|
<CheckBoxPreference
|
||||||
|
android:defaultValue="false"
|
||||||
android:key="vibrate_Hourly"
|
android:key="vibrate_Hourly"
|
||||||
android:title="@string/pref_vibrate_hourly"
|
android:title="@string/pref_vibrate_hourly"
|
||||||
android:defaultValue="false"
|
|
||||||
app:wear_iconOff="@drawable/settings_off"
|
app:wear_iconOff="@drawable/settings_off"
|
||||||
app:wear_iconOn="@drawable/settings_on" />
|
app:wear_iconOn="@drawable/settings_on" />
|
||||||
|
|
||||||
</PreferenceScreen>
|
</PreferenceScreen>
|
||||||
|
|
|
@ -42,11 +42,11 @@
|
||||||
app:wear_iconOff="@drawable/settings_off"
|
app:wear_iconOff="@drawable/settings_off"
|
||||||
app:wear_iconOn="@drawable/settings_on" />
|
app:wear_iconOn="@drawable/settings_on" />
|
||||||
|
|
||||||
|
|
||||||
<CheckBoxPreference
|
<CheckBoxPreference
|
||||||
|
android:defaultValue="false"
|
||||||
android:key="vibrate_Hourly"
|
android:key="vibrate_Hourly"
|
||||||
android:title="@string/pref_vibrate_hourly"
|
android:title="@string/pref_vibrate_hourly"
|
||||||
android:defaultValue="false"
|
|
||||||
app:wear_iconOff="@drawable/settings_off"
|
app:wear_iconOff="@drawable/settings_off"
|
||||||
app:wear_iconOn="@drawable/settings_on" />
|
app:wear_iconOn="@drawable/settings_on" />
|
||||||
|
|
||||||
</PreferenceScreen>
|
</PreferenceScreen>
|
||||||
|
|
|
@ -3,18 +3,18 @@
|
||||||
xmlns:app="http://schemas.android.com/apk/res-auto">
|
xmlns:app="http://schemas.android.com/apk/res-auto">
|
||||||
|
|
||||||
<CheckBoxPreference
|
<CheckBoxPreference
|
||||||
|
android:defaultValue="false"
|
||||||
android:key="vibrate_Hourly"
|
android:key="vibrate_Hourly"
|
||||||
android:title="@string/pref_vibrate_hourly"
|
android:title="@string/pref_vibrate_hourly"
|
||||||
android:defaultValue="false"
|
|
||||||
app:wear_iconOff="@drawable/settings_off"
|
app:wear_iconOff="@drawable/settings_off"
|
||||||
app:wear_iconOn="@drawable/settings_on" />
|
app:wear_iconOn="@drawable/settings_on" />
|
||||||
|
|
||||||
<CheckBoxPreference
|
<ListPreference
|
||||||
android:defaultValue="false"
|
android:defaultValue="off"
|
||||||
android:key="simplify_ui_charging"
|
android:entries="@array/watchface_simplify_ui_name"
|
||||||
android:summary="@string/pref_simplify_ui_charging_sum"
|
android:entryValues="@array/watchface_simplify_ui_values"
|
||||||
android:title="@string/pref_simplify_ui_charging"
|
android:key="simplify_ui"
|
||||||
app:wear_iconOff="@drawable/settings_off"
|
android:summary="@string/pref_simplify_ui_sum"
|
||||||
app:wear_iconOn="@drawable/settings_on" />
|
android:title="@string/pref_simplify_ui" />
|
||||||
|
|
||||||
</PreferenceScreen>
|
</PreferenceScreen>
|
||||||
|
|
|
@ -4,59 +4,59 @@
|
||||||
|
|
||||||
|
|
||||||
<ListPreference
|
<ListPreference
|
||||||
android:key="digitalstyle_frameStyle"
|
|
||||||
android:title="@string/digitalstyle_pref_your_style"
|
|
||||||
android:defaultValue="full"
|
android:defaultValue="full"
|
||||||
android:entries="@array/digitalstyle_styles_name"
|
android:entries="@array/digitalstyle_styles_name"
|
||||||
android:entryValues="@array/digitalstyle_styles_values"/>
|
android:entryValues="@array/digitalstyle_styles_values"
|
||||||
|
android:key="digitalstyle_frameStyle"
|
||||||
|
android:title="@string/digitalstyle_pref_your_style" />
|
||||||
|
|
||||||
<ListPreference
|
<ListPreference
|
||||||
android:key="digitalstyle_frameColor"
|
|
||||||
android:title="@string/digitalstyle_pref_your_color"
|
|
||||||
android:defaultValue="red"
|
android:defaultValue="red"
|
||||||
android:entries="@array/digitalstyle_color_name"
|
android:entries="@array/digitalstyle_color_name"
|
||||||
android:entryValues="@array/digitalstyle_color_values"/>
|
android:entryValues="@array/digitalstyle_color_values"
|
||||||
|
android:key="digitalstyle_frameColor"
|
||||||
|
android:title="@string/digitalstyle_pref_your_color" />
|
||||||
<ListPreference
|
<ListPreference
|
||||||
android:key="digitalstyle_frameColorSaturation"
|
|
||||||
android:title="@string/digitalstyle_pref_your_color_saturation"
|
|
||||||
android:defaultValue="700"
|
android:defaultValue="700"
|
||||||
android:entries="@array/digitalstyle_color_saturation"
|
android:entries="@array/digitalstyle_color_saturation"
|
||||||
android:entryValues="@array/digitalstyle_color_saturation"/>
|
android:entryValues="@array/digitalstyle_color_saturation"
|
||||||
|
android:key="digitalstyle_frameColorSaturation"
|
||||||
|
android:title="@string/digitalstyle_pref_your_color_saturation" />
|
||||||
|
|
||||||
<ListPreference
|
<ListPreference
|
||||||
android:key="digitalstyle_frameColorOpacity"
|
|
||||||
android:title="@string/digitalstyle_pref_your_color_opacity"
|
|
||||||
android:defaultValue="1"
|
android:defaultValue="1"
|
||||||
android:entries="@array/digitalstyle_color_opacity_name"
|
android:entries="@array/digitalstyle_color_opacity_name"
|
||||||
android:entryValues="@array/digitalstyle_color_opacity_value"/>
|
android:entryValues="@array/digitalstyle_color_opacity_value"
|
||||||
|
android:key="digitalstyle_frameColorOpacity"
|
||||||
|
android:title="@string/digitalstyle_pref_your_color_opacity" />
|
||||||
|
|
||||||
<CheckBoxPreference
|
<CheckBoxPreference
|
||||||
|
android:defaultValue="true"
|
||||||
android:key="show_date"
|
android:key="show_date"
|
||||||
android:title="@string/pref_show_date"
|
android:title="@string/pref_show_date"
|
||||||
android:defaultValue="true"
|
|
||||||
app:wear_iconOff="@drawable/settings_off"
|
app:wear_iconOff="@drawable/settings_off"
|
||||||
app:wear_iconOn="@drawable/settings_on" />
|
app:wear_iconOn="@drawable/settings_on" />
|
||||||
|
|
||||||
<CheckBoxPreference
|
<CheckBoxPreference
|
||||||
|
android:defaultValue="false"
|
||||||
android:key="show_weeknumber"
|
android:key="show_weeknumber"
|
||||||
android:title="@string/pref_show_weeknumber"
|
android:title="@string/pref_show_weeknumber"
|
||||||
android:defaultValue="false"
|
|
||||||
app:wear_iconOff="@drawable/settings_off"
|
app:wear_iconOff="@drawable/settings_off"
|
||||||
app:wear_iconOn="@drawable/settings_on" />
|
app:wear_iconOn="@drawable/settings_on" />
|
||||||
|
|
||||||
<CheckBoxPreference
|
<CheckBoxPreference
|
||||||
|
android:defaultValue="false"
|
||||||
android:key="vibrate_Hourly"
|
android:key="vibrate_Hourly"
|
||||||
android:title="@string/pref_vibrate_hourly"
|
android:title="@string/pref_vibrate_hourly"
|
||||||
android:defaultValue="false"
|
|
||||||
app:wear_iconOff="@drawable/settings_off"
|
app:wear_iconOff="@drawable/settings_off"
|
||||||
app:wear_iconOn="@drawable/settings_on" />
|
app:wear_iconOn="@drawable/settings_on" />
|
||||||
|
|
||||||
<CheckBoxPreference
|
<ListPreference
|
||||||
android:defaultValue="false"
|
android:defaultValue="off"
|
||||||
android:key="simplify_ui_charging"
|
android:entries="@array/watchface_simplify_ui_name"
|
||||||
android:summary="@string/pref_simplify_ui_charging_sum"
|
android:entryValues="@array/watchface_simplify_ui_values"
|
||||||
android:title="@string/pref_simplify_ui_charging"
|
android:key="simplify_ui"
|
||||||
app:wear_iconOff="@drawable/settings_off"
|
android:summary="@string/pref_simplify_ui_sum"
|
||||||
app:wear_iconOn="@drawable/settings_on" />
|
android:title="@string/pref_simplify_ui" />
|
||||||
|
|
||||||
</PreferenceScreen>
|
</PreferenceScreen>
|
||||||
|
|
|
@ -19,18 +19,18 @@
|
||||||
app:wear_iconOn="@drawable/settings_on" />
|
app:wear_iconOn="@drawable/settings_on" />
|
||||||
|
|
||||||
<CheckBoxPreference
|
<CheckBoxPreference
|
||||||
|
android:defaultValue="false"
|
||||||
android:key="vibrate_Hourly"
|
android:key="vibrate_Hourly"
|
||||||
android:title="@string/pref_vibrate_hourly"
|
android:title="@string/pref_vibrate_hourly"
|
||||||
android:defaultValue="false"
|
|
||||||
app:wear_iconOff="@drawable/settings_off"
|
app:wear_iconOff="@drawable/settings_off"
|
||||||
app:wear_iconOn="@drawable/settings_on" />
|
app:wear_iconOn="@drawable/settings_on" />
|
||||||
|
|
||||||
<CheckBoxPreference
|
<ListPreference
|
||||||
android:defaultValue="false"
|
android:defaultValue="off"
|
||||||
android:key="simplify_ui_charging"
|
android:entries="@array/watchface_simplify_ui_name"
|
||||||
android:summary="@string/pref_simplify_ui_charging_sum"
|
android:entryValues="@array/watchface_simplify_ui_values"
|
||||||
android:title="@string/pref_simplify_ui_charging"
|
android:key="simplify_ui"
|
||||||
app:wear_iconOff="@drawable/settings_off"
|
android:summary="@string/pref_simplify_ui_sum"
|
||||||
app:wear_iconOn="@drawable/settings_on" />
|
android:title="@string/pref_simplify_ui" />
|
||||||
|
|
||||||
</PreferenceScreen>
|
</PreferenceScreen>
|
||||||
|
|
|
@ -32,12 +32,12 @@
|
||||||
app:wear_iconOff="@drawable/settings_off"
|
app:wear_iconOff="@drawable/settings_off"
|
||||||
app:wear_iconOn="@drawable/settings_on" />
|
app:wear_iconOn="@drawable/settings_on" />
|
||||||
|
|
||||||
<CheckBoxPreference
|
<ListPreference
|
||||||
android:defaultValue="false"
|
android:defaultValue="off"
|
||||||
android:key="simplify_ui_charging"
|
android:entries="@array/watchface_simplify_ui_name"
|
||||||
android:summary="@string/pref_simplify_ui_charging_sum"
|
android:entryValues="@array/watchface_simplify_ui_values"
|
||||||
android:title="@string/pref_simplify_ui_charging"
|
android:key="simplify_ui"
|
||||||
app:wear_iconOff="@drawable/settings_off"
|
android:summary="@string/pref_simplify_ui_sum"
|
||||||
app:wear_iconOn="@drawable/settings_on" />
|
android:title="@string/pref_simplify_ui" />
|
||||||
|
|
||||||
</PreferenceScreen>
|
</PreferenceScreen>
|
||||||
|
|
|
@ -19,18 +19,18 @@
|
||||||
app:wear_iconOn="@drawable/settings_on" />
|
app:wear_iconOn="@drawable/settings_on" />
|
||||||
|
|
||||||
<CheckBoxPreference
|
<CheckBoxPreference
|
||||||
|
android:defaultValue="false"
|
||||||
android:key="vibrate_Hourly"
|
android:key="vibrate_Hourly"
|
||||||
android:title="@string/pref_vibrate_hourly"
|
android:title="@string/pref_vibrate_hourly"
|
||||||
android:defaultValue="false"
|
|
||||||
app:wear_iconOff="@drawable/settings_off"
|
app:wear_iconOff="@drawable/settings_off"
|
||||||
app:wear_iconOn="@drawable/settings_on" />
|
app:wear_iconOn="@drawable/settings_on" />
|
||||||
|
|
||||||
<CheckBoxPreference
|
<ListPreference
|
||||||
android:defaultValue="false"
|
android:defaultValue="off"
|
||||||
android:key="simplify_ui_charging"
|
android:entries="@array/watchface_simplify_ui_name"
|
||||||
android:summary="@string/pref_simplify_ui_charging_sum"
|
android:entryValues="@array/watchface_simplify_ui_values"
|
||||||
android:title="@string/pref_simplify_ui_charging"
|
android:key="simplify_ui"
|
||||||
app:wear_iconOff="@drawable/settings_off"
|
android:summary="@string/pref_simplify_ui_sum"
|
||||||
app:wear_iconOn="@drawable/settings_on" />
|
android:title="@string/pref_simplify_ui" />
|
||||||
|
|
||||||
</PreferenceScreen>
|
</PreferenceScreen>
|
||||||
|
|
|
@ -12,9 +12,10 @@
|
||||||
|
|
||||||
|
|
||||||
<CheckBoxPreference
|
<CheckBoxPreference
|
||||||
|
android:defaultValue="false"
|
||||||
android:key="vibrate_Hourly"
|
android:key="vibrate_Hourly"
|
||||||
android:title="@string/pref_vibrate_hourly"
|
android:title="@string/pref_vibrate_hourly"
|
||||||
android:defaultValue="false"
|
|
||||||
app:wear_iconOff="@drawable/settings_off"
|
app:wear_iconOff="@drawable/settings_off"
|
||||||
app:wear_iconOn="@drawable/settings_on" />
|
app:wear_iconOn="@drawable/settings_on" />
|
||||||
|
|
||||||
</PreferenceScreen>
|
</PreferenceScreen>
|
||||||
|
|
|
@ -11,18 +11,18 @@
|
||||||
android:title="@string/pref_delta_granularity" />
|
android:title="@string/pref_delta_granularity" />
|
||||||
|
|
||||||
<CheckBoxPreference
|
<CheckBoxPreference
|
||||||
|
android:defaultValue="false"
|
||||||
android:key="vibrate_Hourly"
|
android:key="vibrate_Hourly"
|
||||||
android:title="@string/pref_vibrate_hourly"
|
android:title="@string/pref_vibrate_hourly"
|
||||||
android:defaultValue="false"
|
|
||||||
app:wear_iconOff="@drawable/settings_off"
|
app:wear_iconOff="@drawable/settings_off"
|
||||||
app:wear_iconOn="@drawable/settings_on" />
|
app:wear_iconOn="@drawable/settings_on" />
|
||||||
|
|
||||||
<CheckBoxPreference
|
<ListPreference
|
||||||
android:defaultValue="false"
|
android:defaultValue="off"
|
||||||
android:key="simplify_ui_charging"
|
android:entries="@array/watchface_simplify_ui_name"
|
||||||
android:summary="@string/pref_simplify_ui_charging_sum"
|
android:entryValues="@array/watchface_simplify_ui_values"
|
||||||
android:title="@string/pref_simplify_ui_charging"
|
android:key="simplify_ui"
|
||||||
app:wear_iconOff="@drawable/settings_off"
|
android:summary="@string/pref_simplify_ui_sum"
|
||||||
app:wear_iconOn="@drawable/settings_on" />
|
android:title="@string/pref_simplify_ui" />
|
||||||
|
|
||||||
</PreferenceScreen>
|
</PreferenceScreen>
|
||||||
|
|
Loading…
Reference in a new issue