diff --git a/android/src/main/java/cn/mandata/react_native_mpchart/MPBarChartManager.java b/android/src/main/java/cn/mandata/react_native_mpchart/MPBarChartManager.java index 63d6174..21c7a6d 100644 --- a/android/src/main/java/cn/mandata/react_native_mpchart/MPBarChartManager.java +++ b/android/src/main/java/cn/mandata/react_native_mpchart/MPBarChartManager.java @@ -80,6 +80,26 @@ public void setData(BarChart chart,ReadableMap rm){ } chart.setData(barData); - chart.invalidate(); + + /** + * Graph animation configurations + * If no animation config provided, call chart.invalidate() + * animation configs are maps with the following keys + * - duration or durationX/durationY in case of animateXY + * - support for easeFunction yet to be given + */ + if (rm.hasKey("animateX")) { + chart.animateX(rm.getMap("animateX").getInt("duration")); + } else if (rm.hasKey("animateY")) { + chart.animateY(rm.getMap("animateY").getInt("duration")); + } else if (rm.hasKey("animateXY")) { + ReadableMap animationConfig = rm.getMap("animateXY"); + chart.animateXY( + animationConfig.getInt("durationX"), + animationConfig.getInt("durationY") + ); + } else { + chart.invalidate(); + } } } diff --git a/android/src/main/java/cn/mandata/react_native_mpchart/MPLineChartManager.java b/android/src/main/java/cn/mandata/react_native_mpchart/MPLineChartManager.java index 7e1d3ac..bfb78ff 100644 --- a/android/src/main/java/cn/mandata/react_native_mpchart/MPLineChartManager.java +++ b/android/src/main/java/cn/mandata/react_native_mpchart/MPLineChartManager.java @@ -106,6 +106,26 @@ public void setData(LineChart chart,ReadableMap rm){ chartData.addDataSet(dataSet); } chart.setData(chartData); - chart.invalidate(); + + /** + * Graph animation configurations + * If no animation config provided, call chart.invalidate() + * animation configs are maps with the following keys + * - duration or durationX/durationY in case of animateXY + * - support for easeFunction yet to be given + */ + if (rm.hasKey("animateX")) { + chart.animateX(rm.getMap("animateX").getInt("duration")); + } else if (rm.hasKey("animateY")) { + chart.animateY(rm.getMap("animateY").getInt("duration")); + } else if (rm.hasKey("animateXY")) { + ReadableMap animationConfig = rm.getMap("animateXY"); + chart.animateXY( + animationConfig.getInt("durationX"), + animationConfig.getInt("durationY") + ); + } else { + chart.invalidate(); + } } }