I'm using 2009 vol 2 xamchart barchart. I'm creating a rotate3d transform that rotates the chart with the mouse. There are a mere 25 columns and 25 series (i'm plotting pixel intensities in an x,y region). The chart initializes resonably fast. The rotate transform is barely acceptable - somewhat choppy. If I increase the datapoints to say a 35 by 35 region, it takes seconds for the chart to redisplay after the rotate3d transform is changed. It's unusable. The chart is the same size, only more datapoints - why would the rotate transform perform worse? I'm not recomputing anything other than a new transform, and I have also tried enablerefresh = false. Any idea what might be going on and how to resolve? Seems like the chart is doing something behind the scenes...
Thanks in advance.
Thanks a lot, I appreciate the help!
I've asked engineering to look into this. They suggested that I report this as a bug in order to ensure that we improve performance with an upcoming release. Until then, I am also looking into seeing if there is a suitable work-around to help you with this issue now.
Thank you!
Curtis,
I have attached a modified version of the chart rotate3D issue that does not have any mouse events in it. It should clearly demonstrate the issue I am reporting regarding peformance degridation during the assignment of a rotate3dtransform to the chart as the amount of data in the chart increases.
To use to program, type in x, y values, then press build data. this will generate a chart with new data. Then press Rotate3D to compute a new rotation and assign it to the chart. With a mere 100 x 100 for x and Y, it takes many many seconds for the rotatetransform3D assignment to complete.
Please let me know if you have further questions. Thanks a lot!
It doesn’t help. As I pointed out, if you make the chart 100 x 100 in X and Y it takes that line of code between 5 and 10 seconds to execute only once. You can actually decouple the mouse handling and just execute that function once with 100 X and 100 Y and you will see what I’m talking about. The mouse movement has nothing to do with it - the question is: why would it take 5 to 10 seconds to execute the assignment of a new rotate transform 3D when the chart has a lot of data in it?
The suggestion to use a DispatcherTimer is to limit the operations to once every 50 milliseconds. Currently, the MouseMove event gets raised more frequently than this. Using your sample, it looks like the MouseMove event is being raised about every 10 milliseconds while the mouse is moving. With a timer you have a sure-fire way to slow down the operations being executed.
Let me know if this helps.
Thanks!