共用方式為


定義屬性

如需屬性的概觀,請參閱屬性概觀。在定義屬性時有一些重要的考量:

  • 您必須套用屬性 (Attribute) 於您定義的屬性 (Property)。屬性 (Attribute) 指定設計工具應該如何顯示屬性 (Property)。如需詳細資訊,請參閱元件的設計階段屬性

  • 如果變更屬性會影響控制項的視覺顯示,請從 set 存取子呼叫 Invalidate 方法 (您控制項繼承自 Control 的方法)。Invalidate 接著呼叫 OnPaint 方法,這將會重繪控制項。對 Invalidate 的多重呼叫為了有效率起見,會產生對 OnPaint 的單一呼叫。

  • .NET Framework 類別庫 (Class Library) 提供型別轉換子 (Type Converter) 給一般資料型別,例如整數、小數數字、布林 (Boolean) 值等。型別轉換子的用途通常提供字串至數值的轉換 (從字串資料至其他資料型別)。一般資料型別與預設型別轉換子有關聯,這轉換子會轉換數值為字串,和轉換字串為適當資料型別。如果您定義自訂 (亦即,非標準的) 資料型別的屬性 (Property),您將必須套用屬性 (Attribute),以指定與那屬性相關的型別轉換子。您可以也可以使用屬性 (Attribute) 來將自訂 UI 型別編輯器與屬性 (Property) 產生關聯。UI 型別編輯器提供用以編輯屬性或資料型別的使用者介面。色彩選擇器即為 UI 型別編輯器的一個例子。屬性的範例在這個主題的結尾會提供。

    注意 如果您的自訂屬性沒有型別轉換子或 UI 型別編輯器,您可以實作一個,如增強設計階段支援中所說明的。

下列程式碼片段為自訂控制項 FlashTrackBar 定義名為 EndColor 的自訂屬性。

Public Class FlashTrackBar
   Inherits Control
   ...
   ' Private data member that backs the EndColor property.
   Private _endColor As Color = Color.LimeGreen

   ' The Category attribute tells the designer to display
   ' it in the Flash grouping. 
   ' The Description attribute provides a description of
   ' the property. 
   <Category("Flash"), _
   Description("The ending color of the bar.")>  _
   Public Property EndColor() As Color
      ' The public property EndColor accesses _endColor.
      Get
         Return _endColor
      End Get
      Set
         _endColor = value
         If Not (baseBackground Is Nothing) And showGradient Then
            baseBackground.Dispose()
            baseBackground = Nothing
         End If
         ' The Invalidate method calls the OnPaint method, which redraws  
         ' the control.
         Invalidate()
      End Set
   End Property
   ...
End Class
[C#]
public class FlashTrackBar : Control {
   ...
   // Private data member that backs the EndColor property.
   private Color endColor = Color.LimeGreen;
   // The Category attribute tells the designer to display
   // it in the Flash grouping. 
   // The Description attribute provides a description of
   // the property. 
   [
   Category("Flash"),
   Description("The ending color of the bar.")
   ]
   // The public property EndColor accesses endColor.
   public Color EndColor {
      get {
         return endColor;
      }
      set {
         endColor = value;
         if (baseBackground != null && showGradient) {
            baseBackground.Dispose();
            baseBackground = null;
         }
         // The Invalidate method calls the OnPaint method, which redraws 
         // the control.
         Invalidate();
      }
   }
   ...
}

下列程式碼片段將型別轉換子和 UI 型別編輯器與屬性 Value 產生關聯。這個案例中 Value 為整數,並具有預設型別轉換子,但 TypeConverter 屬性套用自訂型別轉換子 (FlashTrackBarValueConverter) 以允許設計工具將它顯示為百分比。UI 型別編輯器 FlashTrackBarValueEditor 讓百分比可以視覺化顯示。這個範例也示範 TypeConverterEditor 屬性指定的型別轉換子或編輯器如何覆寫預設轉換子。

<Category("Flash"), _
TypeConverter(GetType(FlashTrackBarValueConverter)), _
Editor(GetType(FlashTrackBarValueEditor), _
GetType(UITypeEditor)), _
Description("The current value of the track bar.  You can enter an actual value or a percentage.")>  _
Public ReadOnly Property Value() As Integer
...
End Property
[C#]
[
Category("Flash"), 
TypeConverter(typeof(FlashTrackBarValueConverter)),
Editor(typeof(FlashTrackBarValueEditor), typeof(UITypeEditor)),
Description("The current value of the track bar.  You can enter an actual value or a percentage.")
]
public int Value {
...
}

請參閱

Windows Form 控制項中的屬性 | ShouldSerialize 和 Reset 方法 | 屬性變更事件