Unverified Commit 7c73053f authored by Anthony's avatar Anthony Committed by GitHub

[Material] Use InkSparkle for splashFactory in ThemeData when useMaterial3 is...

[Material] Use InkSparkle for splashFactory in ThemeData when useMaterial3 is true for Android non-web runtimes (#99882)

[Material] Use InkSparkle for splashFactory in ThemeData when useMaterial3 is true for Android non-web runtimes (#99882)
parent ca2f2415
...@@ -26,6 +26,7 @@ import 'drawer_theme.dart'; ...@@ -26,6 +26,7 @@ import 'drawer_theme.dart';
import 'elevated_button_theme.dart'; import 'elevated_button_theme.dart';
import 'expansion_tile_theme.dart'; import 'expansion_tile_theme.dart';
import 'floating_action_button_theme.dart'; import 'floating_action_button_theme.dart';
import 'ink_sparkle.dart';
import 'ink_splash.dart'; import 'ink_splash.dart';
import 'ink_well.dart' show InteractiveInkFeatureFactory; import 'ink_well.dart' show InteractiveInkFeatureFactory;
import 'input_decorator.dart'; import 'input_decorator.dart';
...@@ -405,9 +406,10 @@ class ThemeData with Diagnosticable { ...@@ -405,9 +406,10 @@ class ThemeData with Diagnosticable {
} }
pageTransitionsTheme ??= const PageTransitionsTheme(); pageTransitionsTheme ??= const PageTransitionsTheme();
scrollbarTheme ??= const ScrollbarThemeData(); scrollbarTheme ??= const ScrollbarThemeData();
splashFactory ??= InkSplash.splashFactory;
visualDensity ??= VisualDensity.adaptivePlatformDensity; visualDensity ??= VisualDensity.adaptivePlatformDensity;
useMaterial3 ??= false; useMaterial3 ??= false;
final bool useInkSparkle = platform == TargetPlatform.android && !kIsWeb;
splashFactory ??= (useMaterial3 && useInkSparkle) ? InkSparkle.splashFactory : InkSplash.splashFactory;
// COLOR // COLOR
assert(colorScheme?.brightness == null || brightness == null || colorScheme!.brightness == brightness); assert(colorScheme?.brightness == null || brightness == null || colorScheme!.brightness == brightness);
...@@ -1109,6 +1111,8 @@ class ThemeData with Diagnosticable { ...@@ -1109,6 +1111,8 @@ class ThemeData with Diagnosticable {
/// * [InkSplash.splashFactory], which defines the default splash. /// * [InkSplash.splashFactory], which defines the default splash.
/// * [InkRipple.splashFactory], which defines a splash that spreads out /// * [InkRipple.splashFactory], which defines a splash that spreads out
/// more aggressively than the default. /// more aggressively than the default.
/// * [InkSparkle.splashFactory], which defines a more aggressive and organic
/// splash with sparkle effects.
final InteractiveInkFeatureFactory splashFactory; final InteractiveInkFeatureFactory splashFactory;
/// The density value for specifying the compactness of various UI components. /// The density value for specifying the compactness of various UI components.
...@@ -1146,12 +1150,15 @@ class ThemeData with Diagnosticable { ...@@ -1146,12 +1150,15 @@ class ThemeData with Diagnosticable {
/// start using new colors, typography and other features of Material 3. /// start using new colors, typography and other features of Material 3.
/// If false, they will use the Material 2 look and feel. /// If false, they will use the Material 2 look and feel.
/// ///
/// If a [ThemeData] is constructed with [useMaterial3] set to true, /// If a [ThemeData] is constructed with [useMaterial3] set to true, then
/// the default [typography] will be [Typography.material2021], /// some properties will get special defaults. However, just copying a [ThemeData]
/// otherwise it will be [Typography.material2014]. /// with [useMaterial3] set to true will not change any of these properties in the
/// /// resulting [ThemeData]. These properties are:
/// However, just copying a [ThemeData] with [useMaterial3] set to true will /// | Property | [useMaterial3] default | fallback default |
/// not change the typography of the resulting ThemeData. /// |:---|:---|:---|
/// | [typography] | [Typography.material2021] | [Typography.material2014] |
/// | [splashFactory] | [InkSparkle]* | [InkSplash] |
/// *if and only if the target platform is Android and the app is not running on the web.
/// ///
/// During the migration to Material 3, turning this on may yield /// During the migration to Material 3, turning this on may yield
/// inconsistent look and feel in your app. Some components will be migrated /// inconsistent look and feel in your app. Some components will be migrated
......
...@@ -2044,6 +2044,9 @@ void main() { ...@@ -2044,6 +2044,9 @@ void main() {
await tester.tap(find.text('Ghi')); await tester.tap(find.text('Ghi'));
expect(selectedIndex, 2); expect(selectedIndex, 2);
// Wait for any pending shader compilation.
tester.pumpAndSettle();
}); });
testWidgets('onDestinationSelected is not called if null', (WidgetTester tester) async { testWidgets('onDestinationSelected is not called if null', (WidgetTester tester) async {
...@@ -2059,6 +2062,9 @@ void main() { ...@@ -2059,6 +2062,9 @@ void main() {
await tester.tap(find.text('Def')); await tester.tap(find.text('Def'));
expect(selectedIndex, 0); expect(selectedIndex, 0);
// Wait for any pending shader compilation.
tester.pumpAndSettle();
}); });
testWidgets('Changing destinations animate when [labelType]=selected', (WidgetTester tester) async { testWidgets('Changing destinations animate when [labelType]=selected', (WidgetTester tester) async {
......
...@@ -268,6 +268,43 @@ void main() { ...@@ -268,6 +268,43 @@ void main() {
expect(theme.applyElevationOverlayColor, isTrue); expect(theme.applyElevationOverlayColor, isTrue);
}); });
testWidgets('splashFactory is InkSparkle only for Android non-web when useMaterial3 is true', (WidgetTester tester) async {
final ThemeData theme = ThemeData(useMaterial3: true);
// Basic check that this theme is in fact using material 3.
expect(theme.useMaterial3, true);
switch (debugDefaultTargetPlatformOverride!) {
case TargetPlatform.android:
if (kIsWeb) {
expect(theme.splashFactory, equals(InkSplash.splashFactory));
} else {
expect(theme.splashFactory, equals(InkSparkle.splashFactory));
}
break;
case TargetPlatform.iOS:
case TargetPlatform.fuchsia:
case TargetPlatform.linux:
case TargetPlatform.macOS:
case TargetPlatform.windows:
expect(theme.splashFactory, equals(InkSplash.splashFactory));
}
}, variant: TargetPlatformVariant.all());
testWidgets('splashFactory is InkSplash for every platform scenario, including Android non-web, when useMaterial3 is false', (WidgetTester tester) async {
final ThemeData theme = ThemeData(useMaterial3: false);
switch (debugDefaultTargetPlatformOverride!) {
case TargetPlatform.android:
case TargetPlatform.iOS:
case TargetPlatform.fuchsia:
case TargetPlatform.linux:
case TargetPlatform.macOS:
case TargetPlatform.windows:
expect(theme.splashFactory, equals(InkSplash.splashFactory));
}
}, variant: TargetPlatformVariant.all());
testWidgets('VisualDensity.adaptivePlatformDensity returns adaptive values', (WidgetTester tester) async { testWidgets('VisualDensity.adaptivePlatformDensity returns adaptive values', (WidgetTester tester) async {
switch (debugDefaultTargetPlatformOverride!) { switch (debugDefaultTargetPlatformOverride!) {
case TargetPlatform.android: case TargetPlatform.android:
......
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