7
votes

I read that the Load event is supposed to be fired after the window handle has been created, but before the window actually become visible. For the most part, this seems to be true. However, I've found that when I create a form with the WindowState property set to FormWindowState.Maximized (either via the VS designer, or programatically in the constructor), the window becomes visible prior to the Load event firing. For example:

using System;
using System.Windows.Forms;

namespace MyApplication
{
    public partial class MyForm : Form
    {
        public MyForm()
        {
            InitializeComponent();
            WindowState = FormWindowState.Maximized;
        }

        protected override void OnLoad(EventArgs e)
        {
            MessageBox.Show("OnLoad - notice that the window is already visible"); 
            base.OnLoad(e);
        }
    }
}

This in turn causes the displayed form to flicker a lot while its controls (which are laid out during the Form.Load event) are resized while the window is visible. If I did not set the state to be maximized, then all the resizing is done before the window is shown (which is what I would have expected).

I could hold off on setting the WindowState until the end of the Load event, but that still causes a lot of flickering because the window becomes visible and then all of the controls resize.

Any thoughts?

4
That MessageBox.Show in the load event will force the form to show.LarsTech
Resizing the controls in the Load event is somewhat suspicious. Why don't you rely on the built-in resizing mechanisms for controls, like Dock or Anchor properties or the TableLayoutPanel? Will you manually resize the controls as well when I resize the window manually later on?Thorsten Dittmar
I'm getting this as well. I'm saving the WindowState between user sessions so that the form can be resized, etc to what the user previously had it and when I set the WindowState to Maximized I get a lot of flickering, etc. Is there a solution to fix this?John Grabanski

4 Answers

2
votes

Try to delay the change of WindowState until the first Activated event firing. This works for me in VB.NET with VS2005 and framework 2.0.

1
votes

If you need to put some diagnostic message in the Load event use System.Diagnostics.Debug.WriteLine();
If you use MessageBox, you will destroy the normal flow order of events.

protected override void OnLoad(EventArgs e)         
{             
     System.Diagnostics.Debug.WriteLine("onLoad");              
     base.OnLoad(e);         
} 

This post explain more details

1
votes

You have to set WindowState BEFORE InitializeComponent():

    public Form() //Constructor
    {
        WindowState = FormWindowState.Maximized;

        InitializeComponent();
    }
0
votes

Things that change the appearance of the window (resizing for instance) cause the window to become visible.

You could call .Hide() or .Visible = False in your ctor and make it visible again at the end of .Load