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
d1d84411
Unverified
Commit
d1d84411
authored
Jun 02, 2021
by
Chinmoy
Committed by
GitHub
Jun 02, 2021
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fix "Added AxisOrientation property to Scrollbar (#75497)" analysis failures (#82818)
parent
c8abf4d4
Changes
6
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
333 additions
and
17 deletions
+333
-17
scrollbar.dart
packages/flutter/lib/src/cupertino/scrollbar.dart
+4
-1
scrollbar.dart
packages/flutter/lib/src/material/scrollbar.dart
+10
-1
scrollbar.dart
packages/flutter/lib/src/widgets/scrollbar.dart
+90
-15
scrollbar_test.dart
packages/flutter/test/cupertino/scrollbar_test.dart
+39
-0
scrollbar_test.dart
packages/flutter/test/material/scrollbar_test.dart
+48
-0
scrollbar_test.dart
packages/flutter/test/widgets/scrollbar_test.dart
+142
-0
No files found.
packages/flutter/lib/src/cupertino/scrollbar.dart
View file @
d1d84411
...
@@ -127,6 +127,7 @@ class CupertinoScrollbar extends RawScrollbar {
...
@@ -127,6 +127,7 @@ class CupertinoScrollbar extends RawScrollbar {
Radius
radius
=
defaultRadius
,
Radius
radius
=
defaultRadius
,
this
.
radiusWhileDragging
=
defaultRadiusWhileDragging
,
this
.
radiusWhileDragging
=
defaultRadiusWhileDragging
,
ScrollNotificationPredicate
?
notificationPredicate
,
ScrollNotificationPredicate
?
notificationPredicate
,
ScrollbarOrientation
?
scrollbarOrientation
,
})
:
assert
(
thickness
!=
null
),
})
:
assert
(
thickness
!=
null
),
assert
(
thickness
<
double
.
infinity
),
assert
(
thickness
<
double
.
infinity
),
assert
(
thicknessWhileDragging
!=
null
),
assert
(
thicknessWhileDragging
!=
null
),
...
@@ -144,6 +145,7 @@ class CupertinoScrollbar extends RawScrollbar {
...
@@ -144,6 +145,7 @@ class CupertinoScrollbar extends RawScrollbar {
timeToFade:
_kScrollbarTimeToFade
,
timeToFade:
_kScrollbarTimeToFade
,
pressDuration:
const
Duration
(
milliseconds:
100
),
pressDuration:
const
Duration
(
milliseconds:
100
),
notificationPredicate:
notificationPredicate
??
defaultScrollNotificationPredicate
,
notificationPredicate:
notificationPredicate
??
defaultScrollNotificationPredicate
,
scrollbarOrientation:
scrollbarOrientation
,
);
);
/// Default value for [thickness] if it's not specified in [CupertinoScrollbar].
/// Default value for [thickness] if it's not specified in [CupertinoScrollbar].
...
@@ -213,7 +215,8 @@ class _CupertinoScrollbarState extends RawScrollbarState<CupertinoScrollbar> {
...
@@ -213,7 +215,8 @@ class _CupertinoScrollbarState extends RawScrollbarState<CupertinoScrollbar> {
..
radius
=
_radius
..
radius
=
_radius
..
padding
=
MediaQuery
.
of
(
context
).
padding
..
padding
=
MediaQuery
.
of
(
context
).
padding
..
minLength
=
_kScrollbarMinLength
..
minLength
=
_kScrollbarMinLength
..
minOverscrollLength
=
_kScrollbarMinOverscrollLength
;
..
minOverscrollLength
=
_kScrollbarMinOverscrollLength
..
scrollbarOrientation
=
widget
.
scrollbarOrientation
;
}
}
double
_pressStartAxisPosition
=
0.0
;
double
_pressStartAxisPosition
=
0.0
;
...
...
packages/flutter/lib/src/material/scrollbar.dart
View file @
d1d84411
...
@@ -117,6 +117,7 @@ class Scrollbar extends StatefulWidget {
...
@@ -117,6 +117,7 @@ class Scrollbar extends StatefulWidget {
this
.
radius
,
this
.
radius
,
this
.
notificationPredicate
,
this
.
notificationPredicate
,
this
.
interactive
,
this
.
interactive
,
this
.
scrollbarOrientation
,
})
:
super
(
key:
key
);
})
:
super
(
key:
key
);
/// {@macro flutter.widgets.Scrollbar.child}
/// {@macro flutter.widgets.Scrollbar.child}
...
@@ -165,6 +166,9 @@ class Scrollbar extends StatefulWidget {
...
@@ -165,6 +166,9 @@ class Scrollbar extends StatefulWidget {
/// {@macro flutter.widgets.Scrollbar.notificationPredicate}
/// {@macro flutter.widgets.Scrollbar.notificationPredicate}
final
ScrollNotificationPredicate
?
notificationPredicate
;
final
ScrollNotificationPredicate
?
notificationPredicate
;
/// {@macro flutter.widgets.Scrollbar.scrollbarOrientation}
final
ScrollbarOrientation
?
scrollbarOrientation
;
@override
@override
State
<
Scrollbar
>
createState
()
=>
_ScrollbarState
();
State
<
Scrollbar
>
createState
()
=>
_ScrollbarState
();
}
}
...
@@ -183,6 +187,7 @@ class _ScrollbarState extends State<Scrollbar> {
...
@@ -183,6 +187,7 @@ class _ScrollbarState extends State<Scrollbar> {
radiusWhileDragging:
widget
.
radius
??
CupertinoScrollbar
.
defaultRadiusWhileDragging
,
radiusWhileDragging:
widget
.
radius
??
CupertinoScrollbar
.
defaultRadiusWhileDragging
,
controller:
widget
.
controller
,
controller:
widget
.
controller
,
notificationPredicate:
widget
.
notificationPredicate
,
notificationPredicate:
widget
.
notificationPredicate
,
scrollbarOrientation:
widget
.
scrollbarOrientation
,
child:
widget
.
child
,
child:
widget
.
child
,
);
);
}
}
...
@@ -195,6 +200,7 @@ class _ScrollbarState extends State<Scrollbar> {
...
@@ -195,6 +200,7 @@ class _ScrollbarState extends State<Scrollbar> {
radius:
widget
.
radius
,
radius:
widget
.
radius
,
notificationPredicate:
widget
.
notificationPredicate
,
notificationPredicate:
widget
.
notificationPredicate
,
interactive:
widget
.
interactive
,
interactive:
widget
.
interactive
,
scrollbarOrientation:
widget
.
scrollbarOrientation
,
child:
widget
.
child
,
child:
widget
.
child
,
);
);
}
}
...
@@ -212,6 +218,7 @@ class _MaterialScrollbar extends RawScrollbar {
...
@@ -212,6 +218,7 @@ class _MaterialScrollbar extends RawScrollbar {
Radius
?
radius
,
Radius
?
radius
,
ScrollNotificationPredicate
?
notificationPredicate
,
ScrollNotificationPredicate
?
notificationPredicate
,
bool
?
interactive
,
bool
?
interactive
,
ScrollbarOrientation
?
scrollbarOrientation
,
})
:
super
(
})
:
super
(
key:
key
,
key:
key
,
child:
child
,
child:
child
,
...
@@ -224,6 +231,7 @@ class _MaterialScrollbar extends RawScrollbar {
...
@@ -224,6 +231,7 @@ class _MaterialScrollbar extends RawScrollbar {
pressDuration:
Duration
.
zero
,
pressDuration:
Duration
.
zero
,
notificationPredicate:
notificationPredicate
??
defaultScrollNotificationPredicate
,
notificationPredicate:
notificationPredicate
??
defaultScrollNotificationPredicate
,
interactive:
interactive
,
interactive:
interactive
,
scrollbarOrientation:
scrollbarOrientation
,
);
);
final
bool
?
showTrackOnHover
;
final
bool
?
showTrackOnHover
;
...
@@ -380,7 +388,8 @@ class _MaterialScrollbarState extends RawScrollbarState<_MaterialScrollbar> {
...
@@ -380,7 +388,8 @@ class _MaterialScrollbarState extends RawScrollbarState<_MaterialScrollbar> {
..
crossAxisMargin
=
_scrollbarTheme
.
crossAxisMargin
??
(
_useAndroidScrollbar
?
0.0
:
_kScrollbarMargin
)
..
crossAxisMargin
=
_scrollbarTheme
.
crossAxisMargin
??
(
_useAndroidScrollbar
?
0.0
:
_kScrollbarMargin
)
..
mainAxisMargin
=
_scrollbarTheme
.
mainAxisMargin
??
0.0
..
mainAxisMargin
=
_scrollbarTheme
.
mainAxisMargin
??
0.0
..
minLength
=
_scrollbarTheme
.
minThumbLength
??
_kScrollbarMinLength
..
minLength
=
_scrollbarTheme
.
minThumbLength
??
_kScrollbarMinLength
..
padding
=
MediaQuery
.
of
(
context
).
padding
;
..
padding
=
MediaQuery
.
of
(
context
).
padding
..
scrollbarOrientation
=
widget
.
scrollbarOrientation
;
}
}
@override
@override
...
...
packages/flutter/lib/src/widgets/scrollbar.dart
View file @
d1d84411
...
@@ -29,6 +29,21 @@ const double _kScrollbarThickness = 6.0;
...
@@ -29,6 +29,21 @@ const double _kScrollbarThickness = 6.0;
const
Duration
_kScrollbarFadeDuration
=
Duration
(
milliseconds:
300
);
const
Duration
_kScrollbarFadeDuration
=
Duration
(
milliseconds:
300
);
const
Duration
_kScrollbarTimeToFade
=
Duration
(
milliseconds:
600
);
const
Duration
_kScrollbarTimeToFade
=
Duration
(
milliseconds:
600
);
/// An orientation along either the horizontal or vertical [Axis].
enum
ScrollbarOrientation
{
/// Place towards the left of the screen.
left
,
/// Place towards the right of the screen.
right
,
/// Place on top of the screen.
top
,
/// Place on the bottom of the screen.
bottom
,
}
/// Paints a scrollbar's track and thumb.
/// Paints a scrollbar's track and thumb.
///
///
/// The size of the scrollbar along its scroll direction is typically
/// The size of the scrollbar along its scroll direction is typically
...
@@ -72,6 +87,7 @@ class ScrollbarPainter extends ChangeNotifier implements CustomPainter {
...
@@ -72,6 +87,7 @@ class ScrollbarPainter extends ChangeNotifier implements CustomPainter {
Radius
?
radius
,
Radius
?
radius
,
double
minLength
=
_kMinThumbExtent
,
double
minLength
=
_kMinThumbExtent
,
double
?
minOverscrollLength
,
double
?
minOverscrollLength
,
ScrollbarOrientation
?
scrollbarOrientation
,
})
:
assert
(
color
!=
null
),
})
:
assert
(
color
!=
null
),
assert
(
thickness
!=
null
),
assert
(
thickness
!=
null
),
assert
(
fadeoutOpacityAnimation
!=
null
),
assert
(
fadeoutOpacityAnimation
!=
null
),
...
@@ -93,6 +109,7 @@ class ScrollbarPainter extends ChangeNotifier implements CustomPainter {
...
@@ -93,6 +109,7 @@ class ScrollbarPainter extends ChangeNotifier implements CustomPainter {
_minLength
=
minLength
,
_minLength
=
minLength
,
_trackColor
=
trackColor
,
_trackColor
=
trackColor
,
_trackBorderColor
=
trackBorderColor
,
_trackBorderColor
=
trackBorderColor
,
_scrollbarOrientation
=
scrollbarOrientation
,
_minOverscrollLength
=
minOverscrollLength
??
minLength
{
_minOverscrollLength
=
minOverscrollLength
??
minLength
{
fadeoutOpacityAnimation
.
addListener
(
notifyListeners
);
fadeoutOpacityAnimation
.
addListener
(
notifyListeners
);
}
}
...
@@ -270,6 +287,46 @@ class ScrollbarPainter extends ChangeNotifier implements CustomPainter {
...
@@ -270,6 +287,46 @@ class ScrollbarPainter extends ChangeNotifier implements CustomPainter {
notifyListeners
();
notifyListeners
();
}
}
/// {@template flutter.widgets.Scrollbar.scrollbarOrientation}
/// Dictates the orientation of the scrollbar.
///
/// [ScrollbarOrientation.top] places the scrollbar on top of the screen.
/// [ScrollbarOrientation.bottom] places the scrollbar on the bottom of the screen.
/// [ScrollbarOrientation.left] places the scrollbar on the left of the screen.
/// [ScrollbarOrientation.right] places the scrollbar on the right of the screen.
///
/// [ScrollbarOrientation.top] and [ScrollbarOrientation.bottom] can only be
/// used with a vertical scroll.
/// [ScrollbarOrientation.left] and [ScrollbarOrientation.right] can only be
/// used with a horizontal scroll.
///
/// For a vertical scroll the orientation defaults to
/// [ScrollbarOrientation.right] for [TextDirection.ltr] and
/// [ScrollbarOrientation.left] for [TextDirection.rtl].
/// For a horizontal scroll the orientation defaults to [ScrollbarOrientation.bottom].
/// {@endtemplate}
ScrollbarOrientation
?
get
scrollbarOrientation
=>
_scrollbarOrientation
;
ScrollbarOrientation
?
_scrollbarOrientation
;
set
scrollbarOrientation
(
ScrollbarOrientation
?
value
)
{
if
(
scrollbarOrientation
==
value
)
return
;
_scrollbarOrientation
=
value
;
notifyListeners
();
}
void
_debugAssertIsValidOrientation
(
ScrollbarOrientation
orientation
)
{
assert
(
(
_isVertical
&&
_isVerticalOrientation
(
orientation
))
||
(!
_isVertical
&&
!
_isVerticalOrientation
(
orientation
)),
'The given ScrollbarOrientation:
$orientation
is incompatible with the current AxisDirection:
$_lastAxisDirection
.'
);
}
/// Check whether given scrollbar orientation is vertical
bool
_isVerticalOrientation
(
ScrollbarOrientation
orientation
)
=>
orientation
==
ScrollbarOrientation
.
left
||
orientation
==
ScrollbarOrientation
.
right
;
ScrollMetrics
?
_lastMetrics
;
ScrollMetrics
?
_lastMetrics
;
AxisDirection
?
_lastAxisDirection
;
AxisDirection
?
_lastAxisDirection
;
Rect
?
_thumbRect
;
Rect
?
_thumbRect
;
...
@@ -317,37 +374,48 @@ class ScrollbarPainter extends ChangeNotifier implements CustomPainter {
...
@@ -317,37 +374,48 @@ class ScrollbarPainter extends ChangeNotifier implements CustomPainter {
'A TextDirection must be provided before a Scrollbar can be painted.'
,
'A TextDirection must be provided before a Scrollbar can be painted.'
,
);
);
final
ScrollbarOrientation
resolvedOrientation
;
if
(
scrollbarOrientation
==
null
)
{
if
(
_isVertical
)
resolvedOrientation
=
textDirection
==
TextDirection
.
ltr
?
ScrollbarOrientation
.
right
:
ScrollbarOrientation
.
left
;
else
resolvedOrientation
=
ScrollbarOrientation
.
bottom
;
}
else
{
resolvedOrientation
=
scrollbarOrientation
!;
}
final
double
x
,
y
;
final
double
x
,
y
;
final
Size
thumbSize
,
trackSize
;
final
Size
thumbSize
,
trackSize
;
final
Offset
trackOffset
;
final
Offset
trackOffset
;
switch
(
direction
)
{
_debugAssertIsValidOrientation
(
resolvedOrientation
);
case
AxisDirection
.
down
:
switch
(
resolvedOrientation
)
{
case
ScrollbarOrientation
.
left
:
thumbSize
=
Size
(
thickness
,
thumbExtent
);
thumbSize
=
Size
(
thickness
,
thumbExtent
);
trackSize
=
Size
(
thickness
+
2
*
crossAxisMargin
,
_trackExtent
);
trackSize
=
Size
(
thickness
+
2
*
crossAxisMargin
,
_trackExtent
);
x
=
textDirection
==
TextDirection
.
rtl
x
=
crossAxisMargin
+
padding
.
left
;
?
crossAxisMargin
+
padding
.
left
:
size
.
width
-
thickness
-
crossAxisMargin
-
padding
.
right
;
y
=
_thumbOffset
;
y
=
_thumbOffset
;
trackOffset
=
Offset
(
x
-
crossAxisMargin
,
0.0
);
trackOffset
=
Offset
(
x
-
crossAxisMargin
,
0.0
);
break
;
break
;
case
AxisDirection
.
up
:
case
ScrollbarOrientation
.
right
:
thumbSize
=
Size
(
thickness
,
thumbExtent
);
thumbSize
=
Size
(
thickness
,
thumbExtent
);
trackSize
=
Size
(
thickness
+
2
*
crossAxisMargin
,
_trackExtent
);
trackSize
=
Size
(
thickness
+
2
*
crossAxisMargin
,
_trackExtent
);
x
=
textDirection
==
TextDirection
.
rtl
x
=
size
.
width
-
thickness
-
crossAxisMargin
-
padding
.
right
;
?
crossAxisMargin
+
padding
.
left
:
size
.
width
-
thickness
-
crossAxisMargin
-
padding
.
right
;
y
=
_thumbOffset
;
y
=
_thumbOffset
;
trackOffset
=
Offset
(
x
-
crossAxisMargin
,
0.0
);
trackOffset
=
Offset
(
x
-
crossAxisMargin
,
0.0
);
break
;
break
;
case
AxisDirection
.
left
:
case
ScrollbarOrientation
.
top
:
thumbSize
=
Size
(
thumbExtent
,
thickness
);
thumbSize
=
Size
(
thumbExtent
,
thickness
);
x
=
_thumbOffset
;
y
=
size
.
height
-
thickness
-
crossAxisMargin
-
padding
.
bottom
;
trackSize
=
Size
(
_trackExtent
,
thickness
+
2
*
crossAxisMargin
);
trackSize
=
Size
(
_trackExtent
,
thickness
+
2
*
crossAxisMargin
);
x
=
_thumbOffset
;
y
=
crossAxisMargin
+
padding
.
top
;
trackOffset
=
Offset
(
0.0
,
y
-
crossAxisMargin
);
trackOffset
=
Offset
(
0.0
,
y
-
crossAxisMargin
);
break
;
break
;
case
AxisDirection
.
right
:
case
ScrollbarOrientation
.
bottom
:
thumbSize
=
Size
(
thumbExtent
,
thickness
);
thumbSize
=
Size
(
thumbExtent
,
thickness
);
trackSize
=
Size
(
_trackExtent
,
thickness
+
2
*
crossAxisMargin
);
trackSize
=
Size
(
_trackExtent
,
thickness
+
2
*
crossAxisMargin
);
x
=
_thumbOffset
;
x
=
_thumbOffset
;
...
@@ -570,7 +638,8 @@ class ScrollbarPainter extends ChangeNotifier implements CustomPainter {
...
@@ -570,7 +638,8 @@ class ScrollbarPainter extends ChangeNotifier implements CustomPainter {
||
radius
!=
old
.
radius
||
radius
!=
old
.
radius
||
minLength
!=
old
.
minLength
||
minLength
!=
old
.
minLength
||
padding
!=
old
.
padding
||
padding
!=
old
.
padding
||
minOverscrollLength
!=
old
.
minOverscrollLength
;
||
minOverscrollLength
!=
old
.
minOverscrollLength
||
scrollbarOrientation
!=
old
.
scrollbarOrientation
;
}
}
@override
@override
...
@@ -655,6 +724,7 @@ class RawScrollbar extends StatefulWidget {
...
@@ -655,6 +724,7 @@ class RawScrollbar extends StatefulWidget {
this
.
pressDuration
=
Duration
.
zero
,
this
.
pressDuration
=
Duration
.
zero
,
this
.
notificationPredicate
=
defaultScrollNotificationPredicate
,
this
.
notificationPredicate
=
defaultScrollNotificationPredicate
,
this
.
interactive
,
this
.
interactive
,
this
.
scrollbarOrientation
,
})
:
assert
(
child
!=
null
),
})
:
assert
(
child
!=
null
),
assert
(
fadeDuration
!=
null
),
assert
(
fadeDuration
!=
null
),
assert
(
timeToFade
!=
null
),
assert
(
timeToFade
!=
null
),
...
@@ -866,6 +936,9 @@ class RawScrollbar extends StatefulWidget {
...
@@ -866,6 +936,9 @@ class RawScrollbar extends StatefulWidget {
/// {@endtemplate}
/// {@endtemplate}
final
bool
?
interactive
;
final
bool
?
interactive
;
/// {@macro flutter.widgets.Scrollbar.scrollbarOrientation}
final
ScrollbarOrientation
?
scrollbarOrientation
;
@override
@override
RawScrollbarState
<
RawScrollbar
>
createState
()
=>
RawScrollbarState
<
RawScrollbar
>();
RawScrollbarState
<
RawScrollbar
>
createState
()
=>
RawScrollbarState
<
RawScrollbar
>();
}
}
...
@@ -937,6 +1010,7 @@ class RawScrollbarState<T extends RawScrollbar> extends State<T> with TickerProv
...
@@ -937,6 +1010,7 @@ class RawScrollbarState<T extends RawScrollbar> extends State<T> with TickerProv
color:
widget
.
thumbColor
??
const
Color
(
0x66BCBCBC
),
color:
widget
.
thumbColor
??
const
Color
(
0x66BCBCBC
),
thickness:
widget
.
thickness
??
_kScrollbarThickness
,
thickness:
widget
.
thickness
??
_kScrollbarThickness
,
fadeoutOpacityAnimation:
_fadeoutOpacityAnimation
,
fadeoutOpacityAnimation:
_fadeoutOpacityAnimation
,
scrollbarOrientation:
widget
.
scrollbarOrientation
,
);
);
}
}
...
@@ -1042,7 +1116,8 @@ class RawScrollbarState<T extends RawScrollbar> extends State<T> with TickerProv
...
@@ -1042,7 +1116,8 @@ class RawScrollbarState<T extends RawScrollbar> extends State<T> with TickerProv
..
textDirection
=
Directionality
.
of
(
context
)
..
textDirection
=
Directionality
.
of
(
context
)
..
thickness
=
widget
.
thickness
??
_kScrollbarThickness
..
thickness
=
widget
.
thickness
??
_kScrollbarThickness
..
radius
=
widget
.
radius
..
radius
=
widget
.
radius
..
padding
=
MediaQuery
.
of
(
context
).
padding
;
..
padding
=
MediaQuery
.
of
(
context
).
padding
..
scrollbarOrientation
=
widget
.
scrollbarOrientation
;
}
}
@override
@override
...
...
packages/flutter/test/cupertino/scrollbar_test.dart
View file @
d1d84411
...
@@ -889,4 +889,43 @@ void main() {
...
@@ -889,4 +889,43 @@ void main() {
),
),
);
);
});
});
testWidgets
(
'CupertinoScrollbar scrollOrientation works correctly'
,
(
WidgetTester
tester
)
async
{
final
ScrollController
scrollController
=
ScrollController
();
await
tester
.
pumpWidget
(
CupertinoApp
(
home:
PrimaryScrollController
(
controller:
scrollController
,
child:
CupertinoScrollbar
(
isAlwaysShown:
true
,
controller:
scrollController
,
scrollbarOrientation:
ScrollbarOrientation
.
left
,
child:
const
SingleChildScrollView
(
child:
SizedBox
(
width:
4000.0
,
height:
4000.0
),
),
),
),
),
);
await
tester
.
pumpAndSettle
();
expect
(
find
.
byType
(
CupertinoScrollbar
),
paints
..
rect
(
rect:
const
Rect
.
fromLTRB
(
0.0
,
0.0
,
9.0
,
594.0
),
)
..
line
(
p1:
Offset
.
zero
,
p2:
const
Offset
(
0.0
,
594.0
),
strokeWidth:
1.0
,
)
..
rrect
(
rrect:
RRect
.
fromRectAndRadius
(
const
Rect
.
fromLTRB
(
3.0
,
3.0
,
6.0
,
92.1
),
const
Radius
.
circular
(
1.5
)),
color:
_kScrollbarColor
.
color
,
),
);
});
}
}
packages/flutter/test/material/scrollbar_test.dart
View file @
d1d84411
...
@@ -1492,4 +1492,52 @@ void main() {
...
@@ -1492,4 +1492,52 @@ void main() {
);
);
}
}
});
});
testWidgets
(
'Scrollbar scrollOrientation works correctly'
,
(
WidgetTester
tester
)
async
{
final
ScrollController
scrollController
=
ScrollController
();
Widget
_buildScrollWithOrientation
(
ScrollbarOrientation
orientation
)
{
return
_buildBoilerplate
(
child:
Theme
(
data:
ThemeData
(
platform:
TargetPlatform
.
android
,
),
child:
PrimaryScrollController
(
controller:
scrollController
,
child:
Scrollbar
(
interactive:
true
,
isAlwaysShown:
true
,
scrollbarOrientation:
orientation
,
controller:
scrollController
,
child:
const
SingleChildScrollView
(
child:
SizedBox
(
width:
4000.0
,
height:
4000.0
)
),
),
),
)
);
}
await
tester
.
pumpWidget
(
_buildScrollWithOrientation
(
ScrollbarOrientation
.
left
));
await
tester
.
pumpAndSettle
();
expect
(
find
.
byType
(
Scrollbar
),
paints
..
rect
(
rect:
const
Rect
.
fromLTRB
(
0.0
,
0.0
,
4.0
,
600.0
),
color:
Colors
.
transparent
,
)
..
line
(
p1:
Offset
.
zero
,
p2:
const
Offset
(
0.0
,
600.0
),
strokeWidth:
1.0
,
color:
Colors
.
transparent
,
)
..
rect
(
rect:
const
Rect
.
fromLTRB
(
0.0
,
0.0
,
4.0
,
90.0
),
color:
_kAndroidThumbIdleColor
,
),
);
});
}
}
packages/flutter/test/widgets/scrollbar_test.dart
View file @
d1d84411
...
@@ -26,6 +26,7 @@ ScrollbarPainter _buildPainter({
...
@@ -26,6 +26,7 @@ ScrollbarPainter _buildPainter({
Radius
?
radius
,
Radius
?
radius
,
double
minLength
=
_kMinThumbExtent
,
double
minLength
=
_kMinThumbExtent
,
double
?
minOverscrollLength
,
double
?
minOverscrollLength
,
ScrollbarOrientation
?
scrollbarOrientation
,
required
ScrollMetrics
scrollMetrics
,
required
ScrollMetrics
scrollMetrics
,
})
{
})
{
return
ScrollbarPainter
(
return
ScrollbarPainter
(
...
@@ -39,6 +40,7 @@ ScrollbarPainter _buildPainter({
...
@@ -39,6 +40,7 @@ ScrollbarPainter _buildPainter({
minLength:
minLength
,
minLength:
minLength
,
minOverscrollLength:
minOverscrollLength
??
minLength
,
minOverscrollLength:
minOverscrollLength
??
minLength
,
fadeoutOpacityAnimation:
kAlwaysCompleteAnimation
,
fadeoutOpacityAnimation:
kAlwaysCompleteAnimation
,
scrollbarOrientation:
scrollbarOrientation
,
)..
update
(
scrollMetrics
,
scrollMetrics
.
axisDirection
);
)..
update
(
scrollMetrics
,
scrollMetrics
.
axisDirection
);
}
}
...
@@ -248,6 +250,128 @@ void main() {
...
@@ -248,6 +250,128 @@ void main() {
},
},
);
);
test
(
'scrollbarOrientation are respected'
,
()
{
const
double
viewportDimension
=
23
;
const
double
maxExtent
=
100
;
final
ScrollMetrics
startingMetrics
=
defaultMetrics
.
copyWith
(
maxScrollExtent:
maxExtent
,
viewportDimension:
viewportDimension
,
);
const
Size
size
=
Size
(
600
,
viewportDimension
);
const
double
margin
=
0
;
for
(
final
ScrollbarOrientation
scrollbarOrientation
in
ScrollbarOrientation
.
values
)
{
final
AxisDirection
axisDirection
;
if
(
scrollbarOrientation
==
ScrollbarOrientation
.
left
||
scrollbarOrientation
==
ScrollbarOrientation
.
right
)
axisDirection
=
AxisDirection
.
down
;
else
axisDirection
=
AxisDirection
.
right
;
painter
=
_buildPainter
(
crossAxisMargin:
margin
,
scrollMetrics:
startingMetrics
,
scrollbarOrientation:
scrollbarOrientation
,
);
painter
.
update
(
startingMetrics
.
copyWith
(
axisDirection:
axisDirection
),
axisDirection
);
painter
.
paint
(
testCanvas
,
size
);
final
Rect
rect
=
captureRect
();
switch
(
scrollbarOrientation
)
{
case
ScrollbarOrientation
.
left
:
expect
(
rect
.
left
,
0
);
expect
(
rect
.
top
,
0
);
expect
(
rect
.
right
,
_kThickness
);
expect
(
rect
.
bottom
,
_kMinThumbExtent
);
break
;
case
ScrollbarOrientation
.
right
:
expect
(
rect
.
left
,
600
-
_kThickness
);
expect
(
rect
.
top
,
0
);
expect
(
rect
.
right
,
600
);
expect
(
rect
.
bottom
,
_kMinThumbExtent
);
break
;
case
ScrollbarOrientation
.
top
:
expect
(
rect
.
left
,
0
);
expect
(
rect
.
top
,
0
);
expect
(
rect
.
right
,
_kMinThumbExtent
);
expect
(
rect
.
bottom
,
_kThickness
);
break
;
case
ScrollbarOrientation
.
bottom
:
expect
(
rect
.
left
,
0
);
expect
(
rect
.
top
,
23
-
_kThickness
);
expect
(
rect
.
right
,
_kMinThumbExtent
);
expect
(
rect
.
bottom
,
23
);
break
;
}
}
});
test
(
'scrollbarOrientation default values are correct'
,
()
{
const
double
viewportDimension
=
23
;
const
double
maxExtent
=
100
;
final
ScrollMetrics
startingMetrics
=
defaultMetrics
.
copyWith
(
maxScrollExtent:
maxExtent
,
viewportDimension:
viewportDimension
,
);
const
Size
size
=
Size
(
600
,
viewportDimension
);
const
double
margin
=
0
;
Rect
rect
;
// Vertical scroll with TextDirection.ltr
painter
=
_buildPainter
(
crossAxisMargin:
margin
,
scrollMetrics:
startingMetrics
,
textDirection:
TextDirection
.
ltr
,
);
painter
.
update
(
startingMetrics
.
copyWith
(
axisDirection:
AxisDirection
.
down
),
AxisDirection
.
down
);
painter
.
paint
(
testCanvas
,
size
);
rect
=
captureRect
();
expect
(
rect
.
left
,
600
-
_kThickness
);
expect
(
rect
.
top
,
0
);
expect
(
rect
.
right
,
600
);
expect
(
rect
.
bottom
,
_kMinThumbExtent
);
// Vertical scroll with TextDirection.rtl
painter
=
_buildPainter
(
crossAxisMargin:
margin
,
scrollMetrics:
startingMetrics
,
textDirection:
TextDirection
.
rtl
,
);
painter
.
update
(
startingMetrics
.
copyWith
(
axisDirection:
AxisDirection
.
down
),
AxisDirection
.
down
);
painter
.
paint
(
testCanvas
,
size
);
rect
=
captureRect
();
expect
(
rect
.
left
,
0
);
expect
(
rect
.
top
,
0
);
expect
(
rect
.
right
,
_kThickness
);
expect
(
rect
.
bottom
,
_kMinThumbExtent
);
// Horizontal scroll
painter
=
_buildPainter
(
crossAxisMargin:
margin
,
scrollMetrics:
startingMetrics
,
);
painter
.
update
(
startingMetrics
.
copyWith
(
axisDirection:
AxisDirection
.
right
),
AxisDirection
.
right
,
);
painter
.
paint
(
testCanvas
,
size
);
rect
=
captureRect
();
expect
(
rect
.
left
,
0
);
expect
(
rect
.
top
,
23
-
_kThickness
);
expect
(
rect
.
right
,
_kMinThumbExtent
);
expect
(
rect
.
bottom
,
23
);
});
group
(
'Padding works for all scroll directions'
,
()
{
group
(
'Padding works for all scroll directions'
,
()
{
const
EdgeInsets
padding
=
EdgeInsets
.
fromLTRB
(
1
,
2
,
3
,
4
);
const
EdgeInsets
padding
=
EdgeInsets
.
fromLTRB
(
1
,
2
,
3
,
4
);
const
Size
size
=
Size
(
60
,
80
);
const
Size
size
=
Size
(
60
,
80
);
...
@@ -1214,4 +1338,22 @@ void main() {
...
@@ -1214,4 +1338,22 @@ void main() {
),
),
);
);
});
});
testWidgets
(
'ScrollbarPainter asserts if scrollbarOrientation is used with wrong axisDirection'
,
(
WidgetTester
tester
)
async
{
final
ScrollbarPainter
painter
=
ScrollbarPainter
(
color:
_kScrollbarColor
,
fadeoutOpacityAnimation:
kAlwaysCompleteAnimation
,
textDirection:
TextDirection
.
ltr
,
scrollbarOrientation:
ScrollbarOrientation
.
left
,
);
const
Size
size
=
Size
(
60
,
80
);
final
ScrollMetrics
scrollMetrics
=
defaultMetrics
.
copyWith
(
maxScrollExtent:
100
,
viewportDimension:
size
.
height
,
axisDirection:
AxisDirection
.
right
,
);
painter
.
update
(
scrollMetrics
,
scrollMetrics
.
axisDirection
);
expect
(()
=>
painter
.
paint
(
testCanvas
,
size
),
throwsA
(
isA
<
AssertionError
>()));
});
}
}
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