Exemplarische Vorgehensweise: Vererben von einem Windows Forms-Steuerelement mit Visual C#
Aktualisiert: November 2007
Mit Visual C# 2005 können Sie leistungsstarke benutzerdefinierte Steuerelemente durch Vererbung erstellen. Durch Vererbung können Sie Steuerelemente mit der gesamten Funktionalität von standardmäßigen Windows Forms-Steuerelementen erstellen, die zusätzlich über benutzerdefinierte Funktionalität verfügen. In dieser exemplarischen Vorgehensweise erstellen Sie ein einfaches geerbtes Steuerelement mit der Bezeichnung ValueButton. Diese Schaltfläche erbt die Funktionalität des standardmäßigen Button-Steuerelements in Windows Forms und macht eine benutzerdefinierte Eigenschaft mit der Bezeichnung ButtonValue verfügbar.
Hinweis: |
---|
Je nach den aktiven Einstellungen oder der verwendeten Version können die angezeigten Dialogfelder und Menübefehle von den in der Hilfe beschriebenen abweichen. Klicken Sie im Menü Extras auf Einstellungen importieren und exportieren, um die Einstellungen zu ändern. Weitere Informationen finden Sie unter Visual Studio-Einstellungen. |
Wenn Sie ein neues Projekt erstellen, geben Sie dessen Namen an, um Stammnamespace, Assemblyname und Projektname einzurichten und sicherzustellen, dass die Standardkomponente sich im richtigen Namespace befindet.
Zeigen Sie im Menü Datei auf Neu, und klicken Sie dann auf Projekt, um das Dialogfeld Neues Projekt zu öffnen.
Wählen Sie in der Liste der Visual C#-Projekte die Projektvorlage Windows-Steuerelementbibliothek aus, und geben Sie im Feld Name die Zeichenfolge ValueButtonLib ein.
Der Projektname ValueButtonLib wird standardmäßig auch dem Stammnamespace zugewiesen. Der Stammnamespace wird dazu verwendet, die Namen der Komponenten in der Assembly zu qualifizieren. Wenn beispielsweise zwei Assemblys Komponenten mit der Bezeichnung ValueButton bereitstellen, können Sie die zu verwendende ValueButton-Komponente mit ValueButtonLib.ValueButton spezifizieren. Weitere Informationen finden Sie unter Namespaces (C#-Programmierhandbuch).
Klicken Sie im Projektmappen-Explorer mit der rechten Maustaste auf UserControl1.cs, und wählen Sie im Kontextmenü Umbenennen aus. Ändern Sie den Dateinamen in ValueButton.cs. Klicken Sie auf die Schaltfläche Ja, wenn Sie gefragt werden, ob Sie alle Verweise auf das Codeelement 'UserControl1' umbenennen möchten.
Klicken Sie im Projektmappen-Explorer mit der rechten Maustaste auf ValueButton.cs, und wählen Sie Code anzeigen aus.
Suchen Sie die class-Anweisungszeile public partial class ValueButton, und ändern Sie den Typ, von dem dieses Steuerelement von UserControl erbt, in Button. Dadurch kann das geerbte Steuerelement die gesamte Funktionalität des Button-Steuerelements erben.
Öffnen Sie im Projektmappen-Explorer den Knoten ValueButton.cs, um die vom Designer generierte Codedatei ValueButton.Designer.cs anzuzeigen. Öffnen Sie diese Datei im Code-Editor.
Suchen Sie die InitializeComponent-Methode, und entfernen Sie die Zeile, die die AutoScaleMode-Eigenschaft zuweist. Diese Eigenschaft ist im Button-Steuerelement nicht vorhanden.
Klicken Sie im Menü Datei auf Alle speichern, um das Projekt zu speichern.
Hinweis: Ein visueller Designer ist nicht mehr verfügbar. Da sich das Button-Steuerelement selbst zeichnet, können Sie dessen Darstellung im Designer nicht ändern. Die visuelle Darstellung des Steuerelements entspricht genau der Klasse, von der es erbt (in diesem Fall Button), sofern im Code keine Änderung vorgenommen wurde. Sie können weiterhin Komponenten, die über keine Benutzeroberflächenelemente verfügen, der Entwurfsoberfläche hinzufügen.
Eine Möglichkeit, geerbte Windows Forms-Steuerelemente zu verwenden, besteht darin, Steuerelemente zu erstellen, die in Art und Aussehen mit den standardmäßigen Windows Forms-Steuerelementen identisch sind, dabei aber benutzerdefinierte Eigenschaften verfügbar machen. In diesem Abschnitt fügen Sie dem Steuerelement eine Eigenschaft mit der Bezeichnung ButtonValue hinzu.
Klicken Sie im Projektmappen-Explorer mit der rechten Maustaste auf ValueButton.cs, und klicken Sie dann im Kontextmenü auf Code anzeigen.
Suchen Sie die class-Anweisung. Fügen Sie direkt nach der geschweiften Klammer ({) den folgenden Code ein:
[C#]
// Creates the private variable that will store the value of your // property. private int varValue; // Declares the property. public int ButtonValue { // Sets the method for retrieving the value of your property. get { return varValue; } // Sets the method for setting the value of your property. set { varValue = value; } }
Durch diesen Code werden die Methoden festgelegt, mit denen die ButtonValue-Eigenschaft gespeichert und abgerufen wird. Die get-Anweisung legt den Wert fest, der für den in der privaten Variable varValue gespeicherten Wert zurückgegeben wird, und die set-Anweisung legt den Wert der privaten Variable mithilfe des value-Schlüsselworts fest.
Klicken Sie im Menü Datei auf Alle speichern, um das Projekt zu speichern.
Steuerelemente sind keine eigenständigen Projekte und müssen daher in einem Container untergebracht werden. Um das Steuerelement zu testen, müssen Sie ein Testprojekt erstellen, in dem es ausgeführt wird. Sie müssen außerdem dem Testprojekt den Zugriff auf das Steuerelement ermöglichen, indem Sie das Testprojekt erstellen (kompilieren). In diesem Abschnitt erstellen Sie das Steuerelement und testen es in einem Windows Form.
Klicken Sie im Menü Erstellen auf Projektmappe erstellen.
Das Build sollte erfolgreich und ohne Compilerfehler oder -warnungen abgeschlossen werden.
Zeigen Sie im Menü Datei auf Hinzufügen, und klicken Sie auf Neues Projekt, um das Dialogfeld Neues Projekt hinzufügen zu öffnen.
Wählen Sie den Knoten Windows unter dem Knoten Visual C# aus, und klicken Sie auf Windows-Anwendung.
Geben Sie im Feld Name die Zeichenfolge Test ein.
Klicken Sie im Projektmappen-Explorer mit der rechten Maustaste auf den Knoten Verweise für das Testprojekt, und klicken Sie im Kontextmenü auf Verweis hinzufügen, um das Dialogfeld Verweis hinzufügen anzuzeigen.
Klicken Sie auf die Registerkarte Projekte. Das ValueButtonLib-Projekt wird unter Projektname aufgeführt. Doppelklicken Sie auf das Projekt, um dem Testprojekt den Verweis hinzuzufügen.
Klicken Sie im Projektmappen-Explorer mit der rechten Maustaste auf Test, und wählen Sie Erstellen aus.
Klicken Sie im Projektmappen-Explorer mit der rechten Maustaste auf Form1.cs, und wählen Sie im Kontextmenü Designer anzeigen aus.
Klicken Sie in der Toolbox auf ValueButtonLib Components. Doppelklicken Sie auf ValueButton.
In dem Formular wird ein ValueButton angezeigt.
Klicken Sie mit der rechten Maustaste auf ValueButton, und wählen Sie im Kontextmenü Eigenschaften aus.
Prüfen Sie im Eigenschaftenfenster die Eigenschaften des Steuerelements. Diese stimmen mit Ausnahme einer Eigenschaft (der ButtonValue-Eigenschaft) mit den durch eine standardmäßige Schaltfläche verfügbar gemachten Eigenschaften überein.
Legen Sie für die ButtonValue-Eigenschaft 5 fest.
Doppelklicken Sie auf der Registerkarte Alle Windows Forms der Toolbox auf Label, um dem Formular ein Label-Steuerelement hinzuzufügen.
Verschieben Sie das Label-Steuerelement in die Mitte des Formulars.
Doppelklicken Sie auf valueButton1.
Der Code-Editor wird geöffnet und springt zum valueButton1_Click-Ereignis.
Geben Sie folgende Codezeile ein.
[C#]
label1.Text = valueButton1.ButtonValue.ToString();
Klicken Sie im Projektmappen-Explorer mit der rechten Maustaste auf Test, und wählen Sie im Kontextmenü Als Startprojekt festlegen.
Wählen Sie im Menü Debuggen die Option Debuggen starten.
Form1 wird angezeigt.
Klicken Sie auf valueButton1.
In label1 wird die Zahl '5' angezeigt, was darauf hinweist, dass die ButtonValue-Eigenschaft des geerbten Steuerelements mithilfe der valueButton1_Click-Methode an label1 übergeben wurde. Somit erbt das ValueButton-Steuerelement alle Funktionen der Windows Forms-Standardschaltfläche, macht jedoch eine zusätzliche benutzerdefinierte Eigenschaft verfügbar.
Gewusst wie: Anzeigen eines Steuerelements im Dialogfeld "Toolbox anpassen"
Exemplarische Vorgehensweise: Erstellen eines zusammengesetzten Steuerelements mit Visual C#