problem with TErrorSeries
problem with TErrorSeries
Hello,
I am creating a TPointSeries and TErrorSeries to show error bars on top of a point series. I create the X,Y coordinates of each one the same, and just give the error bar a value for the bar height. This works fine if I have just one point series and one errorSeries. However, If I have two pointseries and two errorseries, the error bars are drawn offset.
I have a attached a sample application demonstrating the issue. If you can please let me know how to fix it I will apply the patch to our own copy of TChart.
We are using TChart 8.04. In the same app run it once with the checkbox off, and the next time with the checkbox on. You will see the error bars are not drawn correctly in the latter case.
I am creating a TPointSeries and TErrorSeries to show error bars on top of a point series. I create the X,Y coordinates of each one the same, and just give the error bar a value for the bar height. This works fine if I have just one point series and one errorSeries. However, If I have two pointseries and two errorseries, the error bars are drawn offset.
I have a attached a sample application demonstrating the issue. If you can please let me know how to fix it I will apply the patch to our own copy of TChart.
We are using TChart 8.04. In the same app run it once with the checkbox off, and the next time with the checkbox on. You will see the error bars are not drawn correctly in the latter case.
- Attachments
-
- errorbars.zip
- (400.48 KiB) Downloaded 991 times
Re: problem with TErrorSeries
Hi davidnovo,
When there are two TErrorSeries, the ErrorBars in the same XValue are drawn one next to the other. Do you mean you would like the ErrorBars in the same XValue to be drawn one over the other, with overlapping?
Doing like this they won't overlap:
If you want to draw the ErrorBars in the same XValue, you could use a unique TErrorSeries:
When there are two TErrorSeries, the ErrorBars in the same XValue are drawn one next to the other. Do you mean you would like the ErrorBars in the same XValue to be drawn one over the other, with overlapping?
Doing like this they won't overlap:
Code: Select all
uses ErrorBar, Series;
procedure TForm1.FormCreate(Sender: TObject);
var i, j: Integer;
begin
Chart1.View3D:=false;
for i:=0 to 3 do with Chart1.AddSeries(TErrorSeries.Create(self)) as TErrorSeries do
for j:=0 to 3 do AddErrorBar(j,random*10,5);
end;
Code: Select all
uses ErrorBar, Series, TeCanvas;
procedure TForm1.FormCreate(Sender: TObject);
var i, j: Integer;
begin
Chart1.View3D:=false;
with Chart1.AddSeries(TErrorSeries.Create(self)) as TErrorSeries do
for i:=0 to 3 do
for j:=0 to 3 do AddErrorBar(j,random*100,random*5,'',OperaPalette[i]);
end;
Best Regards,
Yeray Alonso Development & Support Steema Software Av. Montilivi 33, 17003 Girona, Catalonia (SP) | |
Please read our Bug Fixing Policy |
Re: problem with TErrorSeries
Hi Yeray,
I am afraid I do not understand. I would kindly ask that you look at the sample application that I sent you. In that application, I create 2 unique error series. The error series have the same x values as each other, but different Y values. They are also the same X,Y values as the point series.
The error series should be drawn on TOP of the point series. i.e. each error bar should be drawn ON TOP of each point. This is because each point and each error series have the same X,Y values. This does happen is there is only one TPointSeries and one TErrorSeries. If there are two TPointSeries and two TErrorSeries then it does not work.
I spent quite a bit of effort debugging this and creating a test app for you that duplicates the error. Please have a look at the attached project. I need to know how if I have two TPointSeries, I can draw an error bar ON TOP of each point, even if some of the points share the same X Value.
I am afraid I do not understand. I would kindly ask that you look at the sample application that I sent you. In that application, I create 2 unique error series. The error series have the same x values as each other, but different Y values. They are also the same X,Y values as the point series.
The error series should be drawn on TOP of the point series. i.e. each error bar should be drawn ON TOP of each point. This is because each point and each error series have the same X,Y values. This does happen is there is only one TPointSeries and one TErrorSeries. If there are two TPointSeries and two TErrorSeries then it does not work.
I spent quite a bit of effort debugging this and creating a test app for you that duplicates the error. Please have a look at the attached project. I need to know how if I have two TPointSeries, I can draw an error bar ON TOP of each point, even if some of the points share the same X Value.
Re: problem with TErrorSeries
Hi davidnovo,
Excuse me if I haven't expressed myself enough clearly. Of course I've seen your application before answering. What I tried to explain is the issue that I understand is behind your problem.
Try to forget for one moment the TPointSeries. Having a TErrorSeries with XValues 0, 1, 2,... the ErrorBars are drawn exactly in the X=0, X=1,... but when you have two TErrorSeries, they are drawn one next to the other so the first is drawn some pixels at the left side of X=0, X=1,... and the second TErrorSeries is drawn some pixels at the right side of X=0, X=1,... This is made to fit as many TErrorSeries as one would like to draw without overlapping.
On the other hand, TPointSeries doesn't do this job. They don't prevent this overlapping.
So, before proceeding with proposing you a workaround, we would need to know if you want your TErrorSeries to overlap or you want them to be drawn side by side for each XValue.
Excuse me if I haven't expressed myself enough clearly. Of course I've seen your application before answering. What I tried to explain is the issue that I understand is behind your problem.
Try to forget for one moment the TPointSeries. Having a TErrorSeries with XValues 0, 1, 2,... the ErrorBars are drawn exactly in the X=0, X=1,... but when you have two TErrorSeries, they are drawn one next to the other so the first is drawn some pixels at the left side of X=0, X=1,... and the second TErrorSeries is drawn some pixels at the right side of X=0, X=1,... This is made to fit as many TErrorSeries as one would like to draw without overlapping.
On the other hand, TPointSeries doesn't do this job. They don't prevent this overlapping.
So, before proceeding with proposing you a workaround, we would need to know if you want your TErrorSeries to overlap or you want them to be drawn side by side for each XValue.
Best Regards,
Yeray Alonso Development & Support Steema Software Av. Montilivi 33, 17003 Girona, Catalonia (SP) | |
Please read our Bug Fixing Policy |
Re: problem with TErrorSeries
Hello,
Thank you. I definately want them to "overlap", because, they are not really overlapping. Even though the X values are the same, the Y values are totally different.
I can see this auto-adjusting to eliminate X-overlap can be a useful feature, but should not be the default behaviour. In AddErrorBar I specify the X,Y and I want the error bar drawn at that X,Y. Perhaps if there was a property on the TErrorSeries called PreventOverlapWithOtherErrorBars that could be cool, but I definately don't want that.
Based on your previous comments, I presume you are going to suggest to put all the error bars in a single error series. If there is another way to make the error bars "overlap" without having to do this, that would be great.
It is also not that easy for me to create a single errorSeries with all the error bars from multiple data sets. Each set of PointSers/ErrorSeries comes from a separate SeriesBuilder Object that we have. The SeriesBuilder objects do not know if other series are going to be created or not. They just know that they have to build a PointSeries and an ErrorBarSeries for the data that they happen to contain.
If I can only add the points to a single error series I will have to rearchitect things quite a bit to allow communication between the different seriesBuilders which is quite a bit of effort.
Thank you. I definately want them to "overlap", because, they are not really overlapping. Even though the X values are the same, the Y values are totally different.
I can see this auto-adjusting to eliminate X-overlap can be a useful feature, but should not be the default behaviour. In AddErrorBar I specify the X,Y and I want the error bar drawn at that X,Y. Perhaps if there was a property on the TErrorSeries called PreventOverlapWithOtherErrorBars that could be cool, but I definately don't want that.
Based on your previous comments, I presume you are going to suggest to put all the error bars in a single error series. If there is another way to make the error bars "overlap" without having to do this, that would be great.
It is also not that easy for me to create a single errorSeries with all the error bars from multiple data sets. Each set of PointSers/ErrorSeries comes from a separate SeriesBuilder Object that we have. The SeriesBuilder objects do not know if other series are going to be created or not. They just know that they have to build a PointSeries and an ErrorBarSeries for the data that they happen to contain.
If I can only add the points to a single error series I will have to rearchitect things quite a bit to allow communication between the different seriesBuilders which is quite a bit of effort.
Re: problem with TErrorSeries
Hello,
To be cleared, I cannot "forget" about the TPointSeries. Each Point+Error bar represents a mean +SD of a particular measurement. The error bar ALWAYS has to be on top of its corresponding point, no matter how far the points/error bars are away from each other. If the points or error bars are too close to each other, well, that is just the way it is.
To be cleared, I cannot "forget" about the TPointSeries. Each Point+Error bar represents a mean +SD of a particular measurement. The error bar ALWAYS has to be on top of its corresponding point, no matter how far the points/error bars are away from each other. If the points or error bars are too close to each other, well, that is just the way it is.
Re: problem with TErrorSeries
Hi davidnovo,
I've tried another idea different from using TPointSeries: Custom drawing directly to the canvas. In a first thought I wasn't sure if the CalcXPos method would return the position with the "offset" or not. Finally it seems to work fine:
Anyway, I'll add to the wish list the possibility to add a property like PreventOverlapWithOtherErrorBars (or a shorter name ) to permit choosing between using the automatic offset or not (TV52014830).
I've tried another idea different from using TPointSeries: Custom drawing directly to the canvas. In a first thought I wasn't sure if the CalcXPos method would return the position with the "offset" or not. Finally it seems to work fine:
Code: Select all
uses series, ErrorBar;
var PointerSize: integer;
procedure TForm1.FormCreate(Sender: TObject);
var i: Integer;
begin
Chart1.View3D:=false;
for i:=0 to 1 do
begin
Chart1.AddSeries(TErrorSeries.Create(self));
Chart1[i].FillSampleValues();
end;
PointerSize:=6;
end;
procedure TForm1.Chart1AfterDraw(Sender: TObject);
var i, j, XCenter, YCenter: Integer;
begin
for i:=0 to Chart1.SeriesCount-1 do
with Chart1[i] as TErrorSeries do
for j:=0 to Count-1 do
begin
XCenter:=CalcXPos(j) + ((BarBounds.Right+BarBounds.Left) div 2 - BarBounds.Left);
YCenter:=CalcYPos(j);
if PtInRect(Chart1.ChartRect,Point(XCenter,YCenter)) then
begin
Chart1.Canvas.Brush.Color:=Color;
Chart1.Canvas.Rectangle(XCenter - (PointerSize div 2), YCenter - (PointerSize div 2), XCenter + (PointerSize div 2), YCenter + (PointerSize div 2));
end;
end;
end;
Best Regards,
Yeray Alonso Development & Support Steema Software Av. Montilivi 33, 17003 Girona, Catalonia (SP) | |
Please read our Bug Fixing Policy |
Re: problem with TErrorSeries
Hi Yeray,
Thanks for the prompt response!
Thanks for the prompt response!
Re: problem with TErrorSeries
Hi davidnovo,
You're welcome!
You're welcome!
Best Regards,
Yeray Alonso Development & Support Steema Software Av. Montilivi 33, 17003 Girona, Catalonia (SP) | |
Please read our Bug Fixing Policy |