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
d3312568
Unverified
Commit
d3312568
authored
Mar 04, 2023
by
Qun Cheng
Committed by
GitHub
Mar 04, 2023
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Reland: Add visual density for menu default style (#114878)
parent
efb1dc86
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
155 additions
and
36 deletions
+155
-36
menu_template.dart
dev/tools/gen_defaults/lib/menu_template.dart
+28
-15
menu_anchor.dart
packages/flutter/lib/src/material/menu_anchor.dart
+28
-15
menu_anchor_test.dart
packages/flutter/test/material/menu_anchor_test.dart
+99
-6
No files found.
dev/tools/gen_defaults/lib/menu_template.dart
View file @
d3312568
...
...
@@ -43,15 +43,15 @@ class _MenuBarDefaultsM3 extends MenuStyle {
@override
MaterialStateProperty<EdgeInsetsGeometry?>? get padding {
return MaterialStatePropertyAll<EdgeInsetsGeometry>(
return
const
MaterialStatePropertyAll<EdgeInsetsGeometry>(
EdgeInsetsDirectional.symmetric(
horizontal: math.max(
_kTopLevelMenuHorizontalMinPadding,
2 + Theme.of(context).visualDensity.baseSizeAdjustment.dx,
),
horizontal: _kTopLevelMenuHorizontalMinPadding
),
);
}
@override
VisualDensity get visualDensity => Theme.of(context).visualDensity;
}
class _MenuButtonDefaultsM3 extends ButtonStyle {
...
...
@@ -188,10 +188,25 @@ class _MenuButtonDefaultsM3 extends ButtonStyle {
// The horizontal padding number comes from the spec.
EdgeInsetsGeometry _scaledPadding(BuildContext context) {
VisualDensity visualDensity = Theme.of(context).visualDensity;
// When horizontal VisualDensity is greater than zero, set it to zero
// because the [ButtonStyleButton] has already handle the padding based on the density.
// However, the [ButtonStyleButton] doesn'
t
allow
the
[
VisualDensity
]
adjustment
// to reduce the width of the left/right padding, so we need to handle it here if
// the density is less than zero, such as on desktop platforms.
if
(
visualDensity
.
horizontal
>
0
)
{
visualDensity
=
VisualDensity
(
vertical:
visualDensity
.
vertical
);
}
return
ButtonStyleButton
.
scaledPadding
(
const EdgeInsets.symmetric(horizontal: 12),
const EdgeInsets.symmetric(horizontal: 8),
const EdgeInsets.symmetric(horizontal: 4),
EdgeInsets
.
symmetric
(
horizontal:
math
.
max
(
_kMenuViewPadding
,
_kLabelItemDefaultSpacing
+
visualDensity
.
baseSizeAdjustment
.
dx
,
)),
EdgeInsets
.
symmetric
(
horizontal:
math
.
max
(
_kMenuViewPadding
,
8
+
visualDensity
.
baseSizeAdjustment
.
dx
,
)),
const
EdgeInsets
.
symmetric
(
horizontal:
_kMenuViewPadding
),
MediaQuery
.
maybeTextScaleFactorOf
(
context
)
??
1
,
);
}
...
...
@@ -229,15 +244,13 @@ class _MenuDefaultsM3 extends MenuStyle {
@override
MaterialStateProperty
<
EdgeInsetsGeometry
?>?
get
padding
{
return MaterialStatePropertyAll<EdgeInsetsGeometry>(
EdgeInsetsDirectional.symmetric(
vertical: math.max(
_kMenuVerticalMinPadding,
2 + Theme.of(context).visualDensity.baseSizeAdjustment.dy,
),
),
return
const
MaterialStatePropertyAll
<
EdgeInsetsGeometry
>(
EdgeInsetsDirectional
.
symmetric
(
vertical:
_kMenuVerticalMinPadding
),
);
}
@override
VisualDensity
get
visualDensity
=>
Theme
.
of
(
context
).
visualDensity
;
}
''';
}
packages/flutter/lib/src/material/menu_anchor.dart
View file @
d3312568
...
...
@@ -3619,15 +3619,15 @@ class _MenuBarDefaultsM3 extends MenuStyle {
@override
MaterialStateProperty
<
EdgeInsetsGeometry
?>?
get
padding
{
return
MaterialStatePropertyAll
<
EdgeInsetsGeometry
>(
return
const
MaterialStatePropertyAll
<
EdgeInsetsGeometry
>(
EdgeInsetsDirectional
.
symmetric
(
horizontal:
math
.
max
(
_kTopLevelMenuHorizontalMinPadding
,
2
+
Theme
.
of
(
context
).
visualDensity
.
baseSizeAdjustment
.
dx
,
),
horizontal:
_kTopLevelMenuHorizontalMinPadding
),
);
}
@override
VisualDensity
get
visualDensity
=>
Theme
.
of
(
context
).
visualDensity
;
}
class
_MenuButtonDefaultsM3
extends
ButtonStyle
{
...
...
@@ -3764,10 +3764,25 @@ class _MenuButtonDefaultsM3 extends ButtonStyle {
// The horizontal padding number comes from the spec.
EdgeInsetsGeometry
_scaledPadding
(
BuildContext
context
)
{
VisualDensity
visualDensity
=
Theme
.
of
(
context
).
visualDensity
;
// When horizontal VisualDensity is greater than zero, set it to zero
// because the [ButtonStyleButton] has already handle the padding based on the density.
// However, the [ButtonStyleButton] doesn't allow the [VisualDensity] adjustment
// to reduce the width of the left/right padding, so we need to handle it here if
// the density is less than zero, such as on desktop platforms.
if
(
visualDensity
.
horizontal
>
0
)
{
visualDensity
=
VisualDensity
(
vertical:
visualDensity
.
vertical
);
}
return
ButtonStyleButton
.
scaledPadding
(
const
EdgeInsets
.
symmetric
(
horizontal:
12
),
const
EdgeInsets
.
symmetric
(
horizontal:
8
),
const
EdgeInsets
.
symmetric
(
horizontal:
4
),
EdgeInsets
.
symmetric
(
horizontal:
math
.
max
(
_kMenuViewPadding
,
_kLabelItemDefaultSpacing
+
visualDensity
.
baseSizeAdjustment
.
dx
,
)),
EdgeInsets
.
symmetric
(
horizontal:
math
.
max
(
_kMenuViewPadding
,
8
+
visualDensity
.
baseSizeAdjustment
.
dx
,
)),
const
EdgeInsets
.
symmetric
(
horizontal:
_kMenuViewPadding
),
MediaQuery
.
maybeTextScaleFactorOf
(
context
)
??
1
,
);
}
...
...
@@ -3805,15 +3820,13 @@ class _MenuDefaultsM3 extends MenuStyle {
@override
MaterialStateProperty
<
EdgeInsetsGeometry
?>?
get
padding
{
return
MaterialStatePropertyAll
<
EdgeInsetsGeometry
>(
EdgeInsetsDirectional
.
symmetric
(
vertical:
math
.
max
(
_kMenuVerticalMinPadding
,
2
+
Theme
.
of
(
context
).
visualDensity
.
baseSizeAdjustment
.
dy
,
),
),
return
const
MaterialStatePropertyAll
<
EdgeInsetsGeometry
>(
EdgeInsetsDirectional
.
symmetric
(
vertical:
_kMenuVerticalMinPadding
),
);
}
@override
VisualDensity
get
visualDensity
=>
Theme
.
of
(
context
).
visualDensity
;
}
// END GENERATED TOKEN PROPERTIES - Menu
packages/flutter/test/material/menu_anchor_test.dart
View file @
d3312568
...
...
@@ -147,6 +147,99 @@ void main() {
);
}
testWidgets
(
'Menu responds to density changes'
,
(
WidgetTester
tester
)
async
{
Widget
buildMenu
({
VisualDensity
?
visualDensity
=
VisualDensity
.
standard
})
=>
MaterialApp
(
theme:
ThemeData
(
visualDensity:
visualDensity
),
home:
Material
(
child:
Column
(
children:
<
Widget
>[
MenuBar
(
children:
createTestMenus
(
onPressed:
onPressed
),
),
const
Expanded
(
child:
Placeholder
()),
],
),
),
);
await
tester
.
pumpWidget
(
buildMenu
());
await
tester
.
pump
();
expect
(
tester
.
getRect
(
find
.
byType
(
MenuBar
)),
equals
(
const
Rect
.
fromLTRB
(
145.0
,
0.0
,
655.0
,
48.0
)));
// Open and make sure things are the right size.
await
tester
.
tap
(
find
.
text
(
TestMenu
.
mainMenu1
.
label
));
await
tester
.
pump
();
expect
(
tester
.
getRect
(
find
.
byType
(
MenuBar
)),
equals
(
const
Rect
.
fromLTRB
(
145.0
,
0.0
,
655.0
,
48.0
)));
expect
(
tester
.
getRect
(
find
.
widgetWithText
(
MenuItemButton
,
TestMenu
.
subMenu10
.
label
)),
equals
(
const
Rect
.
fromLTRB
(
257.0
,
56.0
,
471.0
,
104.0
)),
);
expect
(
tester
.
getRect
(
find
.
ancestor
(
of:
find
.
text
(
TestMenu
.
subMenu10
.
label
),
matching:
find
.
byType
(
Material
)).
at
(
1
),
),
equals
(
const
Rect
.
fromLTRB
(
257.0
,
48.0
,
471.0
,
208.0
)),
);
// Test compact visual density (-2, -2)
await
tester
.
pumpWidget
(
Container
());
await
tester
.
pumpWidget
(
buildMenu
(
visualDensity:
VisualDensity
.
compact
));
await
tester
.
pump
();
// The original horizontal padding with standard visual density for menu buttons are 12 px, and the total length
// for the menu bar is (655 - 145) = 510.
// There are 4 buttons in the test menu bar, and with compact visual density,
// the padding will reduce by abs(2 * (-2)) = 4. So the total length
// now should reduce by abs(4 * 2 * (-4)) = 32, which would be 510 - 32 = 478, and
// 478 = 639 - 161
expect
(
tester
.
getRect
(
find
.
byType
(
MenuBar
)),
equals
(
const
Rect
.
fromLTRB
(
161.0
,
0.0
,
639.0
,
40.0
)));
// Open and make sure things are the right size.
await
tester
.
tap
(
find
.
text
(
TestMenu
.
mainMenu1
.
label
));
await
tester
.
pump
();
expect
(
tester
.
getRect
(
find
.
byType
(
MenuBar
)),
equals
(
const
Rect
.
fromLTRB
(
161.0
,
0.0
,
639.0
,
40.0
)));
expect
(
tester
.
getRect
(
find
.
widgetWithText
(
MenuItemButton
,
TestMenu
.
subMenu10
.
label
)),
equals
(
const
Rect
.
fromLTRB
(
265.0
,
40.0
,
467.0
,
80.0
)),
);
expect
(
tester
.
getRect
(
find
.
ancestor
(
of:
find
.
text
(
TestMenu
.
subMenu10
.
label
),
matching:
find
.
byType
(
Material
)).
at
(
1
),
),
equals
(
const
Rect
.
fromLTRB
(
265.0
,
40.0
,
467.0
,
160.0
)),
);
await
tester
.
pumpWidget
(
Container
());
await
tester
.
pumpWidget
(
buildMenu
(
visualDensity:
const
VisualDensity
(
horizontal:
2.0
,
vertical:
2.0
)));
await
tester
.
pump
();
// Similarly, there are 4 buttons in the test menu bar, and with (2, 2) visual density,
// the padding will increase by abs(2 * 4) = 8. So the total length for buttons
// should increase by abs(4 * 2 * 8) = 64. The horizontal padding for the menu bar
// increases by 2 * 8, so the total width increases to 510 + 64 + 16 = 590, and
// 590 = 695 - 105
expect
(
tester
.
getRect
(
find
.
byType
(
MenuBar
)),
equals
(
const
Rect
.
fromLTRB
(
105.0
,
0.0
,
695.0
,
72.0
)));
// Open and make sure things are the right size.
await
tester
.
tap
(
find
.
text
(
TestMenu
.
mainMenu1
.
label
));
await
tester
.
pump
();
expect
(
tester
.
getRect
(
find
.
byType
(
MenuBar
)),
equals
(
const
Rect
.
fromLTRB
(
105.0
,
0.0
,
695.0
,
72.0
)));
expect
(
tester
.
getRect
(
find
.
widgetWithText
(
MenuItemButton
,
TestMenu
.
subMenu10
.
label
)),
equals
(
const
Rect
.
fromLTRB
(
249.0
,
80.0
,
483.0
,
136.0
)),
);
expect
(
tester
.
getRect
(
find
.
ancestor
(
of:
find
.
text
(
TestMenu
.
subMenu10
.
label
),
matching:
find
.
byType
(
Material
)).
at
(
1
),
),
equals
(
const
Rect
.
fromLTRB
(
241.0
,
64.0
,
491.0
,
264.0
)),
);
});
testWidgets
(
'menu defaults colors'
,
(
WidgetTester
tester
)
async
{
final
ThemeData
themeData
=
ThemeData
();
await
tester
.
pumpWidget
(
...
...
@@ -2182,9 +2275,9 @@ void main() {
expect
(
collectSubmenuRects
(),
equals
(
const
<
Rect
>[
Rect
.
fromLTRB
(
1
45.0
,
0.0
,
655
.0
,
40.0
),
Rect
.
fromLTRB
(
2
57.0
,
40.0
,
467.0
,
176
.0
),
Rect
.
fromLTRB
(
467.0
,
80.0
,
715.0
,
256
.0
),
Rect
.
fromLTRB
(
1
61.0
,
0.0
,
639
.0
,
40.0
),
Rect
.
fromLTRB
(
2
65.0
,
40.0
,
467.0
,
160
.0
),
Rect
.
fromLTRB
(
467.0
,
72.0
,
707.0
,
232
.0
),
]),
);
});
...
...
@@ -2198,9 +2291,9 @@ void main() {
expect
(
collectSubmenuRects
(),
equals
(
const
<
Rect
>[
Rect
.
fromLTRB
(
1
45.0
,
0.0
,
655
.0
,
40.0
),
Rect
.
fromLTRB
(
333.0
,
40.0
,
5
43.0
,
176
.0
),
Rect
.
fromLTRB
(
85.0
,
80.0
,
333.0
,
256
.0
),
Rect
.
fromLTRB
(
1
61.0
,
0.0
,
639
.0
,
40.0
),
Rect
.
fromLTRB
(
333.0
,
40.0
,
5
35.0
,
160
.0
),
Rect
.
fromLTRB
(
93.0
,
72.0
,
333.0
,
232
.0
),
]),
);
});
...
...
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