UIElement.Focusable Özellik
Tanım
Önemli
Bazı bilgiler ürünün ön sürümüyle ilgilidir ve sürüm öncesinde önemli değişiklikler yapılmış olabilir. Burada verilen bilgilerle ilgili olarak Microsoft açık veya zımni hiçbir garanti vermez.
Öğesinin odağı alıp alamayacağını gösteren bir değer alır veya ayarlar. Bu bir bağımlılık özelliğidir.
public:
property bool Focusable { bool get(); void set(bool value); };
public bool Focusable { get; set; }
member this.Focusable : bool with get, set
Public Property Focusable As Boolean
Özellik Değeri
Öğenin odaklanabilir olup olmadığını true
; aksi takdirde false
. Varsayılan değer false
.
Uygulamalar
Örnekler
Aşağıdaki örnek kod, belirli bir özel denetim için şablon içindeki öğelerden birinde Focusablefalse
ayarlayan bir denetim şablonunu gösterir.
<Window.Resources>
<Style x:Key="TextBoxNoScrollViewer" TargetType="{x:Type TextBoxBase}">
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="{x:Type TextBoxBase}">
<Border
CornerRadius="2"
Background="{TemplateBinding Background}"
BorderThickness="{TemplateBinding BorderThickness}"
BorderBrush="{TemplateBinding BorderBrush}"
>
<!--
The control template for a TextBox or RichTextBox must
include an element tagged as the content host. An element is
tagged as the content host element when it has the special name
PART_ContentHost. The content host element must be a ScrollViewer,
or an element that derives from Decorator.
-->
<AdornerDecorator
x:Name="PART_ContentHost"
Focusable="False"
/>
</Border>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
</Window.Resources>
Açıklamalar
Yalnızca odaklanmış öğe klavye girişi alır.
Focusable, gerçekte bir bağımlılık özelliği için Microsoft .NET özellik erişimcisidir. Bu belirli bağımlılık özelliği, özellikle denetimlerde türetilmiş öğe sınıflarında belirgin "varsayılan" değeri farklı ayarlanmıştır. Bu genellikle iki yoldan biriyle gerçekleşir:
Bağımlılık özelliği belirli bir türetilmiş sınıf tarafından devralınır, ancak bu türetilmiş sınıf bağımlılık özelliğinin meta verilerini geçersiz kılar ve özellik varsayılan değerini değiştirir.
Bağımlılık özelliği değerini farklı şekilde ayarlayan bir öğeye stil veya şablon uygulanır.
Örneğin, bir Button denetimi için Focusable görünen "varsayılan" değeri, ButtonFocusable doğrudan UIElement'den ortak dil çalışma zamanı (CLR) özelliği olarak devralsa bile true
olur. Bunun nedeni, Focusable bağımlılık özelliği için uygulanan meta veri değerinin, sınıf hiyerarşisindeki Button ile UIElement arasında yer alan Control temel sınıfının statik oluşturucusunda geçersiz kılınmış olmasıdır.
Control veya türetilmiş sınıfları tarafından devralındığında, Control bu özelliğin varsayılan değerini true
olacak şekilde yeniden tanımlar.
Label (Control türetilmiş bir sınıf) tarafından devralındığında, varsayılan değer false
olacak şekilde yeniden tanımlanır.
Bağımlılık Özelliği Bilgileri
Tanımlayıcı alanı | FocusableProperty |
meta veri özellikleri true olarak ayarlandı |
Hiç kimse |
Devralanlara Notlar
doğrudan UIElement türetilirken (Control'den farklı olarak), öğenizin odaklanabilir olmasını isteyip istemediğinizi düşünün, çünkü varsayılan olarak öğe odaklanılabilir olmayacaktır. Öğenizin odaklanabilir olmasını istiyorsanız, türünüzün statik oluşturucusunun içindeki bu özelliğin meta verilerini aşağıdaki gibi geçersiz kılın:
FocusableProperty.OverrideMetadata(typeof(myElement), new UIPropertyMetadata(true));
FocusableProperty.OverrideMetadata(GetType(myElement), New UIPropertyMetadata(True))
burada myElement
, meta veri değerini geçersiz kıldığınız türün sınıf adı olmalıdır.