Hi there, I'm using the Infragistics Android trial release on a few devices (we have a license for iOS and Android too I think).
This crash in particular is on a Samsung Galaxy Tab 8.0 (GT-5110) running Android 4.4.2. I'm getting this crash when adding some amount (300-400 entries) of data to a DataChartView. The DataChartView has a RangeAreaSeries and an overlapping LineSeries.
As would typically happen with a stack overflow, we lose the actual root of the stack, unfortunately.
E/AndroidRuntime( 3327): java.lang.StackOverflowErrorE/AndroidRuntime( 3327): at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:485)E/AndroidRuntime( 3327): at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:485)E/AndroidRuntime( 3327): at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:485)E/AndroidRuntime( 3327): at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:485)E/AndroidRuntime( 3327): at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:487)E/AndroidRuntime( 3327): at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:485)E/AndroidRuntime( 3327): at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:485)E/AndroidRuntime( 3327): at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:485)E/AndroidRuntime( 3327): at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:485)E/AndroidRuntime( 3327): at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:485)E/AndroidRuntime( 3327): at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:485)E/AndroidRuntime( 3327): at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:485)
Hello Ben,
Thank you for your post.
I am investigating into this issue to see if I can reproduce the StackOverflowError that you are seeing. It is also possible that this may have been fixed internally as well. I will update this thread again as soon as I have more information for you on this matter.
Please let me know if you have any other questions or concerns on this matter.
Sincerely,AndrewAssociate DeveloperInfragistics Inc.www.infragistics.com/support
Thanks. FWIW, I've only seen this on this specific device. I don't see the same crash ever running a Genymotion emulator (5.x and 4.x) or on my Nexus 5 running Android 5.1.
Thank you for your response.
I will keep this forum thread active until your next response. In the meantime though, it may be beneficial for us regarding this issue if you were to test the sample I created on your device which is receiving this exception. I have attached the sample project. Please test this on your machine and let me know what results you find. Or, if this sample application does not accurately demonstrate what you are trying to do, feel free to modify it and send it back.
Hello Andrew, thanks for continuing with this.
I've taken this sample and modified it to try to reflect our dataset and view parameters, but it simply doesn't trigger the same stack overflow exception. There are many little things that make it difficult to know if things are set up the same.
Originally I had only seen the failure on Samsung devices, but we are now seeing this on multiple device types in testing and on the Genymotion emulator as well.
I'll keep trying to produce a reliable failure case that I can hand off to you, but the data and project are sensitive.
I will continue to monitor this forum thread while I await your "reliable failure" sample project. Please let me know if you have any other questions or concerns on this matter.
We continue to see crashes on certain data sets. Here's one sample that causes a stack overflow on a Samsung Tab S.
https://www.dropbox.com/s/f9o8bht3knzkchm/csv.txt?dl=0
Here's a screenshot of the crash:http://i.glui.me/1Dg2EXo
I understand this isn't a lot to go on. Perhaps you could comment on what kind of data might induce fragility into the recursive algorithm.
Here's the full trace:
java.lang.StackOverflowErrorat com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:516)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:516)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:516)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:516)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:516)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:516)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:516)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:516)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:516)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:516)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:516)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:516)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlatten(Flattener.java:305)at com.infragistics.controls.Flattener.fastFlatten(Flattener.java:268)at com.infragistics.controls.Flattener.chunkedFastFlatten(Flattener.java:226)at com.infragistics.controls.CategoryLineRasterizer.flattenPoints(CategoryLineRasterizer.java:234)at com.infragistics.controls.CategoryLineRasterizer.rasterizePolyline(CategoryLineRasterizer.java:309)at com.infragistics.controls.CategoryLineRasterizer.rasterizePolylinePaths(CategoryLineRasterizer.java:104)at com.infragistics.controls.LineSeriesView.rasterizeLine(LineSeriesView.java:68)at com.infragistics.controls.LineSeriesImplementation.renderFrame(LineSeriesImplementation.java:82)at com.infragistics.controls.CategorySeriesImplementation.renderSeriesOverride(CategorySeriesImplementation.java:925)at com.infragistics.controls.SeriesImplementation.doRenderSeries(SeriesImplementation.java:977)at com.infragistics.controls.SeriesImplementation.access$100(SeriesImplementation.java:24)at com.infragistics.controls.SeriesImplementation$10.invoke(SeriesImplementation.java:1455)at com.infragistics.controls.SeriesImplementation$10.invoke(SeriesImplementation.java:1455)at com.infragistics.controls.ContentInfo.doRefresh(ContentInfo.java:117)at com.infragistics.controls.ChartContentManager.doRefresh(ChartContentManager.java:209)at com.infragistics.controls.ChartContentManager.force(ChartContentManager.java:189)at com.infragistics.controls.SeriesViewerView.beforeContentRefresh(SeriesViewerView.java:2085)at com.infragistics.controls.SeriesViewerImplementation.beforeContentRefresh(SeriesViewerImplementation.java:3903)at com.infragistics.controls.ChartContentManager.doRefresh(ChartContentManager.java:203)at com.infragistics.controls.ChartContentManager.access$000(ChartContentManager.java:19)at com.infragistics.controls.ChartContentManager$1.invoke(ChartContentManager.java:93)at com.infragistics.controls.ComponentProxy.doInvalidate(ComponentProxy.java:239)at com.infragistics.controls.SeriesViewerBaseView.onDraw(SeriesViewerBaseView.java:94)at android.view.View.draw(View.java:15423)at android.view.View.getDisplayList(View.java:14317)at android.view.View.getDisplayList(View.java:14359)at android.view.View.draw(View.java:15137)at android.view.ViewGroup.drawChild(ViewGroup.java:3322)at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3158)at android.view.View.draw(View.java:15426)at android.widget.FrameLayout.draw(FrameLayout.java:472)at android.view.View.getDisplayList(View.java:14317)at android.view.View.getDisplayList(View.java:14359)at android.view.View.draw(View.java:15137)at android.view.ViewGroup.drawChild(ViewGroup.java:3322)at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3158)at android.view.View.getDisplayList(View.java:14312)at android.view.View.getDisplayList(View.java:14359)at android.view.View.draw(View.java:15137)at android.view.ViewGroup.drawChild(ViewGroup.java:3322)at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3158)at android.view.View.getDisplayList(View.java:14312)at android.view.View.getDisplayList(View.java:14359)at android.view.View.draw(View.java:15137)at android.view.ViewGroup.drawChild(ViewGroup.java:3322)at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3158)at android.view.View.draw(View.java:15426)at android.widget.FrameLayout.draw(FrameLayout.java:472)at android.view.View.getDisplayList(View.java:14317)at android.view.View.getDisplayList(View.java:14359)at android.view.View.draw(View.java:15137)at android.view.ViewGroup.drawChild(ViewGroup.java:3322)at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3158)at android.view.View.getDisplayList(View.java:14312)at android.view.View.getDisplayList(View.java:14359)at android.view.View.draw(View.java:15137)at android.view.ViewGroup.drawChild(ViewGroup.java:3322)at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3158)at android.view.View.getDisplayList(View.java:14312)at android.view.View.getDisplayList(View.java:14359)at android.view.View.draw(View.java:15137)at android.view.ViewGroup.drawChild(ViewGroup.java:3322)at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3158)at android.view.View.getDisplayList(View.java:14312)at android.view.View.getDisplayList(View.java:14359)at android.view.View.draw(View.java:15137)at android.view.ViewGroup.drawChild(ViewGroup.java:3322)at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3158)at android.view.View.getDisplayList(View.java:14312)at android.view.View.getDisplayList(View.java:14359)at android.view.HardwareRenderer$GlRenderer.buildDisplayList(HardwareRenderer.java:1585)at android.view.HardwareRenderer$GlRenderer.draw(HardwareRenderer.java:1457)at android.view.ViewRootImpl.draw(ViewRootImpl.java:2779)at android.view.ViewRootImpl.performDraw(ViewRootImpl.java:2645)at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:2213)at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1256)at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:6649)at android.view.Choreographer$CallbackRecord.run(Choreographer.java:813)at android.view.Choreographer.doCallbacks(Choreographer.java:613)at android.view.Choreographer.doFrame(Choreographer.java:583)at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:799)at android.os.Handler.handleCallback(Handler.java:733)at android.os.Handler.dispatchMessage(Handler.java:95)at android.os.Looper.loop(Looper.java:146)at android.app.ActivityThread.main(ActivityThread.java:5653)at java.lang.reflect.Method.invokeNative(Native Method)at java.lang.reflect.Method.invoke(Method.java:515)at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1291)at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1107)at dalvik.system.NativeStart.main(Native Method)
I have been testing out the private build, and it appears to solve the issues that you were having with the Flattener exception as well as the orientation flip OutOfMemory exception. I have created a case for you so that I can send you this private build. It has a case ID of CAS-152678-X1X7T7 and you can access it here: https://es.infragistics.com/my-account/support-activity. I will be sending an update to that case shortly with more information on the build changes, along with the private build attached to it.
Hi Andrew, that's great news. Thank you.
We only use the Android components, no Xamarin Forms.
Ben
Hello Caylan,
We have internally created a parameter that can be set to solve this current issue you are having, and I just need to test it a little bit more before sending it, just to be sure. I will likely be creating a case tomorrow that will be viewable to Ben through which I will send a new private build. One thing though, are you using the Android components exclusively, or are you using Xamarin Forms?
Great. Thanks for all your hard work! Our only concern is to have this fixed as soon as possible. This issue is a showstopper for our app release and we are a few days behind schedule because of it.
Hello Caylan/Ben,
I have been testing the standalone application that was provided, and I have reproduced this issue. I also noticed that after lowering the multiplier on the data in the MainActivity load and getting the application to startup, if you zoom in on the chart, the same exception is thrown. I am currently collaborating with Graham to see what can be done about this. I will update you again soon.