Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Sign in
Toggle navigation
F
Front-End
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
abdullh.alsoleman
Front-End
Commits
6ec0b835
Unverified
Commit
6ec0b835
authored
Mar 17, 2022
by
Darren Austin
Committed by
GitHub
Mar 17, 2022
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add support for surface tint color overlays to `Material` widget. (#100036)
parent
e99a66a4
Changes
8
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
8 changed files
with
371 additions
and
27 deletions
+371
-27
gen_defaults.dart
dev/tools/gen_defaults/bin/gen_defaults.dart
+3
-1
surface_tint.dart
dev/tools/gen_defaults/lib/surface_tint.dart
+27
-0
button.dart
packages/flutter/lib/src/material/button.dart
+2
-0
elevation_overlay.dart
packages/flutter/lib/src/material/elevation_overlay.dart
+90
-1
material.dart
packages/flutter/lib/src/material/material.dart
+80
-22
theme_data.dart
packages/flutter/lib/src/material/theme_data.dart
+9
-1
elevation_overlay_test.dart
packages/flutter/test/material/elevation_overlay_test.dart
+88
-0
material_test.dart
packages/flutter/test/material/material_test.dart
+72
-2
No files found.
dev/tools/gen_defaults/bin/gen_defaults.dart
View file @
6ec0b835
...
@@ -21,6 +21,7 @@ import 'package:gen_defaults/dialog_template.dart';
...
@@ -21,6 +21,7 @@ import 'package:gen_defaults/dialog_template.dart';
import
'package:gen_defaults/fab_template.dart'
;
import
'package:gen_defaults/fab_template.dart'
;
import
'package:gen_defaults/navigation_bar_template.dart'
;
import
'package:gen_defaults/navigation_bar_template.dart'
;
import
'package:gen_defaults/navigation_rail_template.dart'
;
import
'package:gen_defaults/navigation_rail_template.dart'
;
import
'package:gen_defaults/surface_tint.dart'
;
import
'package:gen_defaults/typography_template.dart'
;
import
'package:gen_defaults/typography_template.dart'
;
Map
<
String
,
dynamic
>
_readTokenFile
(
String
fileName
)
{
Map
<
String
,
dynamic
>
_readTokenFile
(
String
fileName
)
{
...
@@ -70,9 +71,10 @@ Future<void> main(List<String> args) async {
...
@@ -70,9 +71,10 @@ Future<void> main(List<String> args) async {
tokens
[
'colorsLight'
]
=
_readTokenFile
(
'color_light.json'
);
tokens
[
'colorsLight'
]
=
_readTokenFile
(
'color_light.json'
);
tokens
[
'colorsDark'
]
=
_readTokenFile
(
'color_dark.json'
);
tokens
[
'colorsDark'
]
=
_readTokenFile
(
'color_dark.json'
);
DialogTemplate
(
'
$materialLib
/dialog.dart'
,
tokens
).
updateFile
();
FABTemplate
(
'
$materialLib
/floating_action_button.dart'
,
tokens
).
updateFile
();
FABTemplate
(
'
$materialLib
/floating_action_button.dart'
,
tokens
).
updateFile
();
NavigationBarTemplate
(
'
$materialLib
/navigation_bar.dart'
,
tokens
).
updateFile
();
NavigationBarTemplate
(
'
$materialLib
/navigation_bar.dart'
,
tokens
).
updateFile
();
NavigationRailTemplate
(
'
$materialLib
/navigation_rail.dart'
,
tokens
).
updateFile
();
NavigationRailTemplate
(
'
$materialLib
/navigation_rail.dart'
,
tokens
).
updateFile
();
SurfaceTintTemplate
(
'
$materialLib
/elevation_overlay.dart'
,
tokens
).
updateFile
();
TypographyTemplate
(
'
$materialLib
/typography.dart'
,
tokens
).
updateFile
();
TypographyTemplate
(
'
$materialLib
/typography.dart'
,
tokens
).
updateFile
();
DialogTemplate
(
'
$materialLib
/dialog.dart'
,
tokens
).
updateFile
();
}
}
dev/tools/gen_defaults/lib/surface_tint.dart
0 → 100644
View file @
6ec0b835
// 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
'template.dart'
;
class
SurfaceTintTemplate
extends
TokenTemplate
{
const
SurfaceTintTemplate
(
String
fileName
,
Map
<
String
,
dynamic
>
tokens
)
:
super
(
fileName
,
tokens
);
@override
String
generate
()
=>
'''
// Generated version
${tokens["version"]}
// Surface tint opacities based on elevations according to the
// Material Design 3 specification:
// https://m3.material.io/styles/color/the-color-system/color-roles
// Ordered by increasing elevation.
const List<_ElevationOpacity> _surfaceTintElevationOpacities = <_ElevationOpacity>[
_ElevationOpacity(
${tokens['md.sys.elevation.level0']}
, 0.0), // Elevation level 0
_ElevationOpacity(
${tokens['md.sys.elevation.level1']}
, 0.05), // Elevation level 1
_ElevationOpacity(
${tokens['md.sys.elevation.level2']}
, 0.08), // Elevation level 2
_ElevationOpacity(
${tokens['md.sys.elevation.level3']}
, 0.11), // Elevation level 3
_ElevationOpacity(
${tokens['md.sys.elevation.level4']}
, 0.12), // Elevation level 4
_ElevationOpacity(
${tokens['md.sys.elevation.level5']}
, 0.14), // Elevation level 5
];
'''
;
}
packages/flutter/lib/src/material/button.dart
View file @
6ec0b835
...
@@ -381,6 +381,8 @@ class _RawMaterialButtonState extends State<RawMaterialButton> with MaterialStat
...
@@ -381,6 +381,8 @@ class _RawMaterialButtonState extends State<RawMaterialButton> with MaterialStat
textStyle:
widget
.
textStyle
?.
copyWith
(
color:
effectiveTextColor
),
textStyle:
widget
.
textStyle
?.
copyWith
(
color:
effectiveTextColor
),
shape:
effectiveShape
,
shape:
effectiveShape
,
color:
widget
.
fillColor
,
color:
widget
.
fillColor
,
// For compatibility during the M3 migration the default shadow needs to be passed.
shadowColor:
Theme
.
of
(
context
).
useMaterial3
?
Theme
.
of
(
context
).
shadowColor
:
null
,
type:
widget
.
fillColor
==
null
?
MaterialType
.
transparency
:
MaterialType
.
button
,
type:
widget
.
fillColor
==
null
?
MaterialType
.
transparency
:
MaterialType
.
button
,
animationDuration:
widget
.
animationDuration
,
animationDuration:
widget
.
animationDuration
,
clipBehavior:
widget
.
clipBehavior
,
clipBehavior:
widget
.
clipBehavior
,
...
...
packages/flutter/lib/src/material/elevation_overlay.dart
View file @
6ec0b835
...
@@ -9,15 +9,65 @@ import 'package:flutter/widgets.dart';
...
@@ -9,15 +9,65 @@ import 'package:flutter/widgets.dart';
import
'theme.dart'
;
import
'theme.dart'
;
/// A utility class for dealing with the overlay color needed
/// A utility class for dealing with the overlay color needed
/// to indicate elevation of surfaces
in a dark theme
.
/// to indicate elevation of surfaces.
class
ElevationOverlay
{
class
ElevationOverlay
{
// This class is not meant to be instantiated or extended; this constructor
// This class is not meant to be instantiated or extended; this constructor
// prevents instantiation and extension.
// prevents instantiation and extension.
ElevationOverlay
.
_
();
ElevationOverlay
.
_
();
/// Applies a surface tint color to a given container color to indicate
/// the level of its elevation.
///
/// With Material Design 3, some components will use a "surface tint" color
/// overlay with an opacity applied to their base color to indicate they are
/// elevated. The amount of opacity will vary with the elevation as described
/// in: https://m3.material.io/styles/color/the-color-system/color-roles.
///
/// If [surfaceTint] is not null then the returned color will be the given
/// [color] with the [surfaceTint] of the appropriate opacity applies to it.
/// Otherwise it will just return [color] unmodified.
static
Color
applySurfaceTint
(
Color
color
,
Color
?
surfaceTint
,
double
elevation
)
{
if
(
surfaceTint
!=
null
)
{
return
Color
.
alphaBlend
(
surfaceTint
.
withOpacity
(
_surfaceTintOpacityForElevation
(
elevation
)),
color
);
}
return
color
;
}
// Calculates the opacity of the surface tint color from the elevation by
// looking it up in the token generated table of opacities, interpolating
// between values as needed. If the elevation is outside the range of values
// in the table it will clamp to the smallest or largest opacity.
static
double
_surfaceTintOpacityForElevation
(
double
elevation
)
{
if
(
elevation
<
_surfaceTintElevationOpacities
[
0
].
elevation
)
{
// Elevation less than the first entry, so just clamp it to the first one.
return
_surfaceTintElevationOpacities
[
0
].
opacity
;
}
// Walk the opacity list and find the closest match(es) for the elevation.
int
index
=
0
;
while
(
elevation
>=
_surfaceTintElevationOpacities
[
index
].
elevation
)
{
// If we found it exactly or walked off the end of the list just return it.
if
(
elevation
==
_surfaceTintElevationOpacities
[
index
].
elevation
||
index
+
1
==
_surfaceTintElevationOpacities
.
length
)
{
return
_surfaceTintElevationOpacities
[
index
].
opacity
;
}
index
+=
1
;
}
// Interpolate between the two opacity values
final
_ElevationOpacity
lower
=
_surfaceTintElevationOpacities
[
index
-
1
];
final
_ElevationOpacity
upper
=
_surfaceTintElevationOpacities
[
index
];
final
double
t
=
(
elevation
-
lower
.
elevation
)
/
(
upper
.
elevation
-
lower
.
elevation
);
return
lower
.
opacity
+
t
*
(
upper
.
opacity
-
lower
.
opacity
);
}
/// Applies an overlay color to a surface color to indicate
/// Applies an overlay color to a surface color to indicate
/// the level of its elevation in a dark theme.
/// the level of its elevation in a dark theme.
///
///
/// If using Material Design 3, this type of color overlay is no longer used.
/// Instead a "surface tint" overlay is used instead. See [applySurfaceTint],
/// [ThemeData.useMaterial3] for more information.
///
/// Material drop shadows can be difficult to see in a dark theme, so the
/// Material drop shadows can be difficult to see in a dark theme, so the
/// elevation of a surface should be portrayed with an "overlay" in addition
/// elevation of a surface should be portrayed with an "overlay" in addition
/// to the shadow. As the elevation of the component increases, the
/// to the shadow. As the elevation of the component increases, the
...
@@ -55,6 +105,10 @@ class ElevationOverlay {
...
@@ -55,6 +105,10 @@ class ElevationOverlay {
/// Computes the appropriate overlay color used to indicate elevation in
/// Computes the appropriate overlay color used to indicate elevation in
/// dark themes.
/// dark themes.
///
///
/// If using Material Design 3, this type of color overlay is no longer used.
/// Instead a "surface tint" overlay is used instead. See [applySurfaceTint],
/// [ThemeData.useMaterial3] for more information.
///
/// See also:
/// See also:
///
///
/// * https://material.io/design/color/dark-theme.html#properties which
/// * https://material.io/design/color/dark-theme.html#properties which
...
@@ -67,6 +121,10 @@ class ElevationOverlay {
...
@@ -67,6 +121,10 @@ class ElevationOverlay {
/// Returns a color blended by laying a semi-transparent overlay (using the
/// Returns a color blended by laying a semi-transparent overlay (using the
/// [overlay] color) on top of a surface (using the [surface] color).
/// [overlay] color) on top of a surface (using the [surface] color).
///
///
/// If using Material Design 3, this type of color overlay is no longer used.
/// Instead a "surface tint" overlay is used instead. See [applySurfaceTint],
/// [ThemeData.useMaterial3] for more information.
///
/// The opacity of the overlay depends on [elevation]. As [elevation]
/// The opacity of the overlay depends on [elevation]. As [elevation]
/// increases, the opacity will also increase.
/// increases, the opacity will also increase.
///
///
...
@@ -84,3 +142,34 @@ class ElevationOverlay {
...
@@ -84,3 +142,34 @@ class ElevationOverlay {
return
color
.
withOpacity
(
opacity
);
return
color
.
withOpacity
(
opacity
);
}
}
}
}
// A data class to hold the opacity at a given elevation.
class
_ElevationOpacity
{
const
_ElevationOpacity
(
this
.
elevation
,
this
.
opacity
);
final
double
elevation
;
final
double
opacity
;
}
// BEGIN GENERATED TOKEN PROPERTIES
// Generated code to the end of this file. Do not edit by hand.
// These defaults are generated from the Material Design Token
// database by the script dev/tools/gen_defaults/bin/gen_defaults.dart.
// Generated version v0_90
// Surface tint opacities based on elevations according to the
// Material Design 3 specification:
// https://m3.material.io/styles/color/the-color-system/color-roles
// Ordered by increasing elevation.
const
List
<
_ElevationOpacity
>
_surfaceTintElevationOpacities
=
<
_ElevationOpacity
>[
_ElevationOpacity
(
0.0
,
0.0
),
// Elevation level 0
_ElevationOpacity
(
1.0
,
0.05
),
// Elevation level 1
_ElevationOpacity
(
3.0
,
0.08
),
// Elevation level 2
_ElevationOpacity
(
6.0
,
0.11
),
// Elevation level 3
_ElevationOpacity
(
8.0
,
0.12
),
// Elevation level 4
_ElevationOpacity
(
12.0
,
0.14
),
// Elevation level 5
];
// END GENERATED TOKEN PROPERTIES
packages/flutter/lib/src/material/material.dart
View file @
6ec0b835
This diff is collapsed.
Click to expand it.
packages/flutter/lib/src/material/theme_data.dart
View file @
6ec0b835
...
@@ -437,7 +437,7 @@ class ThemeData with Diagnosticable {
...
@@ -437,7 +437,7 @@ class ThemeData with Diagnosticable {
dialogBackgroundColor
??=
colorScheme
.
background
;
dialogBackgroundColor
??=
colorScheme
.
background
;
indicatorColor
??=
onPrimarySurfaceColor
;
indicatorColor
??=
onPrimarySurfaceColor
;
errorColor
??=
colorScheme
.
error
;
errorColor
??=
colorScheme
.
error
;
applyElevationOverlayColor
??=
isD
ark
;
applyElevationOverlayColor
??=
brightness
==
Brightness
.
d
ark
;
}
}
applyElevationOverlayColor
??=
false
;
applyElevationOverlayColor
??=
false
;
primarySwatch
??=
Colors
.
blue
;
primarySwatch
??=
Colors
.
blue
;
...
@@ -922,6 +922,7 @@ class ThemeData with Diagnosticable {
...
@@ -922,6 +922,7 @@ class ThemeData with Diagnosticable {
factory
ThemeData
.
from
({
factory
ThemeData
.
from
({
required
ColorScheme
colorScheme
,
required
ColorScheme
colorScheme
,
TextTheme
?
textTheme
,
TextTheme
?
textTheme
,
bool
?
useMaterial3
,
})
{
})
{
final
bool
isDark
=
colorScheme
.
brightness
==
Brightness
.
dark
;
final
bool
isDark
=
colorScheme
.
brightness
==
Brightness
.
dark
;
...
@@ -947,6 +948,7 @@ class ThemeData with Diagnosticable {
...
@@ -947,6 +948,7 @@ class ThemeData with Diagnosticable {
errorColor:
colorScheme
.
error
,
errorColor:
colorScheme
.
error
,
textTheme:
textTheme
,
textTheme:
textTheme
,
applyElevationOverlayColor:
isDark
,
applyElevationOverlayColor:
isDark
,
useMaterial3:
useMaterial3
,
);
);
}
}
...
@@ -1003,6 +1005,11 @@ class ThemeData with Diagnosticable {
...
@@ -1003,6 +1005,11 @@ class ThemeData with Diagnosticable {
/// Apply a semi-transparent overlay color on Material surfaces to indicate
/// Apply a semi-transparent overlay color on Material surfaces to indicate
/// elevation for dark themes.
/// elevation for dark themes.
///
///
/// If [useMaterial3] is true, then this flag is ignored as there is a new
/// [Material.surfaceTintColor] used to create an overlay for Material 3.
/// This flag is meant only for the Material 2 elevation overlay for dark
/// themes.
///
/// Material drop shadows can be difficult to see in a dark theme, so the
/// Material drop shadows can be difficult to see in a dark theme, so the
/// elevation of a surface should be portrayed with an "overlay" in addition
/// elevation of a surface should be portrayed with an "overlay" in addition
/// to the shadow. As the elevation of the component increases, the
/// to the shadow. As the elevation of the component increases, the
...
@@ -1161,6 +1168,7 @@ class ThemeData with Diagnosticable {
...
@@ -1161,6 +1168,7 @@ class ThemeData with Diagnosticable {
/// * [AlertDialog]
/// * [AlertDialog]
/// * [Dialog]
/// * [Dialog]
/// * [FloatingActionButton]
/// * [FloatingActionButton]
/// * [Material]
/// * [NavigationBar]
/// * [NavigationBar]
/// * [NavigationRail]
/// * [NavigationRail]
///
///
...
...
packages/flutter/test/material/elevation_overlay_test.dart
0 → 100644
View file @
6ec0b835
// 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_test/flutter_test.dart'
;
void
main
(
)
{
test
(
'applySurfaceTint with null surface tint returns given color'
,
()
{
final
Color
result
=
ElevationOverlay
.
applySurfaceTint
(
const
Color
(
0xff888888
),
null
,
42.0
);
expect
(
result
,
equals
(
const
Color
(
0xFF888888
)));
});
test
(
'applySurfaceTint with exact elevation levels uses the right opacity overlay'
,
()
{
const
Color
baseColor
=
Color
(
0xff888888
);
const
Color
surfaceTintColor
=
Color
(
0xff44CCFF
);
Color
overlayWithOpacity
(
double
opacity
)
{
return
Color
.
alphaBlend
(
surfaceTintColor
.
withOpacity
(
opacity
),
baseColor
);
}
// Based on values from the spec:
// https://m3.material.io/styles/color/the-color-system/color-roles
// Elevation level 0 (0.0) - should have opacity 0.0.
expect
(
ElevationOverlay
.
applySurfaceTint
(
baseColor
,
surfaceTintColor
,
0.0
),
equals
(
overlayWithOpacity
(
0.0
)));
// Elevation level 1 (1.0) - should have opacity 0.05.
expect
(
ElevationOverlay
.
applySurfaceTint
(
baseColor
,
surfaceTintColor
,
1.0
),
equals
(
overlayWithOpacity
(
0.05
)));
// Elevation level 2 (3.0) - should have opacity 0.08.
expect
(
ElevationOverlay
.
applySurfaceTint
(
baseColor
,
surfaceTintColor
,
3.0
),
equals
(
overlayWithOpacity
(
0.08
)));
// Elevation level 3 (6.0) - should have opacity 0.11`.
expect
(
ElevationOverlay
.
applySurfaceTint
(
baseColor
,
surfaceTintColor
,
6.0
),
equals
(
overlayWithOpacity
(
0.11
)));
// Elevation level 4 (8.0) - should have opacity 0.12.
expect
(
ElevationOverlay
.
applySurfaceTint
(
baseColor
,
surfaceTintColor
,
8.0
),
equals
(
overlayWithOpacity
(
0.12
)));
// Elevation level 5 (12.0) - should have opacity 0.14.
expect
(
ElevationOverlay
.
applySurfaceTint
(
baseColor
,
surfaceTintColor
,
12.0
),
equals
(
overlayWithOpacity
(
0.14
)));
});
test
(
'applySurfaceTint with elevation lower than level 0 should have no overlay'
,
()
{
const
Color
baseColor
=
Color
(
0xff888888
);
const
Color
surfaceTintColor
=
Color
(
0xff44CCFF
);
Color
overlayWithOpacity
(
double
opacity
)
{
return
Color
.
alphaBlend
(
surfaceTintColor
.
withOpacity
(
opacity
),
baseColor
);
}
expect
(
ElevationOverlay
.
applySurfaceTint
(
baseColor
,
surfaceTintColor
,
-
42.0
),
equals
(
overlayWithOpacity
(
0.0
)));
});
test
(
'applySurfaceTint with elevation higher than level 5 should have no level 5 overlay'
,
()
{
const
Color
baseColor
=
Color
(
0xff888888
);
const
Color
surfaceTintColor
=
Color
(
0xff44CCFF
);
Color
overlayWithOpacity
(
double
opacity
)
{
return
Color
.
alphaBlend
(
surfaceTintColor
.
withOpacity
(
opacity
),
baseColor
);
}
// Elevation level 5 (12.0) - should have opacity 0.14.
expect
(
ElevationOverlay
.
applySurfaceTint
(
baseColor
,
surfaceTintColor
,
42.0
),
equals
(
overlayWithOpacity
(
0.14
)));
});
test
(
'applySurfaceTint with elevation between two levels should interpolate the opacity'
,
()
{
const
Color
baseColor
=
Color
(
0xff888888
);
const
Color
surfaceTintColor
=
Color
(
0xff44CCFF
);
Color
overlayWithOpacity
(
double
opacity
)
{
return
Color
.
alphaBlend
(
surfaceTintColor
.
withOpacity
(
opacity
),
baseColor
);
}
// Elevation between level 4 (8.0) and level 5 (12.0) should be interpolated
// between the opacities 0.12 and 0.14.
// One third (0.3): (elevation 9.2) -> (opacity 0.126)
expect
(
ElevationOverlay
.
applySurfaceTint
(
baseColor
,
surfaceTintColor
,
9.2
),
equals
(
overlayWithOpacity
(
0.126
)));
// Half way (0.5): (elevation 10.0) -> (opacity 0.13)
expect
(
ElevationOverlay
.
applySurfaceTint
(
baseColor
,
surfaceTintColor
,
10.0
),
equals
(
overlayWithOpacity
(
0.13
)));
// Two thirds (0.6): (elevation 10.4) -> (opacity 0.132)
expect
(
ElevationOverlay
.
applySurfaceTint
(
baseColor
,
surfaceTintColor
,
10.4
),
equals
(
overlayWithOpacity
(
0.132
)));
});
}
packages/flutter/test/material/material_test.dart
View file @
6ec0b835
...
@@ -25,6 +25,7 @@ class NotifyMaterial extends StatelessWidget {
...
@@ -25,6 +25,7 @@ class NotifyMaterial extends StatelessWidget {
Widget
buildMaterial
(
{
Widget
buildMaterial
(
{
double
elevation
=
0.0
,
double
elevation
=
0.0
,
Color
shadowColor
=
const
Color
(
0xFF00FF00
),
Color
shadowColor
=
const
Color
(
0xFF00FF00
),
Color
?
surfaceTintColor
,
Color
color
=
const
Color
(
0xFF0000FF
),
Color
color
=
const
Color
(
0xFF0000FF
),
})
{
})
{
return
Center
(
return
Center
(
...
@@ -34,6 +35,7 @@ Widget buildMaterial({
...
@@ -34,6 +35,7 @@ Widget buildMaterial({
child:
Material
(
child:
Material
(
color:
color
,
color:
color
,
shadowColor:
shadowColor
,
shadowColor:
shadowColor
,
surfaceTintColor:
surfaceTintColor
,
elevation:
elevation
,
elevation:
elevation
,
shape:
const
CircleBorder
(),
shape:
const
CircleBorder
(),
),
),
...
@@ -99,6 +101,7 @@ void main() {
...
@@ -99,6 +101,7 @@ void main() {
const
Material
(
const
Material
(
color:
Color
(
0xFFFFFFFF
),
color:
Color
(
0xFFFFFFFF
),
shadowColor:
Color
(
0xffff0000
),
shadowColor:
Color
(
0xffff0000
),
surfaceTintColor:
Color
(
0xff0000ff
),
textStyle:
TextStyle
(
color:
Color
(
0xff00ff00
)),
textStyle:
TextStyle
(
color:
Color
(
0xff00ff00
)),
borderRadius:
BorderRadiusDirectional
.
all
(
Radius
.
circular
(
10
)),
borderRadius:
BorderRadiusDirectional
.
all
(
Radius
.
circular
(
10
)),
).
debugFillProperties
(
builder
);
).
debugFillProperties
(
builder
);
...
@@ -112,6 +115,7 @@ void main() {
...
@@ -112,6 +115,7 @@ void main() {
'type: canvas'
,
'type: canvas'
,
'color: Color(0xffffffff)'
,
'color: Color(0xffffffff)'
,
'shadowColor: Color(0xffff0000)'
,
'shadowColor: Color(0xffff0000)'
,
'surfaceTintColor: Color(0xff0000ff)'
,
'textStyle.inherit: true'
,
'textStyle.inherit: true'
,
'textStyle.color: Color(0xff00ff00)'
,
'textStyle.color: Color(0xff00ff00)'
,
'borderRadius: BorderRadiusDirectional.circular(10.0)'
,
'borderRadius: BorderRadiusDirectional.circular(10.0)'
,
...
@@ -265,12 +269,72 @@ void main() {
...
@@ -265,12 +269,72 @@ void main() {
expect
(
pressed
,
isTrue
);
expect
(
pressed
,
isTrue
);
});
});
group
(
'Elevation Overlay'
,
()
{
group
(
'Surface Tint Overlay'
,
()
{
testWidgets
(
'applyElevationOverlayColor does not effect anything with useMaterial3 set to true'
,
(
WidgetTester
tester
)
async
{
const
Color
surfaceColor
=
Color
(
0xFF121212
);
await
tester
.
pumpWidget
(
Theme
(
data:
ThemeData
(
useMaterial3:
true
,
applyElevationOverlayColor:
true
,
colorScheme:
const
ColorScheme
.
dark
().
copyWith
(
surface:
surfaceColor
),
),
child:
buildMaterial
(
color:
surfaceColor
,
elevation:
8.0
),
));
final
RenderPhysicalShape
model
=
getModel
(
tester
);
expect
(
model
.
color
,
equals
(
surfaceColor
));
});
testWidgets
(
'surfaceTintColor is used to as an overlay to indicate elevation'
,
(
WidgetTester
tester
)
async
{
const
Color
baseColor
=
Color
(
0xFF121212
);
const
Color
surfaceTintColor
=
Color
(
0xff44CCFF
);
// With no surfaceTintColor specified, it should not apply an overlay
await
tester
.
pumpWidget
(
Theme
(
data:
ThemeData
(
useMaterial3:
true
,
),
child:
buildMaterial
(
color:
baseColor
,
elevation:
12.0
,
),
),
);
await
tester
.
pumpAndSettle
();
final
RenderPhysicalShape
noTintModel
=
getModel
(
tester
);
expect
(
noTintModel
.
color
,
equals
(
baseColor
));
// With surfaceTintColor specified, it should not apply an overlay based
// on the elevation.
await
tester
.
pumpWidget
(
Theme
(
data:
ThemeData
(
useMaterial3:
true
,
),
child:
buildMaterial
(
color:
baseColor
,
surfaceTintColor:
surfaceTintColor
,
elevation:
12.0
,
),
),
);
await
tester
.
pumpAndSettle
();
final
RenderPhysicalShape
tintModel
=
getModel
(
tester
);
// Final color should be the base with a tint of 0.14 opacity or 0xff192c33
expect
(
tintModel
.
color
,
equals
(
const
Color
(
0xff192c33
)));
});
});
// Surface Tint Overlay group
group
(
'Elevation Overlay M2'
,
()
{
// These tests only apply to the Material 2 overlay mechanism. This group
// can be removed after migration to Material 3 is complete.
testWidgets
(
'applyElevationOverlayColor set to false does not change surface color'
,
(
WidgetTester
tester
)
async
{
testWidgets
(
'applyElevationOverlayColor set to false does not change surface color'
,
(
WidgetTester
tester
)
async
{
const
Color
surfaceColor
=
Color
(
0xFF121212
);
const
Color
surfaceColor
=
Color
(
0xFF121212
);
await
tester
.
pumpWidget
(
Theme
(
await
tester
.
pumpWidget
(
Theme
(
data:
ThemeData
(
data:
ThemeData
(
useMaterial3:
false
,
applyElevationOverlayColor:
false
,
applyElevationOverlayColor:
false
,
colorScheme:
const
ColorScheme
.
dark
().
copyWith
(
surface:
surfaceColor
),
colorScheme:
const
ColorScheme
.
dark
().
copyWith
(
surface:
surfaceColor
),
),
),
...
@@ -303,6 +367,7 @@ void main() {
...
@@ -303,6 +367,7 @@ void main() {
await
tester
.
pumpWidget
(
await
tester
.
pumpWidget
(
Theme
(
Theme
(
data:
ThemeData
(
data:
ThemeData
(
useMaterial3:
false
,
applyElevationOverlayColor:
true
,
applyElevationOverlayColor:
true
,
colorScheme:
const
ColorScheme
.
dark
().
copyWith
(
colorScheme:
const
ColorScheme
.
dark
().
copyWith
(
surface:
surfaceColor
,
surface:
surfaceColor
,
...
@@ -325,6 +390,7 @@ void main() {
...
@@ -325,6 +390,7 @@ void main() {
await
tester
.
pumpWidget
(
await
tester
.
pumpWidget
(
Theme
(
Theme
(
data:
ThemeData
(
data:
ThemeData
(
useMaterial3:
false
,
applyElevationOverlayColor:
true
,
applyElevationOverlayColor:
true
,
colorScheme:
const
ColorScheme
.
dark
(),
colorScheme:
const
ColorScheme
.
dark
(),
),
),
...
@@ -343,6 +409,7 @@ void main() {
...
@@ -343,6 +409,7 @@ void main() {
await
tester
.
pumpWidget
(
await
tester
.
pumpWidget
(
Theme
(
Theme
(
data:
ThemeData
(
data:
ThemeData
(
useMaterial3:
false
,
applyElevationOverlayColor:
true
,
applyElevationOverlayColor:
true
,
colorScheme:
const
ColorScheme
.
light
(),
colorScheme:
const
ColorScheme
.
light
(),
),
),
...
@@ -364,6 +431,7 @@ void main() {
...
@@ -364,6 +431,7 @@ void main() {
await
tester
.
pumpWidget
(
await
tester
.
pumpWidget
(
Theme
(
Theme
(
data:
ThemeData
(
data:
ThemeData
(
useMaterial3:
false
,
applyElevationOverlayColor:
true
,
applyElevationOverlayColor:
true
,
colorScheme:
const
ColorScheme
.
dark
(),
colorScheme:
const
ColorScheme
.
dark
(),
),
),
...
@@ -390,6 +458,7 @@ void main() {
...
@@ -390,6 +458,7 @@ void main() {
await
tester
.
pumpWidget
(
await
tester
.
pumpWidget
(
Theme
(
Theme
(
data:
ThemeData
(
data:
ThemeData
(
useMaterial3:
false
,
applyElevationOverlayColor:
true
,
applyElevationOverlayColor:
true
,
colorScheme:
const
ColorScheme
.
dark
(
colorScheme:
const
ColorScheme
.
dark
(
surface:
surfaceColor
,
surface:
surfaceColor
,
...
@@ -407,7 +476,8 @@ void main() {
...
@@ -407,7 +476,8 @@ void main() {
expect
(
model
.
color
,
equals
(
surfaceColorWithOverlay
));
expect
(
model
.
color
,
equals
(
surfaceColorWithOverlay
));
expect
(
model
.
color
,
isNot
(
equals
(
surfaceColor
)));
expect
(
model
.
color
,
isNot
(
equals
(
surfaceColor
)));
});
});
});
});
// Elevation Overlay M2 group
group
(
'Transparency clipping'
,
()
{
group
(
'Transparency clipping'
,
()
{
testWidgets
(
'No clip by default'
,
(
WidgetTester
tester
)
async
{
testWidgets
(
'No clip by default'
,
(
WidgetTester
tester
)
async
{
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment