1
0
mirror of https://codeberg.org/Freeyourgadget/Gadgetbridge synced 2025-01-14 19:57:32 +01:00

Merge branch 'master' of https://codeberg.org/Freeyourgadget/Gadgetbridge into fossil-q-hr-background-image

This commit is contained in:
Daniel Dakhno 2020-04-08 03:26:30 +02:00
commit b34e74494d
9 changed files with 61 additions and 61 deletions

View File

@ -1,5 +1,6 @@
package nodomain.freeyourgadget.gadgetbridge.devices.qhybrid; package nodomain.freeyourgadget.gadgetbridge.devices.qhybrid;
import android.annotation.SuppressLint;
import android.app.AlertDialog; import android.app.AlertDialog;
import android.content.DialogInterface; import android.content.DialogInterface;
import android.content.Intent; import android.content.Intent;
@ -240,7 +241,6 @@ public class HRConfigActivity extends AbstractGBActivity implements View.OnClick
JSONObject widgetObject = new JSONObject(); JSONObject widgetObject = new JSONObject();
widgetObject widgetObject
.put("name", widget.getName()) .put("name", widget.getName())
.put("drawCircle", widget.getDrawCircle())
.put("elements", elementArray); .put("elements", elementArray);
widgetArray.put(widgetObject); widgetArray.put(widgetObject);
@ -261,7 +261,7 @@ public class HRConfigActivity extends AbstractGBActivity implements View.OnClick
for (int i = 0; i < customWidgets.length(); i++) { for (int i = 0; i < customWidgets.length(); i++) {
JSONObject customWidgetObject = customWidgets.getJSONObject(i); JSONObject customWidgetObject = customWidgets.getJSONObject(i);
CustomWidget widget = new CustomWidget( CustomWidget widget = new CustomWidget(
customWidgetObject.getString("name"), 0, 0, "default", false // FIXME: handle force white background customWidgetObject.getString("name"), 0, 0, "default" // FIXME: handle force white background
); );
JSONArray elements = customWidgetObject.getJSONArray("elements"); JSONArray elements = customWidgetObject.getJSONArray("elements");
@ -527,6 +527,7 @@ public class HRConfigActivity extends AbstractGBActivity implements View.OnClick
super(HRConfigActivity.this, 0, objects); super(HRConfigActivity.this, 0, objects);
} }
@SuppressLint("ResourceType")
@NonNull @NonNull
@Override @Override
public View getView(final int position, @Nullable View convertView, @NonNull ViewGroup parent) { public View getView(final int position, @Nullable View convertView, @NonNull ViewGroup parent) {

View File

@ -50,10 +50,9 @@ public class WidgetSettingsActivity extends AbstractGBActivity {
if(getIntent().hasExtra("EXTRA_WIDGET")){ if(getIntent().hasExtra("EXTRA_WIDGET")){
subject = (CustomWidget) getIntent().getExtras().get("EXTRA_WIDGET"); subject = (CustomWidget) getIntent().getExtras().get("EXTRA_WIDGET");
((EditText) findViewById(R.id.qhybrid_widget_name)).setText(subject.getName()); ((EditText) findViewById(R.id.qhybrid_widget_name)).setText(subject.getName());
((CheckBox)findViewById(R.id.qhybrid_widget_circle)).setChecked(subject.getDrawCircle());
resultCode = RESULT_CODE_WIDGET_UPDATED; resultCode = RESULT_CODE_WIDGET_UPDATED;
}else{ }else{
subject = new CustomWidget("", 0, 63, "default", false); // FIXME: handle force white background subject = new CustomWidget("", 0, 63, "default"); // FIXME: handle force white background
resultCode = RESULT_CODE_WIDGET_CREATED; resultCode = RESULT_CODE_WIDGET_CREATED;
findViewById(R.id.qhybrid_widget_delete).setEnabled(false); findViewById(R.id.qhybrid_widget_delete).setEnabled(false);
} }
@ -96,13 +95,6 @@ public class WidgetSettingsActivity extends AbstractGBActivity {
showElementDialog(null); showElementDialog(null);
} }
}); });
((CheckBox)findViewById(R.id.qhybrid_widget_circle)).setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
@Override
public void onCheckedChanged(CompoundButton compoundButton, boolean b) {
subject.setDrawCircle(b);
}
});
} }
private void showElementDialog(@Nullable final CustomWidgetElement element){ private void showElementDialog(@Nullable final CustomWidgetElement element){

View File

@ -242,8 +242,7 @@ public class FossilHRWatchAdapter extends FossilWatchAdapter {
customWidget.getString("name"), customWidget.getString("name"),
positionMap.get(position), positionMap.get(position),
63, 63,
fontColor, fontColor
drawCircle
); );
JSONArray elements = customWidget.getJSONArray("elements"); JSONArray elements = customWidget.getJSONArray("elements");
@ -290,32 +289,50 @@ public class FossilHRWatchAdapter extends FossilWatchAdapter {
private void renderWidgets() { private void renderWidgets() {
Prefs prefs = new Prefs(GBApplication.getDeviceSpecificSharedPrefs(getDeviceSupport().getDevice().getAddress())); Prefs prefs = new Prefs(GBApplication.getDeviceSpecificSharedPrefs(getDeviceSupport().getDevice().getAddress()));
boolean forceWhiteBackground = prefs.getBoolean("force_white_color_scheme", false); boolean forceWhiteBackground = prefs.getBoolean("force_white_color_scheme", false);
boolean drawCircles = prefs.getBoolean("widget_draw_circles", false);
Bitmap circleBitmap = null;
if(drawCircles) {
circleBitmap = Bitmap.createBitmap(76, 76, Bitmap.Config.ARGB_8888);
Canvas circleCanvas = new Canvas(circleBitmap);
Paint circlePaint = new Paint();
circlePaint.setColor(forceWhiteBackground ? Color.WHITE : Color.BLACK);
circlePaint.setStyle(Paint.Style.FILL);
circlePaint.setStrokeWidth(3);
circleCanvas.drawCircle(38, 38, 37, circlePaint);
circlePaint.setColor(forceWhiteBackground ? Color.BLACK : Color.WHITE);
circlePaint.setStyle(Paint.Style.STROKE);
circlePaint.setStrokeWidth(3);
circleCanvas.drawCircle(38, 38, 37, circlePaint);
}
try { try {
ArrayList<AssetImage> widgetImages = new ArrayList<>(); ArrayList<AssetImage> widgetImages = new ArrayList<>();
for (int i = 0; i < this.widgets.size(); i++) { for (int i = 0; i < this.widgets.size(); i++) {
Widget w = widgets.get(i); Widget w = widgets.get(i);
if(!(w instanceof CustomWidget)) continue; if(!(w instanceof CustomWidget)){
if(drawCircles) {
widgetImages.add(AssetImageFactory.createAssetImage(
circleBitmap,
true,
w.getAngle(),
w.getDistance(),
1
));
}
continue;
};
CustomWidget widget = (CustomWidget) w; CustomWidget widget = (CustomWidget) w;
Bitmap widgetBitmap = Bitmap.createBitmap(76, 76, Bitmap.Config.ARGB_8888); Bitmap widgetBitmap = Bitmap.createBitmap(76, 76, Bitmap.Config.ARGB_8888);
Canvas widgetCanvas = new Canvas(widgetBitmap); Canvas widgetCanvas = new Canvas(widgetBitmap);
boolean backgroundDrawn = false; if(drawCircles){
widgetCanvas.drawBitmap(circleBitmap, 0, 0, null);
if(widget.getDrawCircle() && !backgroundDrawn){
Paint circlePaint = new Paint();
circlePaint.setColor(forceWhiteBackground ? Color.WHITE : Color.BLACK);
circlePaint.setStyle(Paint.Style.FILL);
circlePaint.setStrokeWidth(3);
widgetCanvas.drawCircle(38, 38, 37, circlePaint);
circlePaint.setColor(forceWhiteBackground ? Color.BLACK : Color.WHITE);
circlePaint.setStyle(Paint.Style.STROKE);
circlePaint.setStrokeWidth(3);
widgetCanvas.drawCircle(38, 38, 37, circlePaint);
} }
for (CustomWidgetElement element : widget.getElements()) { for (CustomWidgetElement element : widget.getElements()) {
@ -338,7 +355,6 @@ public class FossilHRWatchAdapter extends FossilWatchAdapter {
0, 0,
0, 0,
null); null);
backgroundDrawn = true;
break; break;
} }
} }

View File

@ -9,44 +9,18 @@ public class CustomWidget extends Widget {
private ArrayList<CustomWidgetElement> elements = new ArrayList<>(); private ArrayList<CustomWidgetElement> elements = new ArrayList<>();
private int angle, distance; private int angle, distance;
private String name; private String name;
private boolean drawCircle;
public CustomWidget(String name, int angle, int distance, String fontColor, boolean drawCircle) { public CustomWidget(String name, int angle, int distance, String fontColor) {
super(null, angle, distance, fontColor); super(null, angle, distance, fontColor);
this.angle = angle; this.angle = angle;
this.distance = distance; this.distance = distance;
this.name = name; this.name = name;
this.drawCircle = drawCircle;
}
public boolean getDrawCircle(){
return this.drawCircle;
}
public void setDrawCircle(boolean drawCircle){
this.drawCircle = drawCircle;
}
public int getAngle() {
return angle;
}
public int getDistance() {
return distance;
} }
public void setElements(ArrayList<CustomWidgetElement> elements) { public void setElements(ArrayList<CustomWidgetElement> elements) {
this.elements = elements; this.elements = elements;
} }
public void setAngle(int angle) {
this.angle = angle;
}
public void setDistance(int distance) {
this.distance = distance;
}
public void setName(String name) { public void setName(String name) {
this.name = name; this.name = name;
} }

View File

@ -21,6 +21,22 @@ public class Widget implements Serializable {
this.fontColor = fontColor; this.fontColor = fontColor;
} }
public int getAngle() {
return angle;
}
public int getDistance() {
return distance;
}
public void setAngle(int angle) {
this.angle = angle;
}
public void setDistance(int distance) {
this.distance = distance;
}
@NonNull @NonNull
@Override @Override
public String toString() { public String toString() {

View File

@ -43,12 +43,6 @@
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:text="add element" /> android:text="add element" />
<CheckBox
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="draw circle"
android:id="@+id/qhybrid_widget_circle" />
</LinearLayout> </LinearLayout>
<LinearLayout <LinearLayout

View File

@ -860,4 +860,5 @@
<string name="devicetype_amazfit_bips">Amazfit Bip S</string> <string name="devicetype_amazfit_bips">Amazfit Bip S</string>
<string name="pref_summary_relax_firmware_checks">Firmwareüberprüfung deaktivieren</string> <string name="pref_summary_relax_firmware_checks">Firmwareüberprüfung deaktivieren</string>
<string name="pref_title_relax_firmware_checks">Aktiviere das flashen von Firmware, die nicht für dieses Gerät bestimmt ist (auf eigenes Risiko)</string> <string name="pref_title_relax_firmware_checks">Aktiviere das flashen von Firmware, die nicht für dieses Gerät bestimmt ist (auf eigenes Risiko)</string>
<string name="pref_qhybrid_title_widget_draw_circles">Widget-Kreise zeichnen</string>
</resources> </resources>

View File

@ -815,6 +815,7 @@
<string name="prefs_button_long_press_action_selection_title">Long press button action</string> <string name="prefs_button_long_press_action_selection_title">Long press button action</string>
<string name="error_no_location_access">Location access must be granted and enabled for scanning to work properly</string> <string name="error_no_location_access">Location access must be granted and enabled for scanning to work properly</string>
<string name="pref_qhybrid_title_widget_draw_circles">Draw widget circles</string>
<plurals name="widget_alarm_target_hours"> <plurals name="widget_alarm_target_hours">
<item quantity="one">%d hour</item> <item quantity="one">%d hour</item>

View File

@ -27,6 +27,11 @@
android:key="force_white_color_scheme" android:key="force_white_color_scheme"
android:summary="@string/pref_summary_force_white_color_scheme" android:summary="@string/pref_summary_force_white_color_scheme"
android:title="@string/pref_title_force_white_color_scheme" /> android:title="@string/pref_title_force_white_color_scheme" />
<SwitchPreference
android:defaultValue="false"
android:key="widget_draw_circles"
android:title="@string/pref_qhybrid_title_widget_draw_circles" />
<SeekBarPreference <SeekBarPreference
android:defaultValue="2" android:defaultValue="2"
android:key="@string/pref_title_vibration_strength" android:key="@string/pref_title_vibration_strength"