From 95aad7dfa4720ee991d306a21278edb028cc3ed8 Mon Sep 17 00:00:00 2001 From: renzhenfei Date: Fri, 19 May 2023 11:12:22 +0800 Subject: [PATCH] fix after call setMinMaxScaleX, when scaleX to bound value, chart will jump --- .../listener/BarLineChartTouchListener.java | 66 +++++++++++++++++-- 1 file changed, 60 insertions(+), 6 deletions(-) diff --git a/MPChartLib/src/main/java/com/github/mikephil/charting/listener/BarLineChartTouchListener.java b/MPChartLib/src/main/java/com/github/mikephil/charting/listener/BarLineChartTouchListener.java index f1858b308..0a7a706f6 100644 --- a/MPChartLib/src/main/java/com/github/mikephil/charting/listener/BarLineChartTouchListener.java +++ b/MPChartLib/src/main/java/com/github/mikephil/charting/listener/BarLineChartTouchListener.java @@ -74,6 +74,10 @@ public class BarLineChartTouchListener extends ChartTouchListener h.getMaxScaleX()) { + resultScaleX = h.getMaxScaleX() / lastScaleX; + } + return resultScaleX; + } + + /** + * limit scaleY range + * @param scaleY + * @param t + * @return + */ + private float getLimitedScaleY(float scaleY, MPPointF t) { + ViewPortHandler h = mChart.getViewPortHandler(); + tempMatrix.set(mSavedMatrix); + tempMatrix.postScale(1f, scaleY, t.x, t.y); + + mSavedMatrix.getValues(matrixBuffer); + float lastScaleY = matrixBuffer[Matrix.MSCALE_Y]; + + tempMatrix.getValues(matrixBuffer); + float calScaleY = matrixBuffer[Matrix.MSCALE_Y]; + + float resultScaleY = scaleY; + + if (calScaleY < h.getMinScaleY()) { + resultScaleY = h.getMinScaleY() / lastScaleY; + } else if (calScaleY > h.getMaxScaleY()) { + resultScaleY = h.getMaxScaleY() / lastScaleY; + } + return resultScaleY; + } + /** * Highlights upon dragging, generates callbacks for the selection-listener. *