Unverified Commit a5ed960d authored by Bruno Leroux's avatar Bruno Leroux Committed by GitHub

SystemUiOverlayStyle, add examples and improve documentation (#122187)

SystemUiOverlayStyle, add two examples and improve documentation
parent c4ca9a41
// Copyright 2014 The Flutter Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
// Flutter code sample for [AppBar.systemOverlayStyle].
import 'dart:math' as math;
import 'package:flutter/material.dart';
import 'package:flutter/services.dart';
void main() => runApp(const SystemOverlayStyleApp());
class SystemOverlayStyleApp extends StatelessWidget {
const SystemOverlayStyleApp({super.key});
@override
Widget build(BuildContext context) {
return MaterialApp(
theme: ThemeData(
useMaterial3: true,
brightness: Brightness.light,
),
home: const SystemOverlayStyleExample(),
);
}
}
class SystemOverlayStyleExample extends StatefulWidget {
const SystemOverlayStyleExample({super.key});
@override
State<SystemOverlayStyleExample> createState() => _SystemOverlayStyleExampleState();
}
class _SystemOverlayStyleExampleState extends State<SystemOverlayStyleExample> {
final math.Random _random = math.Random();
SystemUiOverlayStyle _currentStyle = SystemUiOverlayStyle.light;
void _changeColor() {
final Color color = Color.fromRGBO(
_random.nextInt(255),
_random.nextInt(255),
_random.nextInt(255),
1.0,
);
setState(() {
_currentStyle = SystemUiOverlayStyle.dark.copyWith(
statusBarColor: color,
systemNavigationBarColor: color,
);
});
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: const Text('SystemUiOverlayStyle Sample'),
systemOverlayStyle: _currentStyle,
),
body: Center(
child: ElevatedButton(
onPressed: _changeColor,
child: const Text('Change Color'),
),
),
);
}
}
...@@ -2,37 +2,38 @@ ...@@ -2,37 +2,38 @@
// Use of this source code is governed by a BSD-style license that can be // Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file. // found in the LICENSE file.
// Flutter code sample for [SystemChrome.setSystemUIOverlayStyle]. // Flutter code sample for setting the [SystemUiOverlayStyle] with an [AnnotatedRegion].
import 'dart:math' as math; import 'dart:math' as math;
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:flutter/services.dart'; import 'package:flutter/services.dart';
void main() => runApp(const MyApp()); void main() => runApp(const SystemOverlayStyleApp());
class MyApp extends StatelessWidget { class SystemOverlayStyleApp extends StatelessWidget {
const MyApp({super.key}); const SystemOverlayStyleApp({super.key});
static const String _title = 'Flutter Code Sample';
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
return const MaterialApp( return MaterialApp(
title: _title, theme: ThemeData(
home: MyStatefulWidget(), useMaterial3: true,
brightness: Brightness.light,
),
home: const SystemOverlayStyleExample(),
); );
} }
} }
class MyStatefulWidget extends StatefulWidget { class SystemOverlayStyleExample extends StatefulWidget {
const MyStatefulWidget({super.key}); const SystemOverlayStyleExample({super.key});
@override @override
State<MyStatefulWidget> createState() => _MyStatefulWidgetState(); State<SystemOverlayStyleExample> createState() => _SystemOverlayStyleExampleState();
} }
class _MyStatefulWidgetState extends State<MyStatefulWidget> { class _SystemOverlayStyleExampleState extends State<SystemOverlayStyleExample> {
final math.Random _random = math.Random(); final math.Random _random = math.Random();
SystemUiOverlayStyle _currentStyle = SystemUiOverlayStyle.light; SystemUiOverlayStyle _currentStyle = SystemUiOverlayStyle.light;
...@@ -46,6 +47,7 @@ class _MyStatefulWidgetState extends State<MyStatefulWidget> { ...@@ -46,6 +47,7 @@ class _MyStatefulWidgetState extends State<MyStatefulWidget> {
setState(() { setState(() {
_currentStyle = SystemUiOverlayStyle.dark.copyWith( _currentStyle = SystemUiOverlayStyle.dark.copyWith(
statusBarColor: color, statusBarColor: color,
systemNavigationBarColor: color,
); );
}); });
} }
...@@ -54,10 +56,26 @@ class _MyStatefulWidgetState extends State<MyStatefulWidget> { ...@@ -54,10 +56,26 @@ class _MyStatefulWidgetState extends State<MyStatefulWidget> {
Widget build(BuildContext context) { Widget build(BuildContext context) {
return AnnotatedRegion<SystemUiOverlayStyle>( return AnnotatedRegion<SystemUiOverlayStyle>(
value: _currentStyle, value: _currentStyle,
child: Center( child: Scaffold(
child: ElevatedButton( body: Column(
onPressed: _changeColor, crossAxisAlignment: CrossAxisAlignment.start,
child: const Text('Change Color'), children: <Widget>[
Padding(
padding: const EdgeInsets.all(16.0),
child: Text(
'SystemUiOverlayStyle Sample',
style: Theme.of(context).textTheme.titleLarge,
),
),
Expanded(
child: Center(
child: ElevatedButton(
onPressed: _changeColor,
child: const Text('Change Color'),
),
),
),
],
), ),
), ),
); );
......
// Copyright 2014 The Flutter 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 'package:flutter/material.dart';
import 'package:flutter/services.dart';
import 'package:flutter_api_samples/services/system_chrome/system_chrome.set_system_u_i_overlay_style.0.dart' as example;
import 'package:flutter_test/flutter_test.dart';
void main() {
testWidgets('AppBar.systemOverlayStyle can change system overlays styles.', (WidgetTester tester) async {
await tester.pumpWidget(
const example.SystemOverlayStyleApp(),
);
final SystemUiOverlayStyle? firstStyle = SystemChrome.latestStyle;
await tester.tap(find.byType(ElevatedButton));
await tester.pump();
final SystemUiOverlayStyle? secondStyle = SystemChrome.latestStyle;
expect(secondStyle?.statusBarColor, isNot(firstStyle?.statusBarColor));
expect(secondStyle?.systemNavigationBarColor, isNot(firstStyle?.systemNavigationBarColor));
await tester.tap(find.byType(ElevatedButton));
await tester.pump();
final SystemUiOverlayStyle? thirdStyle = SystemChrome.latestStyle;
expect(thirdStyle?.statusBarColor, isNot(secondStyle?.statusBarColor));
expect(thirdStyle?.systemNavigationBarColor, isNot(secondStyle?.systemNavigationBarColor));
});
}
// Copyright 2014 The Flutter 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 'package:flutter/material.dart';
import 'package:flutter/services.dart';
import 'package:flutter_api_samples/services/system_chrome/system_chrome.set_system_u_i_overlay_style.1.dart' as example;
import 'package:flutter_test/flutter_test.dart';
void main() {
testWidgets('AnnotatedRegion can change system overlays style.', (WidgetTester tester) async {
await tester.pumpWidget(
const example.SystemOverlayStyleApp(),
);
final SystemUiOverlayStyle? firstStyle = SystemChrome.latestStyle;
await tester.tap(find.byType(ElevatedButton));
await tester.pump();
final SystemUiOverlayStyle? secondStyle = SystemChrome.latestStyle;
expect(secondStyle?.statusBarColor, isNot(firstStyle?.statusBarColor));
expect(secondStyle?.systemNavigationBarColor, isNot(firstStyle?.systemNavigationBarColor));
await tester.tap(find.byType(ElevatedButton));
await tester.pump();
final SystemUiOverlayStyle? thirdStyle = SystemChrome.latestStyle;
expect(thirdStyle?.statusBarColor, isNot(secondStyle?.statusBarColor));
expect(thirdStyle?.systemNavigationBarColor, isNot(secondStyle?.systemNavigationBarColor));
});
}
...@@ -678,7 +678,8 @@ class AppBar extends StatefulWidget implements PreferredSizeWidget { ...@@ -678,7 +678,8 @@ class AppBar extends StatefulWidget implements PreferredSizeWidget {
final TextStyle? titleTextStyle; final TextStyle? titleTextStyle;
/// {@template flutter.material.appbar.systemOverlayStyle} /// {@template flutter.material.appbar.systemOverlayStyle}
/// Specifies the style to use for the system overlays that overlap the AppBar. /// Specifies the style to use for the system overlays (e.g. the status bar on
/// Android or iOS, the system navigation bar on Android).
/// ///
/// If this property is null, then [AppBarTheme.systemOverlayStyle] of /// If this property is null, then [AppBarTheme.systemOverlayStyle] of
/// [ThemeData.appBarTheme] is used. If that is also null, an appropriate /// [ThemeData.appBarTheme] is used. If that is also null, an appropriate
...@@ -692,7 +693,10 @@ class AppBar extends StatefulWidget implements PreferredSizeWidget { ...@@ -692,7 +693,10 @@ class AppBar extends StatefulWidget implements PreferredSizeWidget {
/// {@endtemplate} /// {@endtemplate}
// //
/// See also: /// See also:
/// * [SystemChrome.setSystemUIOverlayStyle] ///
/// * [AnnotatedRegion], for placing [SystemUiOverlayStyle] in the layer tree.
/// * [SystemChrome.setSystemUIOverlayStyle], the imperative API for setting
/// system overlays style.
final SystemUiOverlayStyle? systemOverlayStyle; final SystemUiOverlayStyle? systemOverlayStyle;
/// {@template flutter.material.appbar.forceMaterialTransparency} /// {@template flutter.material.appbar.forceMaterialTransparency}
......
...@@ -182,7 +182,9 @@ enum SystemUiMode { ...@@ -182,7 +182,9 @@ enum SystemUiMode {
/// Specifies a preference for the style of the system overlays. /// Specifies a preference for the style of the system overlays.
/// ///
/// Used by [SystemChrome.setSystemUIOverlayStyle]. /// Used by [AppBar.systemOverlayStyle] for declaratively setting the style of
/// the system overlays, and by [SystemChrome.setSystemUIOverlayStyle] for
/// imperatively setting the style of the systeme overlays.
@immutable @immutable
class SystemUiOverlayStyle { class SystemUiOverlayStyle {
/// Creates a new [SystemUiOverlayStyle]. /// Creates a new [SystemUiOverlayStyle].
...@@ -492,8 +494,8 @@ class SystemChrome { ...@@ -492,8 +494,8 @@ class SystemChrome {
); );
} }
/// Specifies the style to use for the system overlays that are visible (if /// Specifies the style to use for the system overlays (e.g. the status bar on
/// any). /// Android or iOS, the system navigation bar on Android) that are visible (if any).
/// ///
/// This method will schedule the embedder update to be run in a microtask. /// This method will schedule the embedder update to be run in a microtask.
/// Any subsequent calls to this method during the current event loop will /// Any subsequent calls to this method during the current event loop will
...@@ -512,14 +514,11 @@ class SystemChrome { ...@@ -512,14 +514,11 @@ class SystemChrome {
/// If a particular style is not supported on the platform, selecting it will /// If a particular style is not supported on the platform, selecting it will
/// have no effect. /// have no effect.
/// ///
/// {@tool snippet} /// {@tool sample}
/// ```dart /// The following example uses an `AppBar` to set the system status bar color and
/// @override /// the system navigation bar color.
/// Widget build(BuildContext context) { ///
/// SystemChrome.setSystemUIOverlayStyle(SystemUiOverlayStyle.dark); /// ** See code in examples/api/lib/services/system_chrome/system_chrome.set_system_u_i_overlay_style.0.dart **
/// return const Placeholder();
/// }
/// ```
/// {@end-tool} /// {@end-tool}
/// ///
/// For more complex control of the system overlay styles, consider using /// For more complex control of the system overlay styles, consider using
...@@ -537,15 +536,18 @@ class SystemChrome { ...@@ -537,15 +536,18 @@ class SystemChrome {
/// overlay style navigation bar properties. /// overlay style navigation bar properties.
/// ///
/// {@tool sample} /// {@tool sample}
/// The following example creates a widget that changes the status bar color /// The following example uses an `AnnotatedRegion<SystemUiOverlayStyle>` to set
/// to a random value on Android. /// the system status bar color and the system navigation bar color.
/// ///
/// ** See code in examples/api/lib/services/system_chrome/system_chrome.set_system_u_i_overlay_style.1.dart ** /// ** See code in examples/api/lib/services/system_chrome/system_chrome.set_system_u_i_overlay_style.1.dart **
/// {@end-tool} /// {@end-tool}
/// ///
/// See also: /// See also:
/// ///
/// * [AnnotatedRegion], the widget used to place data into the layer tree. /// * [AppBar.systemOverlayStyle], a convenient property for declaratively setting
/// the style of the system overlays.
/// * [AnnotatedRegion], the widget used to place a `SystemUiOverlayStyle` into
/// the layer tree.
static void setSystemUIOverlayStyle(SystemUiOverlayStyle style) { static void setSystemUIOverlayStyle(SystemUiOverlayStyle style) {
if (_pendingStyle != null) { if (_pendingStyle != null) {
// The microtask has already been queued; just update the pending value. // The microtask has already been queued; just update the pending value.
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment