mirror of
https://github.com/flutter/flutter.git
synced 2025-06-03 00:51:18 +00:00

This adds a Semantics node to the Focus and FocusScope widgets, setting the focused and focusable attributes so that the accessibility subsystem can be told when a control has the input focus. Includes an engine roll to flutter/engine@77252d2, and the following 8 engine changes: flutter/engine@77252d2 Greg Spencer Add missing focusable testing info (flutter/engine#13013) flutter/engine@0e42a29 skia-flutter-.. Roll src/third_party/skia 54548626a977..e27a503a0a21 (1 commits) (flutter/engine#13024) flutter/engine@6b56ed7 gaaclarke Refactor: FlutterDartProject (flutter/engine#13006) flutter/engine@393480c skia-flutter-.. Roll src/third_party/skia 77dde599c98a..54548626a977 (1 commits) (flutter/engine#13023) flutter/engine@080b89d skia-flutter-.. Roll src/third_party/skia 2b1a25a4d324..77dde599c98a (1 commits) (flutter/engine#13021) flutter/engine@90b0f30 Ben Konyi Roll src/third_party/dart f4a72bfc64..bb04f145b2 (18 commits) (flutter/engine#13020) flutter/engine@049fb89 skia-flutter-.. Roll fuchsia/sdk/core/linux-amd64 from q_uYX... to cknsi... (flutter/engine#13019) flutter/engine@6925b2a skia-flutter-.. Roll fuchsia/sdk/core/mac-amd64 from wuAtw... to u0JpE... (flutter/engine#13018) Related Issues Addresses #40101 Landing on red in order to fix the build: it's red because of the needed engine roll.
77 lines
2.3 KiB
Dart
77 lines
2.3 KiB
Dart
// Copyright 2018 The Chromium Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
|
|
import 'dart:async';
|
|
import 'dart:convert';
|
|
|
|
import 'package:flutter/material.dart';
|
|
import 'package:flutter/scheduler.dart';
|
|
import 'package:flutter/services.dart';
|
|
import 'package:flutter_driver/driver_extension.dart';
|
|
|
|
import 'src/tests/controls_page.dart';
|
|
import 'src/tests/popup_constants.dart';
|
|
import 'src/tests/popup_page.dart';
|
|
import 'src/tests/text_field_page.dart';
|
|
|
|
void main() {
|
|
timeDilation = 0.05; // remove animations.
|
|
enableFlutterDriverExtension(handler: dataHandler);
|
|
runApp(const TestApp());
|
|
}
|
|
|
|
const MethodChannel kSemanticsChannel = MethodChannel('semantics');
|
|
|
|
Future<String> dataHandler(String message) async {
|
|
if (message.contains('getSemanticsNode')) {
|
|
final Completer<String> completer = Completer<String>();
|
|
final int id = int.tryParse(message.split('#')[1]) ?? 0;
|
|
Future<void> completeSemantics([Object _]) async {
|
|
final dynamic result = await kSemanticsChannel.invokeMethod<dynamic>('getSemanticsNode', <String, dynamic>{
|
|
'id': id,
|
|
});
|
|
completer.complete(json.encode(result));
|
|
}
|
|
if (SchedulerBinding.instance.hasScheduledFrame)
|
|
SchedulerBinding.instance.addPostFrameCallback(completeSemantics);
|
|
else
|
|
completeSemantics();
|
|
return completer.future;
|
|
}
|
|
throw UnimplementedError();
|
|
}
|
|
|
|
Map<String, WidgetBuilder> routes = <String, WidgetBuilder>{
|
|
selectionControlsRoute : (BuildContext context) => SelectionControlsPage(),
|
|
popupControlsRoute : (BuildContext context) => PopupControlsPage(),
|
|
textFieldRoute : (BuildContext context) => TextFieldPage(),
|
|
};
|
|
|
|
class TestApp extends StatelessWidget {
|
|
const TestApp();
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return MaterialApp(
|
|
routes: routes,
|
|
home: Builder(
|
|
builder: (BuildContext context) {
|
|
return Scaffold(
|
|
body: ListView(
|
|
children: routes.keys.map<Widget>((String value) {
|
|
return MaterialButton(
|
|
child: Text(value),
|
|
onPressed: () {
|
|
Navigator.of(context).pushNamed(value);
|
|
},
|
|
);
|
|
}).toList(),
|
|
),
|
|
);
|
|
}
|
|
),
|
|
);
|
|
}
|
|
}
|