One of our users has sent in a log for our .NET Winforms application that indicates that the Activated
event is occurring before the Load
event. I didn't think this was possible and have coded with the assumption that Load
would always happen before Activated
.
Has anyone else observed Activated
occurring before Load
?
If so, why and is there any way to make sure it doesn't happen?
From Order of Events in Windows Forms at MSDN:
Application Startup and Shutdown Events
The Form and Control classes expose a set of events related to application startup and shutdown. When a Windows Forms application starts, the startup events of the main form are raised in the following order:
System.Windows.Forms.Control.HandleCreated
System.Windows.Forms.Control.BindingContextChanged
System.Windows.Forms.Form.Load
System.Windows.Forms.Control.VisibleChanged
System.Windows.Forms.Form.Activated
System.Windows.Forms.Form.Shown
When an application closes, the shutdown events of the main form are raised in the following order:
System.Windows.Forms.Form.Closing
System.Windows.Forms.Form.FormClosing
System.Windows.Forms.Form.Closed
System.Windows.Forms.Form.FormClosed
System.Windows.Forms.Form.Deactivate
Are you using a MessageBox in any of your startup events? This can cause the events to appear to trigger out of order because of the way the Windows Forms Message Loop handles dialog windows.
Activated comes before Load. If you want to write some code that should be executed after Load then you can Use Shown Method.
Please find below the sequence :
- Activated
- Load
- Shown
EDIT : Please check this very interesting answer on SO which explains WinForms Load vs. Shown events
EDIT :I have Now created one default Winform project with single winform. Now it is giving me sequence
- Load
- Activated
- Shown
I am confused now.
Even though it goes against Microsoft's documentation, this can happen sometimes when you access a loading form's public variable or function from outside the form. If necessary, you can set a flag in the shown event and use it to exit the activated handler before the form has loaded.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With