Tutorial: Demostración de la herencia visual
La herencia visual le permite ver los controles del formulario base y agregar controles nuevos. En este tutorial, creará un formulario base y lo compilará para convertirlo en una biblioteca de clases. Importará la biblioteca de clases en otro proyecto y creará un nuevo formulario que herede del formulario base. Durante este tutorial aprenderá a:
Crear un proyecto de biblioteca de clases que contiene un formulario base.
Agregar un botón con propiedades que las clases derivadas del formulario base pueden modificar.
Agregar un botón que los herederos del formulario base no pueden modificar.
Crear un proyecto que contiene un formulario que hereda de
BaseForm
.
Por último, en este tutorial se mostrará la diferencia entre los controles privados y los protegidos de un formulario heredado.
Precaución
No todos los controles admiten la herencia visual a partir de un formulario base. Los siguientes controles no admiten el escenario que se describe en este tutorial:
Estos controles del formulario heredado siempre son de solo lectura, independientemente de los modificadores que utilice (private
, protected
o public
).
Creación de un proyecto de biblioteca de clases que contiene un formulario base
En Visual Studio, en el menú Archivo, elija Nuevo>Proyecto para abrir el cuadro de diálogo Nuevo proyecto.
Cree una aplicación de Windows Forms llamada
BaseFormLibrary
.Para crear una biblioteca de clases en lugar de una aplicación de Windows Forms estándar, en el Explorador de soluciones, haga clic con el botón derecho en el nodo de proyecto BaseFormLibrary y, después, elija Propiedades.
En las propiedades del proyecto, cambie el Tipo de resultado de Aplicación Windows a Biblioteca de clases.
En el menú Archivo, elija Guardar todo para guardar el proyecto y los archivos en la ubicación predeterminada.
Los dos procedimientos siguientes agregan botones al formulario base. Para ilustrar la herencia visual, proporcionará a los botones distintos niveles de acceso estableciendo sus propiedades Modifiers
.
Adición de un botón que los herederos del formulario base puedan modificar
Abra Form1 en el diseñador.
En la pestaña Todos los formularios Windows Forms del Cuadro de herramientas, haga doble clic en Botón para agregar un botón al formulario. Use el mouse para colocar y cambiar de tamaño el botón.
En la ventana Propiedades, establezca las propiedades siguientes del botón:
Establezca la propiedad Text como Decir hola.
Establezca la propiedad (Name) como btnProtected.
Establezca la propiedad Modifiers como Protected. Esto permite que los formularios que heredan de Form1 modifiquen las propiedades de btnProtected.
Haga doble clic en el botón Decir hola para agregar un controlador de eventos para el evento Click.
Agregue la línea de código siguiente al controlador del evento:
MessageBox.Show("Hello, World!")
MessageBox.Show("Hello, World!");
Adición de un botón que los herederos del formulario base no pueden modificar
Pase a la vista Diseño haciendo clic en la pestaña Form1.vb [Diseño], Form1.cs [Diseño] o Form1.jsl [Diseño] encima del editor de código o presionando F7.
Agregue un segundo botón y establezca sus propiedades como sigue:
Establezca la propiedad Text como Decir adiós.
Establezca la propiedad (Name) como btnPrivate.
Establezca la propiedad Modifiers como Private. Esto impide que los formularios que heredan de Form1 modifiquen las propiedades de btnPrivate.
Haga doble clic en el botón Decir adiós para agregar un controlador de eventos para el evento Click. Coloque la siguiente línea de código en el procedimiento de evento:
MessageBox.Show("Goodbye!")
MessageBox.Show("Goodbye!");
En el menú Compilación, elija Compilar biblioteca BaseForm para compilar la biblioteca de clases.
Una vez compilada la biblioteca, puede crear un nuevo proyecto que herede del formulario que acaba de crear.
Creación de un proyecto que contenga un formulario que herede del formulario base
En el menú Archivo, elija Agregar y, luego, elija Nuevo proyecto para abrir el cuadro de diálogo Agregar nuevo proyecto.
Cree una aplicación de Windows Forms llamada
InheritanceTest
.
Adición de un formulario heredado
En el Explorador de soluciones, haga clic con el botón derecho en el proyecto InheritanceTest, elija Agregar y, luego, elija Nuevo elemento.
En el cuadro de diálogo Agregar nuevo elemento, seleccione la categoría Windows Forms (si aparece una lista de categorías) y, después, seleccione la plantilla Formulario heredado.
Deje el nombre predeterminado de
Form2
y haga clic en Agregar.En el cuadro de diálogo Selector de herencia, elija Form1 desde el proyecto BaseFormLibrary como el formulario del que se heredará y haga clic en Aceptar.
Se creará un formulario en el proyecto InheritanceTest que derivará del formulario de BaseFormLibrary.
Abra el formulario heredado (Form2) en el diseñador haciendo doble clic en él, si no está abierto ya.
En el diseñador, los botones heredados tienen un símbolo () en la esquina superior para indicar que son heredados.
Elija el botón Decir hola y observe los controladores de tamaño. Como este botón está protegido, los herederos pueden moverlo, cambiarlo de tamaño, cambiar su descripción y realizar otras modificaciones.
Elija el botón privado Decir adiós y observe que no tiene controladores de tamaño. Además, en la ventana Propiedades, las propiedades del botón aparecen en gris para indicar que no se pueden modificar.
Si usa Visual C#:
En el Explorador de soluciones, haga clic con el botón derecho en Form1 en el proyecto InheritanceTest y, luego, elija Eliminar. En el cuadro de mensaje que aparece, haga clic en Aceptar para confirmar la eliminación.
Abra el archivo Program.cs y cambie la línea
Application.Run(new Form1());
porApplication.Run(new Form2());
.
En el Explorador de soluciones, haga clic con el botón derecho en el proyecto InheritanceTest y elija Establecer como proyecto de inicio.
En el Explorador de soluciones, haga clic con el botón derecho en el proyecto InheritanceTest y elija Propiedades.
En las páginas de propiedades de InheritanceTest, establezca el Objeto de inicio de modo que sea el formulario heredado (Form2).
Presione F5 para ejecutar la aplicación y observe el comportamiento del formulario heredado.
Pasos siguientes
La herencia de los controles de usuario funciona más o menos de la misma manera. Abra un proyecto nuevo de biblioteca de clases y agregue un control de usuario. Coloque en él controles constituyentes y compile el proyecto. Abra otro proyecto nuevo de biblioteca de clases y agregue una referencia a la biblioteca de clases compilada. Además, pruebe a agregar al proyecto un control heredado (con el cuadro de diálogo Agregar nuevos elementos) y a usar el Selector de herencia. Agregue un control de usuario y cambie la instrucción Inherits
(:
en Visual C#). Para más información, consulte Cómo: Heredar formularios Windows Forms.
Consulte también
.NET Desktop feedback