public class AccessibilityChannel extends Object
See AccessibilityChannel.AccessibilityMessageHandler
, which lists all accessibility requests and
events that might be sent from Flutter to the Android platform.
Modifier and Type | Class and Description |
---|---|
static interface |
AccessibilityChannel.AccessibilityMessageHandler
Handler that receives accessibility messages sent from Flutter to Android
through a given
AccessibilityChannel . |
Modifier and Type | Field and Description |
---|---|
BasicMessageChannel<Object> |
channel |
FlutterJNI |
flutterJNI |
Constructor and Description |
---|
AccessibilityChannel(DartExecutor dartExecutor,
FlutterJNI flutterJNI)
Constructs an
AccessibilityChannel that connects Android to the Dart code
running in dartExecutor . |
Modifier and Type | Method and Description |
---|---|
void |
dispatchSemanticsAction(int virtualViewId,
AccessibilityBridge.Action action)
Instructs Flutter to perform the given
action on the SemanticsNode
referenced by the given virtualViewId . |
void |
dispatchSemanticsAction(int virtualViewId,
AccessibilityBridge.Action action,
Object args)
Instructs Flutter to perform the given
action on the SemanticsNode
referenced by the given virtualViewId , passing the given args . |
void |
onAndroidAccessibilityDisabled()
Informs Flutter that the Android OS currently has accessibility disabled.
|
void |
onAndroidAccessibilityEnabled()
Informs Flutter that the Android OS currently has accessibility enabled.
|
void |
setAccessibilityFeatures(int accessibilityFeatureFlags)
Instructs Flutter to activate/deactivate accessibility features corresponding to the
flags provided by
accessibilityFeatureFlags . |
void |
setAccessibilityMessageHandler(AccessibilityChannel.AccessibilityMessageHandler handler)
Sets the
AccessibilityChannel.AccessibilityMessageHandler which receives all events and requests
that are parsed from the underlying accessibility channel. |
@NonNull public final BasicMessageChannel<Object> channel
@NonNull public final FlutterJNI flutterJNI
public AccessibilityChannel(@NonNull DartExecutor dartExecutor, @NonNull FlutterJNI flutterJNI)
AccessibilityChannel
that connects Android to the Dart code
running in dartExecutor
.
The given dartExecutor
is permitted to be idle or executing code.
See DartExecutor
.public void onAndroidAccessibilityEnabled()
public void onAndroidAccessibilityDisabled()
public void setAccessibilityFeatures(int accessibilityFeatureFlags)
accessibilityFeatureFlags
.public void dispatchSemanticsAction(int virtualViewId, @NonNull AccessibilityBridge.Action action)
action
on the SemanticsNode
referenced by the given virtualViewId
.
One might wonder why Flutter would need to be instructed that the user wants to perform
an action. When the user is touching the screen in accessibility mode, Android takes over the
touch input, categorizing input as one of a many accessibility gestures. Therefore, Flutter
does not have an opportunity to react to said touch input. Instead, Flutter must be notified
by Android of the desired action. Additionally, some accessibility systems use other input
methods, such as speech, to take virtual actions. Android interprets those requests and then
instructs the app to take the appropriate action.public void dispatchSemanticsAction(int virtualViewId, @NonNull AccessibilityBridge.Action action, @Nullable Object args)
action
on the SemanticsNode
referenced by the given virtualViewId
, passing the given args
.public void setAccessibilityMessageHandler(@Nullable AccessibilityChannel.AccessibilityMessageHandler handler)
AccessibilityChannel.AccessibilityMessageHandler
which receives all events and requests
that are parsed from the underlying accessibility channel.