Page 1 of 1
Scale gauge chartview elements on resize (Xamarin Forms)
Posted: Sun May 09, 2021 8:19 pm
by 18290001
Steema version = Steema.TeeChart.NET.Xamarin.Forms v4.2021.4.22
Xamarin Forms version = v5.0.0.2012
Development platform = Visual Studio 2019 Pro v16.9.1
Target device = Android 6.0 (API 23) to API 10.0 (API 29) smallest res = 480x800
I am trying to write code to re-size aspects of a circular gauge control when the gauge itself is resized. My code does work, but only when the gauge control is pressed after being resized. I assume I am not calling my resize code in the correct event (currently calling in the AfterDraw event) but I cannot determine the best solution.
I have written a small test solution (attached) to demonstrate what I am trying to achieve.
In my test App whenever the SIZE button(s) are pressed, the gauge control does resize but the label font, line band & center point only size correctly when the gauge control is subsequently pressed.
Incorrect result
- ChartWrongSizeResult.png (46.36 KiB) Viewed 15198 times
Correct result (after gauge control pressed)
- ChartCorrectSizeResult.png (56.57 KiB) Viewed 15198 times
All feedback & assistance greatly appreciated
Re: Scale gauge chartview elements on resize (Xamarin Forms)
Posted: Tue May 11, 2021 8:12 am
by Pep
Hello,
ok, let me take a look and check your project and back to you with a possible solution as soon as possible.
Re: Scale gauge chartview elements on resize (Xamarin Forms)
Posted: Wed May 12, 2021 9:01 am
by Pep
Hello Scobie,
in order to fix this problem just add an InternalDraw at the end of the resize method :
Code: Select all
// ### AXIS ###
CircularGauge.Axis.Labels.Font.Size = 7.0D * (CircularGauge.XRadius / 100D);
this.Chart.Chart.InternalDraw();
Re: Scale gauge chartview elements on resize (Xamarin Forms)
Posted: Wed May 12, 2021 9:37 pm
by 18290001
Thank you for your help.
I have added the Chart.Chart.InternalDraw() method call to the end of the Resize method & while it does re-draw the font, centre point & colour band in the correct size it leaves the original (incorrectly sized) chart elements in position, creating a "shadow" effect - see image.
- ChartFontShadowAfterInternalDraw.png (107.27 KiB) Viewed 15122 times
Should I be calling some sort of repaint or invalidate method before the InternalDraw method to remove the old graphics?
Re: Scale gauge chartview elements on resize (Xamarin Forms)
Posted: Thu May 13, 2021 11:59 am
by Pep
Hello,
yes, you're correct, it seems to be a repaint problem. I'll add as a bug on our bug list in order to be addressed.
In meantime I found a solution, it's to use the OnBeforeDraw event to hide the axis labels and then make them visible again once these have been resized :
Code: Select all
// Add the beforeDraw method at the CreateGauge method
cv.Chart.BeforeDraw += Chart_BeforeDraw;
private void Chart_BeforeDraw(object sender, Steema.TeeChart.Drawing.Graphics3D g)
{
CircularGauge.Axis.Labels.Visible = false;
}
// Add these lines at the end of the Resize method
CircularGauge.Axis.Labels.Visible = true;
this.Chart.Chart.InternalDraw();
Re: Scale gauge chartview elements on resize (Xamarin Forms)
Posted: Thu May 13, 2021 9:13 pm
by 18290001
Hello
I have implemented your suggestion, along with further lines to deal with the center, hand & green/red lines & the solution is working...
Code: Select all
// Add the beforeDraw method at the CreateGauge method
cv.Chart.BeforeDraw += Chart_BeforeDraw;
private void Chart_BeforeDraw(object sender, Steema.TeeChart.Drawing.Graphics3D g)
{
CircularGauge.Axis.Labels.Visible = false;
CircularGauge.Center.Visible = false;
CircularGauge.Hand.Visible = false;
CircularGauge.GreenLine.Visible = false;
CircularGauge.RedLine.Visible = false;
}
// Add these lines at the end of the Resize method
CircularGauge.Axis.Labels.Visible = true;
CircularGauge.Center.Visible = true;
CircularGauge.Hand.Visible = true;
CircularGauge.GreenLine.Visible = true;
CircularGauge.RedLine.Visible = true;
this.Chart.Chart.InternalDraw();
Thankyou for your help to get this code working.