From 5f51623993aea7dbdac82842b7a02b3a0e37d460 Mon Sep 17 00:00:00 2001 From: Philipp Jahoda Date: Sun, 28 Feb 2016 19:31:49 +0100 Subject: [PATCH] Add matrixbuffer to avoid constant allocations --- .../charting/utils/ViewPortHandler.java | 27 +++++++++++-------- 1 file changed, 16 insertions(+), 11 deletions(-) diff --git a/MPChartLib/src/com/github/mikephil/charting/utils/ViewPortHandler.java b/MPChartLib/src/com/github/mikephil/charting/utils/ViewPortHandler.java index 1c66bcc6d..0a220cf50 100644 --- a/MPChartLib/src/com/github/mikephil/charting/utils/ViewPortHandler.java +++ b/MPChartLib/src/com/github/mikephil/charting/utils/ViewPortHandler.java @@ -4,6 +4,7 @@ import android.graphics.Matrix; import android.graphics.PointF; import android.graphics.RectF; +import android.util.Log; import android.view.View; /** @@ -350,6 +351,11 @@ public void centerViewPort(final float[] transformedPts, final View view) { refresh(save, view, true); } + /** + * buffer for storing matrix values + */ + protected final float[] matrixBuffer = new float[9]; + /** * call this method to refresh the graph with a given matrix * @@ -377,14 +383,13 @@ public Matrix refresh(Matrix newMatrix, View chart, boolean invalidate) { */ public void limitTransAndScale(Matrix matrix, RectF content) { - float[] vals = new float[9]; - matrix.getValues(vals); + matrix.getValues(matrixBuffer); - float curTransX = vals[Matrix.MTRANS_X]; - float curScaleX = vals[Matrix.MSCALE_X]; + float curTransX = matrixBuffer[Matrix.MTRANS_X]; + float curScaleX = matrixBuffer[Matrix.MSCALE_X]; - float curTransY = vals[Matrix.MTRANS_Y]; - float curScaleY = vals[Matrix.MSCALE_Y]; + float curTransY = matrixBuffer[Matrix.MTRANS_Y]; + float curScaleY = matrixBuffer[Matrix.MSCALE_Y]; // min scale-x is 1f, max is the max float mScaleX = Math.min(Math.max(mMinScaleX, curScaleX), mMaxScaleX); @@ -408,13 +413,13 @@ public void limitTransAndScale(Matrix matrix, RectF content) { float newTransY = Math.max(Math.min(curTransY, maxTransY + mTransOffsetY), -mTransOffsetY); mTransY = newTransY; - vals[Matrix.MTRANS_X] = mTransX; - vals[Matrix.MSCALE_X] = mScaleX; + matrixBuffer[Matrix.MTRANS_X] = mTransX; + matrixBuffer[Matrix.MSCALE_X] = mScaleX; - vals[Matrix.MTRANS_Y] = mTransY; - vals[Matrix.MSCALE_Y] = mScaleY; + matrixBuffer[Matrix.MTRANS_Y] = mTransY; + matrixBuffer[Matrix.MSCALE_Y] = mScaleY; - matrix.setValues(vals); + matrix.setValues(matrixBuffer); } /**