Support multiple 2nd-TZ and Custom widgets

This commit is contained in:
Arjan Schrijver 2021-11-12 15:34:57 +01:00
parent cd183eb953
commit 1a5ebe2ee7
10 changed files with 58 additions and 59 deletions

View File

@ -376,14 +376,18 @@ public class HybridHRWatchfaceDesignerActivity extends AbstractGBActivity implem
widgetName = "widget2ndTZ"; widgetName = "widget2ndTZ";
break; break;
} }
if (widgetName.equals("widget2ndTZ")) { if (widgetName.startsWith("widget2ndTZ")) {
try { try {
widgetName = "widget2ndTZ";
JSONObject widgetData = layoutItem.getJSONObject("data"); JSONObject widgetData = layoutItem.getJSONObject("data");
widgetTimezone = widgetData.getString("tzName"); widgetTimezone = widgetData.getString("tzName");
} catch (JSONException e) { } catch (JSONException e) {
LOG.error("Couldn't determine tzName!", e); LOG.error("Couldn't determine tzName!", e);
} }
} }
if (widgetName.startsWith("widgetCustom")) {
widgetName = "widgetCustom";
}
int widgetColor = layoutItem.getString("color").equals("white") ? HybridHRWatchfaceWidget.COLOR_WHITE : HybridHRWatchfaceWidget.COLOR_BLACK; int widgetColor = layoutItem.getString("color").equals("white") ? HybridHRWatchfaceWidget.COLOR_WHITE : HybridHRWatchfaceWidget.COLOR_BLACK;
widgets.add(new HybridHRWatchfaceWidget(widgetName, widgets.add(new HybridHRWatchfaceWidget(widgetName,
layoutItem.getJSONObject("pos").getInt("x"), layoutItem.getJSONObject("pos").getInt("x"),

View File

@ -71,10 +71,7 @@ public class HybridHRWatchfaceFactory {
case "widgetCalories": case "widgetCalories":
case "widgetActiveMins": case "widgetActiveMins":
case "widgetChanceOfRain": case "widgetChanceOfRain":
case "widgetCustom0": case "widgetCustom":
case "widgetCustom1":
case "widgetCustom2":
case "widgetCustom3":
widget.put("type", "comp"); widget.put("type", "comp");
widget.put("name", widgetDesc.getWidgetType()); widget.put("name", widgetDesc.getWidgetType());
widget.put("goal_ring", false); widget.put("goal_ring", false);
@ -120,16 +117,17 @@ public class HybridHRWatchfaceFactory {
} }
} }
private boolean includeWidget(String name) { private int includeWidget(String name) {
int count = 0;
for (JSONObject widget : this.widgets) { for (JSONObject widget : this.widgets) {
try { try {
if (widget.get("name").equals(name)) { if (widget.get("name").equals(name)) {
return true; count++;
} }
} catch (JSONException e) { } catch (JSONException e) {
} }
} }
return false; return count;
} }
public byte[] getWapp(Context context) throws IOException { public byte[] getWapp(Context context) throws IOException {
@ -138,19 +136,20 @@ public class HybridHRWatchfaceFactory {
LinkedHashMap<String, InputStream> code = new LinkedHashMap<>(); LinkedHashMap<String, InputStream> code = new LinkedHashMap<>();
try { try {
code.put(watchfaceName, context.getAssets().open("fossil_hr/openSourceWatchface.bin")); code.put(watchfaceName, context.getAssets().open("fossil_hr/openSourceWatchface.bin"));
if (includeWidget("widgetDate")) code.put("widgetDate", context.getAssets().open("fossil_hr/widgetDate.bin")); if (includeWidget("widgetDate") > 0) code.put("widgetDate", context.getAssets().open("fossil_hr/widgetDate.bin"));
if (includeWidget("widgetWeather")) code.put("widgetWeather", context.getAssets().open("fossil_hr/widgetWeather.bin")); if (includeWidget("widgetWeather") > 0) code.put("widgetWeather", context.getAssets().open("fossil_hr/widgetWeather.bin"));
if (includeWidget("widgetSteps")) code.put("widgetSteps", context.getAssets().open("fossil_hr/widgetSteps.bin")); if (includeWidget("widgetSteps") > 0) code.put("widgetSteps", context.getAssets().open("fossil_hr/widgetSteps.bin"));
if (includeWidget("widgetHR")) code.put("widgetHR", context.getAssets().open("fossil_hr/widgetHR.bin")); if (includeWidget("widgetHR") > 0) code.put("widgetHR", context.getAssets().open("fossil_hr/widgetHR.bin"));
if (includeWidget("widgetBattery")) code.put("widgetBattery", context.getAssets().open("fossil_hr/widgetBattery.bin")); if (includeWidget("widgetBattery") > 0) code.put("widgetBattery", context.getAssets().open("fossil_hr/widgetBattery.bin"));
if (includeWidget("widgetCalories")) code.put("widgetCalories", context.getAssets().open("fossil_hr/widgetCalories.bin")); if (includeWidget("widgetCalories") > 0) code.put("widgetCalories", context.getAssets().open("fossil_hr/widgetCalories.bin"));
if (includeWidget("widgetActiveMins")) code.put("widgetActiveMins", context.getAssets().open("fossil_hr/widgetActiveMins.bin")); if (includeWidget("widgetActiveMins") > 0) code.put("widgetActiveMins", context.getAssets().open("fossil_hr/widgetActiveMins.bin"));
if (includeWidget("widgetChanceOfRain")) code.put("widgetChanceOfRain", context.getAssets().open("fossil_hr/widgetChanceOfRain.bin")); if (includeWidget("widgetChanceOfRain") > 0) code.put("widgetChanceOfRain", context.getAssets().open("fossil_hr/widgetChanceOfRain.bin"));
if (includeWidget("widget2ndTZ")) code.put("widget2ndTZ", context.getAssets().open("fossil_hr/widget2ndTZ.bin")); for (int i=0; i<includeWidget("widget2ndTZ"); i++) {
if (includeWidget("widgetCustom0")) code.put("widgetCustom0", context.getAssets().open("fossil_hr/widgetCustom0.bin")); code.put("widget2ndTZ" + i, context.getAssets().open("fossil_hr/widget2ndTZ.bin"));
if (includeWidget("widgetCustom1")) code.put("widgetCustom1", context.getAssets().open("fossil_hr/widgetCustom1.bin")); }
if (includeWidget("widgetCustom2")) code.put("widgetCustom2", context.getAssets().open("fossil_hr/widgetCustom2.bin")); for (int i=0; i<includeWidget("widgetCustom"); i++) {
if (includeWidget("widgetCustom3")) code.put("widgetCustom3", context.getAssets().open("fossil_hr/widgetCustom3.bin")); code.put("widgetCustom" + i, context.getAssets().open("fossil_hr/widgetCustom.bin"));
}
} catch (IOException e) { } catch (IOException e) {
LOG.warn("Unable to read asset file", e); LOG.warn("Unable to read asset file", e);
} }
@ -158,23 +157,23 @@ public class HybridHRWatchfaceFactory {
try { try {
icons.put("background.raw", backgroundStream); icons.put("background.raw", backgroundStream);
icons.put("icTrophy", context.getAssets().open("fossil_hr/icTrophy.rle")); icons.put("icTrophy", context.getAssets().open("fossil_hr/icTrophy.rle"));
if (includeWidget("widgetWeather")) icons.put("icWthClearDay", context.getAssets().open("fossil_hr/icWthClearDay.rle")); if (includeWidget("widgetWeather") > 0) icons.put("icWthClearDay", context.getAssets().open("fossil_hr/icWthClearDay.rle"));
if (includeWidget("widgetWeather")) icons.put("icWthClearNite", context.getAssets().open("fossil_hr/icWthClearNite.rle")); if (includeWidget("widgetWeather") > 0) icons.put("icWthClearNite", context.getAssets().open("fossil_hr/icWthClearNite.rle"));
if (includeWidget("widgetWeather")) icons.put("icWthCloudy", context.getAssets().open("fossil_hr/icWthCloudy.rle")); if (includeWidget("widgetWeather") > 0) icons.put("icWthCloudy", context.getAssets().open("fossil_hr/icWthCloudy.rle"));
if (includeWidget("widgetWeather")) icons.put("icWthPartCloudyDay", context.getAssets().open("fossil_hr/icWthPartCloudyDay.rle")); if (includeWidget("widgetWeather") > 0) icons.put("icWthPartCloudyDay", context.getAssets().open("fossil_hr/icWthPartCloudyDay.rle"));
if (includeWidget("widgetWeather")) icons.put("icWthPartCloudyNite", context.getAssets().open("fossil_hr/icWthPartCloudyNite.rle")); if (includeWidget("widgetWeather") > 0) icons.put("icWthPartCloudyNite", context.getAssets().open("fossil_hr/icWthPartCloudyNite.rle"));
if (includeWidget("widgetWeather")) icons.put("icWthRainy", context.getAssets().open("fossil_hr/icWthRainy.rle")); if (includeWidget("widgetWeather") > 0) icons.put("icWthRainy", context.getAssets().open("fossil_hr/icWthRainy.rle"));
if (includeWidget("widgetWeather")) icons.put("icWthSnowy", context.getAssets().open("fossil_hr/icWthSnowy.rle")); if (includeWidget("widgetWeather") > 0) icons.put("icWthSnowy", context.getAssets().open("fossil_hr/icWthSnowy.rle"));
if (includeWidget("widgetWeather")) icons.put("icWthStormy", context.getAssets().open("fossil_hr/icWthStormy.rle")); if (includeWidget("widgetWeather") > 0) icons.put("icWthStormy", context.getAssets().open("fossil_hr/icWthStormy.rle"));
if (includeWidget("widgetWeather")) icons.put("icWthWindy", context.getAssets().open("fossil_hr/icWthWindy.rle")); if (includeWidget("widgetWeather") > 0) icons.put("icWthWindy", context.getAssets().open("fossil_hr/icWthWindy.rle"));
if (includeWidget("widgetSteps")) icons.put("icSteps", context.getAssets().open("fossil_hr/icSteps.rle")); if (includeWidget("widgetSteps") > 0) icons.put("icSteps", context.getAssets().open("fossil_hr/icSteps.rle"));
if (includeWidget("widgetHR")) icons.put("icHeart", context.getAssets().open("fossil_hr/icHeart.rle")); if (includeWidget("widgetHR") > 0) icons.put("icHeart", context.getAssets().open("fossil_hr/icHeart.rle"));
if (includeWidget("widgetBattery")) icons.put("icBattCharging", context.getAssets().open("fossil_hr/icBattCharging.rle")); if (includeWidget("widgetBattery") > 0) icons.put("icBattCharging", context.getAssets().open("fossil_hr/icBattCharging.rle"));
if (includeWidget("widgetBattery")) icons.put("icBattEmpty", context.getAssets().open("fossil_hr/icBattEmpty.rle")); if (includeWidget("widgetBattery") > 0) icons.put("icBattEmpty", context.getAssets().open("fossil_hr/icBattEmpty.rle"));
if (includeWidget("widgetBattery")) icons.put("icBattery", context.getAssets().open("fossil_hr/icBattery.rle")); if (includeWidget("widgetBattery") > 0) icons.put("icBattery", context.getAssets().open("fossil_hr/icBattery.rle"));
if (includeWidget("widgetCalories")) icons.put("icCalories", context.getAssets().open("fossil_hr/icCalories.rle")); if (includeWidget("widgetCalories") > 0) icons.put("icCalories", context.getAssets().open("fossil_hr/icCalories.rle"));
if (includeWidget("widgetActiveMins")) icons.put("icActiveMins", context.getAssets().open("fossil_hr/icActiveMins.rle")); if (includeWidget("widgetActiveMins") > 0) icons.put("icActiveMins", context.getAssets().open("fossil_hr/icActiveMins.rle"));
if (includeWidget("widgetChanceOfRain")) icons.put("icRainChance", context.getAssets().open("fossil_hr/icRainChance.rle")); if (includeWidget("widgetChanceOfRain") > 0) icons.put("icRainChance", context.getAssets().open("fossil_hr/icRainChance.rle"));
} catch (IOException e) { } catch (IOException e) {
LOG.warn("Unable to read asset file", e); LOG.warn("Unable to read asset file", e);
} }
@ -190,7 +189,7 @@ public class HybridHRWatchfaceFactory {
LOG.warn("Could not generate image_layout", e); LOG.warn("Could not generate image_layout", e);
} }
try { try {
if (includeWidget("widgetBattery")) layout.put("battery_layout", getBatteryLayout()); if (includeWidget("widgetBattery") > 0) layout.put("battery_layout", getBatteryLayout());
} catch (JSONException e) { } catch (JSONException e) {
LOG.warn("Could not generate battery_layout", e); LOG.warn("Could not generate battery_layout", e);
} }
@ -401,8 +400,20 @@ public class HybridHRWatchfaceFactory {
pos.put("y", 120); pos.put("y", 120);
background.put("pos", pos); background.put("pos", pos);
layout.put(background); layout.put(background);
int count_widget2ndTZ = 0;
int count_widgetCustom = 0;
for (JSONObject widget : widgets) { for (JSONObject widget : widgets) {
layout.put(widget); if (widget.get("name").equals("widget2ndTZ")) {
widget.put("name", "widget2ndTZ" + count_widget2ndTZ);
layout.put(widget);
count_widget2ndTZ++;
} else if (widget.get("name").equals("widgetCustom")) {
widget.put("name", "widgetCustom" + count_widgetCustom);
layout.put(widget);
count_widgetCustom++;
} else {
layout.put(widget);
}
} }
configuration.put("layout", layout); configuration.put("layout", layout);

View File

@ -59,10 +59,7 @@ public class HybridHRWatchfaceWidget {
widgetTypes.put("widgetCalories", context.getString(R.string.watchface_widget_type_calories)); widgetTypes.put("widgetCalories", context.getString(R.string.watchface_widget_type_calories));
widgetTypes.put("widget2ndTZ", context.getString(R.string.watchface_widget_type_2nd_tz)); widgetTypes.put("widget2ndTZ", context.getString(R.string.watchface_widget_type_2nd_tz));
widgetTypes.put("widgetActiveMins", context.getString(R.string.watchface_widget_type_active_mins)); widgetTypes.put("widgetActiveMins", context.getString(R.string.watchface_widget_type_active_mins));
widgetTypes.put("widgetCustom0", context.getString(R.string.watchface_widget_type_custom_0)); widgetTypes.put("widgetCustom", context.getString(R.string.watchface_widget_type_custom));
widgetTypes.put("widgetCustom1", context.getString(R.string.watchface_widget_type_custom_1));
widgetTypes.put("widgetCustom2", context.getString(R.string.watchface_widget_type_custom_2));
widgetTypes.put("widgetCustom3", context.getString(R.string.watchface_widget_type_custom_3));
// widgetTypes.put("widgetChanceOfRain", context.getString(R.string.watchface_widget_type_chance_rain)); // Disabled due to missing support in Gadgetbridge // widgetTypes.put("widgetChanceOfRain", context.getString(R.string.watchface_widget_type_chance_rain)); // Disabled due to missing support in Gadgetbridge
return widgetTypes; return widgetTypes;
} }

View File

@ -1234,13 +1234,6 @@ public class FossilHRWatchAdapter extends FossilWatchAdapter {
.put("widgetCustom1._.config.upper_text", "1 up") .put("widgetCustom1._.config.upper_text", "1 up")
.put("widgetCustom1._.config.lower_text", "1 low") .put("widgetCustom1._.config.lower_text", "1 low")
.put("widgetCustom2._.config.upper_text", "2 up")
.put("widgetCustom2._.config.lower_text", "2 low")
.put("widgetCustom3._.config.upper_text", "3 up")
.put("widgetCustom3._.config.lower_text", "3 low")
) )
); );
queueWrite(new JsonPutRequest(data, this)); queueWrite(new JsonPutRequest(data, this));

View File

@ -1376,9 +1376,6 @@
<string name="sony_automatic_power_off_30_min">30 minutes</string> <string name="sony_automatic_power_off_30_min">30 minutes</string>
<string name="sony_automatic_power_off_1_hour">1 hour</string> <string name="sony_automatic_power_off_1_hour">1 hour</string>
<string name="sony_automatic_power_off_3_hour">3 hours</string> <string name="sony_automatic_power_off_3_hour">3 hours</string>
<string name="watchface_widget_type_custom_0">Custom widget 0</string> <string name="watchface_widget_type_custom">Custom widget</string>
<string name="watchface_widget_type_custom_1">Custom widget 1</string>
<string name="watchface_widget_type_custom_2">Custom widget 2</string>
<string name="watchface_widget_type_custom_3">Custom widget 3</string>
</resources> </resources>

View File

@ -14,9 +14,6 @@ $jerry generate -f '' widget_calories.js -o widgetCalories.bin
$jerry generate -f '' widget_2nd_tz.js -o widget2ndTZ.bin $jerry generate -f '' widget_2nd_tz.js -o widget2ndTZ.bin
$jerry generate -f '' widget_activemins.js -o widgetActiveMins.bin $jerry generate -f '' widget_activemins.js -o widgetActiveMins.bin
$jerry generate -f '' widget_chanceofrain.js -o widgetChanceOfRain.bin $jerry generate -f '' widget_chanceofrain.js -o widgetChanceOfRain.bin
$jerry generate -f '' widget_custom.js -o widgetCustom0.bin $jerry generate -f '' widget_custom.js -o widgetCustom.bin
cp widgetCustom0.bin widgetCustom1.bin
cp widgetCustom0.bin widgetCustom2.bin
cp widgetCustom0.bin widgetCustom3.bin
popd popd
mv fossil-hr-watchface/*.bin ../app/src/main/assets/fossil_hr/ mv fossil-hr-watchface/*.bin ../app/src/main/assets/fossil_hr/