Cómo: Crear una interfaz de usuario de varios paneles con formularios Windows Forms
El procedimiento siguiente permite crear una interfaz de usuario de varios recuadros parecida a la utilizada en Microsoft Outlook, con una lista de Carpetas, un recuadro de Mensajes y un recuadro de Vista previa. Esta organización se logra principalmente mediante el acoplamiento de los controles con el formulario.
Al acoplar un control se determina a cuál de los bordes del contenedor principal deberá fijarse. Por consiguiente, si establece la propiedad Dock en Right, el borde derecho del control se acoplará al borde derecho de su control primario. Además, el tamaño del borde acoplado del control se ajusta al tamaño del control contenedor. Para obtener más información sobre cómo funciona la propiedad Dock, vea Cómo: Acoplar controles en formularios Windows Forms.
Este procedimiento se centra en organizar el contenedor SplitContainer y los demás controles del formulario, no se trata de agregar funcionalidades para obtener una aplicación que imite a Microsoft Outlook.
Para crear esta interfaz de usuario, se colocan todos los controles dentro de un control SplitContainer que, a su vez, contiene un control TreeView en el panel izquierdo. El panel derecho del control SplitContainer contiene un segundo control SplitContainer, que a su vez tiene un control ListView por encima de un control RichTextBox. Estos controles SplitContainer permiten realizar el ajuste del tamaño de los demás controles del formulario de manera independiente. Puede adaptar las técnicas de este procedimiento para crear interfaces de usuario personalizadas propias.
Para crear una interfaz de usuario de estilo Outlook mediante programación
En un formulario, declare cada uno de los controles que constituyen la interfaz de usuario. Para este ejemplo, utilice los controles TreeView, ListView, SplitContainer y RichTextBox para imitar la interfaz de usuario de Microsoft Outlook.
Private WithEvents treeView1 As System.Windows.Forms.TreeView Private WithEvents listView1 As System.Windows.Forms.ListView Private WithEvents richTextBox1 As System.Windows.Forms.RichTextBox Private WithEvents splitContainer1 As _ System.Windows.Forms.SplitContainer Private WithEvents splitContainer2 As _ System.Windows.Forms.SplitContainer
private System.Windows.Forms.TreeView treeView1; private System.Windows.Forms.ListView listView1; private System.Windows.Forms.RichTextBox richTextBox1; private System.Windows.Forms. SplitContainer splitContainer2; private System.Windows.Forms. SplitContainer splitContainer1;
private System.Windows.Forms.TreeView treeView1; private System.Windows.Forms.ListView listView1; private System.Windows.Forms.RichTextBox richTextBox1; private System.Windows.Forms.SplitContainer splitContainer2; private System.Windows.Forms.SplitContainer splitContainer1;
Cree un procedimiento que defina la interfaz de usuario. El código siguiente establece las propiedades de modo que el formulario se asemeje a la interfaz de usuario de Microsoft Outlook. Sin embargo, si utiliza otros controles o los acopla de forma diferente, es igual de fácil crear otras interfaces de usuario que tengan la misma flexibilidad.
Public Sub CreateOutlookUI() ' Create an instance of each control being used. Me.components = New System.ComponentModel.Container() Me.treeView1 = New System.Windows.Forms.TreeView() Me.listView1 = New System.Windows.Forms.ListView() Me.richTextBox1 = New System.Windows.Forms.RichTextBox() Me.splitContainer1 = New System.Windows.Forms.SplitContainer() Me.splitContainer2= New System.Windows.Forms. SplitContainer() ' Should you develop this into a working application, ' use the AddHandler method to hook up event procedures here. ' Set properties of TreeView control. ' Use the With statement to avoid repetitive code. With Me.treeView1 .Dock = System.Windows.Forms.DockStyle.Fill .TabIndex = 0 .Nodes.Add("treeView") End With ' Set properties of ListView control. With Me.listView1 .Dock = System.Windows.Forms.DockStyle.Top .TabIndex = 2 .Items.Add("listView") End With ' Set properties of RichTextBox control. With Me.richTextBox1 .Dock = System.Windows.Forms.DockStyle.Fill .TabIndex = 3 .Text = "richTextBox1" End With ' Set properties of the first SplitContainer control. With Me.splitContainer1 .Dock = System.Windows.Forms.DockStyle.Fill .TabIndex = 1 .SplitterWidth = 4 .SplitterDistance = 150 .Orientation = Orientation.Horizontal .Panel1.Controls.Add(Me.listView1) .Panel2.Controls.Add(Me.richTextBox1) End With ' Set properties of the second SplitContainer control. With Me.splitContainer2 .Dock = System.Windows.Forms.DockStyle.Fill .TabIndex = 4 .SplitterWidth = 4 .SplitterDistance = 100 .Panel1.Controls.Add(Me.treeView1) .Panel2.Controls.Add(Me.SplitContainer1) End With ' Add the main SplitContainer control to the form. Me.Controls.Add(Me.splitContainer2) Me.Text = "Intricate UI Example" End Sub
public void createOutlookUI() { // Create an instance of each control being used. treeView1 = new System.Windows.Forms.TreeView(); listView1 = new System.Windows.Forms.ListView(); richTextBox1 = new System.Windows.Forms.RichTextBox(); splitContainer2 = new System.Windows.Forms.SplitContainer(); splitContainer1 = new System.Windows.Forms.SplitContainer(); // Insert code here to hook up event methods. // Set properties of TreeView control. treeView1.Dock = System.Windows.Forms.DockStyle.Fill; treeView1.TabIndex = 0; treeView1.Nodes.Add("treeView"); // Set properties of ListView control. listView1.Dock = System.Windows.Forms.DockStyle.Top; listView1.TabIndex = 2; listView1.Items.Add("listView"); // Set properties of RichTextBox control. richTextBox1.Dock = System.Windows.Forms.DockStyle.Fill; richTextBox1.TabIndex = 3; richTextBox1.Text = "richTextBox1"; // Set properties of first SplitContainer control. splitContainer1.Dock = System.Windows.Forms.DockStyle.Fill; splitContainer2.TabIndex = 1; splitContainer2.SplitterWidth = 4; splitContainer2.SplitterDistance = 150; splitContainer2.Orientation = Orientation.Horizontal; splitContainer2.Panel1.Controls.Add(this.listView1); splitContainer2.Panel1.Controls.Add(this.richTextBox1); // Set properties of second SplitContainer control. splitContainer2.Dock = System.Windows.Forms.DockStyle.Fill; splitContainer2.TabIndex = 4; splitContainer2.SplitterWidth = 4; splitContainer2.SplitterDistance = 100; splitContainer2.Panel1.Controls.Add(this.treeView1); splitContainer2.Panel1.Controls.Add(this.splitContainer1); // Add the main SplitContainer control to the form. this.Controls.Add(this.splitContainer2); this.Text = "Intricate UI Example"; }
public void createOutlookUI() { // Create an instance of each control being used. treeView1 = new System.Windows.Forms.TreeView(); listView1 = new System.Windows.Forms.ListView(); richTextBox1 = new System.Windows.Forms.RichTextBox(); splitContainer2 = new System.Windows.Forms.SplitContainer(); splitContainer1 = new System.Windows.Forms.SplitContainer(); // Insert code here to hook up event methods. // Set properties of TreeView control. treeView1.set_Dock(System.Windows.Forms.DockStyle.Fill); treeView1.set_TabIndex(0); treeView1.get_Nodes().Add("treeView"); // Set properties of ListView control. listView1.set_Dock(System.Windows.Forms.DockStyle.Top); listView1.set_TabIndex(2); listView1.get_Items().Add("listView"); // Set properties of RichTextBox control. richTextBox1.set_Dock(System.Windows.Forms.DockStyle.Fill); richTextBox1.set_TabIndex(3); richTextBox1.set_Text("richTextBox1"); // Set properties of first SplitContainer control. splitContainer1.set_Dock(System.Windows.Forms.DockStyle.Fill); splitContainer2.set_TabIndex(1); splitContainer2.set_SplitterWidth(4); splitContainer2.set_SplitterDistance(150); splitContainer2.set_Orientation(Orientation.Horizontal); splitContainer2.get_Panel1().get_Controls().Add(this.listView1); splitContainer2.get_Panel1().get_Controls().Add(this.richTextBox1); // Set properties of second SplitContainer control. splitContainer2.set_Dock(System.Windows.Forms.DockStyle.Fill); splitContainer2.set_TabIndex(4); splitContainer2.set_SplitterWidth(4); splitContainer2.set_SplitterDistance(100); splitContainer2.get_Panel1().get_Controls().Add(this.treeView1); splitContainer2.get_Panel1().get_Controls().Add(this.splitContainer1); // Add the main SplitContainer control to the form. this.get_Controls().Add(this.splitContainer2); this.set_Text("Intricate UI Example"); }
En Visual Basic, agregue una llamada al procedimiento que acaba de crear en el procedimiento New(). En Visual C#, agregue esta línea de código al constructor de la clase de formulario.
' Add this to the New procedure. CreateOutlookUI()
// Add this to the form class's constructor. createOutlookUI();
// Add this to the form class's constructor. createOutlookUI();