AccessibleStates Wyliczenie
Definicja
Ważne
Niektóre informacje odnoszą się do produktu w wersji wstępnej, który może zostać znacząco zmodyfikowany przed wydaniem. Firma Microsoft nie udziela żadnych gwarancji, jawnych lub domniemanych, w odniesieniu do informacji podanych w tym miejscu.
Określa wartości reprezentujące możliwe stany dla dostępnego obiektu.
To wyliczenie obsługuje bitową kombinację jego wartości składowych.
public enum class AccessibleStates
[System.Flags]
public enum AccessibleStates
[<System.Flags>]
type AccessibleStates =
Public Enum AccessibleStates
- Dziedziczenie
- Atrybuty
Pola
AlertHigh | 268435456 | Ważne informacje, które powinny zostać natychmiast przekazane użytkownikowi. Na przykład wskaźnik poziomu baterii osiągający krytyczny niski poziom przejdzie do tego stanu, w takim przypadku narzędzie do ślepego dostępu natychmiast ogłosi te informacje użytkownikowi, a program powiększania ekranu przewija ekran tak, aby wskaźnik baterii był w widoku. Ten stan jest również odpowiedni dla każdego monitu lub operacji, które należy wykonać, zanim użytkownik będzie mógł kontynuować. |
AlertLow | 67108864 | Informacje o niskim priorytcie, które mogą nie być ważne dla użytkownika. |
AlertMedium | 134217728 | Ważne informacje, które nie muszą być natychmiast przekazywane użytkownikowi. Na przykład gdy wskaźnik poziomu baterii zaczyna osiągać niski poziom, może wygenerować alert na średnim poziomie. Narzędzia dostępu ślepego mogą następnie wygenerować dźwięk, aby poinformować użytkownika, że ważne informacje są dostępne, bez przerywania pracy użytkownika. Użytkownicy mogą następnie wysyłać zapytania o informacje o alertach w dowolnym momencie. |
Animated | 16384 | Obiekt, który szybko lub stale zmienia wygląd. Grafiki, które są od czasu do czasu animowane, ale nie zawsze, powinny być zdefiniowane jako Graphic |
Busy | 2048 | Kontrolka, która nie może zaakceptować danych wejściowych w bieżącym warunku. |
Checked | 16 | Obiekt z zaznaczonym polem wyboru. |
Collapsed | 1024 | Ukryte elementy podrzędne obiektu, które są elementami w strukturze konspektu lub drzewa. |
Default | 256 | Domyślny przycisk lub element menu. |
Expanded | 512 | Wyświetlane elementy podrzędne obiektu, które są elementami w strukturze konspektu lub drzewa. |
ExtSelectable | 33554432 | Zmieniono zaznaczenie tak, aby wszystkie obiekty między kotwicą zaznaczenia, czyli obiektem z fokusem klawiatury, a ten obiekt przejął stan zaznaczenia obiektu zakotwiczonego. Jeśli obiekt zakotwiczenia nie jest zaznaczony, obiekty zostaną usunięte z zaznaczenia. Jeśli zaznaczono obiekt zakotwiczenia, zaznaczenie zostanie rozszerzone w celu uwzględnienia tego obiektu i wszystkich obiektów między nimi. Stan zaznaczenia można ustawić, łącząc ten element z elementem AddSelection lub RemoveSelection. Ten stan nie zmienia fokusu ani kotwicy zaznaczenia, chyba że jest połączony z elementem TakeFocus. |
Floating | 4096 | Obiekt, który nie jest ustalony na granicy jego obiektu nadrzędnego i który nie przenosi się automatycznie wraz z obiektem nadrzędnym. |
Focusable | 1048576 | Obiekt w aktywnym oknie, które może odbierać fokus klawiatury. |
Focused | 4 | Obiekt z fokusem klawiatury. |
HasPopup | 1073741824 | Obiekt wyświetla wyskakujące menu lub okno po wywołaniu. |
HotTracked | 128 | Obiekt na gorąco śledzony przez mysz, co oznacza, że jego wygląd jest wyróżniony, aby wskazać, że wskaźnik myszy znajduje się nad nim. |
Indeterminate | 32 | Trzystanowe pole wyboru lub przycisk paska narzędzi, którego stan jest nieokreślony. Pole wyboru nie jest zaznaczone ani niezaznaczone i znajduje się w trzecim lub mieszanym stanie. |
Invisible | 32768 | Obiekt bez widocznego interfejsu użytkownika. |
Linked | 4194304 | Obiekt połączony, który nie został wcześniej wybrany. |
Marqueed | 8192 | Obiekt z przewijaniem lub przenoszeniem tekstu lub grafiki. |
Mixed | 32 | Trzystanowe pole wyboru lub przycisk paska narzędzi, którego stan jest nieokreślony. Pole wyboru nie jest zaznaczone ani niezaznaczone i znajduje się w trzecim lub mieszanym stanie. |
Moveable | 262144 | Obiekt ruchomy. |
MultiSelectable | 16777216 | Obiekt, który akceptuje wiele zaznaczonych elementów. |
None | 0 | Brak stanu. |
Offscreen | 65536 | Brak reprezentacji na ekranie. Obiekt dźwięku lub alertu będzie miał ten stan lub ukryte okno, które nigdy nie jest widoczne. |
Pressed | 8 | Obiekt naciśnięty. |
Protected | 536870912 | Kontrolka edycji chroniona hasłem. |
ReadOnly | 64 | Obiekt tylko do odczytu. |
Selectable | 2097152 | Obiekt, który może akceptować zaznaczenie. |
Selected | 2 | Wybrany obiekt. |
SelfVoicing | 524288 | Obiekt lub element podrzędny może użyć zamiany tekstu na mowę (TTS) do opisania się. Pomoc dotycząca ułatwień dostępu na podstawie mowy nie powinna ogłaszać informacji, gdy obiekt o tym stanie ma fokus, ponieważ obiekt automatycznie ogłasza informacje o sobie. |
Sizeable | 131072 | Obiekt o dużej rozmiarze. |
Traversed | 8388608 | Obiekt połączony, który został wcześniej wybrany. |
Unavailable | 1 | Obiekt niedostępny. |
Valid | 1073741823 | Prawidłowy obiekt. Ta właściwość jest przestarzała w .NET Framework 2.0. |
Przykłady
W poniższym przykładzie kodu pokazano tworzenie kontrolki wykresu obsługującego ułatwienia dostępu przy użyciu AccessibleObject klas i Control.ControlAccessibleObject w celu uwidocznienia dostępnych informacji. Kontrolka wykreśli dwie krzywe wraz z legendą. Klasa ChartControlAccessibleObject
, która pochodzi z ControlAccessibleObject
klasy , jest używana w metodzie CreateAccessibilityInstance w celu zapewnienia niestandardowych informacji dostępnych dla kontrolki wykresu. Ponieważ legenda wykresu nie jest rzeczywistą kontrolką opartą na metodzie Control, ale zamiast tego jest rysowana przez kontrolkę wykresu, nie zawiera żadnych wbudowanych informacji dostępnych. W związku z tym ChartControlAccessibleObject
klasa zastępuje metodę GetChild , aby zwrócić CurveLegendAccessibleObject
element reprezentujący dostępne informacje dla każdej części legendy. Gdy ta kontrolka jest używana przez aplikację z ułatwieniami dostępu, kontrolka może dostarczać niezbędne dostępne informacje.
Ten fragment kodu przedstawia użycie AccessibleStates wyliczenia z właściwością State . Zobacz omówienie klasy, AccessibleObject aby zapoznać się z kompletnym przykładem kodu.
// Inner class ChartControlAccessibleObject represents accessible information associated with the ChartControl.
// The ChartControlAccessibleObject is returned in the ChartControl::CreateAccessibilityInstance .
ref class ChartControlAccessibleObject: public ControlAccessibleObject
{
private:
ChartControl^ chartControl;
public:
ChartControlAccessibleObject( ChartControl^ ctrl )
: ControlAccessibleObject( ctrl )
{
chartControl = ctrl;
}
property System::Windows::Forms::AccessibleRole Role
{
// Gets the role for the Chart. This is used by accessibility programs.
virtual System::Windows::Forms::AccessibleRole get() override
{
return ::AccessibleRole::Chart;
}
}
property AccessibleStates State
{
// Gets the state for the Chart. This is used by accessibility programs.
virtual AccessibleStates get() override
{
return AccessibleStates::ReadOnly;
}
}
// The CurveLegend objects are "child" controls in terms of accessibility so
// return the number of ChartLengend objects.
virtual int GetChildCount() override
{
return chartControl->Legends->Length;
}
// Gets the Accessibility object of the child CurveLegend idetified by index.
virtual AccessibleObject^ GetChild( int index ) override
{
if ( index >= 0 && index < chartControl->Legends->Length )
{
return chartControl->Legends[ index ]->AccessibilityObject;
}
return nullptr;
}
internal:
// Helper function that is used by the CurveLegend's accessibility object
// to navigate between sibiling controls. Specifically, this function is used in
// the CurveLegend::CurveLegendAccessibleObject.Navigate function.
AccessibleObject^ NavigateFromChild( CurveLegend::CurveLegendAccessibleObject^ child, AccessibleNavigation navdir )
{
switch ( navdir )
{
case AccessibleNavigation::Down:
case AccessibleNavigation::Next:
return GetChild( child->ID + 1 );
case AccessibleNavigation::Up:
case AccessibleNavigation::Previous:
return GetChild( child->ID - 1 );
}
return nullptr;
}
// Helper function that is used by the CurveLegend's accessibility object
// to select a specific CurveLegend control. Specifically, this function is used
// in the CurveLegend::CurveLegendAccessibleObject.Select function.
void SelectChild( CurveLegend::CurveLegendAccessibleObject^ child, AccessibleSelection selection )
{
int childID = child->ID;
// Determine which selection action should occur, based on the
// AccessibleSelection value.
if ( (selection & AccessibleSelection::TakeSelection) != (AccessibleSelection)0 )
{
for ( int i = 0; i < chartControl->Legends->Length; i++ )
{
if ( i == childID )
{
chartControl->Legends[ i ]->Selected = true;
}
else
{
chartControl->Legends[ i ]->Selected = false;
}
}
// AccessibleSelection->AddSelection means that the CurveLegend will be selected.
if ( (selection & AccessibleSelection::AddSelection) != (AccessibleSelection)0 )
{
chartControl->Legends[ childID ]->Selected = true;
}
// AccessibleSelection->AddSelection means that the CurveLegend will be unselected.
if ( (selection & AccessibleSelection::RemoveSelection) != (AccessibleSelection)0 )
{
chartControl->Legends[ childID ]->Selected = false;
}
}
}
};
// class ChartControlAccessibleObject
// Inner class ChartControlAccessibleObject represents accessible information associated with the ChartControl.
// The ChartControlAccessibleObject is returned in the ChartControl.CreateAccessibilityInstance override.
public class ChartControlAccessibleObject : ControlAccessibleObject
{
ChartControl chartControl;
public ChartControlAccessibleObject(ChartControl ctrl) : base(ctrl)
{
chartControl = ctrl;
}
// Gets the role for the Chart. This is used by accessibility programs.
public override AccessibleRole Role
{
get {
return AccessibleRole.Chart;
}
}
// Gets the state for the Chart. This is used by accessibility programs.
public override AccessibleStates State
{
get {
return AccessibleStates.ReadOnly;
}
}
// The CurveLegend objects are "child" controls in terms of accessibility so
// return the number of ChartLengend objects.
public override int GetChildCount()
{
return chartControl.Legends.Length;
}
// Gets the Accessibility object of the child CurveLegend idetified by index.
public override AccessibleObject GetChild(int index)
{
if (index >= 0 && index < chartControl.Legends.Length) {
return chartControl.Legends[index].AccessibilityObject;
}
return null;
}
// Helper function that is used by the CurveLegend's accessibility object
// to navigate between sibiling controls. Specifically, this function is used in
// the CurveLegend.CurveLegendAccessibleObject.Navigate function.
internal AccessibleObject NavigateFromChild(CurveLegend.CurveLegendAccessibleObject child,
AccessibleNavigation navdir)
{
switch(navdir) {
case AccessibleNavigation.Down:
case AccessibleNavigation.Next:
return GetChild(child.ID + 1);
case AccessibleNavigation.Up:
case AccessibleNavigation.Previous:
return GetChild(child.ID - 1);
}
return null;
}
// Helper function that is used by the CurveLegend's accessibility object
// to select a specific CurveLegend control. Specifically, this function is used
// in the CurveLegend.CurveLegendAccessibleObject.Select function.
internal void SelectChild(CurveLegend.CurveLegendAccessibleObject child, AccessibleSelection selection)
{
int childID = child.ID;
// Determine which selection action should occur, based on the
// AccessibleSelection value.
if ((selection & AccessibleSelection.TakeSelection) != 0) {
for(int i = 0; i < chartControl.Legends.Length; i++) {
if (i == childID) {
chartControl.Legends[i].Selected = true;
} else {
chartControl.Legends[i].Selected = false;
}
}
// AccessibleSelection.AddSelection means that the CurveLegend will be selected.
if ((selection & AccessibleSelection.AddSelection) != 0) {
chartControl.Legends[childID].Selected = true;
}
// AccessibleSelection.AddSelection means that the CurveLegend will be unselected.
if ((selection & AccessibleSelection.RemoveSelection) != 0) {
chartControl.Legends[childID].Selected = false;
}
}
}
}
' Inner Class ChartControlAccessibleObject represents accessible information
' associated with the ChartControl.
' The ChartControlAccessibleObject is returned in the ' ChartControl.CreateAccessibilityInstance override.
Public Class ChartControlAccessibleObject
Inherits Control.ControlAccessibleObject
Private chartControl As ChartControl
Public Sub New(ctrl As ChartControl)
MyBase.New(ctrl)
chartControl = ctrl
End Sub
' Get the role for the Chart. This is used by accessibility programs.
Public Overrides ReadOnly Property Role() As AccessibleRole
Get
Return System.Windows.Forms.AccessibleRole.Chart
End Get
End Property
' Get the state for the Chart. This is used by accessibility programs.
Public Overrides ReadOnly Property State() As AccessibleStates
Get
Return AccessibleStates.ReadOnly
End Get
End Property
' The CurveLegend objects are "child" controls in terms of accessibility so
' return the number of ChartLengend objects.
Public Overrides Function GetChildCount() As Integer
Return chartControl.Legends.Length
End Function
' Get the Accessibility object of the child CurveLegend idetified by index.
Public Overrides Function GetChild(index As Integer) As AccessibleObject
If index >= 0 And index < chartControl.Legends.Length Then
Return chartControl.Legends(index).AccessibilityObject
End If
Return Nothing
End Function
' Helper function that is used by the CurveLegend's accessibility object
' to navigate between sibiling controls. Specifically, this function is used in
' the CurveLegend.CurveLegendAccessibleObject.Navigate function.
Friend Function NavigateFromChild(child As CurveLegend.CurveLegendAccessibleObject, _
navdir As AccessibleNavigation) As AccessibleObject
Select Case navdir
Case AccessibleNavigation.Down, AccessibleNavigation.Next
Return GetChild(child.ID + 1)
Case AccessibleNavigation.Up, AccessibleNavigation.Previous
Return GetChild(child.ID - 1)
End Select
Return Nothing
End Function
' Helper function that is used by the CurveLegend's accessibility object
' to select a specific CurveLegend control. Specifically, this function is used
' in the CurveLegend.CurveLegendAccessibleObject.Select function.
Friend Sub SelectChild(child As CurveLegend.CurveLegendAccessibleObject, selection As AccessibleSelection)
Dim childID As Integer = child.ID
' Determine which selection action should occur, based on the
' AccessibleSelection value.
If (selection And AccessibleSelection.TakeSelection) <> 0 Then
Dim i As Integer
For i = 0 To chartControl.Legends.Length - 1
If i = childID Then
chartControl.Legends(i).Selected = True
Else
chartControl.Legends(i).Selected = False
End If
Next i
' AccessibleSelection.AddSelection means that the CurveLegend will be selected.
If (selection And AccessibleSelection.AddSelection) <> 0 Then
chartControl.Legends(childID).Selected = True
End If
' AccessibleSelection.AddSelection means that the CurveLegend will be unselected.
If (selection And AccessibleSelection.RemoveSelection) <> 0 Then
chartControl.Legends(childID).Selected = False
End If
End If
End Sub
End Class
Uwagi
Dostępny obiekt może być skojarzony z co najmniej jednym z tych stanów.