-
Notifications
You must be signed in to change notification settings - Fork 902
Open
Labels
Description
Bug description
When changing the range, I update the series data. This update occurs asynchronously. When the data is updated but before setState is called, the app crashes as the length of the regular points and the control high points do not match. As far as I could see, the error only occured in the Android app.
I implemented a fix for my use case here: DrNiels@82e98fe
However, I assume my fix does not handle all cases where this error can occur, even though it fixes my case. But maybe it can support you as inspiration.
Steps to reproduce
- Load the sample as Android app
- Pan the chart to the left
- See it crash
Code sample
Code sample
import 'package:flutter/material.dart';
import 'package:syncfusion_flutter_charts/charts.dart';
import 'package:syncfusion_flutter_core/core.dart';
void main() {
return runApp(_ChartApp());
}
class _ChartApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
theme: ThemeData(primarySwatch: Colors.blue, useMaterial3: false),
home: _MyHomePage(),
);
}
}
class _MyHomePage extends StatefulWidget {
// ignore: prefer_const_constructors_in_immutables
_MyHomePage({Key? key}) : super(key: key);
@override
_MyHomePageState createState() => _MyHomePageState();
}
class _MyHomePageState extends State<_MyHomePage> {
List<_SalesData> data = [
_SalesData(DateTime(2025, 11, 20, 0), 35),
_SalesData(DateTime(2025, 11, 21, 6), 28),
_SalesData(DateTime(2025, 11, 22, 12), 34),
_SalesData(DateTime(2025, 11, 23, 18), 32),
_SalesData(DateTime(2025, 11, 24, 0), 40),
_SalesData(DateTime(2025, 11, 25, 0), 32),
];
RangeController _rangeController = RangeController(
start: DateTime(2025, 11, 20, 0),
end: DateTime(2025, 11, 27, 0),
);
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(title: const Text('Syncfusion Flutter chart')),
body: Expanded(
child: SfCartesianChart(
primaryXAxis: DateTimeAxis(
minimum: DateTime(2025, 1, 1, 0),
maximum: DateTime(2025, 11, 27, 0),
rangeController: _rangeController,
),
zoomPanBehavior: ZoomPanBehavior(enablePanning: true),
onActualRangeChanged: (ActualRangeChangedArgs args) async {
if (_rangeController.start.isBefore(data.first.year)) {
await Future.delayed(const Duration(milliseconds: 100));
data.insertAll(0, [
_SalesData(
data.first.year.subtract(const Duration(days: 3)),
25,
),
_SalesData(
data.first.year.subtract(const Duration(days: 2)),
28,
),
_SalesData(
data.first.year.subtract(const Duration(days: 1)),
34,
),
]);
await Future.delayed(const Duration(milliseconds: 100));
WidgetsBinding.instance.addPostFrameCallback((_) {
if (this.mounted) {
//setState(() {});
}
});
}
},
// Chart title
title: ChartTitle(text: 'Half yearly sales analysis'),
// Enable legend
legend: Legend(isVisible: true),
// Enable tooltip
tooltipBehavior: TooltipBehavior(enable: true),
series: [
SplineAreaSeries<_SalesData, DateTime>(
dataSource: data,
xValueMapper: (_SalesData sales, _) => sales.year,
yValueMapper: (_SalesData sales, _) => sales.sales,
splineType: SplineType.monotonic,
animationDuration: 0,
markerSettings: MarkerSettings(
isVisible: false,
height: 4,
width: 4,
borderWidth: 6,
color: Colors.purple,
borderColor: Colors.purple,
),
),
],
),
),
);
}
}
class _SalesData {
_SalesData(this.year, this.sales);
final DateTime year;
final double sales;
}
Screenshots or Video
Screenshots / Video demonstration
Current State with Bug:
Screen_Recording_20251105_100231.mp4
With my Fix:
Screen_Recording_20251105_095844.mp4
Stack Traces
Stack Traces
RangeError (RangeError (length): Invalid value: Not in inclusive range 0..4: 5)
SplineAreaSegment._createFillPath (c:\Users\Niels\Documents\flutter-widgets\packages\syncfusion_flutter_charts\lib\src\charts\series\spline_series.dart:1619)
SplineAreaSegment.transformValues (c:\Users\Niels\Documents\flutter-widgets\packages\syncfusion_flutter_charts\lib\src\charts\series\spline_series.dart:1420)
ContinuousSeriesMixin.transformValues (c:\Users\Niels\Documents\flutter-widgets\packages\syncfusion_flutter_charts\lib\src\charts\series\chart_series.dart:4582)
ChartSeriesRenderer.performLayout (c:\Users\Niels\Documents\flutter-widgets\packages\syncfusion_flutter_charts\lib\src\charts\series\chart_series.dart:2450)
CartesianSeriesRenderer.performLayout (c:\Users\Niels\Documents\flutter-widgets\packages\syncfusion_flutter_charts\lib\src\charts\series\chart_series.dart:4235)
XyDataSeriesRenderer.performLayout (c:\Users\Niels\Documents\flutter-widgets\packages\syncfusion_flutter_charts\lib\src\charts\series\chart_series.dart:6287)
RenderObject._layoutWithoutResize (c:\Users\Niels\Documents\flutter\packages\flutter\lib\src\rendering\object.dart:2655)
PipelineOwner.flushLayout (c:\Users\Niels\Documents\flutter\packages\flutter\lib\src\rendering\object.dart:1160)
PipelineOwner.flushLayout (c:\Users\Niels\Documents\flutter\packages\flutter\lib\src\rendering\object.dart:1173)
RendererBinding.drawFrame (c:\Users\Niels\Documents\flutter\packages\flutter\lib\src\rendering\binding.dart:629)
WidgetsBinding.drawFrame (c:\Users\Niels\Documents\flutter\packages\flutter\lib\src\widgets\binding.dart:1242)
RendererBinding._handlePersistentFrameCallback (c:\Users\Niels\Documents\flutter\packages\flutter\lib\src\rendering\binding.dart:495)
SchedulerBinding._invokeFrameCallback (c:\Users\Niels\Documents\flutter\packages\flutter\lib\src\scheduler\binding.dart:1438)
SchedulerBinding.handleDrawFrame (c:\Users\Niels\Documents\flutter\packages\flutter\lib\src\scheduler\binding.dart:1351)
SchedulerBinding._handleDrawFrame (c:\Users\Niels\Documents\flutter\packages\flutter\lib\src\scheduler\binding.dart:1204)
_invoke (c:\Users\Niels\Documents\flutter\bin\cache\pkg\sky_engine\lib\ui\hooks.dart:331)
PlatformDispatcher._drawFrame (c:\Users\Niels\Documents\flutter\bin\cache\pkg\sky_engine\lib\ui\platform_dispatcher.dart:444)
_drawFrame (c:\Users\Niels\Documents\flutter\bin\cache\pkg\sky_engine\lib\ui\hooks.dart:303)On which target platforms have you observed this bug?
Android
Flutter Doctor output
Doctor output
[√] Flutter (Channel stable, 3.32.0, on Microsoft Windows [Version 10.0.19045.6456], locale de-DE) [789ms]
• Flutter version 3.32.0 on channel stable at C:\Users\Niels\Documents\flutter
• Upstream repository https://github.com/flutter/flutter.git
• Framework revision be698c48a6 (6 months ago), 2025-05-19 12:59:14 -0700
• Engine revision 1881800949
• Dart version 3.8.0
• DevTools version 2.45.1
[√] Windows Version (10 Education 64-bit, 22H2, 2009) [4,0s]
[!] Android toolchain - develop for Android devices (Android SDK version 35.0.0) [7,3s]
• Android SDK at C:\Users\Niels\AppData\Local\Android\Sdk
• Platform android-35, build-tools 35.0.0
• Java binary at: C:\Program Files\Android\Android Studio1\jbr\bin\java
This is the JDK bundled with the latest Android Studio installation on this machine.
To manually set the JDK path, use: `flutter config --jdk-dir="path/to/jdk"`.
• Java version OpenJDK Runtime Environment (build 17.0.11+0--11852314)
! Some Android licenses not accepted. To resolve this, run: flutter doctor --android-licenses
[√] Chrome - develop for the web [209ms]
• Chrome at C:\Users\Niels\AppData\Local\Google\Chrome\Application\chrome.exe
[√] Visual Studio - develop Windows apps (Visual Studio Community 2022 17.14.15 (September 2025)) [207ms]
• Visual Studio at C:\Program Files\Microsoft Visual Studio\2022\Community
• Visual Studio Community 2022 version 17.14.36511.14
• Windows 10 SDK version 10.0.26100.0
[!] Android Studio (version 2021.2) [34ms]
• Android Studio at C:\Program Files\Android\Android Studio
• Flutter plugin can be installed from:
https://plugins.jetbrains.com/plugin/9212-flutter
• Dart plugin can be installed from:
https://plugins.jetbrains.com/plugin/6351-dart
X Unable to determine bundled Java version.
• Try updating or re-installing Android Studio.
[√] Android Studio (version 2024.1) [32ms]
• Android Studio at C:\Program Files\Android\Android Studio1
• Flutter plugin can be installed from:
https://plugins.jetbrains.com/plugin/9212-flutter
• Dart plugin can be installed from:
https://plugins.jetbrains.com/plugin/6351-dart
• Java version OpenJDK Runtime Environment (build 17.0.11+0--11852314)
[√] VS Code, 64-bit edition (version 1.104.2) [31ms]
• VS Code at C:\Program Files\Microsoft VS Code
• Flutter extension version 3.122.0
[√] Connected device (4 available) [959ms]
• SM S921B (wireless) (mobile) • adb-RFCX306GLHZ-2OV7MI._adb-tls-connect._tcp. • android-arm64 • Android 16 (API 36)
• Windows (desktop) • windows • windows-x64 • Microsoft Windows [Version 10.0.19045.6456]
• Chrome (web) • chrome • web-javascript • Google Chrome 142.0.7444.59
• Edge (web) • edge • web-javascript • Microsoft Edge 128.0.2739.42
[√] Network resources [1.444ms]
• All expected network resources are available.
! Doctor found issues in 2 categories.