Setting Focus to a .NET UserControl...?

too long for a comment, includes link, and code ... but this is a comment ...

Lots of people have complained about a UserControl not firing the 'GotFocus() event. For example : UserControl and GotFocus() fyi : LostFocus() will fire as expected, in my experience. In the past, in a multiple Forms project, I've experimented with implementing 'Enter and 'Leave event handlers on a UserControl on each Form, and found that 'Enter is only called on Form load, once.

Evidently the Controls on the UserControl "take focus" (in a way I can't explain, but perhaps one of SO's WinForms gurus will). Perhaps this is related to the fact that UserControl descends from ContainerControl ?

I experimented with writing one 'GotFocus() handler :

    private void Control_GotFocus(object sender, EventArgs e)
    {
        Console.WriteLine("Control GotFocus : " + ((sender as Control).Name));
    }

And then, in the UserControl 'Load event, wired up all the Controls on the UserControl to that event handler : what I observed was that the Control on the UserControl with the lowest TabIndex would fire the 'GotFocus event just on launching the app, and on switching between Forms.

The only other thing I've seen mentioned in this situation is to make sure the 'IsTabStop property of the UserControl is set to 'True : this was from Shawn Wildermuth at MS in the context of a SilverLight related question, so no idea if this might apply in your case.

Another suggestion, which was to write a MouseDown or MouseClick event handler for the UserControl, and in that call: this.SetFocus(); led me nowhere.

Hope you get an answer !


From http://msdn.microsoft.com/en-us/library/system.windows.forms.control.canfocus.aspx

Remarks

In order for a control to receive input focus, the control must have a handle assigned to it, and the Visible and Enabled properties must both be set to true for both the control and all its parent controls, and the control must be a form or the control's outermost parent must be a form.

Ensure you have meet these prerequesits.


UserControl will fight you tooth and nail to avoid getting the focus. It has code that automatically passes the focus to a child control (if any) if it does get the focus. You'll at a minimum have to override WndProc() and trap the WM_SETFOCUS message. There might be other surgery needed, like ControlStyles.Selectable and the TabStop and TabIndex properties.

Your next issue is that UserControl won't respond meaningfully to, say, keyboard messages when it does have focus. You'll need to detect clicks on the UC background to handle mouse messages, as well as override the painting so it is obvious to the user that the UC has the focus (use ControlPaint.DrawFocusRectangle). If this starts to sound unattractive, it's because UC was really meant to be a container control.