Microsoft KB Archive/319465

= How to change the background color for an MDI parent form in Visual C# =

Article ID: 319465

Article Last Modified on 12/11/2006

-

APPLIES TO


 * Microsoft Visual C# .NET 2002 Standard Edition
 * Microsoft Visual C# 2005 Express Edition

-



This article was previously published under Q319465



For a Microsoft Visual Basic .NET version of this article, see 319417.

IN THIS TASK
SUMMARY
 * Create a Sample Windows Application by Using Visual C# .NET

REFERENCES



SUMMARY
This step-by-step article demonstrates how to programmatically change the background color for a multiple-document interface (MDI) parent form by using Visual C#.

When you use a Windows Form as an MDI parent form, the Application Background color setting in Windows Control Panel, not the form's BackgroundColor property, determines the background color of the form. The following steps demonstrate how to programmatically change the MDI parent form's background color to another color.

back to the top

Create a Sample Windows Application by Using Visual C# .NET
 Create a new Visual C# Windows application. Form1 is created by default. Click the form, and then, on the View menu, select Properties Window to view the properties for the form. Set the BackColor property to the color that you want (such as LightBlue). Set the IsMDIContainer property to True. Note that the background color of the form changes to the color that the Application Background color is set to in Control Panel. Set the WindowState property to Maximized. Double-click the form to view its code window.  Paste the following code into the form's Load event handler: MdiClient ctlMDI;

// Loop through all of the form's controls looking // for the control of type MdiClient. foreach (Control ctl in this.Controls) {  try {     // Attempt to cast the control to type MdiClient. ctlMDI = (MdiClient) ctl;

// Set the BackColor of the MdiClient control. ctlMDI.BackColor = this.BackColor; }  catch (InvalidCastException exc) {     // Catch and ignore the error if casting failed. }                } // Display a child form to show this is still an MDI application. Form2 frm = new Form2; frm.MdiParent = this; frm.Show; </li> On the Project menu, click Add Windows Form.</li> Accept the default name Form2.cs, and then click Open.</li> Press F5 to run the application.</li></ol>

Note that the MDI parent form loads and has a light blue background.

back to the top

<div class="references_section">