Wear cwf put all hardcoded keys within enum
This commit is contained in:
parent
991fbcb0d4
commit
fb9991ad4b
2 changed files with 248 additions and 154 deletions
|
@ -18,33 +18,38 @@ import java.util.zip.ZipInputStream
|
||||||
import java.util.zip.ZipOutputStream
|
import java.util.zip.ZipOutputStream
|
||||||
|
|
||||||
val CUSTOM_VERSION = "0.10"
|
val CUSTOM_VERSION = "0.10"
|
||||||
|
|
||||||
enum class CustomWatchfaceDrawableDataKey(val key: String, @DrawableRes val icon: Int?, val fileName: String) {
|
enum class CustomWatchfaceDrawableDataKey(val key: String, @DrawableRes val icon: Int?, val fileName: String) {
|
||||||
UNKNOWN("unknown", null, "Unknown"),
|
UNKNOWN("unknown", null, "Unknown"),
|
||||||
CUSTOM_WATCHFACE("customWatchface", R.drawable.watchface_custom, "CustomWatchface"),
|
CUSTOM_WATCHFACE("customWatchface", R.drawable.watchface_custom, "CustomWatchface"),
|
||||||
BACKGROUND("background", R.drawable.background, "Background"),
|
BACKGROUND(ViewKeys.BACKGROUND.key, R.drawable.background, "Background"),
|
||||||
BACKGROUND_HIGH("background", R.drawable.background, "BackgroundHigh"),
|
BACKGROUND_HIGH(ViewKeys.BACKGROUND.key, R.drawable.background, "BackgroundHigh"),
|
||||||
BACKGROUND_LOW("background", R.drawable.background, "BackgroundLow"),
|
BACKGROUND_LOW(ViewKeys.BACKGROUND.key, R.drawable.background, "BackgroundLow"),
|
||||||
COVERCHART("cover_chart", null, "CoverChart"),
|
COVER_CHART(ViewKeys.COVER_CHART.key, null, "CoverChart"),
|
||||||
COVERPLATE("cover_plate", R.drawable.simplified_dial, "CoverPlate"),
|
COVER_PLATE(ViewKeys.COVER_PLATE.key, R.drawable.simplified_dial, "CoverPlate"),
|
||||||
HOURHAND("hour_hand", R.drawable.hour_hand, "HourHand"),
|
HOUR_HAND(ViewKeys.HOUR_HAND.key, R.drawable.hour_hand, "HourHand"),
|
||||||
MINUTEHAND("minute_hand", R.drawable.minute_hand, "MinuteHand"),
|
MINUTE_HAND(ViewKeys.MINUTE_HAND.key, R.drawable.minute_hand, "MinuteHand"),
|
||||||
SECONDHAND("second_hand", R.drawable.second_hand, "SecondHand");
|
SECOND_HAND(ViewKeys.SECOND_HAND.key, R.drawable.second_hand, "SecondHand");
|
||||||
|
|
||||||
companion object {
|
companion object {
|
||||||
|
|
||||||
fun fromKey(key: String): CustomWatchfaceDrawableDataKey =
|
fun fromKey(key: String): CustomWatchfaceDrawableDataKey =
|
||||||
values().firstOrNull { it.key == key } ?: UNKNOWN
|
values().firstOrNull { it.key == key } ?: UNKNOWN
|
||||||
|
|
||||||
fun fromFileName(file: String): CustomWatchfaceDrawableDataKey = values().firstOrNull { it.fileName == file.substringBeforeLast(".") } ?: UNKNOWN
|
fun fromFileName(file: String): CustomWatchfaceDrawableDataKey = values().firstOrNull { it.fileName == file.substringBeforeLast(".") } ?: UNKNOWN
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
enum class DrawableFormat(val extension: String) {
|
enum class DrawableFormat(val extension: String) {
|
||||||
UNKNOWN(""),
|
UNKNOWN(""),
|
||||||
|
|
||||||
//XML("xml"),
|
//XML("xml"),
|
||||||
//SVG("svg"),
|
//SVG("svg"),
|
||||||
JPG("jpg"),
|
JPG("jpg"),
|
||||||
PNG("png");
|
PNG("png");
|
||||||
|
|
||||||
companion object {
|
companion object {
|
||||||
|
|
||||||
fun fromFileName(fileName: String): DrawableFormat =
|
fun fromFileName(fileName: String): DrawableFormat =
|
||||||
values().firstOrNull { it.extension == fileName.substringAfterLast(".") } ?: UNKNOWN
|
values().firstOrNull { it.extension == fileName.substringAfterLast(".") } ?: UNKNOWN
|
||||||
|
|
||||||
|
@ -112,12 +117,109 @@ enum class CustomWatchfaceMetadataKey(val key: String, @StringRes val label: Int
|
||||||
CWF_PREF_WATCH_SHOW_AGO("key_show_ago", R.string.metadata_label_watchface_pref, true),
|
CWF_PREF_WATCH_SHOW_AGO("key_show_ago", R.string.metadata_label_watchface_pref, true),
|
||||||
CWF_PREF_WATCH_SHOW_BG("key_show_bg", R.string.metadata_label_watchface_pref, true),
|
CWF_PREF_WATCH_SHOW_BG("key_show_bg", R.string.metadata_label_watchface_pref, true),
|
||||||
CWF_PREF_WATCH_SHOW_LOOP_STATUS("key_show_loop_status", R.string.metadata_label_watchface_pref, true);
|
CWF_PREF_WATCH_SHOW_LOOP_STATUS("key_show_loop_status", R.string.metadata_label_watchface_pref, true);
|
||||||
|
|
||||||
companion object {
|
companion object {
|
||||||
|
|
||||||
fun fromKey(key: String): CustomWatchfaceMetadataKey? =
|
fun fromKey(key: String): CustomWatchfaceMetadataKey? =
|
||||||
values().firstOrNull { it.key == key }
|
values().firstOrNull { it.key == key }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
enum class ViewKeys(val key: String, @StringRes val comment: Int?) {
|
||||||
|
|
||||||
|
BACKGROUND("background", null),
|
||||||
|
CHART("chart", null),
|
||||||
|
COVER_CHART("cover_chart", null),
|
||||||
|
FREETEXT1("freetext1", null),
|
||||||
|
FREETEXT2("freetext2", null),
|
||||||
|
FREETEXT3("freetext3", null),
|
||||||
|
FREETEXT4("freetext4", null),
|
||||||
|
IOB1("iob1", null),
|
||||||
|
IOB2("iob2", null),
|
||||||
|
COB1("cob1", null),
|
||||||
|
COB2("cob2", null),
|
||||||
|
DELTA("delta", null),
|
||||||
|
AVG_DELTA("avg_delta", null),
|
||||||
|
UPLOADER_BATTERY("uploader_battery", null),
|
||||||
|
RIG_BATTERY("rig_battery", null),
|
||||||
|
BASALRATE("basalRate", null),
|
||||||
|
BGI("bgi", null),
|
||||||
|
TIME("time", null),
|
||||||
|
HOUR("hour", null),
|
||||||
|
MINUTE("minute", null),
|
||||||
|
SECOND("second", null),
|
||||||
|
TIMEPERIOD("timePeriod", null),
|
||||||
|
DAY_NAME("day_name", null),
|
||||||
|
DAY("day", null),
|
||||||
|
MONTH("month", null),
|
||||||
|
LOOP("loop", null),
|
||||||
|
DIRECTION("direction", null),
|
||||||
|
TIMESTAMP("timestamp", null),
|
||||||
|
SGV("sgv", null),
|
||||||
|
COVER_PLATE("cover_plate", null),
|
||||||
|
HOUR_HAND("hour_hand", null),
|
||||||
|
MINUTE_HAND("minute_hand", null),
|
||||||
|
SECOND_HAND("second_hand", null)
|
||||||
|
}
|
||||||
|
|
||||||
|
enum class JsonKeys(val key: String, val viewType: ViewType, @StringRes val comment: Int?) {
|
||||||
|
METADATA("metadata", ViewType.NONE, null),
|
||||||
|
ENABLESECOND("enableSecond", ViewType.NONE, null),
|
||||||
|
HIGHCOLOR("highColor", ViewType.NONE, null),
|
||||||
|
MIDCOLOR("midColor", ViewType.NONE, null),
|
||||||
|
LOWCOLOR("lowColor", ViewType.NONE, null),
|
||||||
|
LOWBATCOLOR("lowBatColor", ViewType.NONE, null),
|
||||||
|
CARBCOLOR("carbColor", ViewType.NONE, null),
|
||||||
|
BASALBACKGROUNDCOLOR("basalBackgroundColor", ViewType.NONE, null),
|
||||||
|
BASALCENTERCOLOR("basalCenterColor", ViewType.NONE, null),
|
||||||
|
GRIDCOLOR("gridColor", ViewType.NONE, null),
|
||||||
|
POINTSIZE("pointSize", ViewType.NONE, null),
|
||||||
|
WIDTH("width", ViewType.ALLVIEWS, null),
|
||||||
|
HEIGHT("height", ViewType.ALLVIEWS, null),
|
||||||
|
TOPMARGIN("topmargin", ViewType.ALLVIEWS, null),
|
||||||
|
LEFTMARGIN("leftmargin", ViewType.ALLVIEWS, null),
|
||||||
|
ROTATION("rotation", ViewType.TEXTVIEW, null),
|
||||||
|
VISIBILITY("visibility", ViewType.ALLVIEWS, null),
|
||||||
|
TEXTSIZE("textsize", ViewType.TEXTVIEW, null),
|
||||||
|
TEXTVALUE("textvalue", ViewType.TEXTVIEW, null),
|
||||||
|
GRAVITY("gravity", ViewType.TEXTVIEW, null),
|
||||||
|
FONT("font", ViewType.TEXTVIEW, null),
|
||||||
|
FONTSTYLE("fontStyle", ViewType.TEXTVIEW, null),
|
||||||
|
FONTCOLOR("fontColor", ViewType.TEXTVIEW, null),
|
||||||
|
COLOR("color", ViewType.IMAGEVIEW, null)
|
||||||
|
}
|
||||||
|
|
||||||
|
enum class JsonKeyValues(val key: String, val jsonKey: JsonKeys) {
|
||||||
|
GONE("gone", JsonKeys.VISIBILITY),
|
||||||
|
VISIBLE("visible", JsonKeys.VISIBILITY),
|
||||||
|
INVISIBLE("invisible", JsonKeys.VISIBILITY),
|
||||||
|
CENTER("center", JsonKeys.GRAVITY),
|
||||||
|
LEFT("left", JsonKeys.GRAVITY),
|
||||||
|
RIGHT("right", JsonKeys.GRAVITY),
|
||||||
|
SANS_SERIF("sans_serif", JsonKeys.FONT),
|
||||||
|
DEFAULT("default", JsonKeys.FONT),
|
||||||
|
DEFAULT_BOLD("default_bold", JsonKeys.FONT),
|
||||||
|
MONOSPACE("monospace", JsonKeys.FONT),
|
||||||
|
SERIF("serif", JsonKeys.FONT),
|
||||||
|
ROBOTO_CONDENSED_BOLD("roboto_condensed_bold", JsonKeys.FONT),
|
||||||
|
ROBOTO_CONDENSED_LIGHT("roboto_condensed_light", JsonKeys.FONT),
|
||||||
|
ROBOTO_CONDENSED_REGULAR("roboto_condensed_regular", JsonKeys.FONT),
|
||||||
|
ROBOTO_SLAB_LIGHT("roboto_slab_light", JsonKeys.FONT),
|
||||||
|
NORMAL("normal", JsonKeys.FONTSTYLE),
|
||||||
|
BOLD("bold", JsonKeys.FONTSTYLE),
|
||||||
|
BOLD_ITALIC("bold_italic", JsonKeys.FONTSTYLE),
|
||||||
|
ITALIC("italic", JsonKeys.FONTSTYLE),
|
||||||
|
BGCOLOR("bgColor", JsonKeys.COLOR),
|
||||||
|
BGCOLOR1("bgColor", JsonKeys.FONTCOLOR)
|
||||||
|
}
|
||||||
|
|
||||||
|
enum class ViewType(@StringRes val comment: Int?) {
|
||||||
|
NONE(null),
|
||||||
|
TEXTVIEW(null),
|
||||||
|
IMAGEVIEW(null),
|
||||||
|
ALLVIEWS(null)
|
||||||
|
}
|
||||||
|
|
||||||
class ZipWatchfaceFormat {
|
class ZipWatchfaceFormat {
|
||||||
companion object {
|
companion object {
|
||||||
|
|
||||||
|
@ -151,10 +253,10 @@ class ZipWatchfaceFormat {
|
||||||
metadata[CustomWatchfaceMetadataKey.CWF_FILENAME] = cwfFile.name
|
metadata[CustomWatchfaceMetadataKey.CWF_FILENAME] = cwfFile.name
|
||||||
metadata[CustomWatchfaceMetadataKey.CWF_AUTHORIZATION] = authorization.toString()
|
metadata[CustomWatchfaceMetadataKey.CWF_AUTHORIZATION] = authorization.toString()
|
||||||
} else {
|
} else {
|
||||||
val customWatchfaceDrawableDataKey = CustomWatchfaceDrawableDataKey.fromFileName(entryName)
|
val customWatchfaceDrawableData = CustomWatchfaceDrawableDataKey.fromFileName(entryName)
|
||||||
val drawableFormat = DrawableFormat.fromFileName(entryName)
|
val drawableFormat = DrawableFormat.fromFileName(entryName)
|
||||||
if (customWatchfaceDrawableDataKey != CustomWatchfaceDrawableDataKey.UNKNOWN && drawableFormat != DrawableFormat.UNKNOWN) {
|
if (customWatchfaceDrawableData != CustomWatchfaceDrawableDataKey.UNKNOWN && drawableFormat != DrawableFormat.UNKNOWN) {
|
||||||
drawableDatas[customWatchfaceDrawableDataKey] = DrawableData(byteArrayOutputStream.toByteArray(), drawableFormat)
|
drawableDatas[customWatchfaceDrawableData] = DrawableData(byteArrayOutputStream.toByteArray(), drawableFormat)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
zipEntry = zipInputStream.nextEntry
|
zipEntry = zipInputStream.nextEntry
|
||||||
|
@ -200,8 +302,8 @@ class ZipWatchfaceFormat {
|
||||||
fun loadMetadata(contents: JSONObject): CustomWatchfaceMetadataMap {
|
fun loadMetadata(contents: JSONObject): CustomWatchfaceMetadataMap {
|
||||||
val metadata: CustomWatchfaceMetadataMap = mutableMapOf()
|
val metadata: CustomWatchfaceMetadataMap = mutableMapOf()
|
||||||
|
|
||||||
if (contents.has("metadata")) {
|
if (contents.has(JsonKeys.METADATA.key)) {
|
||||||
val meta = contents.getJSONObject("metadata")
|
val meta = contents.getJSONObject(JsonKeys.METADATA.key)
|
||||||
for (key in meta.keys()) {
|
for (key in meta.keys()) {
|
||||||
val metaKey = CustomWatchfaceMetadataKey.fromKey(key)
|
val metaKey = CustomWatchfaceMetadataKey.fromKey(key)
|
||||||
if (metaKey != null) {
|
if (metaKey != null) {
|
||||||
|
|
|
@ -41,6 +41,9 @@ import info.nightscout.rx.weardata.CustomWatchfaceMetadataMap
|
||||||
import info.nightscout.rx.weardata.DrawableData
|
import info.nightscout.rx.weardata.DrawableData
|
||||||
import info.nightscout.rx.weardata.DrawableFormat
|
import info.nightscout.rx.weardata.DrawableFormat
|
||||||
import info.nightscout.rx.weardata.EventData
|
import info.nightscout.rx.weardata.EventData
|
||||||
|
import info.nightscout.rx.weardata.JsonKeyValues
|
||||||
|
import info.nightscout.rx.weardata.JsonKeys.*
|
||||||
|
import info.nightscout.rx.weardata.ViewKeys
|
||||||
import info.nightscout.rx.weardata.ZipWatchfaceFormat
|
import info.nightscout.rx.weardata.ZipWatchfaceFormat
|
||||||
import info.nightscout.shared.extensions.toVisibility
|
import info.nightscout.shared.extensions.toVisibility
|
||||||
import info.nightscout.shared.extensions.toVisibilityKeepSpace
|
import info.nightscout.shared.extensions.toVisibilityKeepSpace
|
||||||
|
@ -86,7 +89,7 @@ class CustomWatchface : BaseWatchFace() {
|
||||||
@SuppressLint("UseCompatLoadingForDrawables")
|
@SuppressLint("UseCompatLoadingForDrawables")
|
||||||
override fun setDataFields() {
|
override fun setDataFields() {
|
||||||
super.setDataFields()
|
super.setDataFields()
|
||||||
binding.direction2.setImageDrawable(this.resources.getDrawable(TrendArrow.icon(singleBg.slopeArrow)))
|
binding.direction2.setImageDrawable(this.resources.getDrawable(TrendArrowMap.icon(singleBg.slopeArrow)))
|
||||||
// rotate the second hand.
|
// rotate the second hand.
|
||||||
binding.secondHand.rotation = TimeOfDay().secondOfMinute * 6f
|
binding.secondHand.rotation = TimeOfDay().secondOfMinute * 6f
|
||||||
// rotate the minute hand.
|
// rotate the minute hand.
|
||||||
|
@ -145,17 +148,17 @@ class CustomWatchface : BaseWatchFace() {
|
||||||
try {
|
try {
|
||||||
val json = JSONObject(it.customWatchfaceData.json)
|
val json = JSONObject(it.customWatchfaceData.json)
|
||||||
val drawableDataMap = it.customWatchfaceData.drawableDatas
|
val drawableDataMap = it.customWatchfaceData.drawableDatas
|
||||||
enableSecond = (if (json.has("enableSecond")) json.getBoolean("enableSecond") else false) && sp.getBoolean(R.string.key_show_seconds, true)
|
enableSecond = (if (json.has(ENABLESECOND.key)) json.getBoolean(ENABLESECOND.key) else false) && sp.getBoolean(R.string.key_show_seconds, true)
|
||||||
|
|
||||||
highColor = if (json.has("highColor")) Color.parseColor(json.getString("highColor")) else ContextCompat.getColor(this, R.color.dark_highColor)
|
highColor = if (json.has(HIGHCOLOR.key)) Color.parseColor(json.getString(HIGHCOLOR.key)) else ContextCompat.getColor(this, R.color.dark_highColor)
|
||||||
midColor = if (json.has("midColor")) Color.parseColor(json.getString("midColor")) else ContextCompat.getColor(this, R.color.inrange)
|
midColor = if (json.has(MIDCOLOR.key)) Color.parseColor(json.getString(MIDCOLOR.key)) else ContextCompat.getColor(this, R.color.inrange)
|
||||||
lowColor = if (json.has("lowColor")) Color.parseColor(json.getString("lowColor")) else ContextCompat.getColor(this, R.color.low)
|
lowColor = if (json.has(LOWCOLOR.key)) Color.parseColor(json.getString(LOWCOLOR.key)) else ContextCompat.getColor(this, R.color.low)
|
||||||
lowBatColor = if (json.has("lowBatColor")) Color.parseColor(json.getString("lowBatColor")) else ContextCompat.getColor(this, R.color.dark_uploaderBatteryEmpty)
|
lowBatColor = if (json.has(LOWBATCOLOR.key)) Color.parseColor(json.getString(LOWBATCOLOR.key)) else ContextCompat.getColor(this, R.color.dark_uploaderBatteryEmpty)
|
||||||
carbColor = if (json.has("carbColor")) Color.parseColor(json.getString("carbColor")) else ContextCompat.getColor(this, R.color.carbs)
|
carbColor = if (json.has(CARBCOLOR.key)) Color.parseColor(json.getString(CARBCOLOR.key)) else ContextCompat.getColor(this, R.color.carbs)
|
||||||
basalBackgroundColor = if (json.has("basalBackgroundColor")) Color.parseColor(json.getString("basalBackgroundColor")) else ContextCompat.getColor(this, R.color.basal_dark)
|
basalBackgroundColor = if (json.has(BASALBACKGROUNDCOLOR.key)) Color.parseColor(json.getString(BASALBACKGROUNDCOLOR.key)) else ContextCompat.getColor(this, R.color.basal_dark)
|
||||||
basalCenterColor = if (json.has("basalCenterColor")) Color.parseColor(json.getString("basalCenterColor")) else ContextCompat.getColor(this, R.color.basal_light)
|
basalCenterColor = if (json.has(BASALCENTERCOLOR.key)) Color.parseColor(json.getString(BASALCENTERCOLOR.key)) else ContextCompat.getColor(this, R.color.basal_light)
|
||||||
gridColor = if (json.has("gridColor")) Color.parseColor(json.getString("gridColor")) else Color.WHITE
|
gridColor = if (json.has(GRIDCOLOR.key)) Color.parseColor(json.getString(GRIDCOLOR.key)) else Color.WHITE
|
||||||
pointSize = if (json.has("pointSize")) json.getInt("pointSize") else 2
|
pointSize = if (json.has(POINTSIZE.key)) json.getInt(POINTSIZE.key) else 2
|
||||||
bgColor = when (singleBg.sgvLevel) {
|
bgColor = when (singleBg.sgvLevel) {
|
||||||
1L -> highColor
|
1L -> highColor
|
||||||
0L -> midColor
|
0L -> midColor
|
||||||
|
@ -170,30 +173,30 @@ class CustomWatchface : BaseWatchFace() {
|
||||||
}
|
}
|
||||||
|
|
||||||
binding.mainLayout.forEach { view ->
|
binding.mainLayout.forEach { view ->
|
||||||
CustomViews.fromId(view.id)?.let { id ->
|
ViewMap.fromId(view.id)?.let { id ->
|
||||||
if (json.has(id.key)) {
|
if (json.has(id.key)) {
|
||||||
val viewJson = json.getJSONObject(id.key)
|
val viewJson = json.getJSONObject(id.key)
|
||||||
val wrapContent = LayoutParams.WRAP_CONTENT
|
val wrapContent = LayoutParams.WRAP_CONTENT
|
||||||
val width = if (viewJson.has("width")) (viewJson.getInt("width") * zoomFactor).toInt() else wrapContent
|
val width = if (viewJson.has(WIDTH.key)) (viewJson.getInt(WIDTH.key) * zoomFactor).toInt() else wrapContent
|
||||||
val height = if (viewJson.has("height")) (viewJson.getInt("height") * zoomFactor).toInt() else wrapContent
|
val height = if (viewJson.has(HEIGHT.key)) (viewJson.getInt(HEIGHT.key) * zoomFactor).toInt() else wrapContent
|
||||||
val params = FrameLayout.LayoutParams(width, height)
|
val params = FrameLayout.LayoutParams(width, height)
|
||||||
params.topMargin = if (viewJson.has("topmargin")) (viewJson.getInt("topmargin") * zoomFactor).toInt() else 0
|
params.topMargin = if (viewJson.has(TOPMARGIN.key)) (viewJson.getInt(TOPMARGIN.key) * zoomFactor).toInt() else 0
|
||||||
params.leftMargin = if (viewJson.has("leftmargin")) (viewJson.getInt("leftmargin") * zoomFactor).toInt() else 0
|
params.leftMargin = if (viewJson.has(LEFTMARGIN.key)) (viewJson.getInt(LEFTMARGIN.key) * zoomFactor).toInt() else 0
|
||||||
view.layoutParams = params
|
view.layoutParams = params
|
||||||
view.visibility = if (viewJson.has("visibility")) setVisibility(viewJson.getString("visibility"), id.visibility(sp)) else View.GONE
|
view.visibility = if (viewJson.has(VISIBILITY.key)) setVisibility(viewJson.getString(VISIBILITY.key), id.visibility(sp)) else View.GONE
|
||||||
if (view is TextView) {
|
if (view is TextView) {
|
||||||
view.rotation = if (viewJson.has("rotation")) viewJson.getInt("rotation").toFloat() else 0F
|
view.rotation = if (viewJson.has(ROTATION.key)) viewJson.getInt(ROTATION.key).toFloat() else 0F
|
||||||
view.setTextSize(TypedValue.COMPLEX_UNIT_PX, ((if (viewJson.has("textsize")) viewJson.getInt("textsize") else 22) * zoomFactor).toFloat())
|
view.setTextSize(TypedValue.COMPLEX_UNIT_PX, ((if (viewJson.has(TEXTSIZE.key)) viewJson.getInt(TEXTSIZE.key) else 22) * zoomFactor).toFloat())
|
||||||
view.gravity = GravityMap.gravity(if (viewJson.has("gravity")) viewJson.getString("gravity") else GravityMap.CENTER.key)
|
view.gravity = GravityMap.gravity(if (viewJson.has(GRAVITY.key)) viewJson.getString(GRAVITY.key) else GravityMap.CENTER.key)
|
||||||
view.setTypeface(
|
view.setTypeface(
|
||||||
FontMap.font(if (viewJson.has("font")) viewJson.getString("font") else FontMap.DEFAULT.key),
|
FontMap.font(if (viewJson.has(FONT.key)) viewJson.getString(FONT.key) else FontMap.DEFAULT.key),
|
||||||
StyleMap.style(if (viewJson.has("fontStyle")) viewJson.getString("fontStyle") else StyleMap.NORMAL.key)
|
StyleMap.style(if (viewJson.has(FONTSTYLE.key)) viewJson.getString(FONTSTYLE.key) else StyleMap.NORMAL.key)
|
||||||
)
|
)
|
||||||
if (viewJson.has("fontColor"))
|
if (viewJson.has(FONTCOLOR.key))
|
||||||
view.setTextColor(getColor(viewJson.getString("fontColor")))
|
view.setTextColor(getColor(viewJson.getString(FONTCOLOR.key)))
|
||||||
|
|
||||||
if (viewJson.has("textvalue"))
|
if (viewJson.has(TEXTVALUE.key))
|
||||||
view.text = viewJson.getString("textvalue")
|
view.text = viewJson.getString(TEXTVALUE.key)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (view is ImageView) {
|
if (view is ImageView) {
|
||||||
|
@ -203,15 +206,15 @@ class CustomWatchface : BaseWatchFace() {
|
||||||
else
|
else
|
||||||
drawableDataMap[CustomWatchfaceDrawableDataKey.fromKey(id.key)]?.toDrawable(resources)
|
drawableDataMap[CustomWatchfaceDrawableDataKey.fromKey(id.key)]?.toDrawable(resources)
|
||||||
drawable?.let {
|
drawable?.let {
|
||||||
if (viewJson.has("color"))
|
if (viewJson.has(COLOR.key))
|
||||||
it.colorFilter = changeDrawableColor(getColor(viewJson.getString("color")))
|
it.colorFilter = changeDrawableColor(getColor(viewJson.getString(COLOR.key)))
|
||||||
else
|
else
|
||||||
it.clearColorFilter()
|
it.clearColorFilter()
|
||||||
view.setImageDrawable(it)
|
view.setImageDrawable(it)
|
||||||
} ?: apply {
|
} ?: apply {
|
||||||
view.setImageDrawable(CustomWatchfaceDrawableDataKey.fromKey(id.key).icon?.let { context.getDrawable(it) })
|
view.setImageDrawable(CustomWatchfaceDrawableDataKey.fromKey(id.key).icon?.let { context.getDrawable(it) })
|
||||||
if (viewJson.has("color"))
|
if (viewJson.has(COLOR.key))
|
||||||
view.setColorFilter(getColor(viewJson.getString("color")))
|
view.setColorFilter(getColor(viewJson.getString(COLOR.key)))
|
||||||
else
|
else
|
||||||
view.clearColorFilter()
|
view.clearColorFilter()
|
||||||
}
|
}
|
||||||
|
@ -226,6 +229,7 @@ class CustomWatchface : BaseWatchFace() {
|
||||||
}
|
}
|
||||||
binding.background.visibility = View.VISIBLE
|
binding.background.visibility = View.VISIBLE
|
||||||
updateSecondVisibility()
|
updateSecondVisibility()
|
||||||
|
setSecond() // Update second visibility for time view
|
||||||
} catch (e: Exception) {
|
} catch (e: Exception) {
|
||||||
aapsLogger.debug(LTag.WEAR, "Crash during Custom watch load")
|
aapsLogger.debug(LTag.WEAR, "Crash during Custom watch load")
|
||||||
persistence.store(defaultWatchface(), false) // relaod correct values to avoid crash of watchface
|
persistence.store(defaultWatchface(), false) // relaod correct values to avoid crash of watchface
|
||||||
|
@ -254,58 +258,47 @@ class CustomWatchface : BaseWatchFace() {
|
||||||
.put(CustomWatchfaceMetadataKey.CWF_VERSION.key, CUSTOM_VERSION)
|
.put(CustomWatchfaceMetadataKey.CWF_VERSION.key, CUSTOM_VERSION)
|
||||||
.put(CustomWatchfaceMetadataKey.CWF_COMMENT.key, getString(info.nightscout.shared.R.string.default_custom_watchface_comment))
|
.put(CustomWatchfaceMetadataKey.CWF_COMMENT.key, getString(info.nightscout.shared.R.string.default_custom_watchface_comment))
|
||||||
val json = JSONObject()
|
val json = JSONObject()
|
||||||
.put("metadata", metadata)
|
.put(METADATA.key, metadata)
|
||||||
.put("highColor", String.format("#%06X", 0xFFFFFF and highColor))
|
.put(HIGHCOLOR.key, String.format("#%06X", 0xFFFFFF and highColor))
|
||||||
.put("midColor", String.format("#%06X", 0xFFFFFF and midColor))
|
.put(MIDCOLOR.key, String.format("#%06X", 0xFFFFFF and midColor))
|
||||||
.put("lowColor", String.format("#%06X", 0xFFFFFF and lowColor))
|
.put(LOWCOLOR.key, String.format("#%06X", 0xFFFFFF and lowColor))
|
||||||
.put("lowBatColor", String.format("#%06X", 0xFFFFFF and lowBatColor))
|
.put(LOWBATCOLOR.key, String.format("#%06X", 0xFFFFFF and lowBatColor))
|
||||||
.put("carbColor", String.format("#%06X", 0xFFFFFF and carbColor))
|
.put(CARBCOLOR.key, String.format("#%06X", 0xFFFFFF and carbColor))
|
||||||
.put("basalBackgroundColor", String.format("#%06X", 0xFFFFFF and basalBackgroundColor))
|
.put(BASALBACKGROUNDCOLOR.key, String.format("#%06X", 0xFFFFFF and basalBackgroundColor))
|
||||||
.put("basalCenterColor", String.format("#%06X", 0xFFFFFF and basalCenterColor))
|
.put(BASALCENTERCOLOR.key, String.format("#%06X", 0xFFFFFF and basalCenterColor))
|
||||||
.put("gridColor", String.format("#%06X", 0xFFFFFF and Color.WHITE))
|
.put(GRIDCOLOR.key, String.format("#%06X", 0xFFFFFF and Color.WHITE))
|
||||||
.put("pointSize", 2)
|
.put(POINTSIZE.key, 2)
|
||||||
.put("enableSecond", true)
|
.put(ENABLESECOND.key, true)
|
||||||
|
|
||||||
binding.mainLayout.forEach { view ->
|
binding.mainLayout.forEach { view ->
|
||||||
val params = view.layoutParams as FrameLayout.LayoutParams
|
val params = view.layoutParams as FrameLayout.LayoutParams
|
||||||
CustomViews.fromId(view.id)?.let {
|
ViewMap.fromId(view.id)?.let {
|
||||||
if (view is TextView) {
|
if (view is TextView) {
|
||||||
json.put(
|
json.put(
|
||||||
it.key,
|
it.key,
|
||||||
JSONObject()
|
JSONObject()
|
||||||
.put("width", (params.width / zoomFactor).toInt())
|
.put(WIDTH.key, (params.width / zoomFactor).toInt())
|
||||||
.put("height", (params.height / zoomFactor).toInt())
|
.put(HEIGHT.key, (params.height / zoomFactor).toInt())
|
||||||
.put("topmargin", (params.topMargin / zoomFactor).toInt())
|
.put(TOPMARGIN.key, (params.topMargin / zoomFactor).toInt())
|
||||||
.put("leftmargin", (params.leftMargin / zoomFactor).toInt())
|
.put(LEFTMARGIN.key, (params.leftMargin / zoomFactor).toInt())
|
||||||
.put("rotation", view.rotation.toInt())
|
.put(ROTATION.key, view.rotation.toInt())
|
||||||
.put("visibility", getVisibility(view.visibility))
|
.put(VISIBILITY.key, getVisibility(view.visibility))
|
||||||
.put("textsize", view.textSize.toInt())
|
.put(TEXTSIZE.key, view.textSize.toInt())
|
||||||
.put("gravity", GravityMap.key(view.gravity))
|
.put(GRAVITY.key, GravityMap.key(view.gravity))
|
||||||
.put("font", FontMap.key())
|
.put(FONT.key, FontMap.key())
|
||||||
.put("fontStyle", StyleMap.key(view.typeface.style))
|
.put(FONTSTYLE.key, StyleMap.key(view.typeface.style))
|
||||||
.put("fontColor", String.format("#%06X", 0xFFFFFF and view.currentTextColor))
|
.put(FONTCOLOR.key, String.format("#%06X", 0xFFFFFF and view.currentTextColor))
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
if (view is ImageView) {
|
if (view is ImageView || view is lecho.lib.hellocharts.view.LineChartView) {
|
||||||
json.put(
|
json.put(
|
||||||
it.key,
|
it.key,
|
||||||
JSONObject()
|
JSONObject()
|
||||||
.put("width", (params.width / zoomFactor).toInt())
|
.put(WIDTH.key, (params.width / zoomFactor).toInt())
|
||||||
.put("height", (params.height / zoomFactor).toInt())
|
.put(HEIGHT.key, (params.height / zoomFactor).toInt())
|
||||||
.put("topmargin", (params.topMargin / zoomFactor).toInt())
|
.put(TOPMARGIN.key, (params.topMargin / zoomFactor).toInt())
|
||||||
.put("leftmargin", (params.leftMargin / zoomFactor).toInt())
|
.put(LEFTMARGIN.key, (params.leftMargin / zoomFactor).toInt())
|
||||||
.put("visibility", getVisibility(view.visibility))
|
.put(VISIBILITY.key, getVisibility(view.visibility))
|
||||||
)
|
|
||||||
}
|
|
||||||
if (view is lecho.lib.hellocharts.view.LineChartView) {
|
|
||||||
json.put(
|
|
||||||
it.key,
|
|
||||||
JSONObject()
|
|
||||||
.put("width", (params.width / zoomFactor).toInt())
|
|
||||||
.put("height", (params.height / zoomFactor).toInt())
|
|
||||||
.put("topmargin", (params.topMargin / zoomFactor).toInt())
|
|
||||||
.put("leftmargin", (params.leftMargin / zoomFactor).toInt())
|
|
||||||
.put("visibility", getVisibility(view.visibility))
|
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -331,17 +324,17 @@ class CustomWatchface : BaseWatchFace() {
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun setVisibility(visibility: String, pref: Boolean = true): Int = when (visibility) {
|
private fun setVisibility(visibility: String, pref: Boolean = true): Int = when (visibility) {
|
||||||
"visible" -> pref.toVisibility()
|
JsonKeyValues.VISIBLE.key -> pref.toVisibility()
|
||||||
"invisible" -> pref.toVisibilityKeepSpace()
|
JsonKeyValues.INVISIBLE.key -> pref.toVisibilityKeepSpace()
|
||||||
"gone" -> View.GONE
|
JsonKeyValues.GONE.key -> View.GONE
|
||||||
else -> View.GONE
|
else -> View.GONE
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun getVisibility(visibility: Int): String = when (visibility) {
|
private fun getVisibility(visibility: Int): String = when (visibility) {
|
||||||
View.VISIBLE -> "visible"
|
View.VISIBLE -> JsonKeyValues.VISIBLE.key
|
||||||
View.INVISIBLE -> "invisible"
|
View.INVISIBLE -> JsonKeyValues.INVISIBLE.key
|
||||||
View.GONE -> "gone"
|
View.GONE -> JsonKeyValues.GONE.key
|
||||||
else -> "gone"
|
else -> JsonKeyValues.GONE.key
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun getResourceByteArray(resourceId: Int): ByteArray? {
|
private fun getResourceByteArray(resourceId: Int): ByteArray? {
|
||||||
|
@ -377,68 +370,67 @@ class CustomWatchface : BaseWatchFace() {
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun getColor(color: String): Int =
|
private fun getColor(color: String): Int =
|
||||||
if (color == "bgColor")
|
if (color == JsonKeyValues.BGCOLOR.key)
|
||||||
bgColor
|
bgColor
|
||||||
else
|
else
|
||||||
try { Color.parseColor(color) } catch (e: Exception) { Color.GRAY }
|
try { Color.parseColor(color) } catch (e: Exception) { Color.GRAY }
|
||||||
|
|
||||||
private enum class CustomViews(val key: String, @IdRes val id: Int, @StringRes val pref: Int?) {
|
private enum class ViewMap(val key: String, @IdRes val id: Int, @StringRes val pref: Int?) {
|
||||||
|
|
||||||
BACKGROUND(CustomWatchfaceDrawableDataKey.BACKGROUND.key, R.id.background, null),
|
BACKGROUND(ViewKeys.BACKGROUND.key, R.id.background, null),
|
||||||
CHART("chart", R.id.chart, null),
|
CHART(ViewKeys.CHART.key, R.id.chart, null),
|
||||||
COVER_CHART(CustomWatchfaceDrawableDataKey.COVERCHART.key, R.id.cover_chart, null),
|
COVER_CHART(ViewKeys.COVER_CHART.key, R.id.cover_chart, null),
|
||||||
FREETEXT1("freetext1", R.id.freetext1, null),
|
FREETEXT1(ViewKeys.FREETEXT1.key, R.id.freetext1, null),
|
||||||
FREETEXT2("freetext2", R.id.freetext2, null),
|
FREETEXT2(ViewKeys.FREETEXT2.key, R.id.freetext2, null),
|
||||||
FREETEXT3("freetext3", R.id.freetext3, null),
|
FREETEXT3(ViewKeys.FREETEXT3.key, R.id.freetext3, null),
|
||||||
FREETEXT4("freetext4", R.id.freetext4, null),
|
FREETEXT4(ViewKeys.FREETEXT4.key, R.id.freetext4, null),
|
||||||
IOB1("iob1", R.id.iob1, R.string.key_show_iob),
|
IOB1(ViewKeys.IOB1.key, R.id.iob1, R.string.key_show_iob),
|
||||||
IOB2("iob2", R.id.iob2, R.string.key_show_iob),
|
IOB2(ViewKeys.IOB2.key, R.id.iob2, R.string.key_show_iob),
|
||||||
COB1("cob1", R.id.cob1, R.string.key_show_cob),
|
COB1(ViewKeys.COB1.key, R.id.cob1, R.string.key_show_cob),
|
||||||
COB2("cob2", R.id.cob2, R.string.key_show_cob),
|
COB2(ViewKeys.COB2.key, R.id.cob2, R.string.key_show_cob),
|
||||||
DELTA("delta", R.id.delta, R.string.key_show_delta),
|
DELTA(ViewKeys.DELTA.key, R.id.delta, R.string.key_show_delta),
|
||||||
AVG_DELTA("avg_delta", R.id.avg_delta, R.string.key_show_avg_delta),
|
AVG_DELTA(ViewKeys.AVG_DELTA.key, R.id.avg_delta, R.string.key_show_avg_delta),
|
||||||
UPLOADER_BATTERY("uploader_battery", R.id.uploader_battery, R.string.key_show_uploader_battery),
|
UPLOADER_BATTERY(ViewKeys.UPLOADER_BATTERY.key, R.id.uploader_battery, R.string.key_show_uploader_battery),
|
||||||
RIG_BATTERY("rig_battery", R.id.rig_battery, R.string.key_show_rig_battery),
|
RIG_BATTERY(ViewKeys.RIG_BATTERY.key, R.id.rig_battery, R.string.key_show_rig_battery),
|
||||||
BASALRATE("basalRate", R.id.basalRate, R.string.key_show_temp_basal),
|
BASALRATE(ViewKeys.BASALRATE.key, R.id.basalRate, R.string.key_show_temp_basal),
|
||||||
BGI("bgi", R.id.bgi, R.string.key_show_bgi),
|
BGI(ViewKeys.BGI.key, R.id.bgi, R.string.key_show_bgi),
|
||||||
TIME("time", R.id.time, null),
|
TIME(ViewKeys.TIME.key, R.id.time, null),
|
||||||
HOUR("hour", R.id.hour, null),
|
HOUR(ViewKeys.HOUR.key, R.id.hour, null),
|
||||||
MINUTE("minute", R.id.minute, null),
|
MINUTE(ViewKeys.MINUTE.key, R.id.minute, null),
|
||||||
SECOND("second", R.id.second, R.string.key_show_seconds),
|
SECOND(ViewKeys.SECOND.key, R.id.second, R.string.key_show_seconds),
|
||||||
TIMEPERIOD("timePeriod", R.id.timePeriod, null),
|
TIMEPERIOD(ViewKeys.TIMEPERIOD.key, R.id.timePeriod, null),
|
||||||
DAY_NAME("day_name", R.id.day_name, null),
|
DAY_NAME(ViewKeys.DAY_NAME.key, R.id.day_name, null),
|
||||||
DAY("day", R.id.day, null),
|
DAY(ViewKeys.DAY.key, R.id.day, null),
|
||||||
MONTH("month", R.id.month, null),
|
MONTH(ViewKeys.MONTH.key, R.id.month, null),
|
||||||
LOOP("loop", R.id.loop, R.string.key_show_external_status),
|
LOOP(ViewKeys.LOOP.key, R.id.loop, R.string.key_show_external_status),
|
||||||
DIRECTION("direction", R.id.direction2, R.string.key_show_direction),
|
DIRECTION(ViewKeys.DIRECTION.key, R.id.direction2, R.string.key_show_direction),
|
||||||
TIMESTAMP("timestamp", R.id.timestamp, R.string.key_show_ago),
|
TIMESTAMP(ViewKeys.TIMESTAMP.key, R.id.timestamp, R.string.key_show_ago),
|
||||||
SGV("sgv", R.id.sgv, R.string.key_show_bg),
|
SGV(ViewKeys.SGV.key, R.id.sgv, R.string.key_show_bg),
|
||||||
COVER_PLATE(CustomWatchfaceDrawableDataKey.COVERPLATE.key, R.id.cover_plate, null),
|
COVER_PLATE(ViewKeys.COVER_PLATE.key, R.id.cover_plate, null),
|
||||||
HOUR_HABD(CustomWatchfaceDrawableDataKey.HOURHAND.key, R.id.hour_hand, null),
|
HOUR_HAND(ViewKeys.HOUR_HAND.key, R.id.hour_hand, null),
|
||||||
MINUTE_HAND(CustomWatchfaceDrawableDataKey.MINUTEHAND.key, R.id.minute_hand, null),
|
MINUTE_HAND(ViewKeys.MINUTE_HAND.key, R.id.minute_hand, null),
|
||||||
SECOND_HAND(CustomWatchfaceDrawableDataKey.SECONDHAND.key, R.id.second_hand, R.string.key_show_seconds);
|
SECOND_HAND(ViewKeys.SECOND_HAND.key, R.id.second_hand, R.string.key_show_seconds);
|
||||||
|
|
||||||
companion object {
|
companion object {
|
||||||
|
|
||||||
fun fromId(id: Int): CustomViews? = values().firstOrNull { it.id == id }
|
fun fromId(id: Int): ViewMap? = values().firstOrNull { it.id == id }
|
||||||
}
|
}
|
||||||
|
|
||||||
fun visibility(sp: SP): Boolean = this.pref?.let { sp.getBoolean(it, true) }
|
fun visibility(sp: SP): Boolean = this.pref?.let { sp.getBoolean(it, true) }
|
||||||
?: true
|
?: true
|
||||||
}
|
}
|
||||||
|
|
||||||
private enum class TrendArrow(val text: String, val symbol: String, @DrawableRes val icon: Int) {
|
private enum class TrendArrowMap(val symbol: String, @DrawableRes val icon: Int) {
|
||||||
NONE("NONE", "??", R.drawable.ic_invalid),
|
NONE("??", R.drawable.ic_invalid),
|
||||||
TRIPLE_UP("TripleUp", "X", R.drawable.ic_doubleup),
|
TRIPLE_UP("X", R.drawable.ic_doubleup),
|
||||||
DOUBLE_UP("DoubleUp", "\u21c8", R.drawable.ic_doubleup),
|
DOUBLE_UP("\u21c8", R.drawable.ic_doubleup),
|
||||||
SINGLE_UP("SingleUp", "\u2191", R.drawable.ic_singleup),
|
SINGLE_UP("\u2191", R.drawable.ic_singleup),
|
||||||
FORTY_FIVE_UP("FortyFiveUp", "\u2197", R.drawable.ic_fortyfiveup),
|
FORTY_FIVE_UP("\u2197", R.drawable.ic_fortyfiveup),
|
||||||
FLAT("Flat", "\u2192", R.drawable.ic_flat),
|
FLAT("\u2192", R.drawable.ic_flat),
|
||||||
FORTY_FIVE_DOWN("FortyFiveDown", "\u2198", R.drawable.ic_fortyfivedown),
|
FORTY_FIVE_DOWN("\u2198", R.drawable.ic_fortyfivedown),
|
||||||
SINGLE_DOWN("SingleDown", "\u2193", R.drawable.ic_singledown),
|
SINGLE_DOWN("\u2193", R.drawable.ic_singledown),
|
||||||
DOUBLE_DOWN("DoubleDown", "\u21ca", R.drawable.ic_doubledown),
|
DOUBLE_DOWN("\u21ca", R.drawable.ic_doubledown),
|
||||||
TRIPLE_DOWN("TripleDown", "X", R.drawable.ic_doubledown)
|
TRIPLE_DOWN("X", R.drawable.ic_doubledown);
|
||||||
;
|
|
||||||
|
|
||||||
companion object {
|
companion object {
|
||||||
|
|
||||||
|
@ -447,9 +439,9 @@ class CustomWatchface : BaseWatchFace() {
|
||||||
}
|
}
|
||||||
|
|
||||||
private enum class GravityMap(val key: String, val gravity: Int) {
|
private enum class GravityMap(val key: String, val gravity: Int) {
|
||||||
CENTER("center", Gravity.CENTER),
|
CENTER(JsonKeyValues.CENTER.key, Gravity.CENTER),
|
||||||
LEFT("left", Gravity.LEFT),
|
LEFT(JsonKeyValues.LEFT.key, Gravity.LEFT),
|
||||||
RIGHT("right", Gravity.RIGHT);
|
RIGHT(JsonKeyValues.RIGHT.key, Gravity.RIGHT);
|
||||||
|
|
||||||
companion object {
|
companion object {
|
||||||
|
|
||||||
|
@ -459,15 +451,15 @@ class CustomWatchface : BaseWatchFace() {
|
||||||
}
|
}
|
||||||
|
|
||||||
private enum class FontMap(val key: String, var font: Typeface, @FontRes val fontRessources: Int?) {
|
private enum class FontMap(val key: String, var font: Typeface, @FontRes val fontRessources: Int?) {
|
||||||
SANS_SERIF("sans_serif", Typeface.SANS_SERIF, null),
|
SANS_SERIF(JsonKeyValues.SANS_SERIF.key, Typeface.SANS_SERIF, null),
|
||||||
DEFAULT("default", Typeface.DEFAULT, null),
|
DEFAULT(JsonKeyValues.DEFAULT.key, Typeface.DEFAULT, null),
|
||||||
DEFAULT_BOLD("default_bold", Typeface.DEFAULT_BOLD, null),
|
DEFAULT_BOLD(JsonKeyValues.DEFAULT_BOLD.key, Typeface.DEFAULT_BOLD, null),
|
||||||
MONOSPACE("monospace", Typeface.MONOSPACE, null),
|
MONOSPACE(JsonKeyValues.MONOSPACE.key, Typeface.MONOSPACE, null),
|
||||||
SERIF("serif", Typeface.SERIF, null),
|
SERIF(JsonKeyValues.SERIF.key, Typeface.SERIF, null),
|
||||||
ROBOTO_CONDENSED_BOLD("roboto_condensed_bold", Typeface.DEFAULT, R.font.roboto_condensed_bold),
|
ROBOTO_CONDENSED_BOLD(JsonKeyValues.ROBOTO_CONDENSED_BOLD.key, Typeface.DEFAULT, R.font.roboto_condensed_bold),
|
||||||
ROBOTO_CONDENSED_LIGHT("roboto_condensed_light", Typeface.DEFAULT, R.font.roboto_condensed_light),
|
ROBOTO_CONDENSED_LIGHT(JsonKeyValues.ROBOTO_CONDENSED_LIGHT.key, Typeface.DEFAULT, R.font.roboto_condensed_light),
|
||||||
ROBOTO_CONDENSED_REGULAR("roboto_condensed_regular", Typeface.DEFAULT, R.font.roboto_condensed_regular),
|
ROBOTO_CONDENSED_REGULAR(JsonKeyValues.ROBOTO_CONDENSED_REGULAR.key, Typeface.DEFAULT, R.font.roboto_condensed_regular),
|
||||||
ROBOTO_SLAB_LIGHT("roboto_slab_light", Typeface.DEFAULT, R.font.roboto_slab_light);
|
ROBOTO_SLAB_LIGHT(JsonKeyValues.ROBOTO_SLAB_LIGHT.key, Typeface.DEFAULT, R.font.roboto_slab_light);
|
||||||
|
|
||||||
companion object {
|
companion object {
|
||||||
fun init(context: Context) = values().forEach { it.font = it.fontRessources?.let { font -> ResourcesCompat.getFont(context, font) } ?: it.font }
|
fun init(context: Context) = values().forEach { it.font = it.fontRessources?.let { font -> ResourcesCompat.getFont(context, font) } ?: it.font }
|
||||||
|
@ -477,10 +469,10 @@ class CustomWatchface : BaseWatchFace() {
|
||||||
}
|
}
|
||||||
|
|
||||||
private enum class StyleMap(val key: String, val style: Int) {
|
private enum class StyleMap(val key: String, val style: Int) {
|
||||||
NORMAL("normal", Typeface.NORMAL),
|
NORMAL(JsonKeyValues.NORMAL.key, Typeface.NORMAL),
|
||||||
BOLD("bold", Typeface.BOLD),
|
BOLD(JsonKeyValues.BOLD.key, Typeface.BOLD),
|
||||||
BOLD_ITALIC("bold_italic", Typeface.BOLD_ITALIC),
|
BOLD_ITALIC(JsonKeyValues.BOLD_ITALIC.key, Typeface.BOLD_ITALIC),
|
||||||
ITALIC("italic", Typeface.ITALIC);
|
ITALIC(JsonKeyValues.ITALIC.key, Typeface.ITALIC);
|
||||||
|
|
||||||
companion object {
|
companion object {
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue