From 256967a27f7c898e4605a9553eed22901ef485d9 Mon Sep 17 00:00:00 2001 From: Alexis Lecanu Date: Thu, 17 Oct 2024 07:22:06 -0700 Subject: [PATCH] Fix : scale bar texts missing on devices with api 23 (#72) --- .../plugins/scalebar/ScaleBarWidget.java | 20 ++++++++----------- 1 file changed, 8 insertions(+), 12 deletions(-) diff --git a/plugin-scalebar/src/main/java/org/maplibre/android/plugins/scalebar/ScaleBarWidget.java b/plugin-scalebar/src/main/java/org/maplibre/android/plugins/scalebar/ScaleBarWidget.java index 9b2bdb76..0dfa961d 100644 --- a/plugin-scalebar/src/main/java/org/maplibre/android/plugins/scalebar/ScaleBarWidget.java +++ b/plugin-scalebar/src/main/java/org/maplibre/android/plugins/scalebar/ScaleBarWidget.java @@ -4,7 +4,6 @@ import android.graphics.Canvas; import android.graphics.Color; import android.graphics.Paint; -import android.graphics.Path; import android.os.Handler; import android.os.Message; import android.util.Pair; @@ -45,7 +44,6 @@ public class ScaleBarWidget extends View { private String unit; private final RefreshHandler refreshHandler; private DecimalFormat decimalFormat = new DecimalFormat("0.#"); - private Path path = new Path(); ScaleBarWidget(@NonNull Context context) { super(context); @@ -107,11 +105,7 @@ protected void onDraw(Canvas canvas) { barPaint.setColor(i % 2 == 0 ? primaryColor : secondaryColor); String text = i == 0 ? String.valueOf(unitDistance * i) : getDistanceText(unitDistance * i); - textPaint.getTextPath(text, 0, text.length(), marginLeft + unitBarWidth * i, textSize + marginTop, path); - if (showTextBorder) { - canvas.drawPath(path, strokePaint); - } - canvas.drawPath(path, textPaint); + drawText(canvas, text, marginLeft + unitBarWidth * i, textSize + marginTop); canvas.drawRect(marginLeft + unitBarWidth * i, textBarMargin + textSize + marginTop, @@ -121,13 +115,15 @@ protected void onDraw(Canvas canvas) { } String distanceText = getDistanceText(unitDistance * i); - textPaint.getTextPath(distanceText, 0, distanceText.length(), marginLeft + unitBarWidth * i, - textSize + marginTop, path); + drawText(canvas, distanceText, marginLeft + unitBarWidth * i, textSize + marginTop); + + } + + private void drawText(Canvas canvas, String text, Float x, Float y) { if (showTextBorder) { - canvas.drawPath(path, strokePaint); + canvas.drawText(text, x, y, strokePaint); } - canvas.drawPath(path, textPaint); - + canvas.drawText(text, x, y, textPaint); } /**