我需要显示用户馈送的项目,其中每个项目都包含一个图表。现在我使用react-native-svg-charts:
<LineChart
style={{ height: 150, position: 'relative', left: -20 }}
data={data}
curve={shape.curveNatural}
svg={{ stroke: chartColor1, strokeWidth: 5 }}
contentInset={{ top: 20, bottom: 20 }}
showGrid={false}
numberOfTicks={0}
key={props.id}
>但当我加载超过50个项目时,应用程序的性能会下降到10-15 fps。
我认为这是因为页面上有很多SVG。你认为我应该使用哪种解决方案来避免这种情况?
发布于 2021-02-16 03:08:18
我最近在这里回答了一个类似的问题:Real-time data update chart in React Native,并将在这里提出同样的建议。
在React Native中使用我尝试过的所有基于SVG的库进行绘图时,我一直在为性能而苦苦挣扎。我最近决定尝试在WebView中使用几个基于画布的绘图库,并获得了非常好的结果。我最终做了一个简单的包:https://www.npmjs.com/package/@dpwiese/react-native-canvas-charts。
如果你不想使用这个包,而是自己去做,那就很简单了。虽然软件包源代码可能是最好的资源,但我将总结以下步骤:
其中包含所选图表库的JavaScript。上面的链接包目前支持Chart.js v3和uPlot。在下面的步骤中,我将显示一个配置引用,例如,您可以向configuration.
其中配置类似于: const addChart = addChart => { webref.injectJavaScript(const el = document.createElement("canvas"); document.body.appendChild(el); window.canvasLine = new Chart(el.getContext('2d'), ${JSON.stringify(config)}););};
而config是一个有效的Chart.js configuration.
window.canvasLine.config.data.datasets[${i}].data = ${JSON.stringify(dataSets[i])}; window.canvasLine.update(););});} };其中dataSets是有效的Chart.js数据集。
https://stackoverflow.com/questions/65051932
复制相似问题