次の方法で共有


チュートリアル: C を使用して Windows フォーム コントロールから継承する#

C# では、 継承を通じて強力なカスタム コントロールを作成できます。 継承により、標準の Windows フォーム コントロールに固有のすべての機能を保持するだけでなく、カスタム機能も組み込むコントロールを作成できます。 このチュートリアルでは、 ValueButtonと呼ばれる単純な継承コントロールを作成します。 このボタンは、標準の Windows フォーム Button コントロールから機能を継承し、 ButtonValueと呼ばれるカスタム プロパティを公開します。

プロジェクトの作成

新しいプロジェクトを作成するときは、ルート名前空間、アセンブリ名、プロジェクト名を設定し、既定のコンポーネントが正しい名前空間に含まれるように、その名前を指定します。

ValueButtonLib コントロール ライブラリと ValueButton コントロールを作成するには

  1. Visual Studio で、新しい Windows フォーム コントロール ライブラリ プロジェクトを 作成し、 ValueButtonLib という名前を付けます。

    プロジェクト名 ValueButtonLibは、既定でルート名前空間にも割り当てられます。 ルート名前空間は、アセンブリ内のコンポーネントの名前を修飾するために使用されます。 たとえば、2 つのアセンブリに ValueButton という名前のコンポーネントが用意されている場合は、ValueButtonを使用してValueButtonLib.ValueButton コンポーネントを指定できます。 詳細については、「名前空間」を参照してください。

  2. ソリューション エクスプローラーでUserControl1.cs右クリックし、ショートカット メニューから [名前の変更] を選択します。 ファイル名を ValueButton.csに変更します。 コード要素 '' へのすべての参照の名前を変更するかどうかを確認するメッセージが表示されたら、[UserControl1] ボタンをクリックします。

  3. ソリューション エクスプローラーでValueButton.csを右クリックし、[コードの表示] を選択します。

  4. classステートメント行を見つけてpublic partial class ValueButtonし、このコントロールの継承元の型をUserControlからButtonに変更します。 これにより、継承されたコントロールは、 Button コントロールのすべての機能を継承できます。

  5. ソリューション エクスプローラーValueButton.cs ノードを開き、デザイナーによって生成されたコード ファイル (ValueButton.Designer.cs) を表示します。 コード エディターでこのファイルを開きます。

  6. InitializeComponentメソッドを見つけて、AutoScaleMode プロパティを割り当てる行を削除します。 このプロパティは、 Button コントロールには存在しません。

  7. [ ファイル ] メニューの [ すべて保存] を選択してプロジェクトを保存します。

    ビジュアル デザイナーは使用できなくなりました。 Button コントロールは独自の描画を行うため、デザイナーでその外観を変更することはできません。 コードで変更しない限り、そのビジュアル表現は継承するクラス (つまり、 Button) とまったく同じになります。 UI 要素のないコンポーネントをデザイン サーフェイスに追加することもできます。

継承したコントロールにプロパティを追加する

継承された Windows フォーム コントロールの 1 つの使用可能な用途は、標準の Windows フォーム コントロールの外観は同じですが、カスタム プロパティを公開するコントロールの作成です。 このセクションでは、 ButtonValue というプロパティをコントロールに追加します。

Value プロパティを追加するには

  1. ソリューション エクスプローラーでValueButton.csを右クリックし、ショートカット メニューの [コードの表示] をクリックします。

  2. class ステートメントを見つけます。 {の直後に、次のコードを入力します。

    // 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;
       }
    }
    

    このコードでは、 ButtonValue プロパティの格納と取得に使用するメソッドを設定します。 get ステートメントは、プライベート変数varValueに格納されている値に返される値を設定し、set ステートメントは、value キーワードを使用してプライベート変数の値を設定します。

  3. [ ファイル ] メニューの [ すべて保存] を選択してプロジェクトを保存します。

コントロールをテストする

コントロールはスタンドアロン プロジェクトではありません。これらはコンテナーでホストされている必要があります。 コントロールをテストするには、コントロールを実行するためのテスト プロジェクトを指定する必要があります。 また、テスト プロジェクトをビルド (コンパイル) して、コントロールにアクセスできるようにする必要があります。 このセクションでは、コントロールをビルドし、Windows フォームでテストします。

コントロールを構築するには

[ビルド] メニューの [ソリューションのビルド] をクリックします。 ビルドは、コンパイラ エラーや警告なしで成功するはずです。

テスト プロジェクトを作成するには

  1. [ ファイル ] メニューの [ 追加 ] をポイントし、[ 新しいプロジェクト ] をクリックして [ 新しいプロジェクトの追加 ] ダイアログ ボックスを開きます。

  2. Visual C# ノードの下にある Windows ノードを選択し、[Windows フォーム アプリケーション] をクリックします。

  3. [ 名前 ] ボックスに「 テスト」と入力します。

  4. ソリューション エクスプローラーで、テスト プロジェクトの [参照] ノードを右クリックし、ショートカット メニューから [参照の追加] を選択して [参照の追加] ダイアログ ボックスを表示します。

  5. [ プロジェクト] というラベルの付いたタブをクリックします。 ValueButtonLib プロジェクトがプロジェクト の下に表示されます。 プロジェクトをダブルクリックして、テスト プロジェクトへの参照を追加します。

  6. ソリューション エクスプローラーで、[テスト] を右クリックし、[ビルド] を選択します。

フォームにコントロールを追加するには

  1. ソリューション エクスプローラーでForm1.cs右クリックし、ショートカット メニューから [デザイナーの表示] を選択します。

  2. ツールボックスで、ValueButtonLib コンポーネントを選択します。 ValueButton をダブルクリックします。

    フォームに ValueButton が表示されます。

  3. ValueButton を右クリックし、ショートカット メニューから [プロパティ] を選択します。

  4. [ プロパティ ] ウィンドウで、このコントロールのプロパティを確認します。 追加のプロパティ ButtonValue がある点を除き、これらは標準ボタンによって公開されるプロパティと同じであることに注意してください。

  5. ButtonValue プロパティを 5 に設定します。

  6. ツールボックスの [すべての Windows フォーム] タブで、[ラベル] をダブルクリックして、フォームにLabel コントロールを追加します。

  7. フォームの中央にラベルを再配置します。

  8. valueButton1をダブルクリックします。

    コード エディターが開き、valueButton1_Click イベントが表示されます。

  9. 次のコード行を挿入します。

    label1.Text = valueButton1.ButtonValue.ToString();
    
  10. ソリューション エクスプローラーで、[テスト] を右クリックし、ショートカット メニューから [スタートアップ プロジェクトとして設定] を選択します。

  11. [ デバッグ ] メニューの [ デバッグの開始] を選択します。

    Form1 が表示されます。

  12. valueButton1をクリックします。

    label1に数字 '5' が表示され、継承されたコントロールのButtonValue プロパティが、label1 メソッドを介してvalueButton1_Clickに渡されたことを示しています。 したがって、 ValueButton コントロールは標準の Windows フォーム ボタンのすべての機能を継承しますが、追加のカスタム プロパティを公開します。

こちらも参照ください