FrameworkPropertyMetadata.Inherits プロパティ
定義
重要
一部の情報は、リリース前に大きく変更される可能性があるプレリリースされた製品に関するものです。 Microsoft は、ここに記載されている情報について、明示または黙示を問わず、一切保証しません。
依存関係プロパティの値が継承可能かどうかを示す値を取得または設定します。
public:
property bool Inherits { bool get(); void set(bool value); };
public bool Inherits { get; set; }
member this.Inherits : bool with get, set
Public Property Inherits As Boolean
プロパティ値
プロパティ値が継承可能な場合は true
、それ以外の場合は false
。 既定値は、false
です。
例外
メタデータがシールされるよう、かつメタデータのプロパティを設定できないように、メタデータは依存関係プロパティの操作に既に適用されています。
例
次の例では、さまざまな依存関係プロパティ フィールドから既定のメタデータを取得し、それに対するさまざまな FrameworkPropertyMetadata プロパティの値を照会し、情報を使用してテーブルにデータを設定し、"メタデータ ブラウザー" を実装します。
pm = dp.GetMetadata(dp.OwnerType);
pm = dp.GetMetadata(dp.OwnerType)
FrameworkPropertyMetadata fpm = pm as FrameworkPropertyMetadata;
if (fpm!=null) {
AffectsArrange.Text = (fpm.AffectsArrange) ? "Yes" : "No";
AffectsMeasure.Text = (fpm.AffectsMeasure) ? "Yes" : "No";
AffectsRender.Text = (fpm.AffectsRender) ? "Yes" : "No";
Inherits.Text = (fpm.Inherits) ? "Yes" : "No";
IsDataBindingAllowed.Text = (fpm.IsDataBindingAllowed) ? "Yes" : "No";
BindsTwoWayByDefault.Text = (fpm.BindsTwoWayByDefault) ? "Yes" : "No";
}
Dim fpm As FrameworkPropertyMetadata = TryCast(pm, FrameworkPropertyMetadata)
If fpm IsNot Nothing Then
AffectsArrange.Text = If((fpm.AffectsArrange), "Yes", "No")
AffectsMeasure.Text = If((fpm.AffectsMeasure), "Yes", "No")
AffectsRender.Text = If((fpm.AffectsRender), "Yes", "No")
[Inherits].Text = If((fpm.Inherits), "Yes", "No")
IsDataBindingAllowed.Text = If((fpm.IsDataBindingAllowed), "Yes", "No")
BindsTwoWayByDefault.Text = If((fpm.BindsTwoWayByDefault), "Yes", "No")
注釈
プロパティ値の継承は、WPF フレームワーク レベルの WPF プロパティ システムの機能です。これにより、特定の依存関係プロパティを XAML 要素ツリーのルートまたはその近くの要素にローカルに設定し、その値を、そのプロパティを持つ子要素の論理ツリー内のすべての要素によって継承されます。 プロパティ値の継承は既定では有効になっていません。このプロパティを有効にすると、パフォーマンスに何らかの影響があります。 詳細については、「プロパティ値の継承」を参照してください。
Note
プロパティ値の継承は、アタッチされていない依存関係プロパティでは機能するように見えるかもしれませんが、ランタイム ツリー内の特定のオブジェクト オブジェクト分割を介した非アタッチプロパティの継承動作は未定義です。 メタデータで Inherits を指定する場合は、必ず RegisterAttached を使用してプロパティを登録します。
の派生クラスの PropertyMetadata プロパティは、通常、オブジェクト モデルで読み取り/書き込みとして定義されます。 これは、インスタンスの初期化後に調整できるようにするためです。 ただし、、、または OverrideMetadataのRegisterAddOwner呼び出しの一部としてメタデータが使用された後、プロパティ システムはそのメタデータ インスタンスと、メタデータの詳細を伝えるプロパティを変更不可と見なします。 このメタデータ インスタンスで が のtrue
後IsSealedにこのプロパティを設定しようとすると、例外が発生します。
XAML テキストの使用法
このクラスのメンバーは、通常、XAML では使用されません。
適用対象
こちらもご覧ください
.NET